@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap";
:root{--primary-50:#f3e8ff;--primary-100:#e9d5ff;--primary-200:#d8b4fe;--primary-300:#c084fc;--primary-400:#a855f7;--primary-500:#8b5cf6;--primary-600:#7c3aed;--primary-700:#6d28d9;--primary-800:#5b21b6;--primary-900:#4c1d95;--accent-50:#fffbeb;--accent-100:#fef3c7;--accent-200:#fde68a;--accent-300:#fcd34d;--accent-400:#fbbf24;--accent-500:#f59e0b;--accent-600:#d97706;--success-400:#4ade80;--success-500:#22c55e;--success-600:#16a34a;--error-400:#f87171;--error-500:#ef4444;--error-600:#dc2626;--gray-50:#fafafa;--gray-100:#f4f4f5;--gray-200:#e4e4e7;--gray-300:#d4d4d8;--gray-400:#a1a1aa;--gray-500:#71717a;--gray-600:#52525b;--gray-700:#3f3f46;--gray-800:#27272a;--gray-850:#1e1e22;--gray-900:#18181b;--gray-950:#0d0d10;--bg-primary:#0a0a12;--bg-secondary:#12121c;--bg-card:#1e1e2d99;--bg-card-hover:#28283cb3;--bg-glass:#ffffff0a;--bg-glass-strong:#ffffff14;--border-subtle:#ffffff0f;--border-default:#ffffff1a;--border-strong:#ffffff26;--border-glow:#8b5cf666;--text-primary:#f4f4f5;--text-secondary:#a1a1aa;--text-tertiary:#71717a;--text-inverse:#18181b;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display:"Space Grotesk", "Inter", sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #8b5cf64d;--shadow-glow-accent:0 0 20px #fbbf244d;--shadow-glow-success:0 0 20px #22c55e4d;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--z-nav:100;--z-modal:200;--z-toast:300}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100dvh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 60% at 20% 10%,#8b5cf61f 0%,#0000 60%),radial-gradient(60% 40% at 80% 90%,#fbbf240f 0%,#0000 50%);position:fixed;inset:0}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}img{max-width:100%;display:block}ul,ol{list-style:none}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--space-lg);background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-card{width:100%;max-width:420px;max-height:80vh;animation:.3s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:700;line-height:1.2}h1{font-size:clamp(1.75rem,4vw,2.5rem)}h2{font-size:clamp(1.375rem,3vw,1.875rem)}h3{font-size:clamp(1.125rem,2.5vw,1.5rem)}h4{font-size:1.125rem}h5{font-size:1rem}.text-gradient{background:linear-gradient(135deg, var(--primary-300), var(--accent-400));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.container{width:100%;max-width:1200px;padding:0 var(--space-md);margin:0 auto}.page-content{z-index:1;min-height:100dvh;padding-bottom:80px;position:relative}@media (min-width:1024px){.page-content{padding-bottom:0;padding-left:240px}}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-default)}.card-glow{box-shadow:var(--shadow-glow);border-color:var(--border-glow)}.card-glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);transition:all var(--transition-base);padding:12px 24px;font-size:.9375rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg, var(--primary-600), var(--primary-700));color:#fff;box-shadow:var(--shadow-sm), 0 0 0 0 #8b5cf600}.btn-primary:hover{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));box-shadow:var(--shadow-md), var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-glass-strong);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{border-color:var(--border-strong);background:#ffffff1f}.btn-accent{background:linear-gradient(135deg, var(--accent-500), var(--accent-600));color:var(--text-inverse)}.btn-accent:hover{background:linear-gradient(135deg, var(--accent-400), var(--accent-500));box-shadow:var(--shadow-md), var(--shadow-glow-accent);transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-glass);color:var(--text-primary)}.btn-sm{padding:8px 16px;font-size:.8125rem}.btn-lg{padding:16px 32px;font-size:1.0625rem}.btn-full{width:100%}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;padding:0}.input-group{gap:var(--space-sm);flex-direction:column;display:flex}.input-group label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.input{background:var(--bg-glass);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:12px 16px;font-size:1rem}.input:focus{border-color:var(--primary-500);background:var(--bg-glass-strong);box-shadow:0 0 0 3px #8b5cf626}.input::placeholder{color:var(--text-tertiary)}.badge{border-radius:var(--radius-full);letter-spacing:.02em;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-primary{color:var(--primary-300);background:#8b5cf626;border:1px solid #8b5cf633}.badge-accent{color:var(--accent-300);background:#fbbf2426;border:1px solid #fbbf2433}.badge-success{color:var(--success-400);background:#22c55e26;border:1px solid #22c55e33}.badge-error{color:var(--error-400);background:#ef444426;border:1px solid #ef444433}.progress-bar{background:var(--bg-glass-strong);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:linear-gradient(90deg, var(--primary-500), var(--accent-400));height:100%;transition:width var(--transition-slow)}.range-slider{appearance:none;background:var(--bg-glass-strong);border-radius:var(--radius-full);width:100%;height:6px;transition:all var(--transition-fast);outline:none}.range-slider::-webkit-slider-thumb{appearance:none;background:linear-gradient(135deg, var(--primary-400), var(--primary-600));cursor:pointer;width:24px;height:24px;transition:all var(--transition-fast);border-radius:50%;box-shadow:0 0 10px #8b5cf666}.range-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 16px #8b5cf699}.range-slider::-moz-range-thumb{background:linear-gradient(135deg, var(--primary-400), var(--primary-600));cursor:pointer;border:none;border-radius:50%;width:24px;height:24px;box-shadow:0 0 10px #8b5cf666}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px #8b5cf64d}50%{box-shadow:0 0 40px #8b5cf699}}@keyframes count-up{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease-out}.animate-fade-in-down{animation:fadeInDown var(--transition-slow) ease-out}.animate-slide-right{animation:slideInRight var(--transition-slow) ease-out}.animate-slide-left{animation:slideInLeft var(--transition-slow) ease-out}.animate-scale-in{animation:scaleIn var(--transition-spring) ease-out}.animate-pulse{animation:2s infinite pulse}.animate-float{animation:3s ease-in-out infinite float}.animate-shake{animation:.5s ease-in-out shake}.animate-glow{animation:2s ease-in-out infinite glow-pulse}.animate-spin{animation:1s linear infinite spin}.stagger-children>*{animation:.4s ease-out both fadeInUp}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:60ms}.stagger-children>:nth-child(3){animation-delay:.12s}.stagger-children>:nth-child(4){animation-delay:.18s}.stagger-children>:nth-child(5){animation-delay:.24s}.stagger-children>:nth-child(6){animation-delay:.3s}.stagger-children>:nth-child(7){animation-delay:.36s}.stagger-children>:nth-child(8){animation-delay:.42s}.skeleton{background:linear-gradient(90deg, var(--bg-glass) 25%, var(--bg-glass-strong) 50%, var(--bg-glass) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.holographic{position:relative;overflow:hidden}.holographic:after{content:"";pointer-events:none;background:linear-gradient(45deg,#0000 30%,#ffffff0d 40%,#ffffff1a 50%,#ffffff0d 60%,#0000 70%);width:200%;height:200%;animation:3s ease-in-out infinite shimmer;position:absolute;top:-50%;left:-50%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-700);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-600)}.auth-page{min-height:100dvh;padding:var(--space-md);z-index:1;justify-content:center;align-items:center;display:flex;position:relative}.auth-card{width:100%;max-width:420px;padding:var(--space-2xl);text-align:center}.auth-logo{font-family:var(--font-display);margin-bottom:var(--space-sm);font-size:2.5rem;font-weight:800}.auth-subtitle{color:var(--text-secondary);margin-bottom:var(--space-2xl);font-size:.9375rem}.auth-form{gap:var(--space-md);flex-direction:column;display:flex}.auth-toggle{margin-top:var(--space-lg);color:var(--text-secondary);font-size:.875rem}.auth-toggle button{color:var(--primary-400);font-weight:600;text-decoration:underline}.auth-error{color:var(--error-400);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:#ef44441a;border:1px solid #ef444433;font-size:.875rem}.dashboard{padding:var(--space-lg) var(--space-md);max-width:900px;margin:0 auto}.dashboard-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.greeting h1{margin-bottom:4px;font-size:clamp(1.5rem,3.5vw,2rem)}.greeting p{color:var(--text-secondary);font-size:.9375rem}.stats-row{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(3,1fr);display:grid}.stat-card{padding:var(--space-md);text-align:center}.stat-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.stat-label{color:var(--text-secondary);margin-top:2px;font-size:.75rem}.stat-icon{margin-bottom:4px;font-size:1.25rem}.continue-card{border:1px solid var(--border-glow);margin-bottom:var(--space-xl);position:relative;overflow:hidden}.continue-card:before{content:"";background:linear-gradient(90deg, var(--primary-500), var(--accent-400));height:3px;position:absolute;top:0;left:0;right:0}.section-title{margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);font-size:1.125rem;font-weight:600;display:flex}.setup-tabs{gap:var(--space-xs);margin-bottom:var(--space-lg);background:var(--bg-glass);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:4px;display:flex}.setup-tab{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);text-align:center;background:0 0;border:none;flex:1;font-size:.9375rem;font-weight:600}.setup-tab:hover{color:var(--text-primary)}.setup-tab.active{background:var(--primary-500);color:#fff;box-shadow:var(--shadow-md)}.tab-content{animation:.3s ease-out fadeInUp}.difficulty-grid{gap:var(--space-sm);margin-bottom:var(--space-xl);grid-template-columns:repeat(2,1fr);display:grid}.difficulty-option{padding:var(--space-md);border-radius:var(--radius-lg);background:var(--bg-glass);border:2px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-base);text-align:center}.difficulty-option:hover{background:var(--bg-glass-strong);border-color:var(--border-default)}.difficulty-option.selected{border-color:var(--primary-500);box-shadow:var(--shadow-glow);background:#8b5cf61a}.difficulty-emoji{margin-bottom:var(--space-xs);font-size:2rem;display:block}.difficulty-name{font-size:.875rem;font-weight:600}.difficulty-desc{color:var(--text-tertiary);margin-top:2px;font-size:.75rem}.training-toggle{padding:var(--space-md);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.toggle-switch{background:var(--gray-700);border-radius:var(--radius-full);cursor:pointer;width:48px;height:26px;transition:all var(--transition-base);position:relative}.toggle-switch.active{background:var(--primary-600)}.toggle-switch:after{content:"";width:20px;height:20px;transition:all var(--transition-base);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.toggle-switch.active:after{left:25px}.slider-section{margin-bottom:var(--space-xl)}.slider-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.slider-value{font-family:var(--font-display);color:var(--primary-400);font-size:1.25rem;font-weight:700}.slider-labels{margin-top:var(--space-xs);justify-content:space-between;padding:0 12px;display:flex}.slider-labels span{color:var(--text-tertiary);font-size:.6875rem}.topic-grid{gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.topic-chip{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);background:var(--bg-glass);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);text-align:center;white-space:nowrap;font-size:.8125rem}.topic-chip:hover{background:var(--bg-glass-strong);border-color:var(--border-default)}.topic-chip.selected{border-color:var(--primary-500);color:var(--primary-300);background:#8b5cf626}.start-section{padding:var(--space-md) 0;z-index:10;position:sticky;bottom:80px}@media (min-width:1024px){.start-section{bottom:var(--space-lg)}}.quiz-back-btn{margin-bottom:var(--space-sm);color:var(--text-secondary);padding:var(--space-xs) var(--space-sm);margin-left:-var(--space-sm);transition:color var(--transition-fast), background var(--transition-fast);z-index:50;align-self:flex-start;font-weight:600}.quiz-back-btn:hover{color:var(--text-primary);background:var(--bg-glass-strong)}@media (min-width:1100px){.quiz-back-btn{top:var(--space-xl);left:var(--space-xl);margin:0;position:fixed}}.quiz-page{max-width:700px;padding:var(--space-sm) var(--space-md);flex-direction:column;min-height:100dvh;max-height:100dvh;margin:0 auto;display:flex;overflow:hidden}.quiz-header{padding:var(--space-sm) 0;margin-bottom:var(--space-sm);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.quiz-header-left{align-items:center;gap:var(--space-md);display:flex}.quiz-progress-text{color:var(--text-secondary);font-size:.875rem}.quiz-score{align-items:center;gap:var(--space-xs);font-family:var(--font-display);color:var(--accent-400);font-weight:700;display:flex}.question-section{min-height:0;padding-bottom:var(--space-sm);flex-direction:column;flex:1;animation:.4s ease-out fadeInUp;display:flex;overflow-y:auto}.question-meta{gap:var(--space-sm);margin-bottom:var(--space-xs);flex-wrap:wrap;display:flex}.question-text{margin-bottom:var(--space-md);font-size:clamp(1.125rem,2.5vw,1.25rem);font-weight:600;line-height:1.4}.answers-grid{gap:var(--space-xs);margin-bottom:var(--space-md);flex-direction:column;display:flex}.answer-option{align-items:center;gap:var(--space-sm);padding:parseInt(var(--space-sm)) var(--space-md);background:var(--bg-glass);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:left;width:100%;color:var(--text-primary);padding:10px 14px;font-size:1rem;display:flex}.answer-option:hover:not(.disabled){background:var(--bg-glass-strong);border-color:var(--border-default);transform:translate(4px)}.answer-option.selected{border-color:var(--primary-500);background:#8b5cf61a}.answer-option.correct{border-color:var(--success-500);box-shadow:var(--shadow-glow-success);background:#22c55e1a}.answer-option.wrong{border-color:var(--error-500);background:#ef44441a;animation:.5s ease-in-out shake}.answer-option.disabled{cursor:default;opacity:.6}.answer-option.disabled.correct{opacity:1}.answer-letter{border-radius:var(--radius-sm);background:var(--bg-glass-strong);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:700;display:flex}.answer-option.correct .answer-letter{background:var(--success-500);color:#fff}.answer-option.wrong .answer-letter{background:var(--error-500);color:#fff}.hint-btn{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);color:var(--accent-400);transition:all var(--transition-base);margin-bottom:var(--space-lg);background:#fbbf241a;border:1px solid #fbbf2433;font-size:.875rem;font-weight:500;display:flex}.hint-btn:hover{background:#fbbf2426;transform:translateY(-1px)}.hint-btn:disabled{opacity:.5;cursor:not-allowed}.hint-panel{border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-lg);background:#fbbf240f;border:1px solid #fbbf2426;animation:.3s ease-out fadeInDown}.hint-panel p{color:var(--accent-300);font-size:.9375rem;line-height:1.6}.explanation-panel{border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-sm);animation:.4s ease-out fadeInUp}.explanation-panel.correct{background:#22c55e0f;border:1px solid #22c55e26}.explanation-panel.wrong{background:#ef44440f;border:1px solid #ef444426}.explanation-title{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);font-weight:700;display:flex}.explanation-text{color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:.9375rem;line-height:1.6}.fun-fact{background:var(--bg-glass);border-radius:var(--radius-md);padding:var(--space-sm);color:var(--text-secondary);font-size:.875rem;line-height:1.6}.fun-fact strong{color:var(--accent-400)}.results-page{max-width:700px;padding:var(--space-lg) var(--space-md);text-align:center;margin:0 auto}.results-header{margin-bottom:var(--space-2xl)}.results-score{font-family:var(--font-display);margin:var(--space-md) 0;font-size:4rem;font-weight:800;animation:.6s ease-out count-up}.results-stars{margin-bottom:var(--space-md);letter-spacing:4px;font-size:2rem}.results-message{color:var(--text-secondary);max-width:400px;margin:0 auto;font-size:1.0625rem}.results-stats{gap:var(--space-md);margin-bottom:var(--space-2xl);grid-template-columns:repeat(2,1fr);display:grid}.results-breakdown{text-align:left;margin-bottom:var(--space-2xl)}.breakdown-item{padding:var(--space-md);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.breakdown-topic{font-weight:500}.breakdown-bar{background:var(--bg-glass-strong);border-radius:var(--radius-full);width:100px;height:6px;margin:0 var(--space-md);flex-shrink:0;overflow:hidden}.breakdown-bar-fill{border-radius:var(--radius-full);height:100%;transition:width .6s ease-out}.ai-insights{text-align:left;margin-bottom:var(--space-2xl)}.insight-card{padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-sm);color:var(--text-secondary);background:#8b5cf60f;border:1px solid #8b5cf61f;font-size:.9375rem;line-height:1.6}.results-actions{gap:var(--space-md);flex-wrap:wrap;justify-content:center;display:flex}.history-page{max-width:900px;padding:var(--space-lg) var(--space-md);margin:0 auto}.history-tabs{gap:var(--space-xs);margin-bottom:var(--space-xl);padding-bottom:var(--space-xs);display:flex;overflow-x:auto}.history-tab{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);white-space:nowrap;color:var(--text-secondary);transition:all var(--transition-base);font-size:.875rem;font-weight:500}.history-tab:hover{background:var(--bg-glass);color:var(--text-primary)}.history-tab.active{background:var(--primary-600);color:#fff}.topic-heatmap{gap:var(--space-sm);margin-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fill,minmax(120px,1fr));display:grid}.heatmap-cell{padding:var(--space-md);border-radius:var(--radius-md);text-align:center;transition:all var(--transition-base);cursor:pointer}.heatmap-cell:hover{transform:scale(1.05)}.heatmap-count{font-family:var(--font-display);font-size:1.25rem;font-weight:700}.heatmap-label{color:var(--text-secondary);margin-top:2px;font-size:.75rem}.question-log{gap:var(--space-sm);flex-direction:column;display:flex}.log-item{padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-base)}.log-item:hover{background:var(--bg-glass-strong)}.log-item-header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);margin-bottom:var(--space-xs);display:flex}.log-question{flex:1;font-size:.9375rem;font-weight:500;line-height:1.4}.log-detail{color:var(--text-tertiary);font-size:.8125rem;line-height:1.5}.collection-page{max-width:900px;padding:var(--space-lg) var(--space-md);margin:0 auto}.collection-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}.power-card{aspect-ratio:3/4;border-radius:var(--radius-lg);padding:var(--space-md);text-align:center;cursor:pointer;transition:all var(--transition-base);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.power-card.unlocked{background:linear-gradient(135deg,#8b5cf626,#fbbf241a);border:1px solid #8b5cf64d}.power-card.unlocked:hover{box-shadow:var(--shadow-glow);transform:translateY(-4px)scale(1.02)}.power-card.locked{background:var(--bg-glass);border:1px solid var(--border-subtle);opacity:.5}.power-card-emoji{margin-bottom:var(--space-sm);font-size:2.5rem}.power-card-name{margin-bottom:4px;font-size:.875rem;font-weight:700}.power-card-desc{color:var(--text-tertiary);font-size:.6875rem;line-height:1.4}.profile-page{max-width:600px;padding:var(--space-lg) var(--space-md);margin:0 auto}.profile-header-section{text-align:center;margin-bottom:var(--space-2xl)}.profile-avatar{background:linear-gradient(135deg, var(--primary-500), var(--accent-500));width:80px;height:80px;margin:0 auto var(--space-md);border-radius:50%;justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:flex}.profile-section{margin-bottom:var(--space-xl)}.profile-section h3{margin-bottom:var(--space-md)}.profile-item{padding:var(--space-md);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.bottom-nav{-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-subtle);height:70px;z-index:var(--z-nav);padding-bottom:env(safe-area-inset-bottom,0);background:#0a0a12e6;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}@media (min-width:1024px){.bottom-nav{width:240px;height:100%;padding:var(--space-xl) var(--space-md);justify-content:flex-start;gap:var(--space-xs);border-top:none;border-right:1px solid var(--border-subtle);flex-direction:column;inset:0 auto 0 0}}.nav-item{padding:var(--space-sm);border-radius:var(--radius-md);color:var(--text-tertiary);transition:all var(--transition-base);flex-direction:column;align-items:center;gap:2px;min-width:56px;font-size:.6875rem;font-weight:500;display:flex}@media (min-width:1024px){.nav-item{gap:var(--space-md);width:100%;padding:var(--space-md);flex-direction:row;justify-content:flex-start;font-size:.9375rem}}.nav-item:hover{color:var(--text-secondary)}.nav-item.active{color:var(--primary-400)}.nav-item.active:after{content:"";background:var(--primary-500);border-radius:var(--radius-full);width:20px;height:3px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}@media (min-width:1024px){.nav-item.active{background:#8b5cf61a}.nav-item.active:after{display:none}}.nav-icon{font-size:1.25rem}@media (min-width:1024px){.nav-icon{font-size:1.125rem}}.nav-logo{display:none}@media (min-width:1024px){.nav-logo{font-family:var(--font-display);margin-bottom:var(--space-xl);padding:0 var(--space-md);font-size:1.5rem;font-weight:800;display:block}}.motivational-banner{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);color:var(--text-secondary);text-align:center;background:linear-gradient(135deg,#8b5cf61a,#fbbf240d);border:1px solid #8b5cf626;font-size:.9375rem;font-style:italic;line-height:1.6}.motivational-banner .quote-emoji{margin-bottom:var(--space-sm);font-size:1.5rem;font-style:normal;display:block}.confetti-container{pointer-events:none;width:100%;height:100%;z-index:var(--z-toast);position:fixed;top:0;left:0;overflow:hidden}.confetti-piece{border-radius:2px;width:10px;height:10px;animation:3s linear forwards confetti-fall;position:absolute}@media (max-width:480px){.stats-row{gap:var(--space-sm);grid-template-columns:repeat(3,1fr)}.stat-card{padding:var(--space-sm)}.stat-value{font-size:1.25rem}.difficulty-grid{grid-template-columns:repeat(2,1fr)}.topic-grid{grid-template-columns:repeat(3,1fr)}.collection-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:768px){.difficulty-grid,.results-stats{grid-template-columns:repeat(4,1fr)}}.loading-screen{justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;min-height:100dvh;display:flex}.loading-spinner{border:3px solid var(--border-default);border-top-color:var(--primary-500);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.age-input-row{align-items:center;gap:var(--space-md);margin-top:var(--space-md);padding:var(--space-md);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:flex}.age-input-row label{color:var(--text-secondary);white-space:nowrap;font-size:.875rem}.age-input-row input{width:80px}.welcome-wizard{max-width:500px;padding:var(--space-2xl) var(--space-md);text-align:center;margin:0 auto}.welcome-wizard h1{margin-bottom:var(--space-md)}.welcome-wizard p{color:var(--text-secondary);margin-bottom:var(--space-2xl)}.wizard-step{animation:.4s ease-out fadeInUp}.donut-chart{width:120px;height:120px;margin:0 auto var(--space-lg);border-radius:50%;position:relative}.donut-center{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.donut-label{color:var(--text-tertiary);font-size:.6875rem}.bar-chart{align-items:flex-end;gap:var(--space-sm);height:120px;padding:var(--space-md) 0;display:flex}.bar-item{align-items:center;gap:var(--space-xs);flex-direction:column;flex:1;justify-content:flex-end;height:100%;display:flex}.bar-fill{border-radius:var(--radius-sm) var(--radius-sm) 0 0;width:100%;max-width:40px;min-height:4px;transition:height .6s ease-out}.bar-label{color:var(--text-tertiary);text-align:center;writing-mode:vertical-rl;max-height:60px;font-size:.625rem;overflow:hidden;transform:rotate(180deg)}@media (min-width:768px){.bar-label{writing-mode:horizontal-tb;max-height:none;transform:none}}.reward-card{padding:var(--space-xl);margin-bottom:var(--space-2xl);animation:scaleIn var(--transition-spring);text-align:center}.reward-emoji{margin-bottom:var(--space-md);font-size:3rem;animation:2s ease-in-out infinite float}.reward-title{font-family:var(--font-display);margin-bottom:var(--space-xs);font-size:1.125rem;font-weight:700}.reward-desc{color:var(--text-secondary);font-size:.875rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.text-center{text-align:center}.w-full{width:100%}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.sparks-page,.spark-collection-page{max-width:760px;padding:var(--space-lg) var(--space-md);margin:0 auto}.sparks-header{justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.spark-level-chip{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--primary-600), var(--accent-500));color:#fff;flex-direction:column;align-items:center;min-width:72px;display:flex}.spark-level-num{font-size:1rem;font-weight:800;line-height:1}.spark-level-xp{opacity:.9;margin-top:2px;font-size:.7rem}.spark-tabs{gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.spark-tab{text-align:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);flex:1;font-size:.8125rem;font-weight:600}.spark-tab.active{border-color:var(--primary-400);color:var(--primary-300);background:#8b5cf626}.spark-counters{gap:var(--space-sm);margin-bottom:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.spark-counter{padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-subtle);flex-direction:column;align-items:center;display:flex}.spark-counter-value{color:var(--primary-300);font-size:1.5rem;font-weight:800}.spark-counter-label{color:var(--text-tertiary);margin-top:2px;font-size:.7rem}.spark-deck-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));display:grid}.spark-deck{padding:var(--space-md);border-radius:var(--radius-lg);color:#fff;text-align:left;cursor:pointer;min-height:130px;box-shadow:var(--shadow-md);transition:transform var(--transition-base);border:none;flex-direction:column;align-items:flex-start;gap:4px;display:flex;position:relative}.spark-deck:hover{transform:translateY(-3px)}.spark-deck-emoji{font-size:2rem}.spark-deck-name{font-size:1.0625rem;font-weight:800}.spark-deck-meta{opacity:.9;font-size:.7rem}.spark-deck-bar{border-radius:var(--radius-full);background:#00000040;width:100%;height:6px;margin-top:auto;display:block;overflow:hidden}.spark-deck-bar-fill{border-radius:var(--radius-full);background:#fff;height:100%;transition:width .5s;display:block}.spark-deck-toolbar{justify-content:space-between;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.spark-deck-title{font-size:.9375rem;font-weight:700}.spark-card-stack{min-height:420px;position:relative}.sparks-page-immersive{max-width:640px;padding:var(--space-md);flex-direction:column;height:100dvh;min-height:100dvh;display:flex}.sparks-page-immersive .spark-deck-view{flex-direction:column;flex:auto;min-height:0;display:flex}.sparks-page-immersive .spark-deck-toolbar{flex:none}.sparks-page-immersive .spark-card-stack{flex:auto;min-height:280px}.sparks-page-immersive .spark-actions,.sparks-page-immersive .spark-deck-progress{flex:none}.sparks-page-immersive .spark-actions{margin-top:var(--space-md)}.sparks-page-immersive .spark-card-top{overflow-y:auto}body:has(.sparks-page-immersive) #main-nav{display:none}body:has(.sparks-page-immersive) .page-content{padding-bottom:0}@media (min-width:1024px){body:has(.sparks-page-immersive) .page-content{padding-left:0}}.spark-card{border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid var(--border-default);box-shadow:var(--shadow-lg);flex-direction:column;display:flex;position:absolute;inset:0;overflow:hidden}.spark-card-behind{opacity:.6;transform:scale(.94)translateY(14px)}.spark-card-top{cursor:grab;-webkit-user-select:none;user-select:none;z-index:2}.spark-card-top:active{cursor:grabbing}.spark-illustration{flex-shrink:0;justify-content:center;align-items:center;height:190px;font-size:5rem;display:flex}.spark-card-body{padding:var(--space-lg)}.spark-headline{margin:0 0 var(--space-sm);color:var(--text-primary);font-size:1.25rem;font-weight:800}.spark-detail{color:var(--text-secondary);margin:0 0 var(--space-md);font-size:.9375rem}.spark-funfact{border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);color:var(--accent-300);background:#fbbf241a;border:1px solid #fbbf244d;font-size:.8125rem}.spark-swipe-badge{border-radius:var(--radius-full);z-index:3;color:#fff;padding:6px 14px;font-size:.85rem;font-weight:800;position:absolute;top:18px}.spark-swipe-badge.collect{background:var(--success-500);right:18px;transform:rotate(8deg)}.spark-swipe-badge.skip{background:var(--gray-600);left:18px;transform:rotate(-8deg)}.spark-swipe-badge.love{background:#d946ef;left:50%;transform:translate(-50%)}.spark-actions{gap:var(--space-md);margin-top:var(--space-lg);justify-content:center;display:flex}.spark-action-btn{width:92px;padding:var(--space-md);border-radius:var(--radius-lg);border:2px solid var(--border-default);background:var(--bg-glass);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);flex-direction:column;align-items:center;gap:4px;font-size:.8125rem;font-weight:700;display:flex}.spark-action-btn .spark-action-icon{font-size:1.5rem}.spark-action-btn.skip:hover{border-color:var(--gray-400);transform:translateY(-2px)}.spark-action-btn.collect:hover{border-color:var(--success-400);color:var(--success-400);transform:translateY(-2px)}.spark-action-btn.love:hover{color:#d946ef;border-color:#d946ef;transform:translateY(-2px)}.spark-deck-progress{text-align:center;margin-top:var(--space-md);color:var(--text-tertiary);font-size:.8rem}.spark-deck-done{text-align:center;padding:var(--space-2xl) var(--space-lg)}.spark-stat-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.spark-stat-tile{text-align:center;padding:var(--space-lg)}.spark-stat-num{color:var(--primary-300);font-size:2rem;font-weight:800}.spark-stat-lbl{color:var(--text-tertiary);margin-top:4px;font-size:.8rem}.spark-topic-bars{gap:var(--space-md);flex-direction:column;display:flex}.spark-topic-row{padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-subtle)}.spark-topic-label{justify-content:space-between;margin-bottom:6px;font-size:.85rem;font-weight:600;display:flex}.spark-topic-sub{color:var(--text-tertiary);margin-top:6px;font-size:.7rem}@media (min-width:600px){.spark-stat-grid{grid-template-columns:repeat(4,1fr)}}.spark-check-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--space-md);z-index:var(--z-modal);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.spark-check-card{width:100%;max-width:460px}.spark-check-tag{text-transform:uppercase;letter-spacing:.06em;color:var(--primary-300);margin-bottom:var(--space-sm);font-size:.7rem;font-weight:700}.spark-check-question{margin:0 0 var(--space-md);font-size:1.125rem}.spark-check-options{gap:var(--space-sm);flex-direction:column;display:flex}.spark-check-option{align-items:center;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-md);border:1.5px solid var(--border-default);background:var(--bg-glass);color:var(--text-primary);text-align:left;cursor:pointer;transition:all var(--transition-base);font-size:.9375rem;display:flex}.spark-check-option:hover:not(:disabled){border-color:var(--primary-400)}.spark-check-option.correct{border-color:var(--success-500);background:#22c55e26}.spark-check-option.wrong{border-color:var(--error-500);background:#ef444426}.spark-check-option.disabled{opacity:.5}.spark-check-feedback{margin-top:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md)}.spark-check-feedback.correct{background:#22c55e1a;border:1px solid #22c55e4d}.spark-check-feedback.wrong{background:#ef44441a;border:1px solid #ef44444d}.spark-check-feedback-title{margin-bottom:4px;font-weight:800}.spark-check-feedback p{color:var(--text-secondary);margin:0 0 6px;font-size:.85rem}.spark-check-status{color:var(--primary-300);font-size:.8rem;font-weight:600}.spark-flash{background:var(--bg-glass-strong);border:1px solid var(--border-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text-primary);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);z-index:var(--z-toast);box-shadow:var(--shadow-lg);font-size:.875rem;font-weight:600;position:fixed;bottom:90px;left:50%;transform:translate(-50%)}.spark-badges{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(90px,1fr));display:grid}.spark-badge{padding:var(--space-md) var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-glass);text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.spark-badge.unlocked{border-color:var(--accent-400);background:#fbbf2414}.spark-badge.locked{opacity:.6}.spark-badge-emoji{font-size:1.5rem}.spark-badge-name{color:var(--text-secondary);font-size:.7rem;font-weight:600}.spark-collection-grid{gap:var(--space-md);margin-top:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));display:grid}.spark-mini-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);overflow:hidden}.spark-mini-illus{justify-content:center;align-items:center;height:90px;font-size:2.5rem;display:flex;position:relative}.spark-mini-badge{font-size:1rem;position:absolute;top:6px;right:6px}.spark-mini-love{font-size:1rem;position:absolute;top:6px;left:6px}.spark-mini-headline{padding:var(--space-sm) var(--space-md) 2px;font-size:.8125rem;font-weight:700}.spark-mini-meta{padding:0 var(--space-md) var(--space-md);color:var(--text-tertiary);font-size:.7rem}@media (max-width:420px){.bottom-nav .nav-item{min-width:48px;padding:var(--space-xs);font-size:.625rem}}
