/* ═══════════════════════════════════════════════════
   CareerCraft AI — CV Builder Mobile
   Method Selection + Each Method Panel
   ═══════════════════════════════════════════════════ */

@media (max-width: 767px) {

  /* ═══ Nav ═══ */
  .nav { height: 56px !important; }
  .nav-links { display: none !important; }
  .container { padding: 60px 14px 80px !important; }

  /* ═══════════════════════════════════════════
     PAGE TITLE
     ═══════════════════════════════════════════ */
  .page-title h1 { font-size: 22px !important; }
  .page-title p { font-size: 12px !important; margin-bottom: 16px !important; }

  /* ═══════════════════════════════════════════
     METHOD TABS — 3 equal buttons
     ═══════════════════════════════════════════ */
  .slider-header h2 { font-size: 16px !important; margin-bottom: 10px !important; }

  .tabs-bar {
    display: flex !important;
    gap: 4px !important;
    padding: 3px !important;
    border-radius: 10px !important;
    margin-bottom: 12px !important;
  }
  .tab-btn {
    flex: 1 !important;
    font-size: 11px !important;
    padding: 8px 6px !important;
    border-radius: 8px !important;
    text-align: center !important;
    justify-content: center !important;
  }
  .tab-btn span {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    white-space: nowrap !important;
  }
  .tab-btn i { font-size: 14px !important; }

  /* ═══════════════════════════════════════════
     TAB PANELS — Vertical card layout
     ═══════════════════════════════════════════ */
  .tab-panel {
    border-radius: 14px !important;
    padding: 16px !important;
  }
  .tab-panel.active {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
  }
  .tab-num {
    font-size: 24px !important;
    margin-bottom: 8px !important;
  }
  .tab-visual {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    margin-bottom: 12px !important;
  }
  .tab-visual img {
    width: 90px !important;
    height: 90px !important;
  }
  .tab-info {
    width: 100% !important;
  }
  .tab-info h3 {
    font-size: 18px !important;
    margin-bottom: 6px !important;
  }
  .tab-info p {
    font-size: 12px !important;
    line-height: 1.5 !important;
    margin-bottom: 12px !important;
  }
  /* Steps — horizontal row */
  .tab-steps {
    display: flex !important;
    justify-content: center !important;
    gap: 12px !important;
    margin-bottom: 14px !important;
  }
  .tab-step {
    font-size: 10px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 3px !important;
    text-align: center !important;
  }
  .tab-step i { font-size: 18px !important; }
  /* Start button — full width */
  .tab-info button {
    width: 100% !important;
    padding: 12px !important;
    font-size: 14px !important;
    border-radius: 12px !important;
    margin-top: 8px !important;
  }

  /* ═══════════════════════════════════════════
     GENERATION HISTORY
     ═══════════════════════════════════════════ */
  .gen-history-title { font-size: 14px !important; }
  .gen-card {
    padding: 12px !important;
    border-radius: 12px !important;
  }
  .gen-card:hover { transform: none !important; }

  /* ═══════════════════════════════════════════
     BACK BUTTON (all panels)
     ═══════════════════════════════════════════ */
  .panel > button:first-child,
  [onclick="backToMethods()"] {
    font-size: 12px !important;
    padding: 8px 14px !important;
    border-radius: 8px !important;
    margin-bottom: 10px !important;
  }

  /* ═══════════════════════════════════════════
     PROMPT PANEL
     ═══════════════════════════════════════════ */
  .prompt-box {
    padding: 14px !important;
    border-radius: 14px !important;
  }
  .prompt-label {
    font-size: 13px !important;
    margin-bottom: 8px !important;
  }
  .prompt-textarea, #promptText {
    font-size: 14px !important;
    min-height: 120px !important;
    border-radius: 10px !important;
    padding: 12px !important;
    line-height: 1.6 !important;
  }
  .prompt-hint {
    font-size: 10px !important;
  }
  /* Mic button */
  #micBtn {
    width: 36px !important;
    height: 36px !important;
    font-size: 16px !important;
  }
  /* Generate button */
  .generate-btn {
    width: 100% !important;
    padding: 14px !important;
    font-size: 15px !important;
    border-radius: 12px !important;
    margin-top: 12px !important;
    min-height: 48px !important;
  }

  /* ═══════════════════════════════════════════
     AI AGENT / CHAT PANEL
     ═══════════════════════════════════════════ */
  .chat-box {
    padding: 12px !important;
    border-radius: 14px !important;
    min-height: 350px !important;
  }
  .chat-messages {
    max-height: 400px !important;
    padding: 8px !important;
  }
  .chat-msg {
    max-width: 88% !important;
    font-size: 13px !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
    line-height: 1.5 !important;
  }
  .agent-label {
    font-size: 10px !important;
    margin-bottom: 4px !important;
  }
  .chat-input-row {
    gap: 6px !important;
    padding: 8px !important;
  }
  .chat-input {
    font-size: 14px !important;
    padding: 10px 12px !important;
    border-radius: 10px !important;
    min-height: 42px !important;
  }
  .chat-send {
    width: 42px !important;
    height: 42px !important;
    border-radius: 10px !important;
    font-size: 18px !important;
  }

  /* ═══════════════════════════════════════════
     UPLOAD PANEL
     ═══════════════════════════════════════════ */
  .upload-box {
    padding: 24px 16px !important;
    border-radius: 14px !important;
    text-align: center !important;
  }
  .upload-box i { font-size: 36px !important; }
  .upload-box h3 { font-size: 16px !important; }
  .upload-box p { font-size: 12px !important; }
  .upload-formats {
    display: flex !important;
    justify-content: center !important;
    gap: 12px !important;
    margin-top: 12px !important;
  }
  .upload-fmt {
    font-size: 11px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 3px !important;
  }
  .upload-fmt i { font-size: 20px !important; }
  .upload-file-info {
    font-size: 12px !important;
    padding: 8px 12px !important;
    border-radius: 8px !important;
  }
  /* Paste textarea */
  #pasteText {
    font-size: 14px !important;
    min-height: 80px !important;
    border-radius: 10px !important;
  }
  /* Extracted text step */
  #uploadStep2 .prompt-box {
    padding: 14px !important;
  }
  #uploadStep2 .prompt-textarea {
    min-height: 150px !important;
  }
  #uploadStep2 [style*="display:flex"][style*="gap:8px"] {
    flex-direction: column !important;
  }
  #uploadStep2 .generate-btn { flex: none !important; width: 100% !important; }
  #uploadStep2 button:last-child { width: 100% !important; }

  /* ═══════════════════════════════════════════
     PROCESSING ANIMATION
     ═══════════════════════════════════════════ */
  .processing-inner {
    padding: 24px 16px !important;
    border-radius: 14px !important;
  }
  .process-ring {
    width: 60px !important;
    height: 60px !important;
  }
  .process-ring i { font-size: 24px !important; }
  .process-text { font-size: 16px !important; }
  .process-step-item { font-size: 12px !important; padding: 6px 0 !important; }

  /* ═══════════════════════════════════════════
     RESULT BOX
     ═══════════════════════════════════════════ */
  .result-box {
    padding: 0 !important;
    border-radius: 14px !important;
  }
  .result-header {
    padding: 12px 14px !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
  .result-header h3 { font-size: 15px !important; }
  .result-actions {
    display: flex !important;
    gap: 6px !important;
    width: 100% !important;
  }
  .result-btn {
    flex: 1 !important;
    font-size: 12px !important;
    padding: 8px 10px !important;
    border-radius: 8px !important;
    min-height: 36px !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* ═══════════════════════════════════════════
     EDITOR LAYOUT (after result)
     ═══════════════════════════════════════════ */
  .editor-layout {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    min-height: auto !important;
  }
  /* sidebar handled by slide overlay below */
  .sidebar-section { padding: 10px 14px !important; }
  .sidebar-box {
    margin: 6px 8px !important;
    padding: 10px 12px !important;
    border-radius: 10px !important;
  }
  .sidebar-box:hover { transform: none !important; box-shadow: none !important; }
  .sidebar-box-title { font-size: 10px !important; margin-bottom: 6px !important; }
  .sidebar-row { margin-bottom: 4px !important; }
  .sidebar-label { font-size: 10px !important; min-width: 34px !important; }
  .sidebar-select { font-size: 12px !important; padding: 6px 8px !important; }
  .ver-btn { font-size: 11px !important; padding: 7px 8px !important; }

  /* Editor main */
  .editor-main { padding: 12px !important; }
  .editor-main input, .editor-main select, .editor-main textarea {
    font-size: 14px !important;
    padding: 10px 12px !important;
    border-radius: 8px !important;
    min-height: 40px !important;
  }
  .editor-main label { font-size: 11px !important; }

  /* ATS Widget */
  .ats-widget { padding: 12px !important; border-radius: 12px !important; }

  /* CV Preview */
  .result-preview { overflow-x: auto !important; -webkit-overflow-scrolling: touch; }
  .cv-v1, .cv-v2, .cv-v3 { min-width: 580px !important; }

  /* Add sections */
  .add-section-bar { padding: 10px !important; border-radius: 10px !important; }
  .add-sec-btn { padding: 5px 8px !important; font-size: 10px !important; border-radius: 6px !important; }

  /* Disable hover effects */
  .method-card:hover, .sidebar-box:hover, .gen-card:hover,
  .prompt-box:hover, .chat-box:hover, .upload-box:hover,
  .ats-widget:hover { transform: none !important; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr 1fr !important; text-align:center !important; }.footer-grid>div:first-child{grid-column:1/-1 !important;}
  .footer-bottom { flex-direction: column !important; gap: 8px !important; }
}

/* ═══ METHOD PANELS — Fullscreen popup on mobile ═══ */
@media (max-width: 767px) {
  .panel.active {
    display: flex !important;
    flex-direction: column !important;
    position: fixed !important;
    inset: 0 !important;
    z-index: 200 !important;
    background: var(--bg) !important;
    padding: 16px !important;
    padding-top: 20px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    animation: mPanelIn 0.3s ease-out !important;
  }
  @keyframes mPanelIn {
    from { transform: translateY(100%); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
  }

  /* Back button — top bar */
  .panel.active > button:first-child {
    z-index: 10 !important;
    padding: 12px 16px !important;
    margin-bottom: 12px !important;
    font-size: 13px !important;
    border-radius: 10px !important;
    min-height: 48px !important;
  }

  /* Processing — fullscreen when shown via JS */
  .processing[style*="display: flex"],
  .processing[style*="display:flex"] {
    position: fixed !important;
    inset: 0 !important;
    z-index: 200 !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--bg) !important;
  }

  /* Result — fullscreen below nav */
  .result-box {
    position: fixed !important;
    top: 56px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 56px !important;
    z-index: 90 !important;
    background: var(--bg) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    border-radius: 0 !important;
    padding: 0 !important;
  }
}

/* ═══ Agent panel — fill screen ═══ */
@media (max-width: 767px) {
  #panelAgent.panel.active {
    display: flex !important;
    flex-direction: column !important;
  }
  #panelAgent .chat-box {
    flex: 1 !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    height: calc(100vh - 160px) !important;
  }
  #panelAgent .chat-messages {
    flex: 1 !important;
    max-height: none !important;
    overflow-y: auto !important;
  }
  #panelAgent .chat-input-row {
    position: sticky !important;
    bottom: 0 !important;
    background: var(--bg) !important;
    padding: 10px 0 calc(10px + env(safe-area-inset-bottom, 0px)) !important;
    margin-bottom: 56px !important;
  }
}

/* ═══ Generation History — Mobile compact ═══ */
@media (max-width: 767px) {
  .gen-history { margin-top: 20px !important; }
  .gen-history-title { font-size: 13px !important; }

  .gen-card {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
    padding: 12px !important;
    border-radius: 12px !important;
    margin-bottom: 8px !important;
  }
  .gen-card:hover { transform: none !important; }
  .gen-card .gen-num {
    font-size: 14px !important;
    width: auto !important;
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    opacity: 0.3 !important;
  }
  .gen-card .gen-info { width: 100% !important; padding-right: 30px !important; }
  .gen-card .gen-info strong { font-size: 13px !important; }
  .gen-card .gen-prompt { font-size: 11px !important; }
  .gen-card .gen-meta { font-size: 9px !important; }
  .gen-card .gen-method { font-size: 8px !important; padding: 2px 5px !important; }

  /* Action buttons — full width row */
  .gen-card > div:last-child {
    width: 100% !important;
    display: flex !important;
    gap: 4px !important;
    flex-wrap: nowrap !important;
    border-top: 1px solid var(--border) !important;
    padding-top: 8px !important;
  }
  .gen-card .ctrl-btn {
    flex: 1 !important;
    font-size: 10px !important;
    padding: 6px 4px !important;
    border-radius: 6px !important;
    min-height: 32px !important;
    justify-content: center !important;
    white-space: nowrap !important;
  }
  .gen-card .ctrl-btn i { font-size: 13px !important; }
  /* Delete button — icon only */
  .gen-card .ctrl-btn[title=Delete] {
    flex: 0 0 32px !important;
    padding: 6px !important;
  }
}

/* ═══ Editor Sidebar — Slide overlay from left ═══ */
@media (max-width: 767px) {
  .editor-sidebar {
    position: fixed !important;
    top: 0 !important;
    left: -300px !important;
    bottom: 0 !important;
    width: 280px !important;
    z-index: 500 !important;
    background: var(--bg) !important;
    border-right: 1px solid rgba(124,106,255,0.2) !important;
    border-bottom: none !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    transition: left 0.3s cubic-bezier(0.22,1,0.36,1) !important;
    padding: 16px 0 80px !important;
    box-shadow: none !important;
    max-height: none !important;
  }
  .editor-sidebar.open {
    left: 0 !important;
    box-shadow: 8px 0 40px rgba(0,0,0,0.4) !important;
  }
  [data-theme="light"] .editor-sidebar {
    background: #F8F8FC !important;
    box-shadow: none !important;
  }
  [data-theme="light"] .editor-sidebar.open {
    box-shadow: 8px 0 40px rgba(0,0,0,0.1) !important;
  }

  /* Overlay behind sidebar */
  [data-theme="light"]

  /* Settings toggle button — floating */

  /* Close button inside sidebar */

  /* Editor main takes full width */
  .editor-main {
    width: 100% !important;
    padding: 12px 14px !important;
  }
}
