*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,Segoe UI,Roboto,sans-serif;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(99,102,241,.08) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 20% 100%,rgba(34,211,238,.04) 0%,transparent 60%);pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(99,102,241,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.03) 1px,transparent 1px);background-size:40px 40px;mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 20%,transparent 70%);pointer-events:none;z-index:0}.app{max-width:1280px;margin:0 auto;padding:20px;position:relative;z-index:1}.mono{font-family:JetBrains Mono,ui-monospace,monospace}.screen{display:none;animation:fadeIn .3s ease-out}.screen.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.menu{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:20px}.title-block{margin-bottom:48px}.title{font-size:clamp(44px,8vw,88px);font-weight:800;letter-spacing:-2px;line-height:1;background:linear-gradient(180deg,#fff 0%,var(--accent-bright) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 60px var(--glow);filter:drop-shadow(0 0 20px var(--glow))}.title-mark{display:inline-block;font-family:JetBrains Mono,monospace;color:var(--magenta);margin-right:12px}.tagline{color:var(--text-dim);font-size:17px;margin-top:14px;letter-spacing:.5px}.tagline .sep{color:var(--accent);margin:0 12px}.mode-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;max-width:720px;width:100%;margin-bottom:40px}.mode-card{background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--border);border-radius:16px;padding:28px 24px;text-align:left;cursor:pointer;transition:all .2s ease;color:inherit;font-family:inherit;position:relative;overflow:hidden}.mode-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 0%,var(--accent) 100%);opacity:0;transition:opacity .3s ease}.mode-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 40px #6366f140}.mode-card:hover:before{opacity:.06}.mode-card .icon{font-size:32px;margin-bottom:16px;display:inline-block;line-height:1}.mode-card h2{font-size:22px;font-weight:700;letter-spacing:-.3px;margin-bottom:6px;position:relative}.mode-card p{color:var(--text-dim);font-size:14px;line-height:1.5;position:relative}.mode-card .mode-tag{position:absolute;top:18px;right:18px;background:#6366f126;color:var(--accent-bright);font-size:10px;font-weight:700;padding:4px 8px;border-radius:4px;letter-spacing:.8px;font-family:JetBrains Mono,monospace}.stats-strip{display:flex;gap:28px;flex-wrap:wrap;justify-content:center;padding:20px 28px;background:var(--panel);border:1px solid var(--border);border-radius:12px}.stats-strip .stat{text-align:center}.stats-strip .stat-value{font-family:JetBrains Mono,monospace;font-size:24px;font-weight:700;color:var(--accent-bright);line-height:1}.stats-strip .stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:6px}.menu-footer-btns{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap;justify-content:center}.link-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:10px 18px;border-radius:8px;cursor:pointer;font-family:inherit;font-size:13px;transition:all .15s ease}.link-btn:hover{border-color:var(--accent);color:var(--text)}.hud{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;padding:12px 18px;background:var(--panel);border:1px solid var(--border);border-radius:12px;margin-bottom:18px}.hud-left,.hud-right{display:flex;gap:14px;align-items:center}.hud-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600}.hud-chip.streak{color:var(--amber);border-color:#fbbf2459}.hud-chip.streak.hot{background:#fbbf241f;box-shadow:0 0 20px #fbbf2440}.hud-chip.level{color:var(--accent-bright)}.hud-chip.xp{color:var(--cyan)}.hud-title{text-align:center;font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text-dim);letter-spacing:1.5px}.hud-title strong{color:var(--text);letter-spacing:2px}.icon-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);width:36px;height:36px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s ease}.icon-btn:hover{background:var(--panel-3);color:var(--text);border-color:var(--accent)}.cockpit{display:grid;grid-template-columns:1fr 1.3fr;gap:20px;margin-bottom:24px}@media (max-width: 900px){.cockpit{grid-template-columns:1fr}}.clearance{background:linear-gradient(180deg,#0f1420,#141b2b);border:1px solid var(--border);border-radius:14px;padding:0;overflow:hidden;display:flex;flex-direction:column}.clearance-header{background:linear-gradient(180deg,var(--panel-3) 0%,var(--panel-2) 100%);padding:12px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-family:JetBrains Mono,monospace;font-size:12px;letter-spacing:1.5px;color:var(--text-dim)}.clearance-header .live-dot{display:inline-flex;align-items:center;gap:6px;color:var(--green-bright)}.clearance-header .live-dot:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green-bright);box-shadow:0 0 8px var(--glow-green);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.clearance-body{padding:20px 22px;flex:1;display:flex;flex-direction:column;gap:14px}.clearance-text{font-family:JetBrains Mono,monospace;font-size:15px;line-height:1.7;color:var(--amber-bright);letter-spacing:.3px}.clearance-text .hl{color:#fff;font-weight:700}.clearance-text .turn-r{color:var(--cyan);font-weight:700}.clearance-text .turn-l{color:var(--magenta-bright);font-weight:700}.clearance-meta{display:flex;gap:18px;padding-top:14px;border-top:1px dashed var(--border);font-family:JetBrains Mono,monospace;font-size:12px;color:var(--muted)}.clearance-meta .meta-item{display:flex;flex-direction:column;gap:2px}.clearance-meta .meta-label{font-size:10px;letter-spacing:1.2px;color:var(--muted)}.clearance-meta .meta-value{color:var(--text);font-size:14px;font-weight:600}.hsi-panel{background:linear-gradient(180deg,#0c111c,#0a0f1a);border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;align-items:center;gap:14px}.hsi-readouts{display:flex;gap:14px;width:100%;justify-content:space-between}.readout-box{background:#000;border:1px solid var(--border-bright);border-radius:6px;padding:6px 12px;display:flex;align-items:center;gap:8px;flex:1;justify-content:center}.readout-box .readout-label{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--muted);letter-spacing:1px}.readout-box .readout-value{font-family:JetBrains Mono,monospace;font-size:20px;font-weight:700;color:var(--green-bright);text-shadow:0 0 10px var(--glow-green);letter-spacing:1px;min-width:42px;text-align:center}.readout-box.course .readout-value{color:var(--magenta-bright);text-shadow:0 0 10px var(--glow-magenta)}.hsi-svg-wrap{width:100%;max-width:420px;aspect-ratio:1;position:relative}.hsi-svg{width:100%;height:100%;display:block}.hsi-caption{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--muted);letter-spacing:1px;text-align:center}.hsi-caption .turn-right{color:var(--cyan)}.hsi-caption .turn-left{color:var(--magenta-bright)}.answer-section{text-align:center;margin-bottom:20px}.answer-prompt{font-size:15px;color:var(--text-dim);margin-bottom:14px;letter-spacing:.5px}.answer-prompt strong{color:var(--text)}.answer-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width: 600px){.answer-buttons{grid-template-columns:1fr}}.answer-btn{background:linear-gradient(180deg,var(--panel-2) 0%,var(--panel) 100%);border:1px solid var(--border);border-radius:12px;padding:18px 16px;cursor:pointer;color:var(--text);font-family:inherit;transition:all .15s ease;display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;overflow:hidden}.answer-btn:hover:not(:disabled){border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 24px #6366f133}.answer-btn:active:not(:disabled){transform:translateY(0)}.answer-btn:disabled{cursor:not-allowed;opacity:.6}.answer-btn.correct{border-color:var(--green);background:linear-gradient(180deg,#22c55e33,#22c55e14);box-shadow:0 0 30px var(--glow-green)}.answer-btn.incorrect{border-color:var(--red);background:linear-gradient(180deg,#ef444433,#ef444414);animation:shake .35s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.answer-btn svg{width:38px;height:38px}.answer-btn .label{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;letter-spacing:2px}.answer-btn .hint{font-size:11px;color:var(--muted);letter-spacing:.3px}.timer-bar{width:100%;height:4px;background:var(--panel-2);border-radius:2px;overflow:hidden;margin-bottom:14px}.timer-fill{height:100%;background:linear-gradient(90deg,var(--green-bright) 0%,var(--amber) 70%,var(--red) 100%);transition:width .1s linear;width:100%}.verdict{display:flex;align-items:center;justify-content:center;gap:16px;padding:20px;border-radius:14px;margin-bottom:20px;font-family:JetBrains Mono,monospace;letter-spacing:2px;font-size:20px;font-weight:700}.verdict.correct{background:linear-gradient(180deg,#22c55e33,#22c55e14);border:1px solid var(--green);color:var(--green-bright);box-shadow:0 0 40px var(--glow-green)}.verdict.incorrect{background:linear-gradient(180deg,#ef444433,#ef444414);border:1px solid var(--red);color:var(--red-bright);box-shadow:0 0 40px var(--glow-red)}.verdict .verdict-badge{font-size:28px}.verdict .xp-gain{margin-left:auto;font-size:16px;color:var(--cyan);font-weight:600}.reveal-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:20px;margin-bottom:24px}@media (max-width: 900px){.reveal-grid{grid-template-columns:1fr}}.topdown-panel{background:linear-gradient(180deg,#0c111c,#0a0f1a);border:1px solid var(--border);border-radius:14px;padding:14px}.topdown-panel .panel-header{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-dim);letter-spacing:1.5px;padding:4px 6px 10px;display:flex;justify-content:space-between;align-items:center}.topdown-svg-wrap{width:100%;aspect-ratio:1;background:#04080f;border-radius:8px;overflow:hidden;position:relative}.topdown-svg{width:100%;height:100%;display:block}.explanation-panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px 22px;display:flex;flex-direction:column;gap:14px}.explanation-panel h3{font-size:12px;letter-spacing:2px;color:var(--text-dim);font-family:JetBrains Mono,monospace;font-weight:600}.explanation-body{font-size:15px;line-height:1.6;color:var(--text)}.explanation-body .tag{display:inline-block;padding:2px 8px;border-radius:4px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;margin:0 2px}.tag.direct{background:#22c55e33;color:var(--green-bright)}.tag.parallel{background:#22d3ee33;color:var(--cyan)}.tag.teardrop{background:#fbbf2433;color:var(--amber)}.tag.num{background:var(--panel-3);color:var(--text)}.sector-breakdown{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:8px}.sector-row{display:grid;grid-template-columns:90px 1fr auto;align-items:center;gap:10px;font-size:13px}.sector-row .bar{height:6px;border-radius:3px;background:var(--panel-3);position:relative;overflow:hidden}.sector-row .bar-fill{height:100%;border-radius:3px}.sector-row.direct .bar-fill{background:var(--green-bright);width:50%}.sector-row.parallel .bar-fill{background:var(--cyan);width:30.5%}.sector-row.teardrop .bar-fill{background:var(--amber);width:19.5%}.sector-row .arc{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--muted)}.sector-row.highlighted{background:#6366f126;margin:-4px -8px;padding:4px 8px;border-radius:6px}.primary-btn{background:linear-gradient(180deg,var(--accent) 0%,#4f51d4 100%);border:1px solid var(--accent-bright);color:#fff;padding:14px 28px;border-radius:10px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:700;letter-spacing:1.5px;transition:all .15s ease;box-shadow:0 4px 20px #6366f159;width:100%}.primary-btn:hover{transform:translateY(-1px);box-shadow:0 6px 28px #6366f180}.primary-btn.secondary{background:var(--panel-2);border-color:var(--border);box-shadow:none;color:var(--text-dim)}.primary-btn.secondary:hover{color:var(--text);border-color:var(--accent)}.result-card{max-width:560px;margin:40px auto 20px;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--border);border-radius:18px;padding:40px;text-align:center}.result-grade-pill{display:inline-block;padding:8px 18px;border-radius:999px;font-family:JetBrains Mono,monospace;font-size:12px;letter-spacing:2px;font-weight:700;margin-bottom:20px}.result-grade-pill.pass{background:#22c55e33;color:var(--green-bright);border:1px solid var(--green)}.result-grade-pill.fail{background:#ef444433;color:var(--red-bright);border:1px solid var(--red)}.result-score-big{font-family:JetBrains Mono,monospace;font-size:96px;font-weight:800;line-height:1;color:#fff;margin-bottom:8px;letter-spacing:-3px}.result-score-big .of{color:var(--muted);font-size:48px}.result-label{font-size:22px;font-weight:700;letter-spacing:.5px;margin-bottom:30px}.result-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}.result-stat{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:12px 10px}.result-stat .value{font-family:JetBrains Mono,monospace;font-size:20px;font-weight:700;color:var(--accent-bright)}.result-stat .label{font-size:11px;color:var(--muted);letter-spacing:1px;margin-top:4px}.result-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.toast{position:fixed;bottom:30px;left:50%;transform:translate(-50%) translateY(100px);background:linear-gradient(180deg,var(--panel-3) 0%,var(--panel-2) 100%);border:1px solid var(--accent);border-radius:12px;padding:14px 22px;display:flex;align-items:center;gap:14px;box-shadow:0 10px 50px #6366f180;opacity:0;transition:all .4s cubic-bezier(.2,.8,.2,1);z-index:100;max-width:90vw}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast .toast-icon{font-size:28px;filter:drop-shadow(0 0 8px var(--glow))}.toast .toast-title{font-weight:700;font-size:14px;color:var(--accent-bright);letter-spacing:.5px}.toast .toast-desc{font-size:12px;color:var(--text-dim);margin-top:2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:50;padding:20px}.modal-overlay.show{display:flex}.modal{background:var(--panel);border:1px solid var(--border-bright);border-radius:16px;padding:28px;max-width:540px;width:100%;max-height:90vh;overflow-y:auto}.modal-title{font-size:20px;font-weight:700;margin-bottom:8px}.modal-sub{color:var(--text-dim);font-size:14px;margin-bottom:20px}.achievement-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.achievement-row{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;transition:all .2s ease}.achievement-row.unlocked{border-color:var(--amber);background:linear-gradient(90deg,rgba(251,191,36,.08) 0%,var(--panel-2) 100%)}.achievement-row .ach-icon{font-size:24px;filter:grayscale(1);opacity:.4}.achievement-row.unlocked .ach-icon{filter:none;opacity:1}.achievement-row .ach-title{font-weight:600;font-size:14px}.achievement-row .ach-desc{font-size:12px;color:var(--text-dim);margin-top:2px}.modal-close{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:10px 16px;border-radius:8px;cursor:pointer;font-family:inherit;font-size:13px;width:100%;transition:all .15s ease}.modal-close:hover{border-color:var(--accent)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;margin-bottom:10px}.settings-row .settings-label{font-size:14px;font-weight:500}.settings-row .settings-sub{font-size:12px;color:var(--text-dim);margin-top:2px}.toggle{width:44px;height:24px;background:var(--panel-3);border-radius:12px;position:relative;cursor:pointer;transition:background .2s ease;flex-shrink:0}.toggle.on{background:var(--accent)}.toggle:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s cubic-bezier(.2,.8,.2,1)}.toggle.on:after{transform:translate(20px)}.hsi-tick{stroke:#fff}.hsi-num{fill:#fff;font-family:JetBrains Mono,monospace;font-weight:600}.hsi-cardinal{fill:#fff;font-family:Inter,sans-serif;font-weight:800}@keyframes xpFlash{0%{transform:scale(1);color:var(--cyan)}30%{transform:scale(1.3);color:var(--amber-bright);text-shadow:0 0 20px var(--amber)}to{transform:scale(1);color:var(--cyan)}}.xp-flash{animation:xpFlash .6s ease-out}@keyframes streakPop{0%{transform:scale(1)}40%{transform:scale(1.25)}to{transform:scale(1)}}.streak-pop{animation:streakPop .4s ease-out}.level-up{position:fixed;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center;z-index:80;pointer-events:none}.level-up.show{display:flex;animation:levelUpFade 2.2s ease-out}@keyframes levelUpFade{0%{opacity:0}15%,85%{opacity:1}to{opacity:0}}.level-up-content{text-align:center}.level-up-title{font-family:JetBrains Mono,monospace;font-size:14px;letter-spacing:4px;color:var(--accent-bright);margin-bottom:10px}.level-up-name{font-size:56px;font-weight:800;letter-spacing:-1px;background:linear-gradient(180deg,#fff 0%,var(--accent-bright) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 40px var(--glow))}.level-up-num{font-family:JetBrains Mono,monospace;font-size:18px;color:var(--amber);margin-top:10px;letter-spacing:2px}.entry-path{fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:1600;stroke-dashoffset:1600;animation:drawPath 2.6s ease-out .3s forwards}@keyframes drawPath{to{stroke-dashoffset:0}}.entry-arrow{opacity:0;filter:drop-shadow(0 0 4px currentColor);animation:arrowFade .5s ease-out 2.4s forwards}@keyframes arrowFade{to{opacity:1}}.aircraft-icon{transform-box:fill-box;transform-origin:center}.checkride-progress-chips{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;margin-bottom:14px}.cr-chip{width:22px;height:8px;border-radius:2px;background:var(--panel-3);transition:background .2s ease}.cr-chip.correct{background:var(--green-bright)}.cr-chip.incorrect{background:var(--red-bright)}.cr-chip.current{background:var(--accent);animation:pulse 1.5s infinite}.text-dim{color:var(--text-dim)}.hidden{display:none!important}.referral-modal{max-width:480px}.referral-actions{display:flex;gap:12px;margin-bottom:14px}.referral-actions .modal-close{flex:0 0 auto;width:auto}.referral-actions .primary-btn{flex:1 1 auto;text-decoration:none;text-align:center;display:inline-flex;align-items:center;justify-content:center}.referral-disclosure{font-size:11px;color:var(--muted);text-align:center;line-height:1.5}.offline-banner{display:none;position:fixed;top:0;left:0;right:0;padding:10px 16px;background:#b91c1c;color:#fff;font-size:14px;font-weight:600;text-align:center;z-index:9999;border-bottom:1px solid rgba(0,0,0,.3)}.offline-banner.show{display:block}.bmac-corner{position:fixed;top:14px;right:14px;z-index:1000;display:inline-flex;align-items:center;gap:6px;padding:7px 12px;background:#fbbf24;color:#1a1a1a;border-radius:7px;text-decoration:none;font-weight:700;font-size:13px;font-family:Inter,system-ui,sans-serif;letter-spacing:.01em;box-shadow:0 2px 8px #00000059;transition:background .12s ease,transform .12s ease}.bmac-corner:hover{background:#f59e0b;transform:translateY(-1px)}.bmac-corner-icon{font-size:14px;line-height:1}@media (max-width: 700px){.bmac-corner{top:10px;right:10px;padding:6px 10px;font-size:12px}.bmac-corner-label{display:none}}
