/* ============================================
   AI-PASS (AI-GENERATOR) - MOBIL
   Matchar referens: ai-pass.html
   ============================================ */

@media (max-width: 768px) {

  /* ======================================
     0. LAYOUT - Stack columns, single page
     ====================================== */

  /* Flatten columns so we can reorder: hero -> history -> form */
  .row.g-0.min-vh-100 {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100dvh !important;
  }

  .col-lg-4 {
    display: contents !important;
  }

  .col-lg-8.ai-gradient-bg {
    display: contents !important;
  }

  .ai-content {
    display: contents !important;
  }

  /* Order: hero(0) -> form(1) -> history(2) */
  .ai-panel-header {
    order: 0 !important;
    width: 100% !important;
  }

  .ai-history {
    order: 2 !important;
    width: 100% !important;
  }

  .ai-form {
    order: 1 !important;
    width: 100% !important;
  }

  /* ======================================
     1. HERO HEADER
     ====================================== */

  .ai-panel-header {
    padding: 20px 20px 16px !important;
    text-align: center !important;
    background: rgba(0, 217, 163, 0.07) !important;
    border-radius: 0 0 24px 24px !important;
    margin-bottom: 20px !important;
    position: relative !important;
    overflow: hidden !important;
  }

  .ai-panel-header::before {
    content: '' !important;
    position: absolute !important;
    top: -60px !important;
    right: -60px !important;
    width: 200px !important;
    height: 200px !important;
    background: linear-gradient(135deg, #00D9A3, #00B389) !important;
    border-radius: 50% !important;
    opacity: 0.07 !important;
    pointer-events: none !important;
  }

  .ai-panel-header .ai-logo {
    width: 52px !important;
    height: 52px !important;
    background: linear-gradient(135deg, #00D9A3, #00B389) !important;
    border-radius: 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 auto 12px !important;
    box-shadow: 0 4px 20px rgba(0, 217, 163, 0.35) !important;
  }

  .ai-panel-header .ai-logo i {
    font-size: 26px !important;
    color: white !important;
  }

  .ai-panel-header h2 {
    font-size: 20px !important;
    font-weight: 900 !important;
    margin-bottom: 8px !important;
    background: linear-gradient(135deg, #00D9A3, #00B389) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    letter-spacing: -0.4px !important;
  }

  .ai-panel-header p {
    font-size: 14px !important;
    color: #64748B !important;
    font-weight: 500 !important;
    max-width: 320px !important;
    margin: 0 auto !important;
    line-height: 1.5 !important;
    padding: 0 16px !important;
  }

  /* ======================================
     2. FORM
     ====================================== */

  .ai-form {
    padding: 0 20px !important;
    padding-bottom: 160px !important;
  }

  .ai-form .form-group {
    margin-bottom: 24px !important;
  }

  .ai-form .form-group > label {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.9px !important;
    color: #94A3B8 !important;
    margin-bottom: 12px !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
  }

  /* ======================================
     3. DURATION SLIDER
     ====================================== */

  .range-slider-container {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
  }

  .range-value {
    text-align: center !important;
    padding: 28px 16px 20px !important;
    background: linear-gradient(135deg, #00D9A3, #00B389) !important;
    border-radius: 12px !important;
    color: white !important;
    box-shadow: 0 4px 20px rgba(0, 217, 163, 0.35) !important;
    position: relative !important;
    overflow: hidden !important;
    order: -1 !important;
  }

  .range-value::before {
    content: '' !important;
    position: absolute !important;
    top: -20px !important;
    right: -20px !important;
    width: 80px !important;
    height: 80px !important;
    background: rgba(255, 255, 255, 0.08) !important;
    border-radius: 50% !important;
  }

  .range-value span {
    font-size: 56px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: -2px !important;
    font-variant-numeric: tabular-nums !important;
    color: white !important;
  }

  .range-slider {
    width: 100% !important;
    height: 8px !important;
    border-radius: 4px !important;
    outline: none !important;
    -webkit-appearance: none !important;
    background: linear-gradient(135deg, #00D9A3, #00B389) !important;
    cursor: pointer !important;
  }

  .range-slider::-webkit-slider-thumb {
    -webkit-appearance: none !important;
    width: 28px !important;
    height: 28px !important;
    background: white !important;
    border: 4px solid #00D9A3 !important;
    border-radius: 50% !important;
    box-shadow: 0 2px 10px rgba(0, 217, 163, 0.3) !important;
  }

  /* ======================================
     4. AGE RANGE SLIDER
     ====================================== */

  .ai-form .age-range-slider {
    background: #F7F9FC !important;
    padding: 16px !important;
    border-radius: 12px !important;
    border: 1px solid #E2E8F0 !important;
  }

  .ai-form .age-range-labels {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 12px !important;
  }

  .ai-form .age-range-labels::before {
    content: 'Välj ålder' !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #0F172A !important;
  }

  .ai-form .age-range-labels span {
    font-size: 16px !important;
    font-weight: 800 !important;
    color: #00D9A3 !important;
    font-variant-numeric: tabular-nums !important;
  }

  .ai-form .age-range-input::-webkit-slider-thumb {
    -webkit-appearance: none !important;
    width: 22px !important;
    height: 22px !important;
    background: #00D9A3 !important;
    border: 3px solid white !important;
    border-radius: 50% !important;
    box-shadow: 0 2px 8px rgba(0, 217, 163, 0.3) !important;
  }

  .ai-form .age-range-fill {
    background: #00D9A3 !important;
  }

  .ai-form .age-range-ticks {
    display: flex !important;
    justify-content: space-between !important;
    margin-top: 8px !important;
    font-size: 11px !important;
    color: #94A3B8 !important;
    font-weight: 600 !important;
  }

  /* Intensity selector hidden - removed from UI */
  .intensity-selector {
    display: none !important;
  }

  /* ======================================
     6. FOCUS AREA TAGS
     ====================================== */

  .focus-area-tags {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }

  .focus-tag {
    padding: 13px 16px !important;
    border: 2px solid #E2E8F0 !important;
    border-radius: 10px !important;
    background: white !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #64748B !important;
    cursor: pointer !important;
    transition: all 0.18s !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    -webkit-tap-highlight-color: transparent !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08) !important;
  }

  .focus-tag:active {
    transform: scale(0.96) !important;
  }

  .focus-tag.active {
    border-color: #00D9A3 !important;
    background: linear-gradient(135deg, #00D9A3, #00B389) !important;
    color: white !important;
    box-shadow: 0 4px 14px rgba(0, 217, 163, 0.3) !important;
  }

  /* ======================================
     7. TEXTAREA (Additional Notes)
     ====================================== */

  .ai-form textarea.form-control {
    width: 100% !important;
    min-height: 100px !important;
    padding: 14px 16px !important;
    border: 2px solid #E2E8F0 !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    resize: vertical !important;
    color: #0F172A !important;
    background: white !important;
    line-height: 1.6 !important;
  }

  .ai-form textarea.form-control:focus {
    border-color: #00D9A3 !important;
    background: rgba(0, 217, 163, 0.04) !important;
    box-shadow: none !important;
    outline: none !important;
  }

  /* ======================================
     8. GENERATE BUTTON (sticky footer)
     ====================================== */

  .btn-generate {
    position: fixed !important;
    bottom: 82px !important;
    left: 20px !important;
    right: 20px !important;
    margin: 0 !important;
    border-radius: 12px !important;
    padding: 18px 20px !important;
    background: linear-gradient(135deg, #00D9A3, #00B389) !important;
    border: none !important;
    color: white !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    min-height: 58px !important;
    box-shadow: 0 4px 20px rgba(0, 217, 163, 0.35) !important;
    z-index: 20 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    -webkit-tap-highlight-color: transparent !important;
    letter-spacing: 0.1px !important;
    width: auto !important;
  }

  .btn-generate:active {
    transform: scale(0.98) !important;
    opacity: 0.95 !important;
  }

  .btn-generate .btn-content {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .btn-generate .btn-content i {
    font-size: 22px !important;
  }

  .btn-generate .btn-loading {
    align-items: center !important;
    gap: 10px !important;
  }

  /* ======================================
     9. HISTORY SECTION (below form on mobile)
     ====================================== */

  /* Show history inline on mobile (moved from right panel) */
  .ai-history {
    margin: 0 !important;
    padding: 24px 20px !important;
    background: linear-gradient(135deg, rgba(15, 23, 42, 0.97), rgba(30, 41, 59, 0.97)) !important;
    border-radius: 0 !important;
    margin-bottom: 24px !important;
    position: relative !important;
    overflow: hidden !important;
  }

  .ai-history::before {
    content: '' !important;
    position: absolute !important;
    top: -40px !important;
    right: -40px !important;
    width: 150px !important;
    height: 150px !important;
    background: #00D9A3 !important;
    border-radius: 50% !important;
    opacity: 0.08 !important;
  }

  .history-header {
    margin-bottom: 16px !important;
  }

  .history-header h3 {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: white !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
  }

  .history-item {
    background: rgba(255, 255, 255, 0.055) !important;
    backdrop-filter: blur(10px) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    border-radius: 12px !important;
    padding: 14px !important;
    margin-bottom: 12px !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    -webkit-tap-highlight-color: transparent !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
  }

  .history-item:active {
    transform: scale(0.985) !important;
    background: rgba(255, 255, 255, 0.09) !important;
  }

  .history-item-content {
    flex: 1 !important;
    min-width: 0 !important;
  }

  .history-item-content h4 {
    font-size: 15px !important;
    font-weight: 800 !important;
    color: white !important;
    margin-bottom: 5px !important;
    letter-spacing: -0.1px !important;
    line-height: 1.3 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  .history-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    font-size: 11px !important;
    color: rgba(255, 255, 255, 0.55) !important;
    font-weight: 600 !important;
  }

  .history-meta span {
    display: flex !important;
    align-items: center !important;
    gap: 3px !important;
    color: rgba(255, 255, 255, 0.55) !important;
    white-space: nowrap !important;
  }

  .history-item-actions {
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
  }

  .history-item-actions .btn-icon {
    width: 36px !important;
    height: 36px !important;
    background: rgba(255, 255, 255, 0.10) !important;
    border: none !important;
    border-radius: 8px !important;
    color: white !important;
    font-size: 16px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    -webkit-tap-highlight-color: transparent !important;
  }

  .history-item-actions .btn-icon:active {
    background: rgba(255, 255, 255, 0.20) !important;
  }

  .empty-history {
    text-align: center !important;
    padding: 32px 20px !important;
    color: rgba(255, 255, 255, 0.5) !important;
  }

  .empty-history i {
    font-size: 32px !important;
    display: block !important;
    margin-bottom: 8px !important;
  }

  .empty-history p {
    font-size: 14px !important;
    color: rgba(255, 255, 255, 0.5) !important;
  }

  /* ======================================
     10. GENERATING STATE
     ====================================== */

  .generating-state {
    text-align: center !important;
    padding: 60px 40px !important;
  }

  .generating-animation {
    position: relative !important;
    width: 88px !important;
    height: 88px !important;
    margin: 0 auto 32px !important;
  }

  .pulse-ring {
    position: absolute !important;
    inset: 0 !important;
    border-radius: 50% !important;
    border: 4px solid rgba(0, 217, 163, 0.2) !important;
    border-top-color: #00D9A3 !important;
    animation: ai-spin 1s linear infinite !important;
  }

  .generating-animation .ai-icon {
    position: absolute !important;
    inset: 6px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 32px !important;
    color: #00D9A3 !important;
  }

  @keyframes ai-spin {
    to { transform: rotate(360deg); }
  }

  /* ======================================
     11. AI-SESSION-DETAIL-MODAL: Fullscreen + scroll
     ====================================== */

  #ai-session-detail-modal {
    padding: 0 !important;
  }

  #ai-session-detail-modal .modal-dialog {
    margin: 0 !important;
    max-width: 100% !important;
    min-height: 100% !important;
    width: 100% !important;
    height: 100% !important;
    align-items: stretch !important;
  }

  #ai-session-detail-modal .modal-content {
    position: fixed !important;
    inset: 0 !important;
    border-radius: 0 !important;
    border: none !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    z-index: 1060 !important;
    height: 100% !important;
  }

  #ai-session-detail-modal .modal-header-gradient,
  #ai-session-detail-modal .modal-stats-bar,
  #ai-session-detail-modal .modal-footer {
    flex-shrink: 0 !important;
  }

  #ai-session-detail-modal .modal-body {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* Header gradient - compact */
  #ai-session-detail-modal .modal-images-collage {
    display: none !important;
  }

  #ai-session-detail-modal .modal-header-gradient {
    padding: 16px 48px 16px 16px !important;
    min-height: 0 !important;
    border-bottom: none !important;
    position: relative !important;
    overflow: hidden !important;
  }

  #ai-session-detail-modal .modal-title {
    font-size: 18px !important;
    font-weight: 900 !important;
    line-height: 1.25 !important;
    margin: 0 !important;
    color: white !important;
    letter-spacing: -0.3px !important;
  }

  #ai-session-detail-modal .modal-title .ai-icon {
    margin-right: 6px !important;
  }

  #ai-session-detail-modal .modal-meta-tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-top: 8px !important;
  }

  #ai-session-detail-modal .meta-tag {
    font-size: 11px !important;
    padding: 3px 10px !important;
    background: rgba(255, 255, 255, 0.20) !important;
    border-radius: 6px !important;
    font-weight: 700 !important;
    color: white !important;
    backdrop-filter: blur(8px) !important;
  }

  #ai-session-detail-modal .modal-close-btn {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    width: 38px !important;
    height: 38px !important;
    background: rgba(255, 255, 255, 0.20) !important;
    border: none !important;
    border-radius: 8px !important;
    color: white !important;
    font-size: 18px !important;
    backdrop-filter: blur(10px) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    z-index: 5 !important;
  }

  /* Stats bar */
  #ai-session-detail-modal .modal-stats-bar {
    display: flex !important;
    justify-content: space-around !important;
    padding: 12px 16px !important;
    background: #F7F9FC !important;
    border-bottom: 1px solid #E2E8F0 !important;
    gap: 6px !important;
  }

  #ai-session-detail-modal .modal-stat {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    padding: 8px !important;
    gap: 4px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 8px !important;
    background: white !important;
  }

  #ai-session-detail-modal .modal-stat i {
    font-size: 16px !important;
    opacity: 0.7 !important;
  }

  #ai-session-detail-modal .modal-stat-value {
    font-size: 17px !important;
    font-weight: 800 !important;
    color: #0F172A !important;
    font-variant-numeric: tabular-nums !important;
  }

  #ai-session-detail-modal .modal-stat-label {
    font-size: 10px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: #64748B !important;
    font-weight: 700 !important;
  }

  /* Body content */
  #ai-session-detail-modal .modal-body {
    padding: 20px !important;
    padding-bottom: 100px !important;
    background: white !important;
  }

  #ai-session-detail-modal .detail-section {
    margin-bottom: 24px !important;
  }

  #ai-session-detail-modal .detail-section h4 {
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    color: #94A3B8 !important;
    font-weight: 700 !important;
    margin-bottom: 12px !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
  }

  #ai-session-detail-modal .session-description-text {
    font-size: 15px !important;
    line-height: 1.8 !important;
    color: #1E293B !important;
    font-weight: 500 !important;
  }

  /* Coach tips */
  #ai-session-detail-modal .coach-tips {
    padding: 16px !important;
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.08), rgba(217, 119, 6, 0.05)) !important;
    border-left: 4px solid #F59E0B !important;
    border-radius: 0 8px 8px 0 !important;
    margin-bottom: 24px !important;
  }

  #ai-session-detail-modal .coach-tips h4 {
    font-size: 13px !important;
    font-weight: 800 !important;
    color: #D97706 !important;
    margin-bottom: 10px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
  }

  #ai-session-detail-modal .coach-tips p {
    font-size: 14px !important;
    line-height: 1.7 !important;
    color: #1E293B !important;
    font-weight: 500 !important;
  }

  /* Timeline exercises */
  #ai-session-detail-modal .timeline-section {
    margin-bottom: 20px !important;
  }

  #ai-session-detail-modal .timeline-header {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 12px !important;
  }

  #ai-session-detail-modal .timeline-header h4 {
    font-size: 13px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: #0F172A !important;
    font-weight: 800 !important;
    margin: 0 !important;
  }

  #ai-session-detail-modal .timeline-icon {
    width: 32px !important;
    height: 32px !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 16px !important;
    flex-shrink: 0 !important;
  }

  #ai-session-detail-modal .timeline-item {
    background: #F7F9FC !important;
    border: 2px solid #E2E8F0 !important;
    border-radius: 12px !important;
    padding: 14px !important;
    margin-bottom: 10px !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 14px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08) !important;
  }

  #ai-session-detail-modal .timeline-number {
    width: 32px !important;
    height: 32px !important;
    background: linear-gradient(135deg, #00D9A3, #00B389) !important;
    border-radius: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    color: white !important;
    flex-shrink: 0 !important;
    box-shadow: 0 4px 10px rgba(0, 217, 163, 0.3) !important;
  }

  #ai-session-detail-modal .timeline-content {
    flex: 1 !important;
    min-width: 0 !important;
  }

  #ai-session-detail-modal .timeline-content h5 {
    font-size: 15px !important;
    font-weight: 800 !important;
    margin-bottom: 3px !important;
    color: #0F172A !important;
    letter-spacing: -0.1px !important;
  }

  #ai-session-detail-modal .timeline-duration {
    font-size: 12px !important;
    color: #64748B !important;
    font-weight: 600 !important;
  }

  #ai-session-detail-modal .timeline-notes {
    font-size: 13px !important;
    color: #64748B !important;
    line-height: 1.5 !important;
    margin-top: 6px !important;
  }

  #ai-session-detail-modal .ai-tip {
    margin-top: 8px !important;
    padding: 10px 12px !important;
    background: rgba(0, 217, 163, 0.07) !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    color: #00D9A3 !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 6px !important;
  }

  /* Footer */
  #ai-session-detail-modal .modal-footer {
    background: white !important;
    border-top: 1px solid #E2E8F0 !important;
    box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.06) !important;
    padding: 12px 20px !important;
    padding-bottom: max(12px, env(safe-area-inset-bottom)) !important;
    display: flex !important;
    gap: 10px !important;
  }

  #ai-session-detail-modal .modal-footer .btn.btn-secondary {
    display: none !important;
  }

  #ai-session-detail-modal #modal-save-ai-btn {
    flex: 1 !important;
    height: 52px !important;
    border-radius: 12px !important;
    background: linear-gradient(135deg, #00D9A3, #00B88A) !important;
    border-color: #00D9A3 !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    box-shadow: 0 4px 20px rgba(0, 217, 163, 0.35) !important;
    color: white !important;
  }

  #ai-session-detail-modal #modal-save-ai-btn:active {
    transform: scale(0.97) !important;
    opacity: 0.95 !important;
  }

  /* ======================================
     12. HIDE WELCOME, RESULT & ANIMATED BG on mobile
     ====================================== */

  .ai-welcome {
    display: none !important;
  }

  .ai-result {
    display: none !important;
  }

  .animated-bg {
    display: none !important;
  }

  /* ======================================
     14. BEKRÄFTELSE-DIALOG (showConfirmDialog)
     ====================================== */

  .modal-overlay > .modal.modal-sm {
    width: calc(100% - 32px) !important;
    max-width: 100% !important;
    margin: auto 16px !important;
    border-radius: 16px !important;
  }

  .modal-overlay > .modal.modal-sm .modal-header {
    padding: 20px 16px 8px !important;
  }

  .modal-overlay > .modal.modal-sm .modal-body {
    padding: 8px 16px 16px !important;
  }

  .modal-overlay > .modal.modal-sm .modal-footer {
    padding: 12px 16px 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
  }

  .modal-overlay > .modal.modal-sm .modal-footer .btn {
    width: 100% !important;
    padding: 12px !important;
    border-radius: 10px !important;
    font-size: 0.95rem !important;
  }

  /* ======================================
     15. NOTIFICATION CONTAINER
     ====================================== */

  #notification-container {
    position: fixed !important;
    top: 12px !important;
    left: 12px !important;
    right: 12px !important;
    z-index: 2000 !important;
  }
}
