:root{--color-primary:#4f46e5;--color-primary-hover:#4338ca;--color-primary-light:#eef2ff;--color-primary-subtle:#c7d2fe;--color-success:#10b981;--color-success-light:#d1fae5;--color-error:#ef4444;--color-error-light:#fee2e2;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-info:#3b82f6;--color-info-light:#dbeafe;--color-bg:#f9fafb;--color-surface:#fff;--color-surface-raised:#fff;--color-surface-overlay:#fffffff2;--color-border:#e5e7eb;--color-border-subtle:#f3f4f6;--color-text-primary:#111827;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-text-disabled:#d1d5db;--color-text-inverse:#fff;--color-focus-ring:#4f46e559;--color-correct:var(--color-success);--color-correct-bg:var(--color-success-light);--color-wrong:var(--color-error);--color-wrong-bg:var(--color-error-light);--font-sans:"Nunito", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", ui-monospace, monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #0000000f, 0 2px 4px #0000000a;--shadow-lg:0 10px 15px #00000014, 0 4px 6px #0000000a;--shadow-xl:0 20px 25px #00000014, 0 10px 10px #0000000a;--shadow-2xl:0 25px 50px #0000001f;--shadow-inner:inset 0 2px 4px #0000000f;--shadow-focus:0 0 0 3px var(--color-focus-ring);--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-bounce:cubic-bezier(.68, -.55, .27, 1.55);--duration-fast:.12s;--duration-normal:.2s;--duration-slow:.35s;--duration-slower:.5s;--z-base:0;--z-raised:10;--z-dropdown:200;--z-sticky:300;--z-overlay:400;--z-modal:500;--z-toast:600;--z-tooltip:700;--sidebar-width:240px;--bottom-nav-height:64px;--content-max-width:860px}[data-theme=dark]{--color-primary:#818cf8;--color-primary-hover:#a5b4fc;--color-primary-light:#1e1b4b;--color-primary-subtle:#312e81;--color-success:#34d399;--color-success-light:#064e3b;--color-error:#f87171;--color-error-light:#450a0a;--color-warning:#fcd34d;--color-warning-light:#451a03;--color-bg:#0f172a;--color-surface:#1e293b;--color-surface-raised:#263348;--color-surface-overlay:#1e293bf7;--color-border:#3b4f6b;--color-border-subtle:#243044;--color-text-primary:#f1f5f9;--color-text-secondary:#b0bfd4;--color-text-tertiary:#7a94b0;--color-text-disabled:#475569;--color-text-inverse:#0f172a;--color-focus-ring:#818cf866;--shadow-xs:0 1px 2px #0000004d;--shadow-sm:0 1px 3px #0006, 0 1px 2px #0003;--shadow-md:0 4px 6px #0000004d, 0 2px 4px #0003;--shadow-lg:0 10px 15px #0006, 0 4px 6px #0003;--shadow-xl:0 20px 25px #0006, 0 10px 10px #0003}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--duration-normal) var(--ease-in-out), color var(--duration-normal) var(--ease-in-out)}#root{flex-direction:column;min-height:100dvh;display:flex}h1,h2,h3,h4,h5,h6{line-height:var(--leading-tight);font-weight:var(--font-semibold);color:var(--color-text-primary)}a{color:var(--color-primary);transition:color var(--duration-fast) var(--ease-out);text-decoration:none}a:hover{color:var(--color-primary-hover)}p{line-height:var(--leading-relaxed)}code,kbd,samp,pre{font-family:var(--font-mono);font-size:.9em}:focus{outline:none}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}::selection{background-color:var(--color-primary-subtle);color:var(--color-text-primary)}.app-layout{min-height:100dvh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);padding:var(--space-6) var(--space-4);height:100dvh;z-index:var(--z-sticky);transition:background-color var(--duration-normal) var(--ease-in-out), border-color var(--duration-normal) var(--ease-in-out);flex-direction:column;flex-shrink:0;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-logo{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);padding:var(--space-2);display:flex}.sidebar-logo-icon{background:var(--color-primary);border-radius:var(--radius-lg);color:#fff;width:36px;height:36px;font-size:var(--text-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-text{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);line-height:1.2}.sidebar-logo-sub{font-size:var(--text-xs);color:var(--color-text-secondary)}.sidebar-section-label{font-size:var(--text-xs);font-weight:var(--font-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary);padding:0 var(--space-3);margin-bottom:var(--space-2)}.sidebar-nav{gap:var(--space-1);flex-direction:column;flex:1;display:flex}.sidebar-nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;text-align:left;width:100%;transition:background-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);background:0 0;border:none;display:flex}.sidebar-nav-item:hover{background:var(--color-border-subtle);color:var(--color-text-primary)}.sidebar-nav-item.active{background:var(--color-primary-light);color:var(--color-primary)}.sidebar-nav-item svg{flex-shrink:0;width:18px;height:18px}.sidebar-bottom{padding-top:var(--space-4);border-top:1px solid var(--color-border);gap:var(--space-1);flex-direction:column;margin-top:auto;display:flex}.main-content{flex-direction:column;flex:1;min-width:0;display:flex}.content-wrapper{padding:var(--space-8);max-width:var(--content-max-width);flex:1;width:100%;margin:0 auto}.bottom-nav{height:var(--bottom-nav-height);background:var(--color-surface);border-top:1px solid var(--color-border);z-index:var(--z-sticky);padding:0 var(--space-2);justify-content:space-around;align-items:center;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);color:var(--color-text-tertiary);font-size:10px;font-weight:var(--font-medium);cursor:pointer;transition:color var(--duration-fast) var(--ease-out);text-align:center;background:0 0;border:none;flex-direction:column;flex:1;display:flex}.bottom-nav-item svg{width:22px;height:22px}.bottom-nav-item.active{color:var(--color-primary)}@media (width<=768px){.sidebar{display:none}.bottom-nav{display:flex}.content-wrapper{padding:var(--space-4);padding-bottom:calc(var(--bottom-nav-height) + var(--space-4))}.subject-selector{display:flex}}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-spring);-webkit-user-select:none;user-select:none;white-space:nowrap;border:none;font-family:inherit;display:inline-flex}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border-subtle);box-shadow:var(--shadow-sm)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{background:var(--color-border-subtle);color:var(--color-text-primary)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{box-shadow:var(--shadow-md);background:#dc2626}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:background-color var(--duration-normal) var(--ease-in-out), border-color var(--duration-normal) var(--ease-in-out)}.card-sm{padding:var(--space-4);border-radius:var(--radius-lg)}.card-lg{padding:var(--space-8);border-radius:var(--radius-2xl)}.card-hover{cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out)}.card-hover:hover{box-shadow:var(--shadow-lg);border-color:var(--color-primary-subtle);transform:translateY(-2px)}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:1.5;display:inline-flex}.badge-default{background:var(--color-border-subtle);color:var(--color-text-secondary)}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-error{background:var(--color-error-light);color:var(--color-error)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge svg{flex-shrink:0;width:12px;height:12px}.progress-bar-container{background:var(--color-border);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:var(--color-primary);height:100%;transition:width var(--duration-slow) var(--ease-out)}.progress-bar-fill.success{background:var(--color-success)}.progress-bar-fill.error{background:var(--color-error)}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary)}.form-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text-primary);transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);font-family:inherit}.form-input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}.form-input::placeholder{color:var(--color-text-tertiary)}.toggle{cursor:pointer;flex-shrink:0;align-items:center;width:44px;height:24px;display:inline-flex;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--color-border);border-radius:var(--radius-full);width:100%;height:100%;transition:background-color var(--duration-fast) var(--ease-out);position:absolute}.toggle input:checked+.toggle-track{background:var(--color-primary)}.toggle-thumb{width:18px;height:18px;box-shadow:var(--shadow-sm);transition:transform var(--duration-fast) var(--ease-spring);background:#fff;border-radius:50%;position:absolute;left:3px}.toggle input:checked~.toggle-thumb{transform:translate(20px)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);padding:var(--space-4);animation:backdropIn var(--duration-normal) var(--ease-out) forwards;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-8);width:100%;max-width:480px;box-shadow:var(--shadow-2xl);animation:modalIn var(--duration-slow) var(--ease-spring) forwards}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.92)translateY(16px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-xl);font-weight:var(--font-semibold)}.toast-container{bottom:var(--space-6);z-index:var(--z-toast);gap:var(--space-2);pointer-events:none;flex-direction:column;align-items:center;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{background:var(--color-text-primary);color:var(--color-text-inverse);padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);box-shadow:var(--shadow-lg);pointer-events:auto;animation:toastIn var(--duration-slow) var(--ease-spring) forwards;white-space:nowrap}.toast.exiting{animation:toastOut var(--duration-normal) var(--ease-in) forwards}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-10px)scale(.95)}}.answer-option{align-items:flex-start;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;text-align:left;width:100%;font-family:inherit;font-size:var(--text-base);color:var(--color-text-primary);transition:border-color var(--duration-fast) var(--ease-out), background-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-out);animation:optionSlideIn var(--duration-slow) var(--ease-spring) both;display:flex}.answer-option:first-child{animation-delay:0s}.answer-option:nth-child(2){animation-delay:60ms}.answer-option:nth-child(3){animation-delay:.12s}.answer-option:nth-child(4){animation-delay:.18s}@keyframes optionSlideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.answer-option:hover:not([disabled]):not(.answered){border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.answer-option[disabled]{cursor:default}.answer-option.correct{border-color:var(--color-correct);background:var(--color-correct-bg)}.answer-option.selected-wrong{border-color:var(--color-wrong);background:var(--color-wrong-bg);animation:shake var(--duration-slow) var(--ease-in-out)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.answer-key{border-radius:var(--radius-md);background:var(--color-border-subtle);width:28px;height:28px;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);transition:background-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);flex-shrink:0;justify-content:center;align-items:center;display:flex}.answer-option:hover:not([disabled]):not(.answered) .answer-key{background:var(--color-primary);color:#fff}.answer-option.correct .answer-key{background:var(--color-correct);color:#fff}.answer-option.selected-wrong .answer-key{background:var(--color-wrong);color:#fff}.answer-option.answered-dim{opacity:.45}.answer-option svg{flex-shrink:0;width:18px;height:18px}.question-card{animation:questionIn var(--duration-slow) var(--ease-spring) forwards}@keyframes questionIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.question-number{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.question-text{font-size:var(--text-xl);font-weight:var(--font-medium);line-height:var(--leading-snug);color:var(--color-text-primary);margin-bottom:var(--space-6)}.countdown-timer{flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;position:relative}.countdown-label{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--font-bold);line-height:1;transition:color .3s;position:absolute}.countdown-timer.urgent .countdown-label{animation:pulse .8s var(--ease-in-out) infinite}.countdown-timer.critical .countdown-label{animation:pulse .4s var(--ease-in-out) infinite}.quiz-timeout-flash{animation:timeoutFlash .5s var(--ease-out) forwards}@keyframes timeoutFlash{0%{background-color:var(--color-surface);box-shadow:0 0 #ef444400}40%{background-color:#ef44440f;box-shadow:0 0 0 8px #ef444466,0 0 60px #ef444440}to{background-color:var(--color-surface);box-shadow:0 0 0 3px #ef444426}}.quiz-wrong-glow{animation:wrongGlow var(--duration-slower) var(--ease-out) forwards}@keyframes wrongGlow{0%{box-shadow:0 0 #ef444400}30%{box-shadow:0 0 0 6px #ef444459,0 0 40px #ef444433}to{box-shadow:0 0 0 3px #ef444426}}.answer-correct-hint{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-wrong-bg);border-left:3px solid var(--color-wrong);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);animation:feedbackIn var(--duration-slow) var(--ease-spring) forwards}@keyframes feedbackIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.streak-dots{gap:var(--space-1);align-items:center;display:flex}.streak-dot{background:var(--color-border);width:8px;height:8px;transition:background-color var(--duration-fast) var(--ease-spring), transform var(--duration-fast) var(--ease-spring);border-radius:50%}.streak-dot.filled{background:var(--color-success);transform:scale(1.15)}.streak-dot.recent{animation:dotPop var(--duration-slow) var(--ease-spring)}@keyframes dotPop{0%{transform:scale(1)}50%{transform:scale(1.6)}to{transform:scale(1.15)}}.circular-progress{justify-content:center;align-items:center;display:inline-flex;position:relative}.circular-progress svg{transform:rotate(-90deg)}.circular-progress-track{fill:none;stroke:var(--color-border)}.circular-progress-fill{fill:none;stroke:var(--color-primary);stroke-linecap:round;transition:stroke-dashoffset var(--duration-slower) var(--ease-out)}.circular-progress-text{text-align:center;font-weight:var(--font-bold);line-height:1;position:absolute}.mode-card{gap:var(--space-3);padding:var(--space-6);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-2xl);cursor:pointer;text-align:left;transition:border-color var(--duration-fast) var(--ease-out), background-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-out);flex-direction:column;width:100%;font-family:inherit;display:flex}.mode-card:hover{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.mode-card.selected{border-color:var(--color-primary);background:var(--color-primary-light)}.mode-card-icon{border-radius:var(--radius-xl);background:var(--color-primary-light);width:48px;height:48px;color:var(--color-primary);transition:background-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);justify-content:center;align-items:center;display:flex}.mode-card-icon svg{flex-shrink:0;width:24px;height:24px}.mode-card:hover .mode-card-icon,.mode-card.selected .mode-card-icon{background:var(--color-primary);color:#fff}.mode-card-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary)}.mode-card-desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.heatmap{gap:var(--space-1);flex-direction:column;display:flex}.heatmap-row{gap:var(--space-1);display:flex}.heatmap-cell{border-radius:var(--radius-sm);background:var(--color-border-subtle);width:14px;height:14px;transition:background-color var(--duration-fast) var(--ease-out);cursor:default}.heatmap-cell[data-level="1"]{background:#c7d2fe}.heatmap-cell[data-level="2"]{background:#818cf8}.heatmap-cell[data-level="3"]{background:#4f46e5}.heatmap-cell[data-level="4"]{background:#3730a3}[data-theme=dark] .heatmap-cell[data-level="1"]{background:#312e81}[data-theme=dark] .heatmap-cell[data-level="2"]{background:#4338ca}[data-theme=dark] .heatmap-cell[data-level="3"]{background:#818cf8}[data-theme=dark] .heatmap-cell[data-level="4"]{background:#a5b4fc}.table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}thead tr{background:var(--color-border-subtle)}th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-semibold);color:var(--color-text-secondary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}td{padding:var(--space-3) var(--space-4);color:var(--color-text-primary);border-top:1px solid var(--color-border)}tbody tr{transition:background-color var(--duration-fast) var(--ease-out)}tbody tr:hover{background:var(--color-border-subtle)}.timer-display{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);min-width:48px}.timer-display.urgent{color:var(--color-error);animation:pulse 1s var(--ease-in-out) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.confetti-container{pointer-events:none;z-index:var(--z-toast);position:fixed;inset:0;overflow:hidden}.confetti-piece{width:10px;height:10px;animation:linear forwards confettiFall;position:absolute}@keyframes confettiFall{0%{opacity:1;transform:translateY(-20px)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.shortcut-row{padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.shortcut-row:last-child{border-bottom:none}.shortcut-desc{font-size:var(--text-sm);color:var(--color-text-secondary)}.shortcut-keys{gap:var(--space-1);display:flex}kbd{padding:2px var(--space-2);background:var(--color-border-subtle);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-secondary);border-bottom-width:2px;justify-content:center;align-items:center;min-width:24px;display:inline-flex}.subject-selector{gap:var(--space-2);padding-bottom:var(--space-2);margin-bottom:var(--space-6);scrollbar-width:none;display:none;overflow-x:auto}.subject-selector::-webkit-scrollbar{display:none}.subject-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);white-space:nowrap;cursor:pointer;border:2px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);transition:border-color var(--duration-fast) var(--ease-out), background-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-spring);flex-shrink:0;font-family:inherit;display:flex}.subject-tab svg{flex-shrink:0;width:15px;height:15px}.subject-tab:hover{border-color:var(--color-primary);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}.home-header{margin-bottom:var(--space-6)}.home-title{font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-2)}.home-subtitle{font-size:var(--text-base);color:var(--color-text-secondary)}.mode-grid{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.stats-bar{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=640px){.stats-bar{grid-template-columns:repeat(2,1fr)}.mode-grid{grid-template-columns:1fr 1fr}}.stat-card{gap:var(--space-2);flex-direction:column;display:flex}.stat-card-icon{border-radius:var(--radius-lg);width:40px;height:40px;margin-bottom:var(--space-2);justify-content:center;align-items:center;display:flex}.stat-card-value{font-size:var(--text-3xl);font-weight:var(--font-bold);line-height:1}.stat-card-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.stat-card-delta{font-size:var(--text-xs);font-weight:var(--font-medium);align-items:center;gap:2px;display:inline-flex}.stat-card-delta.up{color:var(--color-success)}.stat-card-delta.down{color:var(--color-error)}.empty-state{text-align:center;padding:var(--space-16) var(--space-8);justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.empty-state-icon{margin-bottom:var(--space-2);font-size:56px;line-height:1}.empty-state-title{font-size:var(--text-xl);font-weight:var(--font-semibold)}.empty-state-desc{font-size:var(--text-base);color:var(--color-text-secondary);max-width:360px}.settings-section{margin-bottom:var(--space-8)}.settings-section-title{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-3)}.settings-row{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-subtle);display:flex}.settings-row:last-child{border-bottom:none}.settings-row-left{flex:1;min-width:0}.settings-row-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary)}.settings-row-desc{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:2px}.quiz-layout{gap:var(--space-6);flex-direction:column;width:100%;max-width:640px;margin:0 auto;display:flex}.quiz-header{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.quiz-controls{gap:var(--space-3);margin-top:var(--space-6);display:flex}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.flex-1{flex:1}.w-full{width:100%}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}
