@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-card:#1e293bb3;--bg-card-hover:#33415599;--bg-glass:#0f172a99;--bg-input:#1e293b80;--color-primary:#3b82f6;--color-primary-light:#60a5fa;--color-primary-dark:#2563eb;--color-primary-glow:#3b82f626;--color-success:#10b981;--color-success-light:#34d399;--color-success-glow:#10b98126;--color-accent:#8b5cf6;--color-accent-light:#a78bfa;--color-accent-glow:#8b5cf626;--color-warning:#f59e0b;--color-warning-light:#fbbf24;--color-warning-glow:#f59e0b26;--color-danger:#ef4444;--color-danger-light:#f87171;--color-danger-glow:#ef444426;--color-info:#06b6d4;--color-info-light:#22d3ee;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--text-inverse:#0f172a;--border-subtle:#94a3b81a;--border-default:#94a3b833;--border-active:#3b82f680;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-code:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--font-mono:var(--font-code);--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;--text-5xl:3rem;--text-6xl:3.75rem;--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;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0000004d, 0 2px 4px -2px #0003;--shadow-lg:0 10px 15px -3px #0000004d, 0 4px 6px -4px #0003;--shadow-xl:0 20px 25px -5px #0000004d, 0 8px 10px -6px #0003;--shadow-glow-blue:0 0 20px #3b82f64d;--shadow-glow-violet:0 0 20px #8b5cf64d;--shadow-glow-emerald:0 0 20px #10b9814d;--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);--navbar-height:4rem;--sidebar-width:280px;--max-content-width:1200px;--z-base:1;--z-card:10;--z-sidebar:100;--z-navbar:200;--z-modal:300;--z-tooltip:400}@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 float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 5px #3b82f64d}50%{box-shadow:0 0 20px #3b82f699}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes gradient-shift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.animate-fade-in{animation:.5s ease-out both fadeIn}.animate-fade-in-up{animation:.5s ease-out both fadeInUp}.animate-fade-in-down{animation:.5s ease-out both fadeInDown}.animate-slide-right{animation:.5s ease-out both slideInRight}.animate-slide-left{animation:.5s ease-out both slideInLeft}.animate-scale-in{animation:.4s ease-out both scaleIn}.animate-float{animation:3s ease-in-out infinite float}.animate-pulse-glow{animation:2s ease-in-out infinite pulse-glow}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}.delay-4{animation-delay:.4s}.delay-5{animation-delay:.5s}.delay-6{animation-delay:.6s}.delay-7{animation-delay:.7s}.delay-8{animation-delay:.8s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20%,#3b82f60d 0%,#0000 50%),radial-gradient(at 80% 20%,#8b5cf60d 0%,#0000 50%),radial-gradient(at 50% 80%,#10b98108 0%,#0000 50%);position:fixed;inset:0}#root{z-index:1;min-height:100vh;position:relative}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;color:var(--text-primary);font-weight:700;line-height:1.2}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}p{color:var(--text-secondary);line-height:1.7}a{color:var(--color-primary-light);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary)}code{font-family:var(--font-code);background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--color-primary-light);padding:.15em .4em;font-size:.9em}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{color:var(--text-primary);background:#3b82f64d}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);transition:all var(--transition-base)}.glass-card:hover{background:var(--bg-card-hover);border-color:var(--border-default);box-shadow:var(--shadow-lg)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-body);font-size:var(--text-sm);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;box-shadow:0 2px 10px #3b82f64d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 20px #3b82f666}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-active);transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);letter-spacing:.02em;font-weight:600;display:inline-flex}.badge-blue{background:var(--color-primary-glow);color:var(--color-primary-light)}.badge-green{background:var(--color-success-glow);color:var(--color-success-light)}.badge-violet{background:var(--color-accent-glow);color:var(--color-accent-light)}.badge-amber{background:var(--color-warning-glow);color:var(--color-warning-light)}.badge-red{background:var(--color-danger-glow);color:var(--color-danger-light)}.page-container{max-width:var(--max-content-width);padding:var(--space-8) var(--space-6);padding-top:calc(var(--navbar-height) + var(--space-8));margin:0 auto}.page-header{margin-bottom:var(--space-10)}.page-header h1{margin-bottom:var(--space-3)}.page-header p{font-size:var(--text-lg);max-width:600px}.grid{gap:var(--space-6);display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.page-container{padding:var(--space-4) var(--space-4);padding-top:calc(var(--navbar-height) + var(--space-4))}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}}.navbar{height:var(--navbar-height);background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);z-index:var(--z-navbar);position:fixed;top:0;left:0;right:0}.navbar-inner{max-width:1400px;height:100%;padding:0 var(--space-6);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.navbar-brand{align-items:center;gap:var(--space-3);flex-shrink:0;text-decoration:none;display:flex}.brand-icon{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.brand-text{font-size:var(--text-lg);color:var(--text-primary);letter-spacing:-.03em;font-weight:800}.brand-highlight{color:var(--color-primary-light)}.navbar-links{align-items:center;gap:var(--space-1);display:flex}.nav-link{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{color:var(--text-primary);background:var(--bg-card)}.nav-link.active{color:var(--color-primary-light);background:var(--color-primary-glow)}.mobile-toggle{color:var(--text-primary);cursor:pointer;padding:var(--space-2);background:0 0;border:none;display:none}@media (width<=1100px){.nav-link span{display:none}.nav-link{padding:var(--space-2)}}@media (width<=768px){.mobile-toggle{display:flex}.navbar-links{top:var(--navbar-height);background:var(--bg-primary);padding:var(--space-6);gap:var(--space-2);flex-direction:column;display:none;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.navbar-links.open{display:flex}.nav-link{width:100%;padding:var(--space-4);font-size:var(--text-base)}.nav-link span{display:inline}}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{padding-top:var(--navbar-height);flex:1}.app-footer{border-top:1px solid var(--border-subtle);padding:var(--space-8) var(--space-6);text-align:center}.footer-inner p{font-size:var(--text-sm);color:var(--text-muted)}.footer-sub{margin-top:var(--space-1);color:var(--text-muted);opacity:.7;font-size:var(--text-xs)!important}.hero{text-align:center;min-height:520px;padding:var(--space-20) var(--space-6) var(--space-12);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero-bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.hero-orb{filter:blur(80px);opacity:.4;border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#3b82f64d,#0000);width:500px;height:500px;animation:8s ease-in-out infinite float;top:-100px;left:-100px}.orb-2{background:radial-gradient(circle,#8b5cf640,#0000);width:400px;height:400px;animation:10s ease-in-out infinite reverse float;top:50px;right:-80px}.orb-3{background:radial-gradient(circle,#10b98133,#0000);width:300px;height:300px;animation:12s ease-in-out infinite float;bottom:-50px;left:30%}.hero-content{z-index:2;max-width:700px;position:relative}.hero-badge{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-primary-glow);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-primary-light);margin-bottom:var(--space-6);border:1px solid #3b82f633;font-weight:600;display:inline-flex}.hero-title{letter-spacing:-.03em;margin-bottom:var(--space-5);font-size:clamp(2.2rem,5vw,3.75rem);font-weight:900;line-height:1.1}.gradient-text{background:linear-gradient(135deg, var(--color-primary-light), var(--color-accent-light), var(--color-success));-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;animation:6s infinite gradient-shift}.hero-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-8);max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7}.hero-actions{gap:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}.countdown-card{z-index:2;margin-top:var(--space-10);padding:var(--space-5) var(--space-8);text-align:center;position:relative}.countdown-header{justify-content:center;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-4);display:flex}.countdown-grid{justify-content:center;align-items:center;gap:var(--space-3);display:flex}.countdown-block{flex-direction:column;align-items:center;display:flex}.countdown-num{font-size:var(--text-4xl);color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:800;line-height:1}.countdown-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-1)}.countdown-sep{font-size:var(--text-3xl);color:var(--text-muted);margin-bottom:14px;font-weight:300}.countdown-final{font-size:var(--text-3xl);color:var(--color-success);font-weight:800}.tip-banner{align-items:flex-start;gap:var(--space-4);padding:var(--space-5);margin-bottom:var(--space-12);border-left:3px solid var(--color-warning);display:flex}.tip-icon{background:var(--color-warning-glow);width:36px;height:36px;color:var(--color-warning);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;display:flex}.tip-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-warning);margin-bottom:var(--space-1);font-weight:700;display:block}.tip-content p{font-size:var(--text-sm);color:var(--text-secondary);font-family:var(--font-code);line-height:1.6}.section-header{margin-bottom:var(--space-8)}.section-header h2{margin-bottom:var(--space-2)}.section-header p{font-size:var(--text-base)}.features-grid{gap:var(--space-6);margin-bottom:var(--space-16);grid-template-columns:repeat(3,1fr);display:grid}.feature-card{padding:var(--space-6);cursor:pointer;flex-direction:column;text-decoration:none;display:flex;position:relative;overflow:hidden}.feature-card:before{content:"";opacity:0;height:3px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.feature-card:hover:before{opacity:1}.color-blue .feature-card:before,.feature-card.color-blue:before{background:var(--color-primary)}.color-violet .feature-card:before,.feature-card.color-violet:before{background:var(--color-accent)}.color-emerald .feature-card:before,.feature-card.color-emerald:before{background:var(--color-success)}.color-amber .feature-card:before,.feature-card.color-amber:before{background:var(--color-warning)}.color-red .feature-card:before,.feature-card.color-red:before{background:var(--color-danger)}.color-info .feature-card:before,.feature-card.color-info:before{background:var(--color-info)}.feature-card-top{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.feature-icon{border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.bg-blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.bg-violet{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.bg-emerald{background:linear-gradient(135deg,#10b981,#059669)}.bg-amber{background:linear-gradient(135deg,#f59e0b,#d97706)}.bg-red{background:linear-gradient(135deg,#ef4444,#dc2626)}.bg-info{background:linear-gradient(135deg,#06b6d4,#0891b2)}.feature-card h3{font-size:var(--text-lg);margin-bottom:var(--space-2);color:var(--text-primary)}.feature-card p{font-size:var(--text-sm);margin-bottom:var(--space-4);flex:1}.feature-cta{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);transition:all var(--transition-fast);font-weight:600;display:flex}.feature-card:hover .feature-cta{color:var(--color-primary-light);gap:var(--space-3)}.units-grid{gap:var(--space-5);margin-bottom:var(--space-16);grid-template-columns:repeat(4,1fr);display:grid}.unit-card{padding:var(--space-6);cursor:pointer;text-decoration:none}.unit-num{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-primary-light);margin-bottom:var(--space-2);font-weight:700}.unit-card h4{font-size:var(--text-base);margin-bottom:var(--space-4);color:var(--text-primary)}.unit-meta{gap:var(--space-2);margin-bottom:var(--space-4);flex-direction:column;display:flex}.unit-weight,.unit-topics{align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-muted);display:flex}.unit-progress-bar{background:var(--bg-tertiary);border-radius:2px;height:4px;overflow:hidden}.unit-progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-accent));border-radius:2px;height:100%;transition:width .5s}.exam-info{padding:var(--space-8);margin-bottom:var(--space-12)}.exam-info h3{text-align:center;margin-bottom:var(--space-8)}.exam-info-grid{justify-content:center;align-items:center;gap:var(--space-8);flex-wrap:wrap;display:flex}.exam-info-block{text-align:center;align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.exam-info-num{font-size:var(--text-4xl);color:var(--text-primary);font-weight:800}.exam-info-label{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.exam-info-detail{font-size:var(--text-xs);color:var(--text-muted)}.exam-info-divider{background:var(--border-default);width:1px;height:60px}@media (width<=1024px){.features-grid,.units-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.hero{min-height:420px;padding-top:var(--space-16)}.features-grid,.units-grid{grid-template-columns:1fr}.hero-actions{flex-direction:column;align-items:stretch}.exam-info-grid{flex-direction:column}.exam-info-divider{width:60px;height:1px}.countdown-num{font-size:var(--text-3xl)}}.code-block{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);margin:var(--space-4) 0;overflow:hidden}.code-block-header{padding:var(--space-3) var(--space-4);background:#1e1f2e;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;display:flex}.code-block-title{font-family:var(--font-code);font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.code-block-dots{gap:6px;display:flex}.dot{border-radius:50%;width:10px;height:10px}.dot.red{background:#ff5f57}.dot.yellow{background:#ffbd2e}.dot.green{background:#28c840}.code-block-body{position:relative}.copy-btn{top:var(--space-3);right:var(--space-3);align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-family:var(--font-body);font-size:var(--text-xs);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:all var(--transition-fast);background:#ffffff14;border:1px solid #ffffff1a;font-weight:500;display:flex;position:absolute}.code-block-body:hover .copy-btn{opacity:1}.copy-btn:hover{color:var(--text-primary);background:#ffffff26}.copy-btn.copied{opacity:1;color:var(--color-success);border-color:var(--color-success)}.units-select-grid{gap:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.unit-select-card{padding:var(--space-6);cursor:pointer;transition:all var(--transition-base);flex-direction:column;text-decoration:none;display:flex}.unit-select-card:hover{transform:translateY(-3px)}.unit-select-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.unit-select-num{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-primary-light);font-weight:700}.unit-select-weight{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px 8px}.unit-select-card h3{font-size:var(--text-xl);margin-bottom:var(--space-2);color:var(--text-primary)}.unit-select-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);flex:1}.unit-select-meta{gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.unit-select-meta span{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-muted);display:flex}.unit-select-progress{align-items:center;gap:var(--space-3);display:flex}.unit-select-progress-bar{background:var(--bg-tertiary);border-radius:2px;flex:1;height:4px;overflow:hidden}.unit-select-progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-accent));border-radius:2px;height:100%;transition:width .5s}.unit-select-progress-text{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.concept-detail-page{min-height:calc(100vh - var(--navbar-height));padding-top:var(--navbar-height);display:flex}.concept-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);border-right:1px solid var(--border-subtle);padding:var(--space-6);top:var(--navbar-height);height:calc(100vh - var(--navbar-height));background:var(--bg-secondary);position:sticky;overflow-y:auto}.sidebar-back{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-6);transition:color var(--transition-fast);text-decoration:none;display:flex}.sidebar-back:hover{color:var(--color-primary-light)}.sidebar-unit-title{margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle)}.sidebar-unit-num{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-primary-light);font-weight:700}.sidebar-unit-title h3{font-size:var(--text-base);margin-top:var(--space-1);margin-bottom:var(--space-3)}.sidebar-progress{align-items:center;gap:var(--space-2);display:flex}.sidebar-progress-bar{background:var(--bg-tertiary);border-radius:2px;flex:1;height:3px;overflow:hidden}.sidebar-progress-fill{background:var(--color-success);border-radius:2px;height:100%;transition:width .5s}.sidebar-progress span{font-size:var(--text-xs);color:var(--text-muted)}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.sidebar-topic-btn{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast);font-family:var(--font-body);background:0 0;border:none;display:flex}.sidebar-topic-btn:hover{background:var(--bg-card)}.sidebar-topic-btn.active{background:var(--color-primary-glow)}.sidebar-topic-btn.completed .topic-check{color:var(--color-success)}.topic-dot{background:var(--text-muted);border-radius:50%;flex-shrink:0;width:6px;height:6px}.topic-num{font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0;min-width:28px;font-weight:600}.topic-title-text{font-size:var(--text-xs);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sidebar-topic-btn:hover .topic-title-text,.sidebar-topic-btn.active .topic-title-text{color:var(--text-primary)}.concept-content{padding:var(--space-8);flex:1;max-width:900px}.concept-content-header{margin-bottom:var(--space-10)}.concept-content-header h1{margin-top:var(--space-3);margin-bottom:var(--space-2)}.concept-content-header p{font-size:var(--text-lg)}.topics-list{gap:var(--space-4);flex-direction:column;display:flex}.topic-card{overflow:hidden}.topic-header{width:100%;padding:var(--space-5);cursor:pointer;font-family:var(--font-body);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.topic-header-left{align-items:center;gap:var(--space-3);display:flex}.topic-number{font-size:var(--text-xs);color:var(--color-primary-light);background:var(--color-primary-glow);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);white-space:nowrap;font-weight:700}.topic-header h3{font-size:var(--text-base);color:var(--text-primary)}.topic-header-right{align-items:center;gap:var(--space-3);color:var(--text-muted);display:flex}.mark-complete-btn{color:var(--text-muted);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:all var(--transition-fast);opacity:.5;background:0 0;border:none}.mark-complete-btn:hover{opacity:1;color:var(--color-success)}.mark-complete-btn.done{color:var(--color-success);opacity:1}.topic-body{padding:0 var(--space-5) var(--space-5);border-top:1px solid var(--border-subtle);overflow:hidden}.content-block{margin-top:var(--space-4)}.content-block p{font-size:var(--text-sm);line-height:1.8}.content-block h4{font-size:var(--text-base);margin-bottom:var(--space-2);color:var(--text-primary)}.content-list{padding-left:var(--space-5);margin:var(--space-2) 0}.content-list li{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1);line-height:1.7}.callout{gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);margin:var(--space-4) 0;display:flex}.callout-icon{flex-shrink:0;margin-top:2px}.callout strong{font-size:var(--text-sm);margin-bottom:var(--space-1);display:block}.callout p{font-size:var(--text-sm)!important}.callout-trap{background:var(--color-danger-glow);border-left:3px solid var(--color-danger)}.callout-trap .callout-icon{color:var(--color-danger)}.callout-trap strong{color:var(--color-danger-light)}.callout-insight{background:var(--color-primary-glow);border-left:3px solid var(--color-primary)}.callout-insight .callout-icon{color:var(--color-primary)}.callout-insight strong{color:var(--color-primary-light)}.essential-knowledge{margin-top:var(--space-6);padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.essential-knowledge h4{font-size:var(--text-sm);margin-bottom:var(--space-3)}.essential-knowledge ul{padding-left:var(--space-5)}.essential-knowledge li{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2);line-height:1.7}.essential-knowledge code{font-size:var(--text-xs);margin-right:var(--space-2);padding:1px 6px}.exclusion-box{margin-top:var(--space-4);padding:var(--space-4);border-left:3px solid var(--color-warning);border-radius:var(--radius-lg);background:#f59e0b0d}.exclusion-box h4{font-size:var(--text-sm);color:var(--color-warning);margin-bottom:var(--space-2)}.exclusion-box ul{padding-left:var(--space-5)}.exclusion-box li{font-size:var(--text-sm);color:var(--text-muted);line-height:1.6}@media (width<=1024px){.units-select-grid{grid-template-columns:1fr}.concept-sidebar{display:none}.concept-detail-page{flex-direction:column}.concept-content{padding:var(--space-4)}}.tracer-grid{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.tracer-card{padding:var(--space-5);cursor:pointer;text-align:left;font-family:var(--font-body);transition:all var(--transition-base);border:none;flex-direction:column;align-items:flex-start;display:flex}.tracer-card-meta{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.tracer-category{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);font-weight:700}.tracer-diff{border-radius:var(--radius-full);text-transform:uppercase;padding:1px 8px;font-size:10px;font-weight:700}.diff-easy{color:var(--color-success);background:#22c55e1f}.diff-medium{color:var(--color-warning);background:#f59e0b1f}.diff-hard{color:var(--color-danger);background:#ef44441f}.tracer-card h3{font-size:var(--text-base);margin-bottom:var(--space-2)}.tracer-card p{font-size:var(--text-sm);color:var(--text-secondary)}.tracer-header{margin:var(--space-4) 0 var(--space-5)}.tracer-header h2{margin-top:var(--space-2)}.tracer-header p{font-size:var(--text-sm);color:var(--text-secondary)}.tracer-layout{gap:var(--space-4);margin-bottom:var(--space-5);grid-template-columns:1fr 1fr;display:grid}.tracer-code-panel{overflow:hidden}.tracer-code-title,.tracer-vars-title{padding:var(--space-3) var(--space-4);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);font-weight:700}.tracer-code-lines{padding:var(--space-2) 0}.tracer-line{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);transition:all .2s;display:flex;position:relative}.tracer-line.visited{background:#6366f108}.tracer-line.active{border-left:3px solid var(--color-primary);background:#6366f11a}.line-num{text-align:right;width:20px;color:var(--text-muted);font-size:var(--text-xs);flex-shrink:0}.tracer-line code{color:var(--text-primary);white-space:pre}.tracer-line.active code{color:var(--color-primary-light);font-weight:600}.line-arrow{right:var(--space-3);color:var(--color-primary-light);position:absolute}.tracer-state-panel{gap:var(--space-4);flex-direction:column;display:flex}.tracer-vars,.tracer-narration,.tracer-output{overflow:hidden}.var-table{padding:var(--space-3) var(--space-4)}.var-row{padding:var(--space-2) 0;border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.var-row:last-child{border-bottom:none}.var-name{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-accent);font-weight:600}.var-val{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-primary-light);background:var(--bg-tertiary);border-radius:var(--radius-md);padding:2px 10px;font-weight:700}.var-empty,.tracer-done{padding:var(--space-4);text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.tracer-done{align-items:center;gap:var(--space-2);color:var(--color-success);flex-direction:column;display:flex}.narration-text{align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;display:flex}.narration-text svg{color:var(--color-warning);flex-shrink:0;margin-top:2px}.narration-text.muted{color:var(--text-muted)}.narration-text.done{color:var(--color-success)}.output-text{padding:var(--space-3) var(--space-4);font-family:var(--font-mono);font-size:var(--text-base);color:var(--color-success);display:block}.tracer-controls{padding:var(--space-4) 0;justify-content:space-between;align-items:center;display:flex}.tracer-step-info{font-size:var(--text-sm);color:var(--text-muted);font-family:var(--font-mono)}.tracer-btn-group{gap:var(--space-2);display:flex}@media (width<=768px){.tracer-grid,.tracer-layout{grid-template-columns:1fr}}.fc-deck-grid{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.fc-deck-card{padding:var(--space-5);cursor:pointer;font-family:var(--font-body);text-align:left;transition:all var(--transition-base);border:none;flex-direction:column;align-items:flex-start;display:flex}.fc-deck-unit{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary-light);margin-bottom:var(--space-2);font-weight:700}.fc-deck-card h3{font-size:var(--text-base);margin-bottom:var(--space-3)}.fc-deck-count{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px 10px}.fc-study{max-width:700px;margin:0 auto}.fc-topbar{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.fc-topbar h3{font-size:var(--text-sm)}.fc-progress-text{font-size:var(--text-xs);color:var(--color-success)}.fc-progress-bar{background:var(--bg-tertiary);width:100%;height:4px;margin-bottom:var(--space-6);border-radius:2px;overflow:hidden}.fc-progress-fill{background:linear-gradient(90deg, var(--color-success), var(--color-primary));height:100%;transition:width .4s}.fc-card-area{cursor:pointer;perspective:1000px;margin-bottom:var(--space-5)}.fc-card{min-height:280px;padding:var(--space-8);text-align:center;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;display:flex}.fc-card.fc-front{border-left:4px solid var(--color-primary)}.fc-card.fc-back{border-left:4px solid var(--color-success);background:#22c55e08}.fc-card-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-4);font-weight:700}.fc-card-text{font-size:var(--text-lg);white-space:pre-line;line-height:1.8}.fc-back .fc-card-text{font-family:var(--font-mono);font-size:var(--text-base)}.fc-card-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-4)}.fc-controls{justify-content:space-between;align-items:center;display:flex}.fc-center-controls{align-items:center;gap:var(--space-3);display:flex}.fc-know-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:var(--text-xs);font-family:var(--font-body);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast);display:flex}.fc-know-btn.active{border-color:var(--color-success);color:var(--color-success);background:#22c55e1f}.fc-counter{font-size:var(--text-sm);color:var(--text-muted);font-family:var(--font-mono)}@media (width<=768px){.fc-deck-grid{grid-template-columns:1fr}.fc-card{min-height:200px;padding:var(--space-6)}}.exam-mode-grid{gap:var(--space-6);margin-bottom:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.exam-mode-card{text-align:center;padding:var(--space-8);cursor:pointer;font-family:var(--font-body);border:none;flex-direction:column;align-items:center;display:flex}.exam-mode-card:hover{transform:translateY(-4px)}.mode-icon{border-radius:var(--radius-xl);width:56px;height:56px;margin-bottom:var(--space-4);justify-content:center;align-items:center;display:flex}.mode-icon.bg-amber{color:var(--color-warning);background:#f59e0b26}.mode-icon.bg-blue{background:var(--color-primary-glow);color:var(--color-primary-light)}.exam-mode-card h3{margin-bottom:var(--space-2)}.exam-mode-card p{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-6)}.exam-info-banner{padding:var(--space-5)}.exam-info-banner h4{margin-bottom:var(--space-2)}.exam-info-banner p{font-size:var(--text-sm);color:var(--text-secondary)}.exam-taking{padding-top:var(--navbar-height);min-height:100vh}.exam-topbar{top:var(--navbar-height);padding:var(--space-3) var(--space-6);background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);z-index:40;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:fixed;left:0;right:0}.exam-topbar-left{align-items:center;gap:var(--space-3);flex:1;display:flex}.exam-progress-text{font-size:var(--text-sm);color:var(--text-muted);white-space:nowrap}.exam-progress-bar{background:var(--bg-tertiary);border-radius:2px;width:120px;height:4px;overflow:hidden}.exam-progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-accent));height:100%;transition:width .3s}.exam-topbar-center{flex:1;justify-content:center;display:flex}.exam-timer{align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-lg);color:var(--text-primary);font-weight:700;display:flex}.exam-timer.timer-warning{color:var(--color-danger);animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.exam-topbar-right{align-items:center;gap:var(--space-3);flex:1;justify-content:flex-end;display:flex}.answered-count{font-size:var(--text-xs);color:var(--text-muted)}.exam-question-container{max-width:800px;padding:calc(var(--space-8) + 48px) var(--space-6) var(--space-8);margin:0 auto}.exam-question{padding:var(--space-6)}.question-num{font-size:var(--text-xs);color:var(--color-primary-light);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-4);font-weight:700}.question-text{font-size:var(--text-base);margin:var(--space-4) 0;line-height:1.7}.choices-list{gap:var(--space-3);margin-top:var(--space-5);flex-direction:column;display:flex}.choice-btn{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg);cursor:pointer;text-align:left;font-family:var(--font-body);transition:all var(--transition-fast);border:2px solid #0000;display:flex}.choice-btn:hover,.choice-btn.selected{border-color:var(--color-primary);background:var(--color-primary-glow)}.choice-btn .choice-letter{border-radius:var(--radius-full);background:var(--bg-secondary);width:28px;height:28px;font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.choice-btn.selected .choice-letter{background:var(--color-primary);color:var(--bg-primary)}.choice-btn .choice-text{font-size:var(--text-sm);color:var(--text-primary);padding-top:3px}.exam-nav{margin-top:var(--space-6);padding:var(--space-4) 0;justify-content:space-between;align-items:center;display:flex}.question-dots{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.q-dot{background:var(--bg-tertiary);border:2px solid var(--border-subtle);cursor:pointer;width:12px;height:12px;transition:all var(--transition-fast);border-radius:50%}.q-dot.answered{background:var(--color-primary);border-color:var(--color-primary)}.q-dot.current{border-color:var(--color-accent);box-shadow:0 0 0 3px #a855f74d}.exam-results{max-width:900px;margin:0 auto}.results-header{align-items:center;gap:var(--space-6);padding:var(--space-8);margin-bottom:var(--space-6);display:flex}.results-score-ring{flex-shrink:0;width:120px;height:120px;position:relative}.results-score-ring svg{width:100%;height:100%}.results-score-text{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.score-num{font-size:var(--text-2xl);font-weight:800}.score-label{font-size:var(--text-xs);color:var(--text-muted)}.results-summary h2{margin-bottom:var(--space-2)}.results-summary p{font-size:var(--text-sm);color:var(--text-secondary)}.time-taken{font-family:var(--font-mono)}.review-controls{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.review-filters{gap:var(--space-2);display:flex}.filter-btn{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:var(--text-xs);cursor:pointer;font-family:var(--font-body);color:var(--text-muted);transition:all var(--transition-fast);display:flex}.filter-btn.active{background:var(--color-primary-glow);border-color:var(--color-primary);color:var(--color-primary-light)}.filter-btn.wrong.active{border-color:var(--color-danger);color:var(--color-danger);background:#ef44441a}.filter-btn.correct.active{border-color:var(--color-success);color:var(--color-success);background:#22c55e1a}.review-list{gap:var(--space-4);flex-direction:column;display:flex}.review-card{padding:var(--space-5)}.review-card.review-correct{border-left:3px solid var(--color-success)}.review-card.review-wrong{border-left:3px solid var(--color-danger)}.review-card-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.review-q-num{font-weight:700;font-size:var(--text-sm)}.review-badge{align-items:center;gap:var(--space-1);font-size:var(--text-xs);border-radius:var(--radius-full);padding:2px 10px;font-weight:600;display:flex}.badge-green{color:var(--color-success);background:#22c55e26}.badge-red{color:var(--color-danger);background:#ef444426}.review-question-text{font-size:var(--text-sm);margin:var(--space-3) 0;line-height:1.6}.review-choices{gap:var(--space-2);margin:var(--space-3) 0;flex-direction:column;display:flex}.review-choice{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--bg-tertiary);display:flex}.review-choice.choice-correct{border:1px solid var(--color-success);background:#22c55e1a}.review-choice.choice-wrong{border:1px solid var(--color-danger);background:#ef44441a}.review-choice .choice-letter{background:var(--bg-secondary);width:24px;height:24px;font-size:var(--text-xs);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.choice-icon{flex-shrink:0;margin-left:auto}.choice-icon.correct{color:var(--color-success)}.choice-icon.wrong{color:var(--color-danger)}.review-explanation{padding:var(--space-3);margin-top:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);background:#6366f10d;line-height:1.6}.review-why-wrong{align-items:flex-start;gap:var(--space-2);padding:var(--space-3);margin-top:var(--space-2);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-danger-light);background:#ef44440d;display:flex}.exam-selector{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.exam-select-btn{text-align:center;padding:var(--space-5);cursor:pointer;font-family:var(--font-body);transition:all var(--transition-fast);border:2px solid #0000;flex-direction:column;align-items:center;display:flex}.exam-select-btn.selected{border-color:var(--color-primary);background:var(--color-primary-glow)}.exam-select-num{font-size:var(--text-3xl);color:var(--color-primary-light);font-weight:800;line-height:1}.exam-select-title{font-size:var(--text-base);color:var(--text-primary);margin:var(--space-2) 0 var(--space-1);font-weight:700}.exam-select-src{font-size:var(--text-xs);color:var(--text-muted)}@media (width<=768px){.exam-mode-grid,.exam-selector{grid-template-columns:1fr}.results-header{text-align:center;flex-direction:column}.exam-topbar{padding:var(--space-2) var(--space-3)}.exam-question-container{padding-left:var(--space-3);padding-right:var(--space-3)}.review-controls{gap:var(--space-3);flex-direction:column}}.frq-type-guide{padding:var(--space-5);margin-bottom:var(--space-6)}.frq-type-guide h3{margin-bottom:var(--space-4)}.frq-types-grid{gap:var(--space-3);grid-template-columns:repeat(4,1fr);display:grid}.frq-type-item{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:var(--text-sm);display:flex}.frq-type-num{background:var(--color-primary-glow);width:32px;height:32px;color:var(--color-primary-light);font-weight:700;font-size:var(--text-xs);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;display:flex}.frq-list{gap:var(--space-4);flex-direction:column;display:flex}.frq-card{padding:var(--space-6);text-align:left;cursor:pointer;font-family:var(--font-body);width:100%;transition:all var(--transition-base);border:none}.frq-card:hover{transform:translateY(-2px)}.frq-card-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.frq-card-type{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);font-weight:700}.frq-card-points{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-warning);display:flex}.frq-card h3{margin-bottom:var(--space-2)}.frq-card p{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4)}.frq-card-parts{gap:var(--space-2);display:flex}.frq-part-chip{background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-muted);padding:2px 10px}.back-btn{margin-bottom:var(--space-4)}.part-tabs{gap:var(--space-2);margin-bottom:var(--space-6);display:flex}.part-tab{padding:var(--space-2) var(--space-5);background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:var(--text-sm);cursor:pointer;font-family:var(--font-body);color:var(--text-muted);transition:all var(--transition-fast);border:2px solid #0000}.part-tab:hover{border-color:var(--border-subtle)}.part-tab.active{background:var(--color-primary-glow);border-color:var(--color-primary);color:var(--color-primary-light)}.frq-prompt{padding:var(--space-5);margin-bottom:var(--space-6)}.frq-prompt h3{margin-bottom:var(--space-3)}.frq-prompt p{font-size:var(--text-sm);white-space:pre-line;line-height:1.8}.steps-section{margin-bottom:var(--space-6)}.steps-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.steps-list{gap:var(--space-3);flex-direction:column;display:flex}.step-card{overflow:hidden}.step-header{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-4);cursor:pointer;font-family:var(--font-body);color:var(--text-muted);background:0 0;border:none;display:flex}.step-card.revealed .step-header{color:var(--text-primary)}.step-num{background:var(--bg-tertiary);border-radius:var(--radius-full);width:28px;height:28px;font-size:var(--text-xs);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.step-card.revealed .step-num{background:var(--color-primary);color:var(--bg-primary)}.step-label{text-align:left;font-weight:600;font-size:var(--text-sm);flex:1}.step-body{padding:0 var(--space-4) var(--space-4);overflow:hidden}.step-hint{align-items:flex-start;gap:var(--space-2);padding:var(--space-3);margin-bottom:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-warning);background:#f59e0b0f;line-height:1.6;display:flex}.solution-section,.rubric-section{margin-bottom:var(--space-4);overflow:hidden}.solution-toggle{width:100%;padding:var(--space-4);cursor:pointer;font-family:var(--font-body);color:var(--text-muted);background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.solution-toggle h3{font-size:var(--text-base);margin:0}.rubric-body{padding:0 var(--space-4) var(--space-4)}.rubric-list{padding:0;list-style:none}.rubric-list li{align-items:flex-start;gap:var(--space-2);padding:var(--space-2) 0;font-size:var(--text-sm);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);display:flex}.rubric-list li:last-child{border-bottom:none}.rubric-list li svg{color:var(--color-success);flex-shrink:0;margin-top:2px}.mistakes-section{padding:var(--space-5);margin-bottom:var(--space-4);border-left:3px solid var(--color-danger)}.mistakes-section h3{align-items:center;gap:var(--space-2);color:var(--color-danger-light);margin-bottom:var(--space-3);display:flex}.mistakes-section ul{padding-left:var(--space-5)}.mistakes-section li{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2);line-height:1.7}.frq-card-skills{gap:var(--space-1);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.frq-skill-chip{background:var(--color-primary-glow);border-radius:var(--radius-full);color:var(--color-primary-light);padding:2px 8px;font-size:10px;font-weight:600}.frq-card-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.frq-description{white-space:pre-line;line-height:1.8}.frq-skills-row{gap:var(--space-2);margin-top:var(--space-4);flex-wrap:wrap;display:flex}.frq-skill-badge{padding:var(--space-1) var(--space-3);background:var(--color-primary-glow);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-primary-light);border:1px solid #8b5cf640;font-weight:600}.frq-context{padding:var(--space-5);margin-bottom:var(--space-5);border-left:3px solid var(--color-primary)}.frq-context h3{margin-bottom:var(--space-2)}.context-note{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-4);font-style:italic;line-height:1.6}.frq-examples{padding:var(--space-5);margin-bottom:var(--space-5);border-left:3px solid var(--color-info)}.frq-examples h3{margin-bottom:var(--space-3)}.examples-pre{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary);white-space:pre-wrap;background:var(--bg-tertiary);padding:var(--space-4);border-radius:var(--radius-md);line-height:1.7;overflow-x:auto}@media (width<=768px){.frq-types-grid{grid-template-columns:repeat(2,1fr)}.frq-skills-row{gap:var(--space-1)}.frq-skill-badge{padding:2px 8px;font-size:10px}}.qr-search-bar{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-6);display:flex}.qr-search-icon{color:var(--text-muted);flex-shrink:0}.qr-search-input{font-size:var(--text-base);color:var(--text-primary);font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1}.qr-search-input::placeholder{color:var(--text-muted)}.qr-search-clear{background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;width:24px;height:24px;font-size:var(--text-xs);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.qr-class-list{gap:var(--space-3);flex-direction:column;display:flex}.qr-class{overflow:hidden}.qr-class-header{width:100%;padding:var(--space-4) var(--space-5);cursor:pointer;font-family:var(--font-body);text-align:left;color:var(--text-primary);background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.qr-class-info{align-items:flex-start;gap:var(--space-3);display:flex}.qr-class-icon{color:var(--color-primary-light);flex-shrink:0;margin-top:2px}.qr-class-info h3{font-size:var(--text-base);margin-bottom:2px}.qr-class-info p{font-size:var(--text-sm);color:var(--text-secondary)}.qr-class-meta{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.qr-method-count{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px 8px}.qr-methods{border-top:1px solid var(--border-subtle);overflow:hidden}.qr-method{border-bottom:1px solid var(--border-subtle)}.qr-method:last-child{border-bottom:none}.qr-method-header{width:100%;padding:var(--space-3) var(--space-5);cursor:pointer;font-family:var(--font-body);color:var(--text-muted);transition:all var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.qr-method-header:hover{background:var(--bg-tertiary);color:var(--text-primary)}.qr-method.expanded .qr-method-header{color:var(--color-primary-light);background:#6366f10d}.qr-signature{font-family:var(--font-mono);font-size:var(--text-sm);color:inherit;background:0 0}.qr-method-detail{padding:0 var(--space-5) var(--space-4);overflow:hidden}.qr-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-3);line-height:1.6}.qr-trap{align-items:flex-start;gap:var(--space-2);padding:var(--space-3);margin-top:var(--space-3);border-left:3px solid var(--color-warning);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-warning);background:#f59e0b0f;line-height:1.6;display:flex}.qr-trap svg{flex-shrink:0;margin-top:2px}.qr-empty{align-items:center;gap:var(--space-3);padding:var(--space-8);color:var(--text-muted);text-align:center;flex-direction:column;display:flex}.progress-page{max-width:900px;margin:0 auto}.progress-hero-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:1.2fr 1fr 1fr;display:grid}.progress-hero-card{align-items:center;gap:var(--space-4);padding:var(--space-5);display:flex}.progress-ring-wrap{flex-shrink:0;position:relative}.progress-ring-wrap svg{display:block}.progress-ring-content{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.ring-pct{font-size:var(--text-2xl);color:var(--color-primary-light);font-weight:800}.hero-stat-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.hero-stat-icon.streak{color:#f59e0b;background:#f59e0b1f}.hero-stat-icon.exams{color:var(--color-primary-light);background:#6366f11f}.hero-stat-info h3{font-size:var(--text-sm);margin-bottom:2px}.hero-stat-info p{font-size:var(--text-xs);color:var(--text-muted)}.hero-stat-num{font-size:var(--text-3xl);background:linear-gradient(135deg, var(--color-primary-light), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-weight:800;line-height:1}.progress-detail-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.progress-detail-card{padding:var(--space-4) var(--space-5)}.detail-header{align-items:center;gap:var(--space-2);color:var(--text-muted);margin-bottom:var(--space-3);display:flex}.detail-header h4{font-size:var(--text-sm)}.detail-stat{align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.detail-num{font-size:var(--text-2xl);color:var(--text-primary);font-weight:800}.detail-of{font-size:var(--text-sm);color:var(--text-muted)}.detail-bar{background:var(--bg-tertiary);width:100%;height:6px;margin-bottom:var(--space-3);border-radius:3px;overflow:hidden}.detail-fill{border-radius:3px;height:100%;transition:width .6s}.detail-link{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-primary-light);font-weight:600;text-decoration:none;display:flex}.detail-link:hover{text-decoration:underline}.achievements-section{margin-bottom:var(--space-6)}.achievements-section h3{align-items:center;gap:var(--space-2);font-size:var(--text-base);margin-bottom:var(--space-4);display:flex}.achievements-grid{gap:var(--space-3);grid-template-columns:repeat(4,1fr);display:grid}.achievement-card{padding:var(--space-4);text-align:center;transition:all var(--transition-fast);position:relative}.achievement-card.locked{opacity:.4;filter:grayscale(.8)}.achievement-card.unlocked{border-color:#6366f133}.achievement-icon{margin-bottom:var(--space-2);font-size:28px;display:block}.achievement-card h5{font-size:var(--text-xs);margin-bottom:2px}.achievement-card p{color:var(--text-muted);font-size:10px;line-height:1.4}.achievement-check{color:var(--color-success);position:absolute;top:8px;right:8px}.progress-reset{padding:var(--space-4) 0;justify-content:center;display:flex}@media (width<=768px){.progress-hero-grid,.progress-detail-grid{grid-template-columns:1fr}.achievements-grid{grid-template-columns:repeat(2,1fr)}}
