:root{--clr-primary: #2563eb;--clr-primary-hover: #1d4ed8;--clr-primary-dark: #1e3a8a;--clr-primary-light: #eff6ff;--clr-primary-border: #bfdbfe;--clr-primary-mid: #dbeafe;--clr-accent: #60a5fa;--clr-reading: #3b82f6;--clr-numeracy: #10b981;--clr-language: #f59e0b;--clr-writing: #8b5cf6;--clr-mixed: #64748b;--clr-success: #10b981;--clr-success-dark: #065f46;--clr-success-light: #f0fdf4;--clr-success-border: #bbf7d0;--clr-warning: #f59e0b;--clr-warning-dark: #92400e;--clr-warning-light: #fffbeb;--clr-warning-border: #fde68a;--clr-danger: #ef4444;--clr-danger-dark: #991b1b;--clr-danger-light: #fef2f2;--clr-danger-border: #fecaca;--clr-purple: #8b5cf6;--clr-purple-dark: #4c1d95;--clr-purple-light: #f5f3ff;--clr-purple-border: #ddd6fe;--clr-bg: #f1f5f9;--clr-surface: #ffffff;--clr-surface-alt: #f8fafc;--clr-border: #e2e8f0;--clr-border-mid: #cbd5e1;--clr-nav: #1e293b;--clr-nav-border: rgba(255,255,255,.07);--clr-text: #1e293b;--clr-text-strong: #0f172a;--clr-text-secondary: #475569;--clr-text-muted: #64748b;--clr-text-faint: #94a3b8;--clr-text-inverse: #ffffff;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--r-xs: 4px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 18px;--r-2xl: 24px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--clr-muted: #64748b;--r-full: 9999px;--sh-xs: 0 1px 2px rgba(0,0,0,.05);--sh-sm: 0 1px 4px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--sh-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--sh-lg: 0 8px 24px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.04);--sh-xl: 0 20px 60px rgba(0,0,0,.15), 0 8px 20px rgba(0,0,0,.08);--sidebar-w: 220px;--header-h: 56px;--content-max: 1100px;--font-2xs: .7rem;--font-xs: .75rem;--font-sm: .875rem;--font-base: .9375rem;--font-md: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--t-fast: .12s ease;--t-base: .18s ease;--t-slow: .25s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;background:var(--clr-bg);color:var(--clr-text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}button{cursor:pointer;border:none;font-family:inherit}a{text-decoration:none}.btn-primary{background:var(--clr-primary);color:#fff;padding:.55rem 1.3rem;border-radius:var(--r-md);font-size:var(--font-base);font-weight:600;transition:background var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast)}.btn-primary:hover{background:var(--clr-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,.25)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--clr-surface);color:var(--clr-text-secondary);padding:.55rem 1.2rem;border-radius:var(--r-md);font-size:var(--font-base);font-weight:500;border:1.5px solid var(--clr-border);transition:border-color var(--t-fast),background var(--t-fast),transform var(--t-fast)}.btn-secondary:hover{border-color:var(--clr-border-mid);background:var(--clr-surface-alt)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-submit{background:#16a34a;color:#fff;padding:.55rem 1.3rem;border-radius:var(--r-md);font-size:var(--font-base);font-weight:600;transition:background var(--t-fast),transform var(--t-fast)}.btn-submit:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.btn-submit:disabled{opacity:.4;cursor:not-allowed}.btn-danger{background:var(--clr-surface);color:#dc2626;border:1.5px solid #fca5a5;padding:.5rem 1rem;border-radius:var(--r-md);font-size:var(--font-sm);font-weight:600;transition:background var(--t-fast)}.btn-danger:hover{background:var(--clr-danger-light)}.btn-ghost{background:transparent;color:#fff;padding:.38rem .8rem;border-radius:var(--r-sm);font-size:var(--font-base);font-weight:500;opacity:.85;transition:opacity var(--t-fast),background var(--t-fast)}.btn-ghost:hover{opacity:1;background:rgba(255,255,255,.15)}.btn-ghost-dark{background:var(--clr-surface-alt);color:var(--clr-text-secondary);border:1px solid var(--clr-border);padding:.35rem .85rem;border-radius:var(--r-md);font-size:var(--font-sm);font-weight:600;transition:background var(--t-fast),border-color var(--t-fast)}.btn-ghost-dark:hover{background:var(--clr-border);border-color:var(--clr-border-mid)}.link-btn{background:none;border:none;color:var(--clr-primary);font-size:var(--font-sm);font-weight:600;cursor:pointer;padding:0;font-family:inherit}.link-btn:hover{text-decoration:underline}.btn-sm{font-size:var(--font-sm)!important;padding:.38rem .9rem!important}.btn-xs{font-size:var(--font-xs)!important;padding:.28rem .65rem!important}.assigned-task-card>.btn-primary,.content-header>.btn-primary,.quick-diagnostic-banner>.btn-primary{flex-shrink:0}.spinner{width:32px;height:32px;border:3px solid var(--clr-border);border-top-color:var(--clr-primary);border-radius:50%;animation:spin .8s linear infinite}.btn-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.band-pill{font-size:var(--font-2xs);font-weight:700;color:#fff;padding:.2rem .55rem;border-radius:var(--r-full)}.answer-type-badge{font-size:var(--font-2xs);font-weight:600;background:var(--clr-surface-alt);color:var(--clr-text-muted);padding:.15rem .45rem;border-radius:var(--r-full);margin-left:.25rem}.skill-tag{background:var(--clr-warning-light);color:var(--clr-warning-dark);border:1px solid var(--clr-warning-border);border-radius:var(--r-full);padding:.2rem .65rem;font-size:var(--font-xs);font-weight:600}.meta-chip{background:var(--clr-surface-alt);color:var(--clr-text-secondary);font-size:var(--font-xs);font-weight:600;padding:.2rem .55rem;border-radius:var(--r-full)}.status-chip{background:#fef9c3;color:#92400e}.error-chip{background:var(--clr-danger-light);color:#dc2626}.dash-nav{background:var(--clr-surface);color:var(--clr-text);padding:0 var(--sp-6);height:var(--header-h);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--clr-border);box-shadow:var(--sh-xs);flex-shrink:0}.dash-logo{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;color:var(--clr-primary)}.dash-logo span{color:var(--clr-text-secondary);font-weight:500;margin-left:.3rem;font-size:var(--font-sm);letter-spacing:0}.dash-nav-right{display:flex;align-items:center;gap:var(--sp-3)}.dash-avatar{width:32px;height:32px;border-radius:50%;background:var(--clr-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-sm);flex-shrink:0}.dash-user-info{display:flex;flex-direction:column;line-height:1.2}.dash-user-name{font-size:var(--font-sm);font-weight:600;color:var(--clr-text)}.dash-user-role{font-size:var(--font-2xs);color:var(--clr-text-muted);text-transform:capitalize}.hamburger-btn{display:none;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:#e2e8f0;padding:.4rem;border-radius:var(--r-sm);transition:background var(--t-fast);flex-shrink:0}.hamburger-btn:hover{background:rgba(255,255,255,.18)}.hamburger-btn svg{display:block}.app-layout{display:flex;height:calc(100vh - var(--header-h));overflow:hidden}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--clr-nav);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;padding:var(--sp-4) 0 var(--sp-12);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px}.sidebar-section{padding:0 var(--sp-3);margin-bottom:var(--sp-2)}.sidebar-heading{font-size:var(--font-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:#64748b;padding:var(--sp-4) var(--sp-2) var(--sp-1)}.sidebar-item{display:flex;align-items:center;gap:.55rem;width:100%;padding:.55rem .65rem;border-radius:var(--r-md);background:none;border:none;color:#94a3b8;font-size:var(--font-sm);font-weight:500;cursor:pointer;font-family:inherit;text-align:left;transition:background var(--t-fast),color var(--t-fast)}.sidebar-item:hover{background:rgba(255,255,255,.07);color:#e2e8f0}.sidebar-item.active{background:rgba(255,255,255,.1);color:#e2e8f0;font-weight:600;box-shadow:inset 3px 0 #60a5fa}.sidebar-icon{font-size:var(--font-md);flex-shrink:0}.sidebar-badge{margin-left:auto;background:rgba(255,255,255,.1);color:#94a3b8;font-size:var(--font-2xs);font-weight:700;padding:.1rem .45rem;border-radius:var(--r-full);flex-shrink:0}.sidebar-item.active .sidebar-badge{background:rgba(37,99,235,.35);color:#93c5fd}.sidebar-badge-warn{background:rgba(245,158,11,.2)!important;color:#fbbf24!important}.sidebar-empty{font-size:var(--font-xs);color:#475569;padding:.3rem .65rem}.sidebar-upload-btn{display:block;width:100%;padding:.6rem .75rem;background:var(--clr-primary);color:#fff;border:none;border-radius:var(--r-md);font-size:var(--font-sm);font-weight:700;cursor:pointer;font-family:inherit;text-align:center;transition:background var(--t-fast),transform var(--t-fast);margin-bottom:var(--sp-2)}.sidebar-upload-btn:hover{background:var(--clr-primary-hover)}.sidebar-upload-btn.active{background:#1e40af;box-shadow:inset 0 2px 6px rgba(0,0,0,.2)}.sidebar-subtabs{margin:.2rem 0 .4rem 1.2rem;display:flex;flex-direction:column;gap:.1rem;border-left:2px solid rgba(255,255,255,.07);padding-left:var(--sp-3)}.sidebar-subtab{display:flex;align-items:center;gap:.4rem;width:100%;padding:.35rem .5rem;border-radius:var(--r-sm);background:none;border:none;color:#64748b;font-size:var(--font-xs);font-weight:500;cursor:pointer;font-family:inherit;text-align:left;transition:background var(--t-fast),color var(--t-fast)}.sidebar-subtab span{margin-left:auto;font-size:var(--font-2xs);background:rgba(255,255,255,.08);color:#64748b;padding:.05rem .35rem;border-radius:var(--r-sm)}.sidebar-subtab:hover{background:rgba(255,255,255,.05);color:#e2e8f0}.sidebar-subtab.active{color:var(--sub-color, #93c5fd);background:rgba(255,255,255,.06);font-weight:700}.sidebar-subtab.active span{color:var(--sub-color, #93c5fd);background:rgba(255,255,255,.12)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;top:var(--header-h);background:rgba(0,0,0,.45);z-index:99;animation:fadeInOverlay .2s ease}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.main-content{flex:1;overflow-y:auto;padding:var(--sp-6) var(--sp-8) var(--sp-12);background:var(--clr-bg);display:flex;flex-direction:column;gap:var(--sp-6);min-width:0}.content-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);background:linear-gradient(135deg,#eff6ff,#f0f9ff 55%,#fff);border-radius:var(--r-xl);border:1px solid #dbeafe;padding:1.5rem 1.75rem;box-shadow:0 2px 12px rgba(37,99,235,.08)}.content-header-text{display:flex;flex-direction:column;gap:.3rem}.content-title{font-size:1.4rem;font-weight:800;letter-spacing:-.025em;color:var(--clr-text-strong);margin:0}.content-sub{font-size:var(--font-sm);color:var(--clr-text-muted);margin:0;line-height:1.5}.section-group-header{display:flex;align-items:center;gap:var(--sp-2);padding-bottom:var(--sp-2);border-bottom:2px solid var(--sec-color, var(--clr-border))}.section-group-header h2{font-size:var(--font-md);font-weight:700;color:var(--sec-color, var(--clr-text));margin:0}.section-group-icon{font-size:1.1rem}.section-group-count{font-size:var(--font-xs);color:var(--clr-text-faint);font-weight:500;margin-left:.25rem}.dashboard{min-height:100vh;background:var(--clr-bg)}.dash-section{display:flex;flex-direction:column;gap:var(--sp-3)}.dash-section-header{display:flex;align-items:center;justify-content:space-between}.dash-section-header h2{font-size:var(--font-base);font-weight:700;color:var(--clr-text-strong);margin:0;letter-spacing:-.01em}.dash-section-eyebrow{font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--clr-text-muted);margin-bottom:var(--sp-1)}.dash-empty{background:var(--clr-surface);border-radius:var(--r-xl);border:2px dashed var(--clr-border);padding:var(--sp-10) var(--sp-6);text-align:center}.dash-empty-icon{font-size:2.5rem;margin-bottom:var(--sp-3)}.dash-empty-title{font-size:var(--font-md);font-weight:700;color:var(--clr-text);margin:0 0 var(--sp-2)}.dash-empty-sub{font-size:var(--font-sm);color:var(--clr-text-faint);margin:0}.dash-stats-wrap{display:flex;gap:var(--sp-3);align-items:stretch}.dash-stats-wrap .dash-stats{flex:1;min-width:0}.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-3)}.stat-card{background:var(--clr-surface);border-radius:var(--r-lg);padding:var(--sp-5) var(--sp-4);text-align:center;box-shadow:var(--sh-sm);border:1px solid var(--clr-border);border-top:3px solid var(--clr-border-mid);transition:box-shadow var(--t-base),transform var(--t-base),border-top-color var(--t-base)}.stat-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-top-color:var(--clr-primary)}.stat-value{font-size:2rem;font-weight:800;color:var(--clr-text-strong);line-height:1;letter-spacing:-.03em;margin-bottom:var(--sp-1)}.stat-label{font-size:var(--font-xs);color:var(--clr-text-muted);font-weight:500;line-height:1.3}.progress-chart-wrap{background:var(--clr-surface);border-radius:var(--r-xl);padding:var(--sp-4) var(--sp-4) var(--sp-3);box-shadow:var(--sh-sm);border:1px solid var(--clr-border);flex:1;min-width:180px;display:flex;flex-direction:column;transition:box-shadow var(--t-base)}.progress-chart-wrap:hover{box-shadow:var(--sh-md)}.progress-chart-label{font-size:var(--font-xs);font-weight:700;color:var(--clr-text-faint);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-2)}.progress-chart-svg{width:100%;height:auto;overflow:visible}.resume-banner{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a;border-left:4px solid #f59e0b;border-radius:var(--r-xl);padding:var(--sp-4) var(--sp-5);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);flex-wrap:wrap;box-shadow:0 2px 10px rgba(245,158,11,.1)}.resume-banner-left{display:flex;align-items:center;gap:var(--sp-3)}.resume-banner-icon{font-size:1.1rem;flex-shrink:0}.resume-banner-title{font-size:var(--font-sm);font-weight:700;color:#92400e}.resume-banner-sub{font-size:var(--font-xs);color:#b45309;margin-top:.1rem}.resume-banner-actions{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}.resume-banner .btn-primary{background:#f59e0b;color:#fff;font-size:var(--font-xs);padding:.35rem .9rem}.resume-banner .btn-primary:hover{background:#d97706;box-shadow:none}.resume-discard-btn{background:none;border:none;color:#b45309;font-size:var(--font-xs);cursor:pointer;font-family:inherit;padding:.2rem .35rem;transition:color var(--t-fast);opacity:.65}.resume-discard-btn:hover{opacity:1}.assigned-tasks-section{display:flex;flex-direction:column;gap:var(--sp-3)}.assigned-tasks-heading{font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--clr-text-faint);padding-left:.1rem}.assigned-task-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-left:4px solid var(--clr-primary);border-radius:var(--r-xl);padding:var(--sp-4) var(--sp-5);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);box-shadow:var(--sh-sm);transition:box-shadow var(--t-base),transform var(--t-base)}.assigned-task-card:hover{box-shadow:var(--sh-md);transform:translateY(-1px)}.assigned-task-card.overdue{border-left-color:var(--clr-danger);background:#fff8f8}.assigned-task-left{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.assigned-task-label{font-size:var(--font-xs);color:var(--clr-text-muted)}.assigned-task-name{font-size:var(--font-base);font-weight:700;color:var(--clr-text)}.assigned-task-meta{display:flex;gap:var(--sp-3);margin-top:.15rem;flex-wrap:wrap}.assigned-task-meta span{font-size:var(--font-xs);color:var(--clr-text-muted)}.overdue-text{color:var(--clr-danger)!important}.overdue-badge{background:var(--clr-danger-light);color:var(--clr-danger);font-size:var(--font-2xs);font-weight:700;padding:.1rem .4rem;border-radius:var(--r-full)}.year-mismatch-badge{background:#fef9c3;color:#92400e;font-size:var(--font-2xs);font-weight:600;padding:.1rem .5rem;border-radius:var(--r-full);border:1px solid #fde68a;cursor:default}.exam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-4)}.exam-tile-card{background:var(--clr-surface);border-radius:var(--r-xl);border:1px solid var(--clr-border);border-top:4px solid var(--accent, var(--clr-mixed));padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2);transition:box-shadow var(--t-base),transform var(--t-base),border-color var(--t-base);cursor:default}.exam-tile-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px);border-color:var(--accent, var(--clr-border-mid))}.exam-tile-card.in-progress{border-top-color:var(--clr-warning);background:var(--clr-warning-light);border-color:var(--clr-warning-border)}.exam-tile-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.1rem}.exam-tile-icon{font-size:1.5rem}.in-progress-dot{width:8px;height:8px;border-radius:50%;background:var(--clr-warning);animation:pulse 1.5s infinite}.exam-tile-title{font-size:var(--font-sm);font-weight:700;color:var(--clr-text);line-height:1.35;flex:1}.exam-tile-meta{font-size:var(--font-xs);color:var(--clr-text-faint);font-weight:500}.exam-tile-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--sp-2)}.in-progress-badge{display:inline-block;background:#fef3c7;color:#92400e;font-size:var(--font-2xs);font-weight:700;padding:.1rem .45rem;border-radius:var(--r-full);border:1px solid var(--clr-warning-border)}.exam-tile-start{margin-top:var(--sp-2);background:var(--accent, var(--clr-primary));color:#fff;border:none;border-radius:var(--r-md);padding:.45rem .75rem;font-size:var(--font-xs);font-weight:700;cursor:pointer;font-family:inherit;width:100%;transition:opacity var(--t-fast),transform var(--t-fast)}.exam-tile-card:hover .exam-tile-start{opacity:.9}.results-list{background:var(--clr-surface);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-sm);border:1px solid var(--clr-border)}.result-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--clr-surface-alt);transition:background var(--t-fast)}.result-row:last-child{border-bottom:none}.result-row:hover{background:var(--clr-surface-alt)}.result-row-icon{font-size:1.35rem;flex-shrink:0}.result-row-info{flex:1;min-width:0}.result-row-title{font-size:var(--font-base);font-weight:600;color:var(--clr-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-row-meta{display:flex;gap:var(--sp-2);margin-top:.15rem}.result-row-meta span{font-size:var(--font-xs);color:var(--clr-text-faint)}.result-row-score{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.result-pct{font-size:var(--font-base);font-weight:700;color:var(--clr-text);min-width:2.8rem;text-align:right}.review-btn{background:transparent;border:1.5px solid var(--clr-border);color:var(--clr-danger);font-size:var(--font-xs);font-weight:600;padding:.2rem .55rem;border-radius:var(--r-sm);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast);white-space:nowrap}.review-btn:hover{background:var(--clr-danger-light);border-color:#fca5a5}.wrong-q-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.55);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--sp-4);animation:fadeInOverlay .15s ease}.wrong-q-modal{background:var(--clr-surface);border-radius:var(--r-xl);width:100%;max-width:680px;max-height:88vh;display:flex;flex-direction:column;box-shadow:var(--sh-xl);overflow:hidden}.wrong-q-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--sp-5) var(--sp-6);border-bottom:1.5px solid var(--clr-surface-alt);flex-shrink:0}.wrong-q-modal-title{font-size:var(--font-lg);font-weight:700;color:var(--clr-text)}.wrong-q-modal-meta{margin-top:.25rem;font-size:var(--font-sm);color:var(--clr-text-muted);display:flex;align-items:center;gap:var(--sp-2)}.wrong-q-close{background:var(--clr-surface-alt);border:none;width:32px;height:32px;border-radius:50%;font-size:var(--font-base);color:var(--clr-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--t-fast),color var(--t-fast)}.wrong-q-close:hover{background:var(--clr-border);color:var(--clr-text)}.wrong-q-list{overflow-y:auto;padding:var(--sp-4) var(--sp-6) var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-3)}.wrong-q-count{font-size:var(--font-xs);font-weight:600;color:var(--clr-danger);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.15rem}.wrong-q-card{border:1.5px solid #fee2e2;border-left:4px solid var(--clr-danger);border-radius:var(--r-md);padding:var(--sp-4);background:var(--clr-surface)}.wrong-q-card-header{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2)}.wrong-q-num{background:var(--clr-primary);color:#fff;font-size:var(--font-xs);font-weight:700;padding:.15rem .5rem;border-radius:var(--r-full)}.wrong-q-text{font-size:var(--font-base);color:#334155;line-height:1.5;margin-bottom:var(--sp-3)}.wrong-q-answers{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.wrong-q-your{font-size:var(--font-sm);color:var(--clr-danger);background:var(--clr-danger-light);padding:.25rem .6rem;border-radius:var(--r-sm)}.wrong-q-correct{font-size:var(--font-sm);color:#16a34a;background:var(--clr-success-light);padding:.25rem .6rem;border-radius:var(--r-sm)}.wrong-q-page-link{display:inline-block;margin-top:var(--sp-2);font-size:var(--font-xs);color:var(--clr-text-muted);text-decoration:none}.wrong-q-page-link:hover{color:var(--clr-primary);text-decoration:underline}.wrong-q-empty{padding:var(--sp-12) var(--sp-6);text-align:center;color:var(--clr-text-muted);font-size:var(--font-base);display:flex;flex-direction:column;align-items:center;gap:var(--sp-2)}.test-screen{display:flex;flex-direction:column;height:100vh;overflow:hidden}.test-header{background:var(--accent, var(--clr-reading));color:#fff;display:flex;align-items:center;justify-content:space-between;padding:.7rem var(--sp-5);flex-shrink:0;gap:var(--sp-4)}.test-title{display:flex;align-items:center;gap:var(--sp-2);font-weight:700;font-size:var(--font-md);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.test-header-right{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}.timer{font-size:var(--font-md);font-weight:700;font-variant-numeric:tabular-nums;background:rgba(0,0,0,.18);padding:.3rem .7rem;border-radius:var(--r-sm);letter-spacing:.02em}.word-count{font-size:var(--font-base);font-weight:600;background:rgba(0,0,0,.15);padding:.25rem .6rem;border-radius:var(--r-sm);color:#fff}.pause-btn{background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.3);color:#fff;border-radius:var(--r-md);padding:.3rem .85rem;font-size:var(--font-xs);font-weight:600;cursor:pointer;font-family:inherit;transition:background var(--t-fast)}.pause-btn:hover{background:rgba(255,255,255,.25)}.pause-btn.paused{background:#fff;color:var(--clr-text);border-color:#fff}.pause-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.85);z-index:300;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);animation:fadeInOverlay .15s ease}.pause-card{background:var(--clr-surface);border-radius:var(--r-2xl);box-shadow:var(--sh-xl);padding:var(--sp-10) var(--sp-8);width:90%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:var(--sp-4);text-align:center}.pause-icon{font-size:2.5rem}.pause-title{font-size:var(--font-2xl);font-weight:800;color:var(--clr-text);margin:0}.pause-sub{font-size:var(--font-base);color:var(--clr-text-muted);margin:0}.pause-stats{display:flex;gap:var(--sp-5);background:var(--clr-surface-alt);border-radius:var(--r-lg);padding:var(--sp-3) var(--sp-5);width:100%;justify-content:center}.pause-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem}.pause-stat-value{font-size:1.3rem;font-weight:800;color:var(--clr-text)}.pause-stat-label{font-size:var(--font-2xs);color:var(--clr-text-faint);font-weight:500}.pause-save-btn{background:none;border:1.5px solid var(--clr-border);color:var(--clr-text-muted);border-radius:var(--r-md);padding:.55rem 1.25rem;font-size:var(--font-sm);font-weight:600;cursor:pointer;font-family:inherit;width:100%;transition:border-color var(--t-fast),color var(--t-fast)}.pause-save-btn:hover{border-color:var(--clr-border-mid);color:var(--clr-text)}.pause-save-confirm{background:#fff7ed;border:1px solid var(--clr-warning-border);border-radius:var(--r-lg);padding:var(--sp-3) var(--sp-4);width:100%;font-size:var(--font-sm);color:var(--clr-warning-dark)}.pause-save-confirm p{margin:0 0 var(--sp-3)}.pause-save-confirm-btns{display:flex;gap:var(--sp-2);justify-content:flex-end}.test-progress{display:flex;align-items:center;gap:var(--sp-3);padding:.65rem var(--sp-5);background:var(--clr-surface);border-bottom:1px solid var(--clr-border);flex-shrink:0}.progress-bar{display:flex;gap:.3rem;flex-wrap:wrap;flex:1}.progress-dot{width:26px;height:7px;border-radius:var(--r-xs);background:var(--clr-border);border:none;cursor:pointer;transition:background var(--t-fast),transform var(--t-fast)}.progress-dot:hover{transform:scaleY(1.4)}.progress-dot.done{background:#86efac}.progress-dot.active,.progress-dot.active.done{background:var(--clr-primary)}.progress-dot.flagged:not(.done){background:var(--clr-warning)}.progress-dot.flagged.done{background:var(--clr-warning)}.progress-actions{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.progress-label{font-size:var(--font-sm);color:var(--clr-text-muted);font-weight:600;white-space:nowrap}.progress-grid-btn{background:none;border:1.5px solid var(--clr-border);color:var(--clr-text-muted);border-radius:var(--r-sm);padding:.15rem .45rem;font-size:var(--font-md);cursor:pointer;line-height:1;transition:background var(--t-fast),border-color var(--t-fast)}.progress-grid-btn:hover{background:var(--clr-surface-alt);border-color:var(--clr-border-mid)}.q-grid-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.4);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;animation:fadeInOverlay .15s ease}.q-grid-panel{background:var(--clr-surface);border-radius:var(--r-xl);box-shadow:var(--sh-xl);padding:var(--sp-5);width:90%;max-width:520px;max-height:70vh;overflow-y:auto}.q-grid-header{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-md);font-weight:700;color:var(--clr-text);margin-bottom:var(--sp-3)}.q-grid-close{background:none;border:none;font-size:var(--font-md);cursor:pointer;color:var(--clr-text-muted);padding:.2rem .4rem;border-radius:var(--r-sm)}.q-grid-close:hover{background:var(--clr-surface-alt);color:var(--clr-text)}.q-grid-legend{display:flex;gap:var(--sp-3);margin-bottom:var(--sp-3);flex-wrap:wrap}.q-legend{font-size:var(--font-xs);font-weight:600;display:flex;align-items:center;gap:.3rem}.q-legend:before{content:"";display:inline-block;width:12px;height:12px;border-radius:3px}.q-legend.answered:before{background:var(--clr-success)}.q-legend.flagged:before{background:var(--clr-warning)}.q-legend.unanswered:before{background:var(--clr-border);border:1px solid var(--clr-border-mid)}.q-legend.answered{color:var(--clr-success-dark)}.q-legend.flagged{color:var(--clr-warning-dark)}.q-legend.unanswered{color:var(--clr-text-muted)}.q-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:var(--sp-2)}.q-grid-btn{aspect-ratio:1;border-radius:var(--r-md);border:1.5px solid var(--clr-border);background:var(--clr-surface-alt);font-size:var(--font-xs);font-weight:600;color:var(--clr-text-secondary);cursor:pointer;font-family:inherit;transition:all .1s}.q-grid-btn:hover{border-color:#93c5fd;background:var(--clr-primary-light)}.q-grid-btn.current{border-color:var(--clr-primary);background:var(--clr-primary);color:#fff}.q-grid-btn.answered:not(.current){background:#d1fae5;border-color:#6ee7b7;color:var(--clr-success-dark)}.q-grid-btn.flagged:not(.current){background:#fef3c7;border-color:#fcd34d;color:var(--clr-warning-dark)}.q-grid-flagged-note{margin-top:var(--sp-3);font-size:var(--font-xs);color:var(--clr-warning-dark);background:#fef3c7;border-radius:var(--r-md);padding:var(--sp-2) var(--sp-3);font-weight:600}.question-number-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:0}.flag-btn{background:none;border:1.5px solid var(--clr-border);border-radius:var(--r-full);padding:.25rem .65rem;font-size:var(--font-xs);font-weight:600;color:var(--clr-text-faint);cursor:pointer;font-family:inherit;transition:all var(--t-fast)}.flag-btn:hover{border-color:#fcd34d;color:var(--clr-warning-dark);background:#fef3c7}.flag-btn.flagged{border-color:#fcd34d;background:#fef3c7;color:var(--clr-warning-dark)}.split-body{flex:1;display:flex;min-height:0;overflow:hidden}.split-body--full .split-right{width:100%;max-width:760px;margin:0 auto}.split-left{width:55%;overflow-y:auto;background:var(--clr-surface-alt);border-right:1.5px solid var(--clr-border);padding:var(--sp-4);display:flex;flex-direction:column;align-items:center}.split-right{width:45%;overflow-y:auto;padding:var(--sp-5);display:flex;flex-direction:column}.page-image{width:100%;border-radius:var(--r-md);box-shadow:var(--sh-md)}.page-image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--clr-text-faint);font-size:var(--font-sm);gap:var(--sp-2);text-align:center;padding:var(--sp-8)}.page-image-placeholder p:first-child{font-size:2.5rem}.mc-image-hint{margin-top:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3)}.mc-image-label{font-size:var(--font-sm);color:var(--clr-text-muted);font-style:italic}.mc-image-buttons{display:flex;gap:var(--sp-3);flex-wrap:wrap}.mc-image-btn{width:54px;height:54px;border-radius:var(--r-lg);border:2px solid var(--clr-border);background:var(--clr-surface);font-size:1.1rem;font-weight:700;color:var(--clr-text-secondary);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast),color var(--t-fast)}.mc-image-btn:hover{border-color:#93c5fd;background:var(--clr-primary-light)}.mc-image-btn.selected{border-color:var(--clr-primary);background:var(--clr-primary);color:#fff}.written-input-wrap{margin-top:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2)}.written-label{font-size:var(--font-sm);font-weight:600;color:var(--clr-text-secondary)}.written-input{border:2px solid var(--clr-border);border-radius:var(--r-md);padding:.6rem .9rem;font-size:1.1rem;font-family:inherit;color:var(--clr-text-strong);max-width:200px;outline:none;transition:border-color var(--t-fast)}.written-input:focus{border-color:var(--clr-primary)}.essay-input{border:2px solid var(--clr-border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);font-size:var(--font-md);font-family:inherit;color:var(--clr-text-strong);width:100%;resize:vertical;line-height:1.7;outline:none;transition:border-color var(--t-fast)}.essay-input:focus{border-color:var(--clr-purple)}.passage{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--r-lg);padding:var(--sp-5) var(--sp-6);line-height:1.8;width:100%}.passage h3{font-weight:700;margin-bottom:var(--sp-3);color:var(--clr-text-strong)}.passage p{margin-bottom:var(--sp-3);color:#334155}.question-card{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--r-lg);padding:var(--sp-5) var(--sp-5)}.question-number{font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--clr-text-faint);margin-bottom:var(--sp-2)}.question-text{font-size:var(--font-lg);font-weight:600;color:var(--clr-text-strong);margin-bottom:var(--sp-5);line-height:1.5;white-space:pre-line}.options{display:flex;flex-direction:column;gap:var(--sp-2)}.option{display:flex;align-items:center;gap:var(--sp-3);padding:.8rem var(--sp-4);border:2px solid var(--clr-border);border-radius:var(--r-md);background:var(--clr-surface);font-size:var(--font-md);color:#334155;text-align:left;transition:border-color var(--t-fast),background var(--t-fast),transform var(--t-fast)}.option:hover{border-color:#93c5fd;background:var(--clr-primary-light);transform:translate(2px)}.option.selected{border-color:var(--clr-primary);background:var(--clr-primary-light);color:#1e40af;font-weight:600}.option-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--clr-border-mid);flex-shrink:0;transition:border-color var(--t-fast),background var(--t-fast)}.option.selected .option-dot{border-color:var(--clr-primary);background:var(--clr-primary)}.unanswered-hint{font-size:var(--font-xs);color:var(--clr-warning);font-weight:600}.submit-confirm{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);background:#fff7ed;border:1px solid var(--clr-warning-border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);font-size:var(--font-sm);color:var(--clr-warning-dark);font-weight:600}.test-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-4) var(--sp-5);background:var(--clr-surface);border-top:1px solid var(--clr-border);flex-shrink:0;gap:var(--sp-3)}.results-screen{display:flex;flex-direction:column;min-height:100vh}.results-header{background:var(--accent, var(--clr-reading));color:#fff;padding:var(--sp-4) var(--sp-6)}.results-header h2{font-size:var(--font-xl);font-weight:700}.score-card{display:flex;flex-direction:column;align-items:center;padding:var(--sp-8) var(--sp-8) var(--sp-5);gap:var(--sp-3);background:var(--clr-surface);border-bottom:1px solid var(--clr-border)}.score-circle{width:120px;height:120px;border-radius:50%;background:conic-gradient(var(--color) calc(var(--pct) * 1%),var(--clr-border) 0);display:flex;align-items:center;justify-content:center}.score-inner{width:92px;height:92px;border-radius:50%;background:var(--clr-surface);display:flex;flex-direction:column;align-items:center;justify-content:center}.score-num{font-size:1.5rem;font-weight:800;color:var(--clr-text-strong)}.score-label{font-size:var(--font-xs);color:var(--clr-text-faint);font-weight:600}.score-pct{font-size:var(--font-md);color:var(--clr-text-muted);font-weight:600}.band-badge{color:#fff;padding:.3rem 1.2rem;border-radius:var(--r-full);font-size:var(--font-base);font-weight:700}.review-section{flex:1;padding:var(--sp-5) var(--sp-5);max-width:700px;margin:0 auto;width:100%}.review-section h3{font-size:var(--font-md);font-weight:700;margin-bottom:var(--sp-4);color:var(--clr-text-strong)}.review-card{background:var(--clr-surface);border-radius:var(--r-md);padding:var(--sp-4);margin-bottom:var(--sp-3);border-left:4px solid;box-shadow:var(--sh-xs)}.review-card.correct{border-color:#22c55e}.review-card.incorrect{border-color:var(--clr-danger)}.review-card.neutral{border-color:var(--clr-border)}.review-q-header{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2)}.review-status{font-size:var(--font-md)}.review-card.correct .review-status{color:#22c55e}.review-card.incorrect .review-status{color:var(--clr-danger)}.review-card.neutral .review-status{color:var(--clr-text-faint)}.review-q-num{font-size:var(--font-xs);font-weight:700;color:var(--clr-text-faint);text-transform:uppercase}.review-question{font-size:var(--font-base);color:#334155;margin-bottom:var(--sp-2);white-space:pre-line}.review-answers{display:flex;flex-direction:column;gap:.25rem}.your-answer{font-size:var(--font-sm);color:var(--clr-danger)}.correct-answer{font-size:var(--font-sm);color:#16a34a}.review-page-link{font-size:var(--font-xs);color:var(--clr-primary);text-decoration:none;display:inline-block;margin-bottom:var(--sp-2)}.review-page-link:hover{text-decoration:underline}.results-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-4) var(--sp-5);background:var(--clr-surface);border-top:1px solid var(--clr-border);position:sticky;bottom:0}.ai-panel{background:var(--clr-surface);border-radius:var(--r-lg);box-shadow:var(--sh-md);padding:var(--sp-5) var(--sp-6);margin-top:var(--sp-3);border:1px solid var(--clr-border)}.ai-panel-header{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--font-md);font-weight:700;color:var(--clr-text);margin-bottom:var(--sp-4)}.ai-loading-badge{margin-left:auto;font-size:var(--font-xs);font-weight:600;background:var(--clr-primary-light);color:var(--clr-primary);padding:.15rem .55rem;border-radius:var(--r-full);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.ai-summary{font-size:var(--font-base);color:#334155;line-height:1.6;margin:0 0 var(--sp-4)}.ai-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-3);margin-bottom:var(--sp-4)}.ai-col{border-radius:var(--r-md);padding:var(--sp-3)}.ai-strengths{background:var(--clr-success-light);border:1px solid var(--clr-success-border)}.ai-weaknesses{background:#fff7ed;border:1px solid var(--clr-warning-border)}.ai-recommendations{background:var(--clr-primary-light);border:1px solid var(--clr-primary-border)}.ai-col-title{font-size:var(--font-xs);font-weight:700;margin-bottom:var(--sp-2);color:var(--clr-text)}.ai-item{font-size:var(--font-xs);color:#334155;line-height:1.4;padding:.25rem 0;border-bottom:1px solid rgba(0,0,0,.05)}.ai-item:last-child{border-bottom:none}.ai-encouragement{background:var(--clr-purple-light);border-left:3px solid var(--clr-purple);border-radius:0 var(--r-md) var(--r-md) 0;padding:var(--sp-3) var(--sp-4);font-size:var(--font-sm);color:var(--clr-purple-dark);font-style:italic;line-height:1.5}.ai-feedback-loading{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);padding:var(--sp-6) var(--sp-4);text-align:center}.ai-feedback-loading-icon{font-size:2rem;animation:ai-bounce 1.4s ease-in-out infinite}@keyframes ai-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.ai-feedback-loading-label{font-size:var(--font-md);font-weight:700;color:var(--clr-text);min-height:1.4em}.ai-feedback-progress-track{width:100%;max-width:340px;height:7px;background:var(--clr-border);border-radius:var(--r-full);overflow:hidden}.ai-feedback-progress-bar{height:100%;background:linear-gradient(90deg,var(--clr-primary),#60a5fa);border-radius:var(--r-full);transition:width .4s ease}.ai-feedback-loading-sub{font-size:var(--font-xs);color:var(--clr-text-muted);max-width:300px;line-height:1.5}.ai-skeleton{display:flex;flex-direction:column;gap:var(--sp-3)}.skeleton-line{height:12px;background:linear-gradient(90deg,var(--clr-border) 25%,var(--clr-surface-alt) 50%,var(--clr-border) 75%);background-size:200% 100%;border-radius:var(--r-sm);animation:shimmer 1.5s infinite}.skeleton-line.w-full{width:100%}.skeleton-line.w-3\/4{width:75%}.skeleton-line.w-1\/2{width:50%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-3);margin-top:var(--sp-2)}.skeleton-card{background:var(--clr-surface-alt);border-radius:var(--r-md);padding:var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-2)}.improvement-card{background:var(--clr-surface);border-radius:var(--r-lg);box-shadow:var(--sh-md);padding:var(--sp-5) var(--sp-6);margin-top:var(--sp-3);border:1px solid var(--clr-border);border-left:4px solid var(--clr-success)}.improvement-card-header{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--font-md);font-weight:700;color:var(--clr-text);margin-bottom:var(--sp-4)}.improvement-narrative{font-size:var(--font-base);color:#334155;line-height:1.6;margin:0 0 var(--sp-3)}.improvement-label{font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--clr-text-muted);margin-bottom:var(--sp-2)}.improvement-weak-areas{margin-bottom:var(--sp-3)}.improvement-tags{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.improvement-projection{background:var(--clr-success-light);border:1px solid var(--clr-success-border);border-radius:var(--r-md);padding:var(--sp-2) var(--sp-3);font-size:var(--font-sm);color:#166534;font-weight:500;margin-bottom:var(--sp-3)}.improvement-tip{font-size:var(--font-sm);color:#334155;line-height:1.5;padding:.2rem 0}.practice-panel{background:var(--clr-surface);border-radius:var(--r-lg);box-shadow:var(--sh-md);padding:var(--sp-5) var(--sp-6);margin-top:var(--sp-3);border:1px solid var(--clr-border);border-left:4px solid var(--clr-primary)}.practice-panel-header{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--font-md);font-weight:700;color:var(--clr-text);margin-bottom:var(--sp-3)}.practice-progress{margin-left:auto;font-size:var(--font-xs);font-weight:600;background:var(--clr-primary-light);color:var(--clr-primary);padding:.15rem .55rem;border-radius:var(--r-full)}.practice-panel-sub{font-size:var(--font-sm);color:var(--clr-text-muted);margin:0 0 var(--sp-4)}.practice-skill-tag{display:inline-block;background:var(--clr-primary-light);color:#1d4ed8;border-radius:var(--r-full);padding:.15rem .6rem;font-size:var(--font-xs);font-weight:600;margin-bottom:var(--sp-3)}.practice-question{font-size:var(--font-base);color:var(--clr-text);line-height:1.6;margin:0 0 var(--sp-3);font-weight:500}.practice-option{width:100%;text-align:left;padding:var(--sp-3) var(--sp-4);border:2px solid var(--clr-border);border-radius:var(--r-md);background:var(--clr-surface-alt);color:#334155;font-size:var(--font-base);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast),transform var(--t-fast)}.practice-option:hover:not(:disabled){border-color:var(--clr-primary);background:var(--clr-primary-light);transform:translate(2px)}.practice-option.selected{border-color:var(--clr-primary);background:var(--clr-primary-light);color:#1d4ed8;font-weight:600}.practice-option.correct{border-color:var(--clr-success);background:var(--clr-success-light);color:#166534;font-weight:600}.practice-option.wrong{border-color:var(--clr-danger);background:var(--clr-danger-light);color:var(--clr-danger-dark)}.practice-feedback{margin-top:var(--sp-3);padding:var(--sp-3);border-radius:var(--r-md)}.practice-feedback.correct{background:var(--clr-success-light);border:1px solid var(--clr-success-border)}.practice-feedback.wrong{background:var(--clr-danger-light);border:1px solid var(--clr-danger-border)}.practice-feedback-result{font-weight:700;font-size:var(--font-base);margin-bottom:var(--sp-2)}.practice-feedback.correct .practice-feedback-result{color:#166534}.practice-feedback.wrong .practice-feedback-result{color:var(--clr-danger-dark)}.practice-feedback-result-bar{margin-top:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);font-weight:700;font-size:var(--font-base)}.practice-feedback-result-bar.correct{background:var(--clr-success-light);border:1px solid var(--clr-success-border);color:#166534}.practice-feedback-result-bar.incorrect{background:var(--clr-danger-light);border:1px solid var(--clr-danger-border);color:var(--clr-danger-dark)}.practice-ai-explanation{margin-top:var(--sp-3);border:1.5px solid #bae6fd;border-radius:var(--r-md);background:#f0f9ff;overflow:hidden}.practice-ai-explanation-header{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);background:#e0f2fe;border-bottom:1px solid #bae6fd;font-weight:700;font-size:var(--font-sm);color:#0369a1}.practice-ai-explanation-loading{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-4);font-size:var(--font-sm);color:#0369a1}.practice-ai-spinner{width:18px;height:18px;border:2.5px solid #bae6fd;border-top-color:#0369a1;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.practice-ai-explanation-text{padding:var(--sp-4);margin:0;font-size:var(--font-sm);color:#0c4a6e;line-height:1.65}.practice-explanation{font-size:var(--font-sm);color:#334155;line-height:1.5;margin:0 0 var(--sp-2)}.practice-panel-done{text-align:center;padding:var(--sp-8) var(--sp-6)}.practice-done-icon{font-size:2.5rem;margin-bottom:var(--sp-2)}.practice-done-score{font-size:2rem;font-weight:800;color:var(--clr-text)}.practice-done-label{font-size:var(--font-base);color:var(--clr-text-muted);margin-bottom:var(--sp-4)}.auth-screen{display:flex;min-height:100vh;background:var(--clr-bg)}.auth-left{flex:1;background:linear-gradient(135deg,#1e3a8a,#1d4ed8,#2563eb);color:#fff;padding:var(--sp-12) var(--sp-12);display:flex;flex-direction:column;justify-content:center;gap:var(--sp-10)}.auth-logo{font-size:2rem;font-weight:900;letter-spacing:.08em;color:#fff}.auth-tagline{font-size:2.25rem;font-weight:700;line-height:1.2;margin:0;color:#fff}.auth-sub{font-size:var(--font-md);color:rgba(255,255,255,.75);margin:0}.auth-features{display:flex;flex-direction:column;gap:var(--sp-3)}.auth-feature{display:flex;align-items:center;gap:var(--sp-3);font-size:var(--font-base);color:rgba(255,255,255,.9)}.auth-feature span:first-child{font-size:1.1rem}.auth-right{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--sp-8)}.auth-card{background:var(--clr-surface);border-radius:var(--r-xl);box-shadow:var(--sh-lg);padding:var(--sp-8);width:100%;max-width:420px}.auth-tabs{display:flex;gap:0;border-bottom:2px solid var(--clr-border);margin-bottom:var(--sp-6)}.auth-tab{flex:1;background:none;border:none;padding:.6rem 0;font-size:var(--font-base);font-weight:600;color:var(--clr-text-faint);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color var(--t-fast),border-color var(--t-fast);font-family:inherit}.auth-tab.active{color:var(--clr-primary);border-bottom-color:var(--clr-primary)}.auth-tab:hover:not(.active){color:var(--clr-text-secondary)}.auth-form{display:flex;flex-direction:column;gap:var(--sp-4)}.auth-field{display:flex;flex-direction:column;gap:.3rem}.auth-field label{font-size:var(--font-xs);font-weight:600;color:var(--clr-text-secondary);text-transform:uppercase;letter-spacing:.04em}.auth-field input{width:100%;padding:.65rem .85rem;border:1.5px solid var(--clr-border);border-radius:var(--r-md);font-size:var(--font-base);font-family:inherit;background:var(--clr-surface-alt);color:var(--clr-text-strong);transition:border-color var(--t-fast),background var(--t-fast);box-sizing:border-box}.auth-field input:focus{outline:none;border-color:var(--clr-primary);background:var(--clr-surface)}.auth-pw-wrap{position:relative}.auth-pw-wrap input{padding-right:2.5rem}.auth-pw-toggle{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:var(--font-md);padding:0;line-height:1}.auth-role-group{display:flex;gap:var(--sp-2)}.auth-role-btn{flex:1;background:var(--clr-surface-alt);border:1.5px solid var(--clr-border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-2);cursor:pointer;text-align:center;transition:border-color var(--t-fast),background var(--t-fast);font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:var(--sp-1)}.auth-role-btn:hover{border-color:#93c5fd;background:var(--clr-primary-light)}.auth-role-btn.active{border-color:var(--clr-primary);background:var(--clr-primary-light)}.role-label{font-size:var(--font-xs);font-weight:700;color:var(--clr-text)}.role-desc{font-size:var(--font-2xs);color:var(--clr-text-muted)}.auth-error{background:var(--clr-danger-light);border:1px solid #fca5a5;color:#dc2626;padding:var(--sp-3);border-radius:var(--r-md);font-size:var(--font-sm)}.auth-submit{background:var(--clr-primary);color:#fff;border:none;border-radius:var(--r-md);padding:.75rem;font-size:var(--font-md);font-weight:700;cursor:pointer;font-family:inherit;transition:background var(--t-fast),transform var(--t-fast);display:flex;align-items:center;justify-content:center;gap:var(--sp-2)}.auth-submit:hover:not(:disabled){background:var(--clr-primary-hover);transform:translateY(-1px)}.auth-submit:disabled{opacity:.65;cursor:not-allowed;transform:none}.auth-back{display:inline-flex;align-items:center;background:none;border:none;color:var(--clr-text-muted);font-size:var(--font-sm);font-weight:500;cursor:pointer;padding:0;font-family:inherit;margin-bottom:var(--sp-5);transition:color var(--t-fast)}.auth-back:hover{color:var(--clr-text)}.auth-footer-note{text-align:center;font-size:var(--font-sm);color:var(--clr-text-muted);margin-top:var(--sp-4)}.auth-link{background:none;border:none;color:var(--clr-primary);cursor:pointer;font-size:inherit;font-weight:600;padding:0;font-family:inherit}.auth-link:hover{text-decoration:underline}.drop-zone{border:2.5px dashed var(--clr-border-mid);border-radius:var(--r-lg);padding:var(--sp-10);text-align:center;cursor:pointer;transition:border-color var(--t-base),background var(--t-base);background:var(--clr-surface)}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--clr-primary);background:var(--clr-primary-light)}.drop-zone.uploading{cursor:wait}.drop-icon{font-size:2.5rem;margin-bottom:var(--sp-2)}.drop-main{font-weight:600;color:#334155;margin-bottom:.25rem}.drop-sub{font-size:var(--font-xs);color:var(--clr-text-faint)}.upload-spinner-wrap{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.upload-spinner-wrap p{font-size:var(--font-sm);color:var(--clr-text-muted)}.error-banner{background:var(--clr-danger-light);border:1px solid var(--clr-danger-border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);color:#dc2626;font-size:var(--font-sm);margin-top:var(--sp-3)}.admin-exam-list{display:flex;flex-direction:column;gap:var(--sp-2)}.admin-exam-card{display:flex;align-items:flex-start;gap:var(--sp-3);background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);transition:border-color var(--t-fast),box-shadow var(--t-fast)}.admin-exam-card:hover{box-shadow:var(--sh-sm)}.admin-exam-card.error{border-color:#fca5a5;background:#fff5f5}.admin-exam-card.processing{border-color:#93c5fd}.admin-exam-card-left{display:flex;gap:var(--sp-3);flex:1;min-width:0;align-items:flex-start}.admin-exam-card-status{padding-top:.35rem;flex-shrink:0}.admin-exam-card-info{flex:1;min-width:0}.exam-row-meta{display:flex;flex-wrap:wrap;gap:var(--sp-2);align-items:center;margin-top:var(--sp-2)}.exam-row-actions{display:flex;gap:var(--sp-2);flex-shrink:0;align-items:flex-start;padding-top:.25rem}.exam-error-msg{font-size:var(--font-xs);color:#dc2626;margin-top:var(--sp-2)}.status-dot{width:8px;height:8px;border-radius:50%;display:block}.status-dot.ready{background:var(--clr-success)}.status-dot.processing{background:var(--clr-reading);animation:pulse 1s infinite}.status-dot.error{background:var(--clr-danger)}.exam-title-input{font-size:var(--font-base);font-weight:700;color:var(--clr-text-strong);border:1.5px solid transparent;border-radius:var(--r-sm);padding:.2rem .4rem;background:transparent;width:100%;font-family:inherit;transition:border-color var(--t-fast)}.exam-title-input:hover{border-color:var(--clr-border)}.exam-title-input:focus{outline:none;border-color:var(--clr-primary);background:var(--clr-surface)}.meta-select{font-size:var(--font-xs);font-weight:600;padding:.2rem .5rem;border-radius:var(--r-full);border:1.5px solid var(--clr-border);background:var(--clr-surface-alt);color:var(--clr-text-secondary);cursor:pointer;font-family:inherit}.meta-select:focus{outline:none;border-color:var(--clr-primary)}.section-select{border:none}.admin-search{width:100%;max-width:380px;padding:var(--sp-2) var(--sp-4);border:1.5px solid var(--clr-border);border-radius:var(--r-md);font-size:var(--font-base);background:var(--clr-surface);color:var(--clr-text);font-family:inherit;transition:border-color var(--t-fast)}.admin-search:focus{outline:none;border-color:var(--clr-primary)}.admin-table-wrap{overflow-x:auto;border-radius:var(--r-lg);box-shadow:var(--sh-sm);border:1px solid var(--clr-border)}.admin-table{width:100%;border-collapse:collapse;background:var(--clr-surface);font-size:var(--font-sm)}.admin-table th{padding:var(--sp-3) var(--sp-4);text-align:left;font-size:var(--font-xs);font-weight:700;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--clr-surface-alt);border-bottom:1px solid var(--clr-border);white-space:nowrap}.admin-table td{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--clr-surface-alt);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:var(--clr-surface-alt)}.cell-muted{color:var(--clr-text-muted)}.cell-center{text-align:center}.user-cell{display:flex;align-items:center;gap:var(--sp-2)}.user-avatar-sm{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-xs);color:#fff;flex-shrink:0}.user-name-cell{font-weight:600;color:var(--clr-text);font-size:var(--font-sm)}.role-pill{font-size:var(--font-xs);font-weight:700;color:#fff;padding:.15rem .55rem;border-radius:var(--r-full)}.sidebar-processing{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-5);font-size:var(--font-xs);color:#60a5fa;margin-top:auto}.writing-screen{display:flex;flex-direction:column;min-height:100vh}.writing-body{flex:1;display:flex;flex-direction:column;gap:var(--sp-4);padding:var(--sp-5);max-width:800px;margin:0 auto;width:100%}.prompt-panel{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--r-lg);padding:var(--sp-5)}.prompt-type-badge{display:inline-block;background:var(--clr-purple-light);color:var(--clr-purple);font-size:var(--font-xs);font-weight:700;padding:.2rem .6rem;border-radius:var(--r-sm);margin-bottom:var(--sp-3)}.prompt-text{font-size:var(--font-md);color:var(--clr-text-strong);line-height:1.6;margin-bottom:var(--sp-3)}.prompt-switch{display:flex;gap:var(--sp-2)}.prompt-tab{padding:.35rem .85rem;border-radius:var(--r-full);font-size:var(--font-xs);font-weight:600;background:var(--clr-surface-alt);color:var(--clr-text-muted);border:none;cursor:pointer;transition:background var(--t-fast),color var(--t-fast)}.prompt-tab.active{background:var(--clr-purple);color:#fff}.writing-area-wrapper{display:flex;flex-direction:column}.writing-area{width:100%;border:1.5px solid var(--clr-border);border-radius:var(--r-lg);padding:var(--sp-4);font-size:var(--font-md);font-family:inherit;color:var(--clr-text-strong);resize:vertical;line-height:1.8;background:var(--clr-surface);outline:none;transition:border-color var(--t-fast)}.writing-area:focus{border-color:var(--clr-purple)}.checklist-panel{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--r-lg);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-2)}.checklist-panel h3{font-size:var(--font-base);font-weight:700;color:var(--clr-text-strong)}.checklist-sub{font-size:var(--font-xs);color:var(--clr-text-faint);margin-bottom:var(--sp-1)}.checklist-item{display:flex;align-items:flex-start;gap:var(--sp-2);font-size:var(--font-sm);color:var(--clr-text-secondary);cursor:pointer;padding:var(--sp-2);border-radius:var(--r-sm);transition:background var(--t-fast)}.checklist-item:hover{background:var(--clr-surface-alt)}.checklist-item.checked{color:#15803d}.checklist-item input[type=checkbox]{margin-top:1px;width:15px;height:15px;flex-shrink:0;accent-color:var(--clr-purple)}.checklist-progress{margin-top:var(--sp-2);font-size:var(--font-xs);font-weight:600;color:var(--clr-purple)}.writing-complete{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-4);padding:var(--sp-8);text-align:center}.complete-icon{font-size:3.5rem}.writing-complete h2{font-size:var(--font-2xl);font-weight:800}.writing-complete p{color:var(--clr-text-secondary);font-size:var(--font-md)}.improve-tip{background:#fef9c3;border:1px solid var(--clr-warning-border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);font-size:var(--font-sm);color:var(--clr-warning-dark);max-width:400px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(min-width:768px){.ai-grid,.skeleton-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:767px){.hamburger-btn{display:flex}.dash-user-info{display:none}.dash-nav{padding:0 var(--sp-4)}.app-layout{height:calc(100vh - var(--header-h));overflow:hidden;position:relative}.sidebar{position:fixed;top:var(--header-h);left:0;height:calc(100vh - var(--header-h));width:270px;z-index:100;transform:translate(-100%);transition:transform var(--t-slow);flex-direction:column;flex-wrap:nowrap;overflow-y:auto;overflow-x:hidden;padding:var(--sp-4) 0 var(--sp-12);align-items:unset;gap:0}.sidebar.open{transform:translate(0);box-shadow:4px 0 32px rgba(0,0,0,.35)}.sidebar-backdrop{display:block}.sidebar-section{display:block;padding:0 var(--sp-3);margin-bottom:var(--sp-2)}.sidebar-heading,.sidebar-empty,.sidebar-upload-btn{display:block}.sidebar-item{width:100%;flex-shrink:unset;border-radius:var(--r-md);white-space:normal;font-size:var(--font-sm);padding:.55rem .65rem}.sidebar-subtabs,.sidebar-processing,.sidebar-badge{display:flex}.main-content{padding:var(--sp-4) var(--sp-4) var(--sp-8);width:100%}.exam-grid{grid-template-columns:1fr 1fr;gap:var(--sp-3)}.dash-stats-wrap{flex-direction:column}.dash-stats{grid-template-columns:repeat(3,1fr)}.ai-grid,.skeleton-grid{grid-template-columns:1fr}.content-title{font-size:var(--font-xl)}.resume-banner{flex-direction:column;align-items:flex-start}.resume-banner-actions{width:100%}.test-header{padding:.6rem var(--sp-4)}.test-title{font-size:var(--font-base)}}@media(max-width:499px){.auth-left{display:none}.auth-screen{background:var(--clr-surface)}.auth-right{padding:var(--sp-6) var(--sp-4);align-items:flex-start}.auth-card{box-shadow:none;padding:var(--sp-5) 0}.auth-role-group{flex-direction:column}.dash-stats{grid-template-columns:1fr 1fr}.exam-grid{grid-template-columns:1fr}.admin-table th:nth-child(n+5),.admin-table td:nth-child(n+5){display:none}}@media(max-width:640px){.content-header{flex-direction:column;align-items:flex-start;padding:1.1rem 1.25rem;gap:var(--sp-3)}.content-title{font-size:var(--font-lg)}.content-header>.btn-primary,.content-header>.btn-primary.btn-sm{width:100%;text-align:center;justify-content:center}.assigned-task-card{flex-direction:column;align-items:flex-start;gap:var(--sp-2)}.assigned-task-card>.btn-primary,.assigned-task-card>.btn-primary.btn-sm{width:100%;text-align:center;margin-top:var(--sp-1)}.quick-diagnostic-banner{padding:.85rem 1rem;gap:.75rem}.quick-diagnostic-banner-icon{width:38px;height:38px;font-size:1.15rem}.resume-banner-actions{flex-direction:column;width:100%;gap:var(--sp-2)}.resume-banner-actions>.btn-primary,.resume-banner-actions>.btn-primary.btn-sm{width:100%;text-align:center}.result-row{flex-wrap:wrap;gap:var(--sp-2) var(--sp-3);align-items:flex-start}.result-row-icon{align-self:center}.result-row-info{width:calc(100% - 2.2rem)}.result-row-score{width:100%;justify-content:flex-end;padding-left:2.2rem}.review-btn{font-size:var(--font-2xs);padding:.18rem .45rem}.readiness-widget{padding:1rem 1.1rem}.readiness-widget-inner{gap:.85rem}.stat-card{padding:var(--sp-4) var(--sp-3)}.stat-value{font-size:1.6rem}.main-content{padding:var(--sp-4) var(--sp-3) var(--sp-8)}}@media(max-width:380px){.stat-value{font-size:1.35rem}.stat-label{font-size:.68rem}.quick-diagnostic-banner-icon{display:none}.dash-nav{gap:var(--sp-2)}.btn-ghost-dark{font-size:var(--font-xs);padding:.3rem .6rem}}@media(max-width:767px){.split-body{flex-direction:column;overflow-y:auto}.split-left{width:100%;border-right:none;border-bottom:1.5px solid var(--clr-border);max-height:42vh;flex-shrink:0}.split-right{width:100%;flex:1;overflow-y:visible}.test-footer{padding:var(--sp-3) var(--sp-4);gap:var(--sp-2)}.test-footer .btn-primary,.test-footer .btn-secondary{padding:.7rem var(--sp-4);font-size:var(--font-base)}.test-footer .btn-submit{padding:.7rem var(--sp-4)}.mc-image-buttons{gap:var(--sp-2)}.mc-image-btn{width:52px;height:52px}.question-text{font-size:var(--font-base)}.option{padding:.75rem var(--sp-4);font-size:var(--font-base)}}@media(max-width:767px){.review-section{padding:var(--sp-4)}}.logo{display:inline-block;background:#1e40af;color:#fff;font-size:var(--font-xs);font-weight:800;letter-spacing:.15em;padding:.3rem .7rem;border-radius:var(--r-sm);margin-bottom:var(--sp-3)}.exam-section-group{display:flex;flex-direction:column;gap:var(--sp-3)}.exam-section-label{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--font-sm);font-weight:700}.exam-section-count{font-size:var(--font-xs);font-weight:500;color:var(--clr-text-faint);margin-left:.2rem}.exam-tiles{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.exam-tile{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--r-md);border-top:3px solid var(--accent);padding:var(--sp-3) var(--sp-4);cursor:pointer;font-family:inherit;text-align:left;transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);min-width:130px}.exam-tile:hover{border-color:var(--accent);box-shadow:var(--sh-md);transform:translateY(-1px)}.exam-tile-title{font-size:var(--font-sm);font-weight:600;color:var(--clr-text);line-height:1.3;margin-bottom:.2rem}.exam-tile-meta{font-size:var(--font-xs);color:var(--clr-text-faint)}.exam-cards{display:flex;flex-direction:column;gap:var(--sp-2)}.exam-card{display:flex;align-items:center;gap:var(--sp-3);background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);cursor:pointer;font-family:inherit;text-align:left;transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);border-left:4px solid var(--accent, #64748b)}.exam-card:hover{border-color:var(--accent, #64748b);box-shadow:var(--sh-md);transform:translate(2px)}.exam-card.in-progress{border-top-color:var(--clr-warning);background:var(--clr-warning-light);border-color:var(--clr-warning-border)}.exam-card-body{flex:1;min-width:0}.exam-card-title{font-size:var(--font-base);font-weight:600;color:var(--clr-text)}.exam-card-meta{font-size:var(--font-xs);color:var(--clr-text-faint);margin-top:.1rem}.exam-card-arrow{font-size:var(--font-md);color:var(--clr-border-mid);flex-shrink:0}.exam-card:hover .exam-card-arrow{color:var(--accent, #64748b)}.exam-card-start-btn{background:none;border:1.5px solid var(--clr-border);color:var(--clr-text-secondary);border-radius:var(--r-md);padding:.35rem .75rem;font-size:var(--font-xs);font-weight:600;cursor:pointer;font-family:inherit;flex-shrink:0;transition:border-color var(--t-fast),color var(--t-fast)}.exam-card:hover .exam-card-start-btn{border-color:var(--accent);color:var(--accent)}.sidebar-lock-icon{margin-left:.35rem;font-size:.8rem;opacity:.7}.exam-tile-card.locked{cursor:pointer;filter:none}.exam-tile-card.locked .exam-tile-title,.exam-tile-card.locked .exam-tile-meta{opacity:.5}.exam-tile-lock-overlay{position:absolute;top:var(--sp-3);right:var(--sp-3);display:flex;align-items:center;gap:.25rem;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.35);border-radius:var(--radius-sm);padding:.2rem .45rem;font-size:var(--font-xs);font-weight:600;color:#b45309}.exam-tile-lock-icon{font-size:.85rem}.exam-tile-lock-label{font-size:.7rem;letter-spacing:.03em}.exam-tile-upgrade{font-size:var(--font-xs);color:#b45309;font-weight:600;margin-top:var(--sp-3);text-align:center}.premium-hint{font-size:var(--font-xs)}.exam-tile-card{position:relative}.upgrade-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.55);z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--sp-4)}.upgrade-modal{background:var(--clr-surface);border-radius:var(--radius-lg);box-shadow:var(--sh-xl);padding:var(--sp-8);max-width:480px;width:100%;text-align:center;position:relative}.upgrade-close{position:absolute;top:var(--sp-4);right:var(--sp-4);background:none;border:none;color:var(--clr-text-muted);font-size:1rem;cursor:pointer;padding:var(--sp-1);line-height:1}.upgrade-header{margin-bottom:var(--sp-6)}.upgrade-icon{font-size:2.5rem;margin-bottom:var(--sp-3)}.upgrade-title{font-size:1.4rem;font-weight:800;color:var(--clr-text);margin:0 0 var(--sp-2)}.upgrade-body{font-size:var(--font-sm);color:var(--clr-text-muted);margin:0;line-height:1.6}.upgrade-countdown{display:inline-block;margin-top:var(--sp-3);padding:.3rem .8rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24;border-radius:999px;font-size:.78rem;font-weight:700;color:#92400e;letter-spacing:.01em}.upgrade-plans{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin-bottom:var(--sp-5)}.upgrade-plan{border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2);position:relative}.upgrade-plan-featured{border-color:#2563eb;background:#eff6ff}.upgrade-plan-badge{position:absolute;top:-11px;left:50%;transform:translate(-50%);background:#f59e0b;color:#fff;font-size:.68rem;font-weight:700;padding:.2rem .65rem;border-radius:99px;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}.upgrade-plan-name{font-size:.78rem;font-weight:700;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.05em}.upgrade-plan-price{display:flex;align-items:flex-end;gap:.2rem}.upgrade-plan-amount{font-size:1.9rem;font-weight:800;color:var(--clr-text);line-height:1}.upgrade-plan-per{font-size:.8rem;color:var(--clr-muted);margin-bottom:.15rem}.upgrade-plan-saving{font-size:.72rem;color:#2563eb;font-weight:600;margin-top:-.25rem}.upgrade-plan-btn{display:block;text-align:center;padding:.55rem .5rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:700;text-decoration:none;margin-top:auto}.upgrade-features{background:var(--clr-bg);border-radius:var(--radius-md);padding:var(--sp-4);margin-bottom:var(--sp-4);text-align:left;display:flex;flex-direction:column;gap:.3rem}.upgrade-feature{font-size:var(--font-sm);color:var(--clr-text);padding:.15rem 0}.upgrade-feature-tick{color:#10b981;font-weight:700;margin-right:.3rem}.upgrade-note{font-size:var(--font-xs);color:var(--clr-text-muted)}.practice-portal{display:flex;flex-direction:column;gap:var(--sp-6)}.practice-year-label{font-size:var(--font-sm);font-weight:600;color:var(--clr-text-muted);margin-bottom:var(--sp-2);display:block}.practice-year-options{display:flex;gap:var(--sp-2);flex-wrap:wrap}.practice-year-btn{padding:.4rem 1rem;border-radius:var(--radius-md);border:1.5px solid var(--clr-border);background:var(--clr-surface);color:var(--clr-text-muted);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--t-fast)}.practice-year-btn.active,.practice-year-btn:hover{border-color:var(--clr-primary);color:var(--clr-primary);background:#eff6ff}.practice-section-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--sp-4)}.practice-section-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-top:3px solid var(--sec-color, var(--clr-primary));border-radius:var(--r-lg);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-2);transition:box-shadow var(--t-base),transform var(--t-base);box-shadow:var(--sh-xs)}.practice-section-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}.practice-section-icon{font-size:1.35rem;width:36px;height:36px;border-radius:var(--r-md);background:color-mix(in srgb,var(--sec-color, var(--clr-primary)) 12%,transparent);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-1)}.practice-section-name{font-size:var(--font-md);font-weight:700;color:var(--clr-text-strong)}.practice-section-desc{font-size:var(--font-sm);color:var(--clr-text-muted);line-height:1.55;flex:1}.practice-generate-btn{margin-top:var(--sp-3);padding:.55rem 1rem;border:none;border-radius:var(--r-md);color:#fff;font-size:var(--font-sm);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--sp-2);transition:opacity var(--t-fast),transform var(--t-fast);letter-spacing:.01em}.practice-generate-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.practice-generate-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.practice-generating-card{display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:3rem 2rem;max-width:480px;margin:2rem auto;box-shadow:0 4px 24px rgba(0,0,0,.07)}.pgc-icon{font-size:3rem;margin-bottom:1rem;animation:pgc-pulse 2s ease-in-out infinite}@keyframes pgc-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.pgc-title{font-size:1.25rem;font-weight:700;color:var(--clr-text);margin:0 0 .25rem}.pgc-subtitle{font-size:var(--font-sm);color:var(--clr-text-muted);margin:0 0 2rem}.pgc-progress-track{width:100%;height:8px;background:var(--clr-border);border-radius:99px;overflow:hidden;margin-bottom:1rem}.pgc-progress-bar{height:100%;border-radius:99px;min-width:4px}.pgc-status{font-size:.9rem;font-weight:600;color:var(--clr-text);min-height:1.4em;margin:0 0 1.5rem}.pgc-hint{font-size:var(--font-sm);color:var(--clr-text-muted);margin:0;line-height:1.5}.bank-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.bank-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.bank-card-header{display:flex;justify-content:space-between;align-items:center}.bank-card-section{font-size:.85rem;font-weight:600}.bank-card-year{font-size:.75rem;color:var(--clr-text-muted);background:var(--clr-bg);padding:.2rem .5rem;border-radius:99px}.bank-card-count{font-size:1.75rem;font-weight:800;color:var(--clr-text);line-height:1}.bank-card-count span{font-size:.9rem;font-weight:400;color:var(--clr-text-muted)}.bank-progress-track{height:6px;background:var(--clr-border);border-radius:99px;overflow:hidden}.bank-progress-bar{height:100%;border-radius:99px;transition:width .4s ease}.bank-card-actions{display:flex;align-items:center;gap:.5rem}.bank-filling-status{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--clr-text-muted)}.practice-screen{min-height:100vh;background:var(--clr-bg);display:flex;flex-direction:column}.practice-header{background:var(--clr-surface);border-bottom:1px solid var(--clr-border);padding:0 var(--sp-6);height:var(--header-h);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.practice-back-btn{background:none;border:none;color:var(--clr-text-muted);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:color var(--t-fast)}.practice-back-btn:hover{color:var(--clr-text)}.practice-title{font-weight:700;color:var(--clr-text);font-size:.95rem}.practice-counter{font-size:var(--font-sm);color:var(--clr-text-muted);font-weight:600}.practice-progress-track{height:4px;background:var(--clr-border);width:100%}.practice-progress-fill{height:4px;transition:width .4s ease}.practice-body{flex:1;max-width:680px;margin:0 auto;width:100%;padding:var(--sp-8) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-6)}.practice-question-card{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);padding:var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-4)}.practice-q-meta{display:flex;gap:var(--sp-2);flex-wrap:wrap}.practice-diff-badge{padding:.2rem .6rem;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:700;background:color-mix(in srgb,var(--diff-color) 12%,transparent);color:var(--diff-color);border:1px solid color-mix(in srgb,var(--diff-color) 25%,transparent)}.practice-skill-badge{padding:.2rem .6rem;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600;background:var(--clr-bg);color:var(--clr-text-muted);border:1px solid var(--clr-border)}.practice-q-text{font-size:1.05rem;line-height:1.65;color:var(--clr-text);font-weight:500}.practice-options{display:flex;flex-direction:column;gap:var(--sp-2)}.practice-option{width:100%;text-align:left;padding:.75rem 1rem;border-radius:var(--radius-md);border:1.5px solid var(--clr-border);background:var(--clr-surface);color:var(--clr-text);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);font-family:inherit}.practice-option:hover:not(:disabled):not(.correct):not(.wrong):not(.dimmed){border-color:var(--clr-primary);background:#eff6ff}.practice-option.correct{border-color:#16a34a;background:#f0fdf4;color:#15803d;font-weight:700}.practice-option.wrong{border-color:#dc2626;background:#fef2f2;color:#dc2626}.practice-option.dimmed{opacity:.45}.practice-option:disabled{cursor:default}.practice-feedback{border-radius:var(--radius-md);padding:var(--sp-4);border:1.5px solid}.practice-feedback.correct{background:#f0fdf4;border-color:#bbf7d0}.practice-feedback.incorrect{background:#fef2f2;border-color:#fecaca}.practice-feedback-header{font-weight:700;font-size:var(--font-sm);margin-bottom:var(--sp-2)}.practice-feedback.correct .practice-feedback-header{color:#15803d}.practice-feedback.incorrect .practice-feedback-header{color:#dc2626}.practice-feedback-explanation{font-size:var(--font-sm);color:var(--clr-text);line-height:1.6}.practice-next-btn{align-self:flex-end;padding:.6rem 1.4rem;border-radius:var(--radius-md);border:none;color:#fff;font-weight:700;cursor:pointer;font-size:var(--font-sm);font-family:inherit;transition:opacity var(--t-fast),transform var(--t-fast)}.practice-next-btn:hover{opacity:.88;transform:translateY(-1px)}.practice-reveal-wrap{display:flex;flex-direction:column;gap:var(--sp-3)}.practice-reveal-btn{padding:.65rem 1.2rem;border:1.5px solid var(--clr-border);border-radius:var(--radius-md);background:var(--clr-surface);color:var(--clr-primary);font-weight:700;font-size:var(--font-sm);cursor:pointer;font-family:inherit;align-self:flex-start;transition:background var(--t-fast)}.practice-reveal-btn:hover{background:#eff6ff}.practice-reveal-answer{padding:var(--sp-3) var(--sp-4);background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:var(--radius-md);color:#15803d;font-size:var(--font-sm);font-weight:600}.practice-results-card{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);padding:var(--sp-8);text-align:center}.practice-results-score{font-size:3.5rem;font-weight:800;line-height:1;margin-bottom:var(--sp-2)}.practice-results-label{font-size:1.1rem;color:var(--clr-text-muted);font-weight:600;margin-bottom:var(--sp-2)}.practice-results-msg{font-size:1rem;color:var(--clr-text)}.practice-review{display:flex;flex-direction:column;gap:var(--sp-4)}.practice-review-heading{font-size:1rem;font-weight:700;color:var(--clr-text)}.practice-review-card{background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--radius-lg);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-3)}.practice-review-card.correct{border-left:4px solid #16a34a}.practice-review-card.incorrect{border-left:4px solid #dc2626}.practice-review-top{display:flex;align-items:center;gap:var(--sp-2)}.practice-review-num{font-size:var(--font-xs);font-weight:700;color:var(--clr-text-muted)}.practice-review-badge{font-size:var(--font-xs);font-weight:700;padding:.15rem .5rem;border-radius:var(--radius-sm)}.practice-review-badge.correct{background:#f0fdf4;color:#15803d}.practice-review-badge.incorrect{background:#fef2f2;color:#dc2626}.practice-review-diff{font-size:var(--font-xs);color:var(--clr-text-muted);margin-left:auto}.practice-review-q{font-size:var(--font-sm);color:var(--clr-text);font-weight:500;line-height:1.5}.practice-review-opts{display:flex;flex-direction:column;gap:var(--sp-1)}.practice-review-opt{font-size:var(--font-xs);padding:.3rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--clr-border);color:var(--clr-text-muted)}.practice-review-opt.answer{background:#f0fdf4;border-color:#bbf7d0;color:#15803d;font-weight:700}.practice-review-opt.wrong-pick{background:#fef2f2;border-color:#fecaca;color:#dc2626}.practice-review-explanation{font-size:var(--font-xs);color:var(--clr-text);line-height:1.6}.practice-review-skill{font-size:var(--font-xs);color:var(--clr-text-muted)}.sub-toggle{padding:.25rem .6rem;border-radius:var(--radius-sm);border:1.5px solid;font-size:var(--font-xs);font-weight:700;cursor:pointer;font-family:inherit;transition:opacity var(--t-fast)}.sub-toggle:hover{opacity:.8}.sub-toggle.premium{background:#fef9c3;border-color:#fbbf24;color:#92400e}.sub-toggle.trial{background:var(--clr-bg);border-color:var(--clr-border);color:var(--clr-text-muted)}.role-select{padding:.25rem .5rem;border-radius:var(--radius-sm);border:1.5px solid var(--role-color, #64748b);background:color-mix(in srgb,var(--role-color, #64748b) 12%,#fff);color:var(--role-color, #64748b);font-size:var(--font-xs);font-weight:700;cursor:pointer;font-family:inherit;transition:opacity var(--t-fast)}.role-select:hover{opacity:.85}.role-select:focus{outline:none;box-shadow:0 0 0 2px color-mix(in srgb,var(--role-color, #64748b) 30%,transparent)}.readiness-bar-track{width:100%;height:10px;background:var(--clr-border);border-radius:99px;overflow:hidden;margin:.5rem 0 .75rem}.readiness-bar-fill{height:100%;border-radius:99px;transition:width .6s ease}.coach-tabs{display:inline-flex;gap:2px;background:var(--clr-surface-alt);border:1px solid var(--clr-border);border-radius:var(--r-lg);padding:4px;margin-bottom:1.75rem;align-self:flex-start}.coach-tab-btn{padding:.45rem 1.1rem;border:none;border-radius:var(--r-md);background:transparent;font-size:var(--font-sm);font-weight:500;color:var(--clr-text-muted);cursor:pointer;transition:all var(--t-fast);font-family:inherit;white-space:nowrap;line-height:1.4}.coach-tab-btn:hover:not(.active){color:var(--clr-text);background:rgba(0,0,0,.04)}.coach-tab-btn.active{background:var(--clr-surface);color:var(--clr-text-strong);font-weight:600;box-shadow:var(--sh-sm)}.coach-tab-btn[data-tab=diagnose].active{color:#6d28d9}.coach-tab-btn[data-tab=train].active{color:#059669}.coach-tab-btn[data-tab=track].active{color:var(--clr-primary)}.coach-tab-btn[data-tab=analyse].active{color:#b45309}.coach-tab-content{display:flex;flex-direction:column;gap:var(--sp-5)}.readiness-widget{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-xl);padding:1.25rem 1.5rem;box-shadow:var(--sh-sm)}.readiness-widget-inner{display:flex;align-items:center;gap:1.5rem}.readiness-ring-wrap{flex-shrink:0}.readiness-ring-wrap svg{display:block}.readiness-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:.4rem}.readiness-header{display:flex;justify-content:space-between;align-items:center}.readiness-label{font-size:var(--font-sm);font-weight:600;color:var(--clr-text-muted)}.readiness-band-pill{display:inline-block;padding:.2rem .65rem;border-radius:99px;font-size:var(--font-xs);font-weight:700;color:#fff}.readiness-meta{display:flex;justify-content:space-between;font-size:var(--font-xs);color:var(--clr-text-muted)}.readiness-next{font-size:var(--font-xs);color:var(--clr-text-secondary);line-height:1.45;padding-top:.25rem;border-top:1px solid var(--clr-border);margin-top:.1rem}.readiness-empty{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-xl);padding:1.5rem;text-align:center;color:var(--clr-text-muted);font-size:var(--font-sm)}.readiness-warming-up{display:flex;align-items:center;gap:1rem;background:linear-gradient(135deg,#f0f9ff,#eff6ff);border:1px solid #dbeafe;border-radius:var(--r-xl);padding:1.25rem 1.5rem;box-shadow:0 2px 8px rgba(37,99,235,.06)}.readiness-warmup-icon{font-size:1.75rem;flex-shrink:0}.readiness-warmup-body{display:flex;flex-direction:column;gap:.35rem}.readiness-warmup-title{font-size:var(--font-sm);font-weight:600;color:var(--clr-text)}.readiness-warmup-sub{font-size:var(--font-xs);color:var(--clr-text-muted);line-height:1.5}.readiness-warmup-progress{display:flex;gap:.4rem;margin-top:.25rem}.readiness-warmup-dot{width:10px;height:10px;border-radius:50%;transition:background .3s}.skill-gap-section{margin-bottom:1.25rem}.skill-gap-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--clr-text-muted);margin-bottom:.5rem}.skill-gap-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--clr-border)}.skill-gap-row:last-child{border-bottom:none}.skill-gap-name{flex:1;font-size:.875rem;font-weight:500;color:var(--clr-text)}.skill-gap-bar-track{flex:1;height:6px;background:var(--clr-border);border-radius:99px;overflow:hidden}.skill-gap-bar-fill{height:100%;border-radius:99px}.skill-gap-count{font-size:.75rem;color:var(--clr-text-muted);min-width:50px;text-align:right}.skill-gap-practice-btn{font-size:.75rem;font-weight:600;color:#3b82f6;background:none;border:none;cursor:pointer;padding:.2rem .4rem;border-radius:var(--radius-sm);transition:background var(--t-fast);font-family:inherit;white-space:nowrap}.skill-gap-practice-btn:hover{background:#eff6ff}.skill-gap-empty{background:var(--clr-bg);border:1px dashed var(--clr-border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;color:var(--clr-text-muted);font-size:.875rem}.band-prediction-bar{background:linear-gradient(135deg,#f0fdf4,#eff6ff);border:1px solid #bbf7d0;border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:1.25rem;display:flex;flex-direction:column;gap:.35rem}.band-prediction-main{font-size:.9rem;font-weight:600;color:var(--clr-text)}.band-prediction-selective{font-size:.8rem;color:#64748b}.recommended-row{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.5rem}.recommended-title{font-size:.85rem;font-weight:700;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.recommended-chips{display:flex;flex-wrap:wrap;gap:.5rem}.recommended-chip{display:flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border-radius:99px;border:1.5px solid #3b82f6;background:#eff6ff;color:#1d4ed8;font-size:.8rem;font-weight:600;cursor:pointer;transition:background var(--t-fast),transform var(--t-fast);font-family:inherit}.recommended-chip:hover{background:#dbeafe;transform:translateY(-1px)}.recommended-chip-section{font-size:.7rem;color:#3b82f6}.parent-readiness-hero{background:linear-gradient(135deg,#f8fafc,#f0f9ff);border:1px solid #bae6fd;border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.25rem}.parent-readiness-empty{background:var(--clr-bg);border:1px dashed var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem;color:var(--clr-text-muted);font-size:.875rem;text-align:center;margin-bottom:1.25rem}.parent-readiness-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.parent-readiness-title{font-size:.875rem;font-weight:700;color:var(--clr-text)}.parent-readiness-band{display:inline-block;padding:.2rem .65rem;border-radius:99px;font-size:.75rem;font-weight:700;color:#fff}.parent-readiness-score-row{display:flex;align-items:baseline;gap:.25rem}.parent-readiness-score{font-size:2.25rem;font-weight:800;line-height:1}.parent-readiness-denom{font-size:.95rem;color:var(--clr-text-muted)}.parent-readiness-meta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--clr-text-muted);margin-top:.5rem}.parent-skill-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.parent-skill-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--clr-bg);border-radius:var(--radius-sm)}.parent-skill-item:before{content:"▸";color:#f59e0b;font-size:.75rem}.parent-skill-name{flex:1;font-size:.875rem;font-weight:500;color:var(--clr-text)}.parent-skill-meta{font-size:.75rem;color:var(--clr-text-muted)}.parent-band-line{font-size:.875rem;color:#374151;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:.6rem 1rem;margin-bottom:1.25rem}.parent-selective-note{color:#64748b}.parent-report-panel{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.5rem}.parent-report-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.parent-report-title{font-size:.9rem;font-weight:700;color:var(--clr-text);display:block}.parent-report-date{font-size:.75rem;color:var(--clr-text-muted);display:block;margin-top:.15rem}.parent-report-body{font-size:.875rem;color:#374151;line-height:1.7;white-space:pre-wrap}.parent-report-empty{font-size:.875rem;color:var(--clr-text-muted);font-style:italic}.parent-link-panel{max-width:480px;margin:4rem auto;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:2.5rem 2rem;text-align:center}.parent-link-icon{font-size:3rem;margin-bottom:1rem;line-height:1}.parent-link-title{font-size:1.25rem;font-weight:700;color:var(--clr-text);margin:0 0 .75rem}.parent-link-desc{font-size:.9rem;color:var(--clr-text-muted);margin:0 0 1.5rem;line-height:1.6}.parent-link-code-row{display:inline-flex;align-items:center;gap:.75rem;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:var(--radius-sm);padding:.6rem 1rem;margin-bottom:1.25rem}.parent-link-code{font-size:1.5rem;font-weight:800;letter-spacing:.25em;color:#0f172a;font-family:monospace}.parent-link-hint{font-size:.8rem;color:var(--clr-text-muted);margin:0;line-height:1.5}.parent-child-panel{display:flex;flex-direction:column;gap:0}.parent-section{margin-bottom:1.5rem}.parent-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--clr-text-muted);margin-bottom:.75rem}.parent-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.parent-section-header .parent-section-title{margin-bottom:0}.parent-empty-tasks{font-size:.875rem;color:var(--clr-text-muted);font-style:italic;padding:.75rem 0}.parent-tasks-list{display:flex;flex-direction:column;gap:.5rem}.parent-task-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-sm);gap:1rem}.parent-task-row.overdue{border-color:#fca5a5;background:#fff5f5}.parent-task-row.done{opacity:.6}.parent-task-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.parent-task-name{font-size:.875rem;font-weight:600;color:var(--clr-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.parent-task-due{font-size:.75rem;color:var(--clr-text-muted)}.parent-task-status{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .5rem;border-radius:99px;flex-shrink:0;background:#e2e8f0;color:#475569}.parent-task-status.done{background:#dcfce7;color:#15803d}.parent-task-status.overdue{background:#fee2e2;color:#b91c1c}.parent-results-list{display:flex;flex-direction:column;gap:.5rem}.parent-result-row{display:flex;justify-content:space-between;align-items:center;padding:.65rem .75rem;background:var(--clr-bg);border-radius:var(--radius-sm);gap:1rem}.parent-result-left{display:flex;flex-direction:column;gap:.2rem;min-width:0}.parent-result-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.parent-result-section{font-size:.8rem;font-weight:600;text-transform:capitalize}.parent-result-meta{font-size:.72rem;color:var(--clr-text-muted)}.parent-result-score{font-size:.9rem;font-weight:700;color:var(--clr-text)}.link-parent-modal{max-width:420px}.link-code-inputs{display:flex;justify-content:center;gap:.5rem;margin-bottom:1rem}.link-code-input{width:2.75rem;height:3.25rem;text-align:center;font-size:1.4rem;font-weight:800;font-family:monospace;border:2px solid var(--clr-border);border-radius:var(--radius-sm);background:var(--clr-bg);color:var(--clr-text);outline:none;text-transform:uppercase;transition:border-color .15s}.link-code-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.15)}.link-code-error{font-size:.85rem;color:#ef4444;margin-bottom:.5rem}.link-code-hint{font-size:.8rem;color:var(--clr-text-muted);line-height:1.5;margin:0 0 .25rem}.skill-breakdown{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.25rem}.skill-breakdown-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--clr-text-muted);margin-bottom:1rem}.skill-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem}.skill-row-name{font-size:.8rem;font-weight:500;color:var(--clr-text);width:130px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.skill-bar-track{flex:1;height:8px;background:var(--clr-bg);border-radius:99px;overflow:hidden}.skill-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.skill-row-label{font-size:.75rem;font-weight:700;width:36px;text-align:right;flex-shrink:0}.diagnostic-report-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.25rem}.diagnostic-report-header{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;color:var(--clr-text);margin-bottom:1rem}.diagnostic-section{padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:.75rem;font-size:.875rem;line-height:1.6;color:#374151}.diagnostic-section:last-child{margin-bottom:0}.diagnostic-section-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem}.diagnostic-strengths{background:#f0fdf4;border:1px solid #bbf7d0}.diagnostic-strengths .diagnostic-section-label{color:#15803d}.diagnostic-weaknesses{background:#fffbeb;border:1px solid #fde68a}.diagnostic-weaknesses .diagnostic-section-label{color:#b45309}.diagnostic-recommendation{background:#eff6ff;border:1px solid #bfdbfe}.diagnostic-recommendation .diagnostic-section-label{color:#1d4ed8}.diagnostic-unavailable{font-size:.875rem;color:var(--clr-text-muted);font-style:italic}.diagnostic-skeleton{display:flex;flex-direction:column;gap:.5rem}.diagnose-empty-state{text-align:center;padding:3rem 2rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg)}.diagnose-empty-icon{font-size:3rem;margin-bottom:.75rem}.diagnose-empty-title{font-size:1.4rem;font-weight:700;margin:0 0 .5rem;color:var(--clr-text)}.diagnose-empty-body{color:var(--clr-muted);margin:0 auto 1.5rem;max-width:420px;line-height:1.6}.diagnose-empty-steps{display:flex;flex-direction:column;gap:.6rem;max-width:340px;margin:0 auto 1.75rem;text-align:left}.diagnose-step{display:flex;align-items:center;gap:.75rem;color:var(--clr-text);font-size:.9rem}.diagnose-step-num{width:24px;height:24px;border-radius:50%;background:#2563eb;color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.diagnose-start-btn{font-size:.95rem;padding:.6rem 1.5rem}.dash-section-sub{font-size:.8rem;color:var(--clr-muted);font-weight:400}.diagnose-skill-breakdown{display:flex;flex-direction:column;gap:.6rem;margin-top:.5rem}.diagnose-skill-row{display:flex;align-items:center;gap:.75rem}.diagnose-skill-name{width:130px;font-size:.85rem;color:var(--clr-text);flex-shrink:0}.diagnose-skill-bar-track{flex:1;height:10px;background:var(--clr-border);border-radius:99px;overflow:hidden}.diagnose-skill-bar-fill{height:100%;border-radius:99px;transition:width .6s ease}.diagnose-skill-label{width:40px;text-align:right;font-size:.8rem;font-weight:600;flex-shrink:0}.diagnose-report-card{display:flex;flex-direction:column;gap:.75rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem;margin-top:1rem}.diagnose-report-section{display:flex;gap:.75rem;align-items:flex-start}.diagnose-report-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.diagnose-report-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--clr-muted);margin-bottom:.2rem}.diagnose-report-text{margin:0;font-size:.88rem;color:var(--clr-text);line-height:1.6}.onboarding-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;padding:1rem}.onboarding-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.2);width:100%;max-width:440px;overflow:hidden}.onboarding-header{background:linear-gradient(135deg,#1e3a5f,#2563eb);padding:2rem 2rem 1.5rem;text-align:center}.onboarding-wave{font-size:2.5rem;margin-bottom:.5rem}.onboarding-title{color:#fff;font-size:1.4rem;font-weight:700;margin:0 0 .4rem}.onboarding-subtitle{color:rgba(255,255,255,.8);font-size:.9rem;margin:0}.onboarding-body{padding:1.5rem 2rem}.onboarding-field{margin-bottom:1.25rem}.onboarding-label{display:block;font-size:.85rem;font-weight:600;color:#374151;margin-bottom:.6rem}.onboarding-optional{font-size:.75rem;font-weight:400;color:#9ca3af;margin-left:.4rem}.onboarding-year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.onboarding-year-btn{padding:.5rem 0;border-radius:8px;font-size:.85rem;font-weight:600;border:2px solid #e5e7eb;background:#f9fafb;color:#374151;cursor:pointer;transition:all .15s}.onboarding-year-btn:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.onboarding-year-btn.active{border-color:#2563eb;background:#2563eb;color:#fff}.onboarding-date-input{width:100%;padding:.55rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;color:#374151;box-sizing:border-box}.onboarding-footer{padding:1rem 2rem 1.5rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid #f3f4f6}.pp-root{min-height:100vh;background:#f1f5f9;display:flex;flex-direction:column}.pp-nav{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:56px;background:#0f172a;border-bottom:1px solid #1e293b;flex-shrink:0}.pp-nav-left{display:flex;align-items:center;gap:.75rem}.pp-nav-logo{font-size:1rem;font-weight:700;color:#f8fafc;letter-spacing:-.01em}.pp-nav-logo span{color:#38bdf8}.pp-back-btn{background:none;border:1px solid #334155;color:#94a3b8;padding:.3rem .7rem;border-radius:6px;cursor:pointer;font-size:.8rem}.pp-back-btn:hover{color:#f8fafc;border-color:#64748b}.pp-nav-right{display:flex;align-items:center;gap:.75rem}.pp-nav-avatar{width:32px;height:32px;border-radius:50%;background:#0ea5e9;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff}.pp-nav-userinfo{display:flex;flex-direction:column}.pp-nav-name{font-size:.85rem;font-weight:600;color:#f8fafc;line-height:1.2}.pp-nav-role{font-size:.72rem;color:#64748b}.pp-layout{flex:1;display:flex;flex-direction:column}.pp-body{display:flex;flex:1;min-height:0}.pp-full-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#64748b}.pp-content-center{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.pp-sidebar{width:240px;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;padding:1.25rem .75rem;display:flex;flex-direction:column;gap:.25rem}.pp-sidebar-heading{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;padding:0 .5rem .75rem}.pp-child-btn{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:8px;border:none;background:none;cursor:pointer;text-align:left;width:100%;transition:background .12s}.pp-child-btn:hover{background:#f1f5f9}.pp-child-btn.active{background:#eff6ff}.pp-child-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#0ea5e9);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:#fff;flex-shrink:0}.pp-child-info{display:flex;flex-direction:column;min-width:0}.pp-child-name{font-size:.875rem;font-weight:600;color:#0f172a}.pp-child-meta{font-size:.75rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pp-sidebar-link-code{margin-top:auto;padding:.75rem;background:#f8fafc;border-radius:8px;border:1px dashed #cbd5e1}.pp-sidebar-link-label{font-size:.72rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.pp-sidebar-link-hint{font-size:.78rem;color:#475569}.pp-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto}.pp-child-header{padding:1.5rem 2rem 0;display:flex;align-items:flex-start;justify-content:space-between}.pp-child-header-left{display:flex;align-items:center;gap:1rem}.pp-child-header-avatar{width:52px;height:52px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,#2563eb,#0ea5e9);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;color:#fff}.pp-child-header-name{font-size:1.4rem;font-weight:700;color:#0f172a;margin:0}.pp-child-header-meta{font-size:.85rem;color:#64748b;margin:.2rem 0 0}.pp-tabs{display:flex;gap:.25rem;padding:1rem 2rem 0;border-bottom:1px solid #e2e8f0;margin:.75rem 0 0}.pp-tab-btn{padding:.5rem 1rem;border:none;background:none;cursor:pointer;font-size:.875rem;font-weight:500;color:#64748b;border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:.4rem;transition:color .12s}.pp-tab-btn:hover{color:#0f172a}.pp-tab-btn.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.pp-tab-badge{background:#2563eb;color:#fff;font-size:.65rem;font-weight:700;padding:0 5px;border-radius:99px;min-width:16px;text-align:center}.pp-tab-loading{flex:1;display:flex;align-items:center;justify-content:center;padding:4rem}.pp-tab-body{padding:1.5rem 2rem 2rem;flex:1}.pp-tab-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;color:#64748b;font-size:.9rem}.pp-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.pp-card-full{grid-column:1 / -1}.pp-card-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin-bottom:1rem}.pp-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.pp-overview{display:flex;flex-direction:column;gap:1.25rem}.pp-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.pp-readiness-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.pp-readiness-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.pp-readiness-label{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.pp-readiness-score{font-size:3rem;font-weight:800;line-height:1}.pp-readiness-denom{font-size:1.2rem;font-weight:400;color:#94a3b8;margin-left:2px}.pp-readiness-band{padding:.3rem .85rem;border-radius:99px;font-size:.8rem;font-weight:700;color:#fff;white-space:nowrap}.pp-readiness-bar-track{height:8px;background:#f1f5f9;border-radius:99px;overflow:hidden;margin-bottom:.75rem}.pp-readiness-bar-fill{height:100%;border-radius:99px;transition:width .6s ease}.pp-readiness-meta{display:flex;justify-content:space-between;font-size:.8rem;color:#64748b}.pp-readiness-empty{display:flex;align-items:center;gap:.75rem;color:#64748b;padding:.5rem 0;font-size:.9rem}.pp-readiness-empty-icon{font-size:1.5rem}.pp-section-breakdown{display:flex;flex-direction:column;gap:.65rem}.pp-section-row{display:flex;align-items:center;gap:.6rem}.pp-section-icon{font-size:1rem;flex-shrink:0}.pp-section-name{width:80px;font-size:.82rem;color:#374151;flex-shrink:0}.pp-section-bar-track{flex:1;height:8px;background:#f1f5f9;border-radius:99px;overflow:hidden}.pp-section-bar-fill{height:100%;border-radius:99px;transition:width .6s}.pp-section-avg{width:36px;text-align:right;font-size:.8rem;font-weight:700;flex-shrink:0}.pp-section-count{font-size:.72rem;color:#94a3b8;flex-shrink:0;width:24px;text-align:right}.pp-band-trajectory{padding:.5rem 0}.pp-band-row{display:flex;align-items:center;gap:1.5rem}.pp-band-item{display:flex;flex-direction:column;align-items:center}.pp-band-item-label{font-size:.72rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.pp-band-item-value{font-size:1.4rem;font-weight:700;color:#0f172a}.pp-band-item-sub{font-size:.75rem;color:#64748b}.pp-band-arrow{font-size:1.25rem;color:#cbd5e1}.pp-band-note{margin-top:.75rem;font-size:.8rem;color:#64748b;background:#f8fafc;border-radius:6px;padding:.4rem .6rem}.pp-skill-gaps{display:flex;flex-direction:column;gap:.5rem}.pp-skill-row{display:flex;align-items:center;gap:.75rem;padding:.4rem 0;border-bottom:1px solid #f1f5f9}.pp-skill-row:last-child{border-bottom:none}.pp-skill-section-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pp-skill-name{flex:1;font-size:.875rem;color:#0f172a;font-weight:500}.pp-skill-section{font-size:.75rem;color:#94a3b8}.pp-skill-misses{font-size:.75rem;font-weight:600;color:#ef4444}.pp-refresh-btn{display:flex;align-items:center;gap:.4rem;padding:.35rem .85rem;border-radius:6px;border:1px solid #e2e8f0;background:#f8fafc;font-size:.8rem;color:#374151;cursor:pointer}.pp-refresh-btn:hover:not(:disabled){background:#f1f5f9}.pp-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.pp-report-text{font-size:.9rem;color:#374151;line-height:1.7;white-space:pre-wrap}.pp-report-empty{font-size:.875rem;color:#94a3b8;padding:.5rem 0}.pp-report-generating{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 0;color:#64748b;font-size:.875rem}.pp-report-date{font-size:.75rem;color:#94a3b8;margin-top:.75rem}.pp-spinner{width:16px;height:16px;border:2px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.pp-spinner-lg{width:32px;height:32px;border-width:3px}.pp-tests-list{display:flex;flex-direction:column;gap:.5rem}.pp-test-row{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:.85rem 1rem}.pp-test-icon{width:40px;height:40px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.pp-test-info{flex:1;min-width:0}.pp-test-title{font-size:.9rem;font-weight:600;color:#0f172a}.pp-test-meta{display:flex;gap:.5rem;font-size:.75rem;color:#94a3b8;margin-top:.15rem}.pp-test-meta span:before{content:"·";margin-right:.5rem}.pp-test-meta span:first-child:before{content:"";margin-right:0}.pp-test-score{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.pp-test-pct{font-size:1rem;font-weight:700;color:#0f172a}.pp-band-chip{font-size:.7rem;font-weight:700;color:#fff;padding:.2rem .55rem;border-radius:99px}.pp-tasks-tab{display:flex;flex-direction:column;gap:1rem}.pp-tasks-header{display:flex;align-items:center;justify-content:space-between}.pp-tasks-sub{font-size:.85rem;color:#64748b;margin:0}.pp-task-list{display:flex;flex-direction:column;gap:.5rem}.pp-task-row{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:.85rem 1rem}.pp-task-info{display:flex;flex-direction:column;gap:.15rem}.pp-task-title{font-size:.9rem;font-weight:600;color:#0f172a}.pp-task-due{font-size:.78rem;color:#64748b}.pp-task-status{font-size:.75rem;font-weight:700;padding:.25rem .65rem;border-radius:99px}.pp-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;padding:1rem}.pp-modal{background:#fff;border-radius:14px;width:100%;max-width:460px;box-shadow:0 20px 60px rgba(0,0,0,.15);overflow:hidden}.pp-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9}.pp-modal-title{font-size:1rem;font-weight:700;color:#0f172a}.pp-modal-sub{font-size:.8rem;color:#64748b;margin-top:.15rem}.pp-modal-close{background:none;border:none;font-size:1.1rem;color:#94a3b8;cursor:pointer;padding:0}.pp-modal-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.pp-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.pp-form-field{display:flex;flex-direction:column;gap:.4rem}.pp-form-label{font-size:.85rem;font-weight:600;color:#374151}.pp-form-optional{font-size:.78rem;font-weight:400;color:#94a3b8;margin-left:.25rem}.pp-form-select{width:100%;padding:.55rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;color:#374151;background:#fff}.pp-empty-state{max-width:420px;text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:2.5rem 2rem}.pp-empty-icon{font-size:3rem;margin-bottom:.75rem}.pp-empty-title{font-size:1.3rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.pp-empty-body{font-size:.9rem;color:#64748b;line-height:1.6;margin:0 0 1.5rem}.pp-link-code-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:1rem 1.25rem;margin-bottom:1rem}.pp-link-code-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;display:block;margin-bottom:.5rem}.pp-link-code-row{display:flex;align-items:center;gap:.75rem}.pp-link-code-value{font-size:1.6rem;font-weight:800;letter-spacing:.15em;color:#0f172a;font-family:monospace;flex:1}.pp-empty-hint{font-size:.8rem;color:#94a3b8;margin:0}@media(max-width:640px){.pp-sidebar{width:100%;border-right:none;border-bottom:1px solid #e2e8f0;padding:.75rem;flex-direction:row;overflow-x:auto}.pp-body{flex-direction:column}.pp-overview-grid{grid-template-columns:1fr}.pp-tab-body{padding:1rem}}.quick-diagnostic-entry{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.25rem}.quick-diagnostic-divider{font-size:.8rem;color:#94a3b8}.quick-diagnostic-btn{display:flex;flex-direction:column;align-items:center;gap:.2rem;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;padding:.9rem 1.5rem;cursor:pointer;transition:border-color .15s,background .15s;font-size:.95rem;font-weight:700;color:#0f172a}.quick-diagnostic-btn:hover{border-color:#2563eb;background:#eff6ff;color:#2563eb}.quick-diagnostic-sub{font-size:.75rem;font-weight:400;color:#64748b}.quick-diagnostic-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(135deg,#eff6ff,#e0f2fe);border:1px solid #bfdbfe;border-radius:var(--r-xl);padding:1.1rem 1.5rem;margin-bottom:0;box-shadow:0 2px 14px rgba(14,165,233,.1);transition:box-shadow var(--t-fast),transform var(--t-fast)}.quick-diagnostic-banner:hover{box-shadow:0 4px 20px rgba(14,165,233,.18);transform:translateY(-1px)}.quick-diagnostic-banner-icon{font-size:1.35rem;width:44px;height:44px;border-radius:var(--r-md);background:linear-gradient(135deg,#0ea5e9,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px rgba(14,165,233,.35)}.quick-diagnostic-banner-body{flex:1;min-width:0}.quick-diagnostic-banner-title{font-size:var(--font-md);font-weight:700;color:var(--clr-text-strong)}.quick-diagnostic-banner-sub{font-size:var(--font-xs);color:var(--clr-text-secondary);margin-top:.2rem;line-height:1.4}.diagnostic-section-banner{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:.55rem 1rem;margin-bottom:.75rem;font-size:.85rem;font-weight:700;color:#1d4ed8;text-align:center;letter-spacing:.02em}.diag-results-screen{min-height:100vh;background:#f1f5f9;display:flex;flex-direction:column}.diag-results-header{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 1.5rem;position:sticky;top:0;z-index:10}.diag-results-title{font-size:1.1rem;font-weight:700;color:#0f172a;margin:0}.diag-results-body{max-width:680px;width:100%;margin:0 auto;padding:1.5rem 1rem 3rem;display:flex;flex-direction:column;gap:1.25rem}.diag-overall-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.75rem 1.5rem;text-align:center}.diag-overall-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin-bottom:.5rem}.diag-overall-score{font-size:3.5rem;font-weight:800;line-height:1;margin-bottom:.4rem}.diag-overall-band{display:inline-block;color:#fff;font-size:.8rem;font-weight:700;padding:.3rem .9rem;border-radius:99px;margin-bottom:.6rem}.diag-overall-sub{font-size:.85rem;color:#64748b}.diag-overall-band-hint{font-size:.78rem;color:#94a3b8;margin-top:.25rem}.diag-encourage-banner{background:linear-gradient(135deg,#1e3a8a,#3b82f6);border-radius:14px;padding:1rem 1.25rem;display:flex;align-items:center;gap:.75rem}.diag-encourage-icon{font-size:1.6rem;flex-shrink:0}.diag-encourage-text{color:#fff}.diag-encourage-text strong{display:block;font-size:.95rem;margin-bottom:.15rem}.diag-encourage-text span{font-size:.82rem;opacity:.85}.diag-sections-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.diag-section-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem .75rem;text-align:center;position:relative;transition:box-shadow .2s}.diag-section-card.is-weakest{border-color:#fca5a5;box-shadow:0 0 0 2px #fee2e2}.diag-section-weakest-tag{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:99px;white-space:nowrap}.diag-section-name{font-size:.75rem;font-weight:700;margin-bottom:.4rem}.diag-section-score{font-size:1.4rem;font-weight:800;margin-bottom:.4rem}.diag-section-bar-track{height:8px;background:#f1f5f9;border-radius:99px;margin-bottom:.35rem;overflow:hidden}.diag-section-bar-fill{height:100%;border-radius:99px;transition:width .6s ease}.diag-section-pct{font-size:.8rem;font-weight:700}.diag-focus-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:1.1rem 1.25rem}.diag-focus-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;margin-bottom:.85rem}.diag-focus-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid #f1f5f9}.diag-focus-row:last-child{border-bottom:none;padding-bottom:0}.diag-focus-rank{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:#fff}.diag-focus-rank.rank-1{background:#ef4444}.diag-focus-rank.rank-2{background:#f97316}.diag-focus-rank.rank-3{background:#f59e0b}.diag-focus-info{flex:1;min-width:0}.diag-focus-skill{font-size:.88rem;font-weight:600;color:#0f172a;white-space:normal;word-break:break-word;line-height:1.3;margin-bottom:.15rem}.diag-focus-meta{display:flex;align-items:center;gap:.4rem}.diag-focus-section{font-size:.7rem;font-weight:600}.diag-focus-pct{font-size:.7rem;font-weight:700;color:#ef4444;background:#fef2f2;padding:.1rem .35rem;border-radius:4px}.diag-focus-bar-track{width:60px;flex-shrink:0;height:6px;background:#f1f5f9;border-radius:99px;overflow:hidden}.diag-focus-bar-fill{height:100%;border-radius:99px}.diag-focus-practice-btn{flex-shrink:0;font-size:.75rem;font-weight:600;padding:.35rem .75rem;border-radius:8px;background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe;cursor:pointer;white-space:nowrap;transition:background .15s}.diag-focus-practice-btn:hover{background:#dbeafe}.diag-focus-practice-btn:disabled{opacity:.5;cursor:not-allowed}.diag-ai-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.diag-ai-header{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;color:#0f172a;margin-bottom:1rem}.diag-ai-section{margin-bottom:.75rem;border-radius:10px;padding:.75rem}.diag-ai-section:last-child{margin-bottom:0}.diag-ai-section.strength{background:#f0fdf4;border:1px solid #bbf7d0}.diag-ai-section.weakness{background:#fffbeb;border:1px solid #fde68a}.diag-ai-section.recommend{background:#eff6ff;border:1px solid #bfdbfe}.diag-ai-section-label{font-size:.78rem;font-weight:700;margin-bottom:.3rem}.diag-ai-section.strength .diag-ai-section-label{color:#16a34a}.diag-ai-section.weakness .diag-ai-section-label{color:#d97706}.diag-ai-section.recommend .diag-ai-section-label{color:#2563eb}.diag-ai-section p{margin:0;font-size:.9rem;color:#334155;line-height:1.6}.diag-actions{display:flex;flex-direction:column;gap:.75rem}.diag-home-btn{width:100%;justify-content:center}@media(max-width:480px){.diag-sections-grid{grid-template-columns:1fr}.diag-overall-score{font-size:2.8rem}.diag-focus-bar-track{display:none}}.result-diag-badge{display:inline-block;margin-left:.5rem;padding:.1rem .45rem;background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe;border-radius:99px;font-size:.7rem;font-weight:600;vertical-align:middle;line-height:1.4}.diag-ai-loading-msg{font-size:.85rem;color:#64748b;margin:0 0 1rem;line-height:1.6}.analytics-summary-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}@media(max-width:600px){.analytics-summary-row{grid-template-columns:1fr}}.analytics-countdown-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.25rem}.analytics-countdown-num{font-size:3rem;font-weight:800;color:var(--clr-primary);line-height:1}.analytics-countdown-label{font-size:.85rem;color:var(--clr-muted);font-weight:500}.analytics-countdown-sub{font-size:.78rem;color:var(--clr-muted);margin-top:.2rem}.analytics-countdown-unset{display:flex;flex-direction:column;align-items:center;gap:.5rem}.analytics-countdown-icon{font-size:1.8rem}.analytics-readiness-wrap{display:flex;flex-direction:column}.analytics-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--r-xl);padding:1.25rem 1.5rem;margin-bottom:1rem;box-shadow:var(--sh-sm)}.analytics-card-title{font-size:.95rem;font-weight:700;color:var(--clr-text);margin-bottom:.15rem}.analytics-card-sub{font-size:.78rem;color:var(--clr-muted);margin-bottom:.85rem}.analytics-chart-wrap{width:100%}.analytics-chart-svg{width:100%;height:auto;display:block}.analytics-chart-empty{font-size:.85rem;color:var(--clr-muted);padding:1rem 0;text-align:center}.analytics-chart-legend{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:.6rem}.analytics-legend-dot{font-size:.75rem;color:var(--clr-muted);display:flex;align-items:center;gap:.3rem}.analytics-legend-dot:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--dot-color, #64748b)}.analytics-section-bars{display:flex;flex-direction:column;gap:.6rem}.analytics-section-bar-row{display:grid;grid-template-columns:160px 1fr 44px;align-items:center;gap:.75rem}@media(max-width:500px){.analytics-section-bar-row{grid-template-columns:120px 1fr 36px}}.analytics-section-bar-label{display:flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--clr-text);font-weight:500}.analytics-section-bar-count{font-size:.72rem;color:var(--clr-muted);margin-left:.2rem}.analytics-section-bar-track{height:8px;background:var(--clr-border);border-radius:99px;overflow:hidden}.analytics-section-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.analytics-section-bar-pct{font-size:.8rem;font-weight:700;text-align:right}.analytics-skill-sparklines{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.analytics-sparkline-card{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-md);padding:.75rem}.analytics-sparkline-name{font-size:.82rem;font-weight:600;color:var(--clr-text);margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.analytics-sparkline-section{font-size:.72rem;margin-bottom:.5rem}.analytics-sparkline{display:flex;align-items:center;gap:.5rem}.analytics-sparkline-svg{width:100px;height:32px;flex-shrink:0}.analytics-sparkline-trend{font-size:.8rem;font-weight:700}.analytics-sparkline-nodata{font-size:.72rem;color:var(--clr-muted)}.analytics-weak-skills{display:flex;flex-direction:column;gap:.6rem}.analytics-weak-card{display:flex;align-items:center;gap:.75rem;background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-md);padding:.75rem 1rem}.analytics-weak-rank{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.82rem;font-weight:700;flex-shrink:0}.analytics-weak-info{flex:1;min-width:0}.analytics-weak-name{font-size:.88rem;font-weight:600;color:var(--clr-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.analytics-weak-meta{display:flex;gap:.5rem;align-items:center;margin-top:.1rem}.analytics-weak-section{font-size:.74rem;font-weight:500}.analytics-weak-misses{font-size:.74rem;color:var(--clr-muted)}.analytics-unlock-state{display:flex;flex-direction:column;gap:1.5rem}.analytics-unlock-hero{text-align:center;padding:2.5rem 2rem 2rem;background:linear-gradient(160deg,#f0f4ff,#e8f0fe);border:1px solid #c7d7fd;border-radius:var(--radius-lg)}.analytics-unlock-icon{font-size:3rem;margin-bottom:.75rem}.analytics-unlock-title{font-size:1.5rem;font-weight:800;color:var(--clr-text);margin:0 0 .5rem}.analytics-unlock-body{color:var(--clr-muted);margin:0 auto 1.5rem;max-width:400px;line-height:1.6;font-size:.92rem}.analytics-unlock-cta{font-size:.95rem;padding:.65rem 1.75rem}.analytics-unlock-previews{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem}@media(min-width:640px){.analytics-unlock-previews{grid-template-columns:repeat(4,1fr)}}.analytics-preview-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.1rem 1rem;display:flex;flex-direction:column;gap:.3rem;opacity:.65;transition:opacity var(--t-fast)}.analytics-preview-card:hover{opacity:.85}.analytics-preview-icon{font-size:1.5rem}.analytics-preview-title{font-size:.85rem;font-weight:700;color:var(--clr-text)}.analytics-preview-desc{font-size:.75rem;color:var(--clr-muted);line-height:1.5}@keyframes nudge-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.results-upgrade-nudge{position:fixed;bottom:0;left:0;right:0;z-index:150;background:linear-gradient(135deg,#1e3a8a,#1d4ed8);border-radius:0;padding:.9rem 1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;box-shadow:0 -4px 24px rgba(37,99,235,.3);animation:nudge-slide-up .35s cubic-bezier(.34,1.56,.64,1) both}.results-upgrade-dismiss{position:absolute;top:.5rem;right:.75rem;background:none;border:none;color:rgba(255,255,255,.6);font-size:.9rem;cursor:pointer;padding:.2rem;line-height:1}.results-upgrade-dismiss:hover{color:#fff}.results-upgrade-left{display:flex;align-items:center;gap:.75rem;flex:1;min-width:200px}.results-upgrade-icon{font-size:1.75rem;flex-shrink:0}.results-upgrade-title{font-size:.95rem;font-weight:700;color:#fff}.results-upgrade-body{font-size:.8rem;color:rgba(255,255,255,.75);margin-top:.1rem}.results-upgrade-plans{display:flex;gap:.6rem;flex-shrink:0}.results-upgrade-btn{display:inline-block;padding:.55rem 1.1rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:700;text-decoration:none;white-space:nowrap;cursor:pointer;border:none}.results-upgrade-btn-secondary{background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.35)}.results-upgrade-btn-secondary:hover{background:rgba(255,255,255,.25)}.results-upgrade-btn-primary{background:#fff;color:#1e3a8a}.results-upgrade-btn-primary:hover{background:#f0f4ff}@media(max-width:500px){.results-upgrade-nudge{flex-direction:column;align-items:flex-start;padding:.85rem 1.25rem 1.1rem;gap:.65rem}.results-upgrade-plans{width:100%}.results-upgrade-btn{flex:1;text-align:center}}
