:root{--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-primary-light: #eef2ff;--color-primary-soft: rgba(79, 70, 229, .08);--color-success: #059669;--color-success-light: #ecfdf5;--color-danger: #dc2626;--color-danger-light: #fef2f2;--color-warning: #d97706;--color-warning-light: #fffbeb;--color-bg: #f8fafc;--color-surface: #ffffff;--color-text: #0f172a;--color-text-secondary: #64748b;--color-text-tertiary: #94a3b8;--color-border: #e2e8f0;--gradient-header: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #0f172a 100%);--gradient-primary: linear-gradient(135deg, #4f46e5, #7c3aed);--gradient-score: linear-gradient(135deg, #4f46e5 0%, #06b6d4 100%);--radius: 10px;--radius-lg: 16px;--radius-xl: 20px;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 24px rgba(0,0,0,.08), 0 4px 8px rgba(0,0,0,.04);--transition: .2s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--gradient-header);color:#fff;padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;position:relative;z-index:10;box-shadow:0 2px 12px #00000026}.header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.header h1{font-size:17px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:10px}.header-badge{background:var(--gradient-primary);padding:2px 10px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.header-right{display:flex;align-items:center;gap:20px;font-size:13px;color:#ffffffb3}.header-progress{font-size:13px;font-weight:500;color:#ffffffd9}.header-timer{font-variant-numeric:tabular-nums;font-weight:700;font-size:15px;background:#ffffff1a;padding:4px 14px;border-radius:8px;letter-spacing:.02em}.header-timer.warning{background:#fbbf2433;color:#fbbf24}.header-timer.danger{background:#f8717133;color:#f87171;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.header-submit-btn{background:#16a34a;color:#fff;border:none;border-radius:8px;padding:8px 20px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;transition:all var(--transition);box-shadow:0 2px 8px #16a34a59}.header-submit-btn:hover{background:#15803d;box-shadow:0 4px 14px #16a34a73;transform:translateY(-1px)}.main-content{flex:1;display:flex;flex-direction:column}.home-page{max-width:960px;margin:0 auto;padding:48px 28px;width:100%}.home-title{font-size:36px;font-weight:800;margin-bottom:6px;letter-spacing:-.03em;background:var(--gradient-score);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-subtitle{font-size:16px;color:var(--color-text-secondary);margin-bottom:36px}.home-stats{display:flex;gap:10px;margin-bottom:36px;flex-wrap:wrap}.stat-chip{background:var(--color-surface);border:1px solid var(--color-border);border-radius:100px;padding:7px 16px;font-size:13px;color:var(--color-text-secondary);box-shadow:var(--shadow-xs)}.stat-chip strong{color:var(--color-primary);font-weight:700}.mode-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px}.mode-card{background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius);padding:16px 20px;cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden;animation:slideDown .3s ease both}.mode-card:nth-child(2){animation-delay:.08s}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition)}.mode-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.mode-card:hover:before{opacity:1}.mode-card.active{border-color:var(--color-primary);background:var(--color-primary-light)}.mode-card.active:before{opacity:1}.mode-card h3{font-size:15px;font-weight:700;margin-bottom:4px;letter-spacing:-.01em}.mode-card p{font-size:13px;color:var(--color-text-secondary);line-height:1.4}.selector-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px;box-shadow:var(--shadow);animation:slideDown .25s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.selector-panel h4{font-size:12px;font-weight:700;margin-bottom:14px;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em}.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.topic-btn{background:linear-gradient(135deg,#eef2ff,#f0f4ff);border:1px solid rgba(79,70,229,.15);border-left:4px solid var(--color-primary);border-radius:var(--radius);padding:16px 18px;text-align:left;cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;color:var(--color-text);transition:all var(--transition);box-shadow:var(--shadow-xs)}.topic-btn:hover{border-color:#4f46e54d;border-left-color:#7c3aed;background:linear-gradient(135deg,#e0e7ff,#ede9fe);transform:translateY(-2px);box-shadow:0 4px 12px #4f46e526}.topic-btn.active{border-color:var(--color-primary);border-left-color:var(--color-primary);background:var(--gradient-primary);color:#fff;box-shadow:0 6px 16px #4f46e559}.topic-btn .question-count{display:block;font-size:12px;font-weight:500;color:var(--color-primary);margin-top:4px;opacity:.7}.topic-btn.active .question-count{color:#fffc;opacity:1}.count-options{display:flex;gap:10px;flex-wrap:wrap}.count-btn{background:linear-gradient(135deg,#eef2ff,#f0f4ff);border:1px solid rgba(79,70,229,.15);border-left:4px solid var(--color-primary);border-radius:var(--radius);padding:12px 24px;font-size:16px;font-weight:700;font-family:inherit;cursor:pointer;transition:all var(--transition);color:var(--color-text);min-width:64px;text-align:center;box-shadow:var(--shadow-xs)}.count-btn:hover{border-color:#4f46e54d;border-left-color:#7c3aed;background:linear-gradient(135deg,#e0e7ff,#ede9fe);transform:translateY(-2px);box-shadow:0 4px 12px #4f46e526}.count-btn.active{border-color:var(--color-primary);border-left-color:var(--color-primary);background:var(--gradient-primary);color:#fff;box-shadow:0 6px 16px #4f46e559}.count-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.start-btn{background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius);padding:14px 36px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:all var(--transition);margin-top:12px;box-shadow:0 4px 14px #4f46e54d}.start-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #4f46e566}.start-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.test-layout{display:flex;flex:1;min-height:0}.test-sidebar{position:relative;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-shrink:0;transition:width .25s cubic-bezier(.4,0,.2,1)}.sidebar-expanded .test-sidebar{width:220px}.sidebar-collapsed .test-sidebar{width:0}.sidebar-content{width:220px;padding:20px 16px;overflow-y:auto;display:flex;flex-direction:column;flex:1;min-height:0}.sidebar-collapsed .sidebar-content{opacity:0;pointer-events:none}.sidebar-expanded .sidebar-content{opacity:1;transition:opacity .15s ease .1s}.sidebar-toggle{position:absolute;top:12px;right:-38px;width:38px;height:38px;border-radius:0 8px 8px 0;border:1px solid var(--color-border);border-left:none;background:var(--color-surface);color:var(--color-text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;box-shadow:2px 1px 4px #0000000f;transition:all .15s ease}.sidebar-toggle:hover{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary)}.test-sidebar h4{font-size:11px;font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.palette-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.palette-item{width:100%;aspect-ratio:1;border:2px solid var(--color-border);border-radius:8px;font-size:12px;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s ease;background:var(--color-surface);color:var(--color-text-secondary);position:relative}.palette-item:hover{border-color:var(--color-primary);transform:scale(1.05)}.palette-item.current{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #4f46e559}.palette-item.answered{background:var(--color-primary-light);border-color:#4f46e566;color:var(--color-primary)}.palette-item.flagged:after{content:"";position:absolute;top:2px;right:2px;width:7px;height:7px;background:var(--color-warning);border-radius:50%;box-shadow:0 0 0 1.5px #fff}.palette-item.correct{background:var(--color-success-light);border-color:var(--color-success);color:var(--color-success)}.palette-item.incorrect{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}.sidebar-legend{margin-top:16px;display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--color-text-tertiary)}.legend-item{display:flex;align-items:center;gap:8px}.legend-dot{width:10px;height:10px;border-radius:4px;flex-shrink:0}.sidebar-submit-section{margin-top:auto;padding-top:16px;border-top:1px solid var(--color-border)}.sidebar-submit-btn{width:100%;background:#16a34a;color:#fff;border:none;border-radius:var(--radius);padding:11px 0;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;transition:all var(--transition);box-shadow:0 2px 8px #16a34a4d}.sidebar-submit-btn:hover{background:#15803d;box-shadow:0 4px 14px #16a34a66}.test-main{flex:1;display:flex;flex-direction:column;padding:28px 32px;overflow-y:auto;align-items:center;justify-content:flex-start}.question-header{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:800px;margin-bottom:20px}.question-label{display:flex;align-items:center;gap:12px}.question-number{font-size:14px;font-weight:700;color:var(--color-text)}.question-id-badge{font-size:11px;font-weight:600;color:var(--color-text-tertiary);background:var(--color-bg);border:1px solid var(--color-border);padding:2px 10px;border-radius:100px;font-family:SF Mono,Fira Code,monospace;letter-spacing:.03em}.question-type-badge{font-size:11px;font-weight:600;padding:2px 10px;border-radius:100px;letter-spacing:.02em}.question-type-badge.mc{background:var(--color-primary-light);color:var(--color-primary)}.question-type-badge.free{background:var(--color-warning-light);color:var(--color-warning)}.question-topic-badge{font-size:11px;font-weight:500;color:var(--color-text-tertiary);background:var(--color-bg);border:1px solid var(--color-border);padding:2px 10px;border-radius:100px;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.question-header-right{display:flex;align-items:center;gap:8px}.flag-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius);padding:7px 14px;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition)}.flag-btn:hover{border-color:var(--color-warning);color:var(--color-warning)}.flag-btn.flagged{border-color:var(--color-warning);background:var(--color-warning-light);color:var(--color-warning);font-weight:600}.progress-bar-wrapper{width:100%;max-width:800px;margin-bottom:20px}.progress-bar{height:4px;background:var(--color-border);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--gradient-primary);border-radius:2px;transition:width .3s ease}.progress-text{display:flex;justify-content:space-between;font-size:12px;color:var(--color-text-tertiary);margin-top:6px}.test-card{width:100%;max-width:800px;background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:20px;animation:slideIn .2s ease}.test-card-body{position:relative;padding:24px;display:flex;align-items:flex-start;justify-content:center;height:50vh;overflow-y:auto}.test-card-body img{max-width:100%;max-height:100%;height:auto;object-fit:contain}.card-flag-btn{position:absolute;top:12px;right:12px;z-index:2;padding:5px 14px;font-size:12px;font-weight:600;border-radius:100px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-tertiary);cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow-xs)}.card-flag-btn:hover{border-color:var(--color-warning);color:var(--color-warning)}.card-flag-btn.flagged{background:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-warning)}.card-status-badge{position:absolute;top:12px;right:12px;z-index:2;padding:4px 14px;font-size:12px;font-weight:700;border-radius:100px;box-shadow:var(--shadow-xs)}.card-status-badge.correct{background:var(--color-success-light);color:var(--color-success)}.card-status-badge.incorrect{background:var(--color-danger-light);color:var(--color-danger)}.card-status-badge.skipped{background:var(--color-bg);color:var(--color-text-tertiary);border:1px solid var(--color-border)}.test-card-footer{padding:20px 24px;border-top:1px solid var(--color-border);background:var(--color-bg)}.mc-options{display:flex;justify-content:space-evenly;width:100%}.mc-option{width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;font-size:22px;font-weight:700;font-family:inherit;display:flex;align-items:center;justify-content:center;transition:all .15s ease;color:#fff}.mc-a{background:#ee352e}.mc-b{background:#ff6319}.mc-c{background:#0039a6}.mc-d{background:#6e3a90}.mc-option:hover{transform:scale(1.1);box-shadow:0 4px 16px #0003}.mc-option.selected{transform:scale(1.1);box-shadow:0 0 0 3px #fff,0 0 0 6px currentColor,0 4px 20px #00000040}.mc-a.selected{box-shadow:0 0 0 3px #fff,0 0 0 6px #ee352e,0 4px 20px #ee352e66}.mc-b.selected{box-shadow:0 0 0 3px #fff,0 0 0 6px #ff6319,0 4px 20px #ff631966}.mc-c.selected{box-shadow:0 0 0 3px #fff,0 0 0 6px #0039a6,0 4px 20px #0039a666}.mc-d.selected{box-shadow:0 0 0 3px #fff,0 0 0 6px #6e3a90,0 4px 20px #6e3a9066}.mc-option.review-correct{box-shadow:0 0 0 3px #fff,0 0 0 6px #16a34a,0 4px 16px #16a34a66;transform:scale(1.1)}.mc-option.review-incorrect{box-shadow:0 0 0 3px #fff,0 0 0 6px #dc2626,0 4px 16px #dc262666;transform:scale(1.1)}.free-response-input{width:100%;padding:16px 20px;border:2px solid var(--color-border);border-radius:var(--radius);font-size:18px;font-family:inherit;outline:none;transition:all var(--transition);background:var(--color-surface)}.free-response-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}.free-response-label{font-size:13px;color:var(--color-text-secondary);margin-bottom:8px;font-weight:500}.test-nav{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:800px;gap:12px}.nav-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:11px 24px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition);color:var(--color-text)}.nav-btn:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow)}.nav-btn:disabled{opacity:.3;cursor:not-allowed;transform:none;box-shadow:none}.nav-center-info{font-size:13px;color:var(--color-text-tertiary);font-weight:500}.submit-btn{background:var(--color-success);color:#fff;border:none;border-radius:var(--radius);padding:11px 28px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 12px #0596694d}.submit-btn:hover{background:#047857;transform:translateY(-1px);box-shadow:0 6px 16px #05966959}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:var(--radius-xl);padding:36px;max-width:460px;width:90%;box-shadow:var(--shadow-lg);animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h3{font-size:20px;font-weight:700;margin-bottom:12px}.modal p{font-size:14px;color:var(--color-text-secondary);margin-bottom:24px;line-height:1.7}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.modal-cancel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:10px 22px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;color:var(--color-text);transition:all var(--transition)}.modal-cancel:hover{background:var(--color-bg)}.modal-confirm{background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius);padding:10px 22px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 12px #4f46e54d}.modal-confirm:hover{transform:translateY(-1px);box-shadow:0 6px 16px #4f46e566}.modal-confirm-danger{background:var(--color-danger)}.modal-confirm-danger:hover{box-shadow:0 6px 16px #dc262666}.results-page{max-width:960px;margin:0 auto;padding:36px 28px;width:100%}.score-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:40px 36px;margin-bottom:24px;box-shadow:var(--shadow-md);text-align:center;position:relative;overflow:hidden}.score-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-score)}.score-card h2{font-size:16px;font-weight:600;color:var(--color-text-secondary);margin-bottom:20px;text-transform:uppercase;letter-spacing:.06em}.score-big{font-size:64px;font-weight:800;background:var(--gradient-score);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:8px}.score-subtitle{font-size:16px;color:var(--color-text-secondary)}.score-details{display:flex;justify-content:center;gap:40px;margin-top:28px;flex-wrap:wrap}.score-detail{text-align:center}.score-detail-value{font-size:28px;font-weight:800}.score-detail-value.correct{color:var(--color-success)}.score-detail-value.incorrect{color:var(--color-danger)}.score-detail-value.skipped{color:var(--color-text-tertiary)}.score-detail-label{font-size:12px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.results-actions{display:flex;gap:12px;justify-content:center;margin-top:28px}.review-slide-section{margin-top:32px}.review-slide-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}.review-slide-title{font-size:18px;font-weight:700}.review-filters{display:flex;gap:6px;flex-wrap:wrap}.filter-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:100px;padding:6px 16px;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition)}.filter-btn:hover{border-color:var(--color-primary)}.filter-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 2px 8px #4f46e540}.review-slide{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.review-slide-body{position:relative;padding:24px;display:flex;align-items:flex-start;justify-content:center;height:50vh;overflow-y:auto}.review-slide-body img{max-width:100%;max-height:100%;height:auto;object-fit:contain}.review-answer-bar{padding:20px 24px;border-top:1px solid var(--color-border);background:var(--color-bg)}.review-answer-row{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:12px}.review-answer-row:last-child{margin-bottom:0}.review-answer-item{font-size:14px}.review-answer-item .review-label{color:var(--color-text-tertiary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:2px}.review-answer-item .review-value{font-weight:700;font-size:15px}.review-answer-item .review-value.correct-text{color:var(--color-success)}.review-answer-item .review-value.incorrect-text{color:var(--color-danger)}.review-answer-item .review-value.skipped-text{color:var(--color-text-tertiary);font-style:italic;font-weight:500}.review-nav{display:flex;align-items:center;justify-content:space-between;margin-top:16px;gap:12px}.review-empty{text-align:center;color:var(--color-text-tertiary);padding:48px 24px;font-size:15px}.loading{display:flex;align-items:center;justify-content:center;flex:1;font-size:15px;color:var(--color-text-secondary);padding:60px 24px}.spinner{width:22px;height:22px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;margin-right:12px}@keyframes spin{to{transform:rotate(360deg)}}.img-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:48px 20px;color:var(--color-text-secondary);font-size:14px}@media(max-width:768px){.mode-cards{grid-template-columns:1fr}.score-details{gap:20px}.home-title{font-size:28px}.test-main{padding:20px 16px}.review-answer-row{flex-direction:column;gap:8px}}.breadcrumb{font-size:13px;color:var(--color-text-tertiary);margin-bottom:10px}.breadcrumb-link{color:var(--color-primary);cursor:pointer;background:none;border:none;font-family:inherit;font-size:inherit;padding:0;font-weight:500}.breadcrumb-link:hover{text-decoration:underline}.available-text{font-size:13px;color:var(--color-text-tertiary);margin-bottom:12px}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--color-text-secondary);text-decoration:none;font-size:14px;font-weight:500;margin-bottom:20px;cursor:pointer;background:none;border:none;font-family:inherit;padding:0;transition:color var(--transition)}.back-link:hover{color:var(--color-primary)}.debug-page{max-width:960px;margin:0 auto;padding:48px 28px;width:100%}.debug-actions-bar{margin-bottom:32px}.debug-topic-group{margin-bottom:36px}.debug-topic-heading{font-size:22px;font-weight:800;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--color-border);letter-spacing:-.02em}.debug-subtopic-group{margin-bottom:24px}.debug-subtopic-heading{font-size:14px;font-weight:700;color:var(--color-text-secondary);margin-bottom:12px;padding-left:4px}.debug-questions{display:flex;flex-direction:column;gap:20px}.debug-question-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:box-shadow var(--transition)}.debug-question-card:hover{box-shadow:var(--shadow-md)}.debug-question-header{display:flex;align-items:center;gap:10px;padding:14px 20px;background:var(--color-bg);border-bottom:1px solid var(--color-border);flex-wrap:wrap}.debug-question-image{padding:20px;display:flex;justify-content:center;border-bottom:1px solid var(--color-border)}.debug-question-image img{max-width:100%;height:auto}.debug-answer-input{padding:20px}.app-nav{background:var(--gradient-header);color:#fff;padding:0 36px;height:64px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;position:relative;z-index:10;box-shadow:0 2px 12px #00000026}.app-nav-left{display:flex;align-items:center;gap:6px}.app-nav-brand{font-size:20px;font-weight:800;margin-right:28px;letter-spacing:-.02em}.app-nav-link{color:#fff9;text-decoration:none;font-size:15px;font-weight:600;padding:8px 18px;border-radius:8px;transition:all var(--transition)}.app-nav-link:hover{color:#ffffffe6;background:#ffffff14}.app-nav-link.active{color:#fff;background:#ffffff26}.app-nav-right{display:flex;align-items:center;gap:12px}.app-nav-avatar{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.2)}.app-nav-name{font-size:13px;color:#fffc;font-weight:500}.app-nav-signout{background:#ffffff1a;color:#fffc;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition)}.app-nav-signout:hover{background:#fff3;color:#fff}.landing-page{min-height:100vh;display:flex;flex-direction:column}.landing-hero{background:var(--gradient-header);color:#fff;text-align:center;padding:100px 28px 80px;position:relative;overflow:hidden}.landing-hero:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:60px;background:var(--color-bg);clip-path:ellipse(55% 100% at 50% 100%)}.landing-hero-title{font-size:56px;font-weight:900;letter-spacing:-.04em;margin-bottom:16px;line-height:1.1}.landing-hero-subtitle{font-size:18px;color:#ffffffbf;max-width:560px;margin:0 auto 40px;line-height:1.6}.landing-cta-btn{display:inline-flex;align-items:center;gap:12px;background:#fff;color:var(--color-text);border:none;border-radius:12px;padding:16px 36px;font-size:16px;font-weight:700;font-family:inherit;cursor:pointer;transition:all var(--transition);box-shadow:0 8px 24px #0003}.landing-cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #00000040}.landing-google-icon{flex-shrink:0}.landing-features{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1060px;margin:-20px auto 0;padding:0 28px 60px;position:relative;z-index:1}.landing-feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px 24px;text-align:center;box-shadow:var(--shadow-md);transition:all var(--transition);position:relative;overflow:hidden}.landing-feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}.landing-feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.landing-feature-icon{font-size:32px;font-weight:900;background:var(--gradient-score);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.landing-feature-card h3{font-size:16px;font-weight:700;margin-bottom:8px;letter-spacing:-.01em}.landing-feature-card p{font-size:13px;color:var(--color-text-secondary);line-height:1.5}.landing-footer{text-align:center;padding:40px 28px;color:var(--color-text-tertiary);font-size:14px}.dashboard-page{max-width:1100px;margin:0 auto;padding:48px 28px;width:100%}.dashboard-empty{text-align:center;padding:60px 24px;color:var(--color-text-secondary);font-size:15px}.dashboard-empty .start-btn{margin-top:20px}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}.dashboard-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow)}.dashboard-stat-value{font-size:28px;font-weight:800;color:var(--color-primary)}.dashboard-stat-label{font-size:12px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.dashboard-charts{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:32px}.chart-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}.chart-title{font-size:14px;font-weight:700;color:var(--color-text);margin-bottom:16px}.chart-empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--color-text-tertiary);font-size:14px}.dashboard-actions{display:flex;gap:12px}.topic-drilldown{margin-top:24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}.topic-drilldown-header{margin-bottom:16px}.topic-drilldown-title{font-size:18px;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}.topic-drilldown-subtitle{font-size:13px;color:var(--color-text-secondary)}.topic-drilldown-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}.topic-drilldown-tab{display:flex;align-items:center;gap:8px;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius);padding:10px 18px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;color:var(--color-text);transition:all var(--transition)}.topic-drilldown-tab:hover{border-color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-1px)}.topic-drilldown-tab.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #4f46e54d}.topic-drilldown-tab-pct{font-size:12px;font-weight:700;opacity:.7;background:#0000000f;padding:2px 8px;border-radius:100px}.topic-drilldown-tab.active .topic-drilldown-tab-pct{background:#fff3;opacity:1}.topic-drilldown-content{margin-top:20px;animation:slideDown .25s ease}.topic-drilldown-stats{display:flex;gap:24px;margin-bottom:20px;padding:16px 20px;background:var(--color-bg);border-radius:var(--radius)}.topic-drilldown-stat{display:flex;flex-direction:column}.topic-drilldown-stat-value{font-size:22px;font-weight:800;color:var(--color-primary)}.topic-drilldown-stat-label{font-size:11px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em}.subject-tabs{display:flex;gap:8px;margin-bottom:28px}.subject-tab{padding:10px 24px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;color:var(--color-text);transition:all var(--transition)}.subject-tab:hover{border-color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-1px)}.subject-tab.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #4f46e54d}.subject-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}.subject-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:16px 20px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;font-family:inherit;transition:all var(--transition);position:relative;overflow:hidden}.subject-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition)}.subject-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.subject-card:hover:before{opacity:1}.subject-card.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 6px 20px #4f46e559}.subject-card.active:before{opacity:0}.subject-card-label{font-size:16px;font-weight:700;letter-spacing:-.01em}.subject-card-count{font-size:12px;font-weight:500;opacity:.7}@media(max-width:480px){.subject-cards{grid-template-columns:1fr}}.history-page{max-width:960px;margin:0 auto;padding:48px 28px;width:100%}.history-list{display:flex;flex-direction:column;gap:12px}.history-row{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-xs)}.history-row:hover{border-color:var(--color-primary);box-shadow:var(--shadow);transform:translateY(-1px)}.history-row-left{display:flex;flex-direction:column;gap:4px}.history-row-title{font-size:15px;font-weight:600}.history-row-meta{display:flex;gap:12px;font-size:12px;color:var(--color-text-tertiary)}.history-row-right{display:flex;align-items:center;gap:20px}.history-score{font-size:20px;font-weight:800}.history-score.good{color:var(--color-success)}.history-score.ok{color:var(--color-warning)}.history-score.bad{color:var(--color-danger)}.history-score-sub{font-size:12px;color:var(--color-text-tertiary);font-weight:500;text-align:right}.history-subject-badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 10px;border-radius:100px;margin-right:8px;letter-spacing:.02em;text-transform:uppercase;vertical-align:middle}.history-subject-badge.math{background:var(--color-primary-light);color:var(--color-primary)}.history-subject-badge.rw{background:#fef3c7;color:#b45309}.history-filter-tabs{display:flex;gap:8px;margin-bottom:12px}.history-filter-tab{padding:6px 16px;font-size:13px;font-weight:600;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:6px}.history-filter-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.history-filter-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.history-filter-count{font-size:11px;font-weight:700;opacity:.7}.history-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:4px}.history-select-all{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.history-select-all input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.history-delete-btn{padding:6px 16px;font-size:13px;font-weight:600;border:1px solid #fecaca;border-radius:var(--radius);background:#fff;color:#dc2626;cursor:pointer;transition:all var(--transition)}.history-delete-btn:hover{background:#fef2f2;border-color:#fca5a5}.history-delete-btn:disabled{opacity:.5;cursor:not-allowed}.history-row-checkbox{display:flex;align-items:center;margin-right:14px;flex-shrink:0}.history-row-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.history-row.selected{border-color:var(--color-primary);background:var(--color-primary-light)}@media(max-width:768px){.landing-hero-title{font-size:36px}.landing-features,.dashboard-stats{grid-template-columns:1fr 1fr}.dashboard-charts{grid-template-columns:1fr}.app-nav-name{display:none}.history-row{flex-direction:column;align-items:flex-start;gap:12px}}@media(max-width:480px){.landing-features,.dashboard-stats{grid-template-columns:1fr}}
