/**
 * Practice Question Mobile Optimization CSS
 * Purpose: Ensure question + options + actions fit in single viewport
 * Version: 1.0.0
 * Created: 2025-10-15
 */

/* ===================================
   MOBILE QUESTION LAYOUT OPTIMIZATION
   =================================== */

@media (max-width: 767px) {
  /* Remove body padding for full viewport usage */
  body.practice-question-page {
    padding-bottom: 0 !important;
  }
  
  /* Question container optimization */
  .question-container {
    padding: var(--mobile-space-sm) var(--mobile-space-md);
    margin-bottom: var(--mobile-space-sm);
    background: var(--mobile-bg-primary);
    border: 1px solid var(--mobile-border-primary);
    border-radius: var(--mobile-radius-md);
  }
  
  /* Compact question header */
  .question-header {
    border-bottom: 1px solid var(--mobile-border-primary);
    padding-bottom: var(--mobile-space-sm);
    margin-bottom: var(--mobile-space-sm);
  }
  
  .question-title {
    font-size: var(--mobile-font-size-lg);
    font-weight: 600;
    color: var(--mobile-text-primary);
    margin: 0 0 var(--mobile-space-xs) 0;
    line-height: var(--mobile-line-height-tight);
  }
  
  /* Ultra-compact metadata */
  .question-meta {
    background: var(--mobile-bg-tertiary);
    padding: var(--mobile-space-xs) var(--mobile-space-sm);
    border-radius: var(--mobile-radius-sm);
    margin-bottom: var(--mobile-space-sm);
    font-size: var(--mobile-font-size-xs);
    line-height: 1.3;
  }
  
  .question-meta .row {
    margin: 0;
  }
  
  .question-meta .col-md-6 {
    padding: 0;
    margin-bottom: var(--mobile-space-xs);
  }
  
  .question-meta .col-md-6:last-child {
    margin-bottom: 0;
  }
  
  /* Compact question text */
  .question-text {
    font-size: var(--mobile-font-size-sm);
    line-height: var(--mobile-line-height-normal);
    color: var(--mobile-text-primary);
    margin-bottom: var(--mobile-space-sm);
    padding: 0;
  }
  
  /* Compact options */
  .options-container {
    margin-bottom: var(--mobile-space-sm);
  }
  
  .option-item {
    background: var(--mobile-bg-tertiary);
    border: 1px solid var(--mobile-border-primary);
    border-radius: var(--mobile-radius-sm);
    padding: var(--mobile-space-sm);
    margin-bottom: var(--mobile-space-xs);
    cursor: pointer;
    transition: var(--mobile-transition-fast);
    font-size: var(--mobile-font-size-xs);
    min-height: var(--mobile-touch-target-min);
    display: flex;
    align-items: center;
  }
  
  .option-item:hover {
    background: var(--mobile-primary-light);
    border-color: var(--mobile-primary);
  }
  
  .option-item.selected {
    background: var(--mobile-primary-light);
    border-color: var(--mobile-primary);
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
  }
  
  .option-item.correct {
    background: #d4edda;
    border-color: var(--mobile-success);
    box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.1);
  }
  
  .option-item.incorrect {
    background: #f8d7da;
    border-color: var(--mobile-danger);
    box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.1);
  }
  
  .option-label {
    font-weight: 600;
    color: var(--mobile-text-primary);
    margin-right: var(--mobile-space-sm);
    min-width: 1.2rem;
    font-size: var(--mobile-font-size-xs);
    flex-shrink: 0;
  }
  
  .option-text {
    color: var(--mobile-text-primary);
    font-size: var(--mobile-font-size-xs);
    line-height: 1.3;
    flex: 1;
  }
  
  /* Compact actions */
  .actions-container {
    display: flex;
    gap: var(--mobile-space-xs);
    flex-wrap: wrap;
    margin-top: var(--mobile-space-sm);
    padding-top: var(--mobile-space-sm);
    border-top: 1px solid var(--mobile-border-primary);
  }
  
  .btn-action {
    padding: var(--mobile-space-sm) var(--mobile-space-md);
    border-radius: var(--mobile-radius-sm);
    font-weight: 500;
    transition: var(--mobile-transition-fast);
    border: none;
    cursor: pointer;
    font-size: var(--mobile-font-size-xs);
    min-height: var(--mobile-touch-target-min);
    flex: 1;
    min-width: 0;
  }
  
  .btn-submit {
    background: var(--mobile-success);
    color: white;
  }
  
  .btn-submit:hover {
    background: #059669;
  }
  
  .btn-clear {
    background: var(--mobile-secondary);
    color: white;
  }
  
  .btn-clear:hover {
    background: #4b5563;
  }
  
  .btn-bookmark {
    background: var(--mobile-warning);
    color: #212529;
  }
  
  .btn-bookmark:hover {
    background: #d97706;
  }
  
  .btn-bookmark.bookmarked {
    background: #ea580c;
    color: white;
  }
  
  .btn-note {
    background: var(--mobile-info);
    color: white;
  }
  
  .btn-note:hover {
    background: #0891b2;
  }
  
  .btn-previous {
    background: #6f42c1;
    color: white;
    text-decoration: none;
  }
  
  .btn-previous:hover {
    background: #5a32a3;
    color: white;
  }
  
  .btn-next {
    background: #20c997;
    color: white;
    text-decoration: none;
  }
  
  .btn-next:hover {
    background: #1aa179;
    color: white;
  }
  
  /* Compact explanation */
  .explanation-container {
    background: #e8f5e8;
    border: 1px solid #c3e6c3;
    border-radius: var(--mobile-radius-sm);
    padding: var(--mobile-space-sm);
    margin-top: var(--mobile-space-sm);
    display: none;
    font-size: var(--mobile-font-size-xs);
  }
  
  .explanation-header {
    color: #155724;
    font-weight: 600;
    margin-bottom: var(--mobile-space-xs);
    font-size: var(--mobile-font-size-xs);
  }
  
  .explanation-text {
    color: #155724;
    line-height: 1.4;
    font-size: var(--mobile-font-size-xs);
  }
  
  /* Compact note container */
  .note-container {
    background: #fff3cd;
    border: 1px solid #ffeaa7;
    border-radius: var(--mobile-radius-sm);
    padding: var(--mobile-space-sm);
    margin-top: var(--mobile-space-sm);
    display: none;
  }
  
  .note-textarea {
    width: 100%;
    min-height: 60px;
    border: 1px solid var(--mobile-border-primary);
    border-radius: var(--mobile-radius-sm);
    padding: var(--mobile-space-sm);
    font-family: inherit;
    resize: vertical;
    font-size: var(--mobile-font-size-xs);
  }
  
  /* Compact login prompt */
  .login-prompt {
    background: #d1ecf1;
    border: 1px solid #bee5eb;
    border-radius: var(--mobile-radius-sm);
    padding: var(--mobile-space-sm);
    margin-top: var(--mobile-space-sm);
    text-align: center;
    font-size: var(--mobile-font-size-xs);
  }
  
  /* Compact difficulty badge */
  .difficulty-badge {
    font-size: var(--mobile-font-size-xs);
    padding: var(--mobile-space-xs);
    border-radius: var(--mobile-radius-sm);
    font-weight: 500;
  }
  
  /* Hide sidebar on mobile for question pages */
  .sidebar-column {
    display: none;
  }
  
  .col-lg-8 {
    width: 100%;
    max-width: 100%;
    flex: 0 0 100%;
  }
  
  /* Full-width container */
  .container-fluid {
    padding-left: var(--mobile-space-sm);
    padding-right: var(--mobile-space-sm);
  }
}

/* ===================================
   EXTRA SMALL DEVICES (320px-375px)
   =================================== */

@media (max-width: 375px) {
  .question-container {
    padding: var(--mobile-space-xs) var(--mobile-space-sm);
  }
  
  .question-title {
    font-size: var(--mobile-font-size-base);
  }
  
  .question-text {
    font-size: var(--mobile-font-size-xs);
  }
  
  .option-item {
    padding: var(--mobile-space-xs) var(--mobile-space-sm);
  }
  
  .option-label {
    min-width: 1rem;
  }
  
  .actions-container {
    flex-direction: column;
  }
  
  .btn-action {
    width: 100%;
    margin-bottom: var(--mobile-space-xs);
  }
}

/* ===================================
   LANDSCAPE ORIENTATION OPTIMIZATION
   =================================== */

@media (max-width: 767px) and (orientation: landscape) {
  .question-container {
    padding: var(--mobile-space-xs) var(--mobile-space-sm);
  }
  
  .question-header {
    padding-bottom: var(--mobile-space-xs);
    margin-bottom: var(--mobile-space-xs);
  }
  
  .question-text {
    margin-bottom: var(--mobile-space-xs);
  }
  
  .options-container {
    margin-bottom: var(--mobile-space-xs);
  }
  
  .option-item {
    padding: var(--mobile-space-xs) var(--mobile-space-sm);
    margin-bottom: 2px;
  }
  
  .actions-container {
    margin-top: var(--mobile-space-xs);
    padding-top: var(--mobile-space-xs);
  }
}

/* ===================================
   VIEWPORT HEIGHT OPTIMIZATION
   =================================== */

/* Ensure content fits in viewport height */
@media (max-width: 767px) and (max-height: 667px) {
  .question-container {
    padding: var(--mobile-space-xs) var(--mobile-space-sm);
  }
  
  .question-meta {
    padding: 2px var(--mobile-space-xs);
    margin-bottom: var(--mobile-space-xs);
  }
  
  .question-text {
    margin-bottom: var(--mobile-space-xs);
    font-size: var(--mobile-font-size-xs);
  }
  
  .option-item {
    padding: var(--mobile-space-xs);
    margin-bottom: 2px;
  }
  
  .actions-container {
    margin-top: var(--mobile-space-xs);
    padding-top: var(--mobile-space-xs);
  }
}

/* ===================================
   ACCESSIBILITY IMPROVEMENTS
   =================================== */

@media (max-width: 767px) {
  /* Ensure sufficient contrast */
  .option-item {
    border-width: 2px;
  }
  
  .option-item:focus {
    outline: 2px solid var(--mobile-primary);
    outline-offset: 2px;
  }
  
  /* High contrast mode support */
  @media (prefers-contrast: high) {
    .option-item {
      border-width: 3px;
    }
    
    .option-item.selected {
      border-width: 4px;
    }
  }
  
  /* Reduced motion support */
  @media (prefers-reduced-motion: reduce) {
    .option-item,
    .btn-action {
      transition: none;
    }
  }
}
