:root{--bg: #0a0a0a;--bg-elev: #141414;--bg-elev-2: #1c1c1c;--border: #262626;--border-strong: #3a3a3a;--cream: #f5e6d3;--cream-dim: #d9c9b4;--cream-mute: #8a7e6e;--text: #f5e6d3;--text-dim: #b8aa97;--text-mute: #6e6457;--accent: #f5e6d3;--accent-hover: #ffffff;--success: #6fcf97;--error: #eb6c6c;--warning: #f0c674;--radius: 14px;--radius-sm: 10px;--radius-lg: 22px;--shadow: 0 4px 24px rgba(0,0,0,.4);--shadow-hover: 0 8px 32px rgba(245, 230, 211, .08);--font: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Text", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", Menlo, monospace}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;min-height:100vh}body{background:var(--bg);color:var(--text);font-family:var(--font);font-weight:400;letter-spacing:-.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.app{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse 80% 60% at 20% 0%,rgba(245,230,211,.04),transparent 70%),radial-gradient(ellipse 60% 50% at 80% 100%,rgba(245,230,211,.03),transparent 70%),var(--bg)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:22px 36px;border-bottom:1px solid var(--border);background:#0a0a0ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:sticky;top:0;z-index:50}.topbar h1{font-size:17px;font-weight:600;letter-spacing:-.02em;color:var(--cream)}.topbar .crumb{color:var(--text-mute);font-weight:400;margin-left:10px}.back-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-size:14px;color:var(--text-dim);border-radius:var(--radius-sm);transition:all .15s ease}.back-btn:hover{background:var(--bg-elev);color:var(--cream)}.container{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:48px 36px 80px}.container-narrow{max-width:780px}.hero{margin-bottom:56px;text-align:left}.hero h1{font-size:56px;font-weight:700;letter-spacing:-.03em;line-height:1.05;color:var(--cream);margin-bottom:14px}.hero p{font-size:18px;color:var(--text-dim);font-weight:400}.hero .stats-row{display:flex;gap:32px;margin-top:28px;flex-wrap:wrap}.stat-pill{display:inline-flex;flex-direction:column;gap:2px;padding:14px 20px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius)}.stat-pill .label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute);font-weight:500}.stat-pill .value{font-size:22px;font-weight:600;color:var(--cream);font-variant-numeric:tabular-nums}.hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-bottom:64px}.hub-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;cursor:pointer;transition:all .18s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;gap:12px;min-height:170px;text-align:left;width:100%}.hub-card:hover{background:var(--bg-elev-2);border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow-hover)}.hub-card .icon{font-size:26px;color:var(--cream);margin-bottom:4px}.hub-card h3{font-size:20px;font-weight:600;color:var(--cream);letter-spacing:-.02em}.hub-card p{font-size:14px;color:var(--text-dim);line-height:1.4;flex:1}.hub-card .meta{font-size:12px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.section-heading{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;margin-top:12px}.section-heading h2{font-size:22px;font-weight:600;color:var(--cream);letter-spacing:-.02em}.section-heading .hint{font-size:13px;color:var(--text-mute)}.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.topic-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px 20px;text-align:left;cursor:pointer;transition:all .15s ease;display:flex;flex-direction:column;gap:8px;width:100%}.topic-card:hover{border-color:var(--cream-mute);background:var(--bg-elev-2)}.topic-card .num{font-size:11px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono)}.topic-card h4{font-size:15px;font-weight:600;color:var(--cream);letter-spacing:-.01em;line-height:1.3}.topic-card .progress-row{display:flex;align-items:center;gap:10px;margin-top:4px}.progress-bar{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--cream);border-radius:2px;transition:width .4s cubic-bezier(.16,1,.3,1)}.progress-label{font-size:11px;color:var(--text-mute);font-variant-numeric:tabular-nums;min-width:30px;text-align:right}.question-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;margin-bottom:24px}.question-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute);font-weight:500}.question-text{font-size:20px;line-height:1.5;color:var(--cream);margin-bottom:32px;font-weight:400;letter-spacing:-.01em;white-space:pre-wrap}.options{display:flex;flex-direction:column;gap:10px}.option{display:flex;align-items:flex-start;gap:14px;padding:18px 22px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);text-align:left;font-size:15px;color:var(--text);line-height:1.4;transition:all .15s ease;width:100%;cursor:pointer;font-family:inherit}.option:hover:not(:disabled){border-color:var(--cream-mute);background:#222}.option:disabled{cursor:default}.option .letter{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--bg);border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-dim)}.option.correct{border-color:var(--success);background:#6fcf9714}.option.correct .letter{background:var(--success);color:#0a0a0a;border-color:var(--success)}.option.incorrect{border-color:var(--error);background:#eb6c6c14}.option.incorrect .letter{background:var(--error);color:#0a0a0a;border-color:var(--error)}.option .text{flex:1;padding-top:2px}.solution{margin-top:24px;padding:22px 26px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);border-left:3px solid var(--cream)}.solution h5{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--cream-mute);font-weight:600;margin-bottom:10px}.solution p,.solution .body{font-size:14.5px;color:var(--text-dim);line-height:1.6;white-space:pre-wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;letter-spacing:-.01em;transition:all .15s ease;cursor:pointer;font-family:inherit}.btn-primary{background:var(--cream);color:#0a0a0a}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:var(--bg-elev-2);color:var(--cream);border:1px solid var(--border-strong)}.btn-secondary:hover{background:var(--bg-elev);border-color:var(--cream-mute)}.btn-row{display:flex;gap:12px;margin-top:8px;align-items:center;flex-wrap:wrap}.flashcard-stage{display:flex;flex-direction:column;align-items:center;gap:28px}.flashcard{width:100%;max-width:640px;height:360px;position:relative;cursor:pointer;perspective:1500px}.flashcard-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.16,1,.3,1);transform-style:preserve-3d}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-face{position:absolute;top:0;right:0;bottom:0;left:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:48px;display:flex;align-items:center;justify-content:center;text-align:center}.flashcard-face.back{transform:rotateY(180deg);background:var(--bg-elev-2);border-color:var(--cream-mute)}.flashcard-face .label{position:absolute;top:18px;left:24px;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-mute);font-weight:600}.flashcard-face .content{font-size:22px;color:var(--cream);line-height:1.5;font-weight:500;letter-spacing:-.01em;max-height:100%;overflow-y:auto;white-space:pre-wrap}.flashcard-face.back .content{font-weight:400;font-size:17px;color:var(--text-dim)}.cheatsheet{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:44px 52px;line-height:1.7;color:var(--text-dim)}.cheatsheet h1,.cheatsheet h2,.cheatsheet h3,.cheatsheet h4{color:var(--cream);letter-spacing:-.02em;font-weight:600;margin-top:28px;margin-bottom:14px}.cheatsheet h1{font-size:28px;margin-top:0}.cheatsheet h2{font-size:22px}.cheatsheet h3{font-size:18px}.cheatsheet h4{font-size:15px}.cheatsheet p{margin-bottom:14px;font-size:15px}.cheatsheet ul,.cheatsheet ol{margin-left:20px;margin-bottom:16px;font-size:15px}.cheatsheet li{margin-bottom:6px}.cheatsheet code{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:2px 7px;font-family:var(--font-mono);font-size:13px;color:var(--cream)}.cheatsheet pre{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin:14px 0;overflow-x:auto}.cheatsheet pre code{background:none;border:none;padding:0;color:var(--text)}.cheatsheet strong{color:var(--cream);font-weight:600}.cheatsheet em{color:var(--cream-dim);font-style:italic}.cheatsheet table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px}.cheatsheet table th,.cheatsheet table td{border:1px solid var(--border);padding:10px 14px;text-align:left}.cheatsheet table th{background:var(--bg);color:var(--cream);font-weight:600}.cheatsheet table td{color:var(--text-dim)}.cheatsheet hr{border:none;border-top:1px solid var(--border);margin:24px 0}.cheatsheet a{color:var(--cream);text-decoration:underline}.exam-header{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:28px}.exam-timer{font-family:var(--font-mono);font-size:20px;font-weight:600;color:var(--cream);font-variant-numeric:tabular-nums}.exam-timer.warning{color:var(--warning)}.exam-timer.danger{color:var(--error)}.exam-progress-text{font-size:13px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em}.exam-results{text-align:center;padding:60px 24px}.exam-results .score-big{font-size:88px;font-weight:700;color:var(--cream);letter-spacing:-.04em;line-height:1;margin-bottom:12px;font-variant-numeric:tabular-nums}.exam-results .score-sub{font-size:18px;color:var(--text-dim);margin-bottom:32px}.exam-results .breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;max-width:600px;margin:32px auto}.exam-results .breakdown .cell{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}.exam-results .breakdown .cell .v{font-size:26px;font-weight:600;color:var(--cream)}.exam-results .breakdown .cell .l{font-size:12px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}.drill-tabs{display:flex;gap:8px;margin-bottom:28px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:5px;width:fit-content}.drill-tab{padding:9px 22px;font-size:14px;font-weight:500;color:var(--text-dim);border-radius:var(--radius-sm);transition:all .15s ease}.drill-tab.active{background:var(--cream);color:#0a0a0a;font-weight:600}.drill-tab:not(.active):hover{color:var(--cream)}.drill-counter{display:flex;gap:18px;margin-bottom:24px;font-size:13px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em}.drill-counter strong{color:var(--cream);font-weight:600}.streak-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#f5e6d30f;border:1px solid var(--cream-mute);border-radius:999px;font-size:13px;color:var(--cream);font-weight:500}.empty{text-align:center;padding:80px 24px;color:var(--text-mute)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--cream-mute)}@media (max-width: 720px){.topbar{padding:16px 20px}.container{padding:32px 20px 60px}.hero h1{font-size:38px}.question-card{padding:26px}.question-text{font-size:17px}.cheatsheet{padding:28px 24px}.flashcard{height:320px}.flashcard-face{padding:28px}.flashcard-face .content{font-size:18px}.exam-results .score-big{font-size:64px}}
