@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-deep:#000;--bg-mid:#060606;--bg-surface:#0f0f0f;--card:#ffffff06;--card-solid:#0d0d0d;--card-hover:#ffffff0d;--border:#ffffff12;--border-lit:#ffffff24;--accent:#fff;--accent-2:#aaa;--cyan:#fff;--green:#fff;--red:#f44;--yellow:#fff;--purple:#fff;--text:#fff;--text-2:#666;--text-3:#333}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg-deep);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif;overflow-x:hidden}#root{flex-direction:column;align-items:center;min-height:100vh;display:flex}.app-bg{pointer-events:none;z-index:0;background-color:#000;background-image:linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-position:0 0;background-repeat:repeat;background-size:48px 48px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;position:fixed;inset:0}.screen{z-index:1;flex-direction:column;flex:1 0 auto;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:2rem 1rem;display:flex;position:relative}.landing{text-align:center;max-width:680px;margin-left:auto;margin-right:auto}.landing-badge{color:#fff6;letter-spacing:.12em;text-transform:uppercase;background:0 0;border:1px solid #ffffff26;border-radius:100px;align-items:center;gap:.4rem;margin-bottom:1.75rem;padding:.35rem .9rem;font-size:.7rem;font-weight:700;display:inline-flex}.landing-title{letter-spacing:-.04em;color:#fff;margin-bottom:1.25rem;font-size:clamp(3rem,9vw,6.5rem);font-weight:900;line-height:.95;position:relative}.landing-sub{color:var(--text-2);max-width:440px;margin:0 auto 2.5rem;font-size:clamp(.98rem,2.5vw,1.2rem);line-height:1.7}.landing-actions{flex-direction:column;align-items:center;gap:.8rem;margin-bottom:3.5rem;display:flex}.friend-banner{text-align:left;background:#ffffff08;border:1px solid #ffffff1a;border-radius:18px;max-width:420px;margin-bottom:2rem;padding:1.25rem 1.75rem}.friend-banner-label{text-transform:uppercase;letter-spacing:.12em;color:#fff6;margin-bottom:.3rem;font-size:.68rem;font-weight:700}.friend-banner-score{color:var(--text);margin-bottom:.2rem;font-size:1.1rem;font-weight:800}.friend-banner-sub{color:var(--text-2);font-size:.85rem}.how-grid{flex-wrap:wrap;justify-content:center;gap:2.5rem;display:flex}.how-item{text-align:center;flex-direction:column;align-items:center;gap:.3rem;max-width:110px;display:flex}.how-icon{font-size:1.6rem}.how-label{color:var(--text);font-size:.82rem;font-weight:800}.how-desc{color:var(--text-2);font-size:.72rem;line-height:1.45}.landing-footer{align-items:center;gap:.75rem;display:flex;position:absolute;bottom:1.75rem}.btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:14px;outline:none;justify-content:center;align-items:center;gap:.5rem;font-family:inherit;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .15s,background .15s,opacity .15s;display:inline-flex}.btn:active{transform:scale(.96)}.btn-primary{color:#000;background:#fff;padding:1rem 2.5rem;font-size:1.05rem}.btn-primary:hover{background:#e8e8e8;transform:translateY(-1px)}.btn-secondary{border:1px solid var(--border-lit);color:var(--text-2);background:0 0;padding:.85rem 2rem;font-size:.95rem}.btn-secondary:hover{color:var(--text);border-color:#ffffff40}.btn-outline{border:1px solid var(--border-lit);color:var(--text);background:#ffffff0a;padding:.7rem 1.4rem;font-size:.88rem}.btn-outline:hover{background:#ffffff14}.btn-ghost{color:var(--text-2);background:0 0;border:none;border-radius:8px;padding:.5rem .9rem;font-size:.88rem}.btn-ghost:hover{color:var(--text);background:#ffffff0d}.btn-success{color:#000;background:#fff;padding:.8rem 1.75rem;font-size:.95rem;font-weight:800}.btn-success:hover{background:#e8e8e8}.preview{width:100%;max-width:560px}.preview-title{text-align:center;margin-bottom:.4rem;font-size:1.6rem;font-weight:900}.preview-sub{color:var(--text-2);text-align:center;margin-bottom:1.75rem;font-size:.9rem}.band-list{flex-direction:column;gap:.4rem;width:100%;margin-bottom:2rem;display:flex}.band-item{background:var(--card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:12px;align-items:center;gap:1rem;padding:.75rem 1.2rem;transition:background .15s,border-color .15s;display:flex}.band-item:hover{background:var(--card-hover);border-color:var(--border-lit)}.band-num{color:#000;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:1.8rem;height:1.8rem;font-size:.75rem;font-weight:900;display:flex}.band-info{flex:1;min-width:0}.band-label{color:var(--text);font-size:.9rem;font-weight:700}.band-grade{color:var(--text-2);margin-top:.07rem;font-size:.74rem}.band-topics{flex-wrap:wrap;gap:.35rem;display:flex}.topic-chip{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-2);white-space:nowrap;border-radius:5px;padding:.15rem .45rem;font-size:.65rem;font-weight:600}@media (width<=500px){.band-topics{display:none}}.game-screen{justify-content:flex-start;width:100%;max-width:740px;margin-left:auto;margin-right:auto;padding-top:2.5rem}.game-header{width:100%;margin-bottom:1.5rem}.game-meta{justify-content:space-between;align-items:center;margin-bottom:.65rem;display:flex}.game-band-label{font-size:.9rem;font-weight:800}.q-counter{color:var(--text-2);font-variant-numeric:tabular-nums;font-size:.75rem;font-weight:700}.game-progress-track{gap:4px;height:5px;display:flex}.game-progress-seg{background:var(--bg-surface);border-radius:3px;flex:1;height:5px;transition:background .4s,box-shadow .4s}.game-progress-seg.active{box-shadow:0 0 10px}.band-dots{justify-content:center;gap:4px;margin-top:.7rem;display:flex}.band-dot{background:var(--bg-surface);border-radius:50%;width:6px;height:6px;transition:background .35s,transform .35s,box-shadow .35s}.band-dot.active{transform:scale(1.6);box-shadow:0 0 8px}.game-content{flex-direction:column;flex:1;justify-content:center;width:100%;display:flex}.band-progress-bar{background:#ffffff12;border-radius:2px;width:100%;height:2px;margin-top:.65rem;overflow:hidden}.band-progress-fill{background:#ffffff59;border-radius:2px;height:100%;transition:width .5s}.band-progress-label{color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;margin-top:.3rem;font-size:.65rem;font-weight:700}.question-card{background:var(--card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:22px;width:100%;margin-bottom:1.1rem;padding:1.75rem 2rem;transition:border-color .25s,box-shadow .25s;position:relative;overflow:hidden;box-shadow:0 8px 48px #00000080,inset 0 1px #ffffff0f}.question-card:before{content:"";opacity:0;background:linear-gradient(90deg,#0000,#ffffff1a,#0000);height:1px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.question-card.correct-card{border-color:#ffffff38}.question-card.correct-card:before{opacity:1}.question-card.wrong-card{border-color:#ff444473;box-shadow:0 0 20px #ff44440f}.question-card.wrong-card:before{opacity:0}.question-card.shake{animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-9px)}40%{transform:translate(9px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.q-topic{text-transform:uppercase;letter-spacing:.13em;color:var(--accent);margin-bottom:.6rem;font-size:.67rem;font-weight:800}.q-prompt{color:var(--text);white-space:pre-line;margin-bottom:1.5rem;font-size:clamp(1.05rem,2.8vw,1.35rem);font-weight:600;line-height:1.6}.choices{grid-template-columns:1fr 1fr;gap:.65rem;display:grid}@media (width<=460px){.choices{grid-template-columns:1fr}}.choice-btn{border:1px solid var(--border);text-align:left;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff08;border-radius:12px;align-items:center;gap:.75rem;padding:.85rem 1.1rem;font-family:inherit;font-size:.96rem;font-weight:600;transition:background .12s,border-color .12s,transform .1s;display:flex}.choice-btn:hover:not(:disabled){background:#ffffff0f;border-color:#ffffff2e}.choice-btn:active:not(:disabled){transform:scale(.97)}.choice-btn:disabled{cursor:default}.choice-letter{letter-spacing:0;background:var(--bg-surface);width:1.5rem;height:1.5rem;color:var(--text-2);border:1px solid var(--border);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:.68rem;font-weight:900;transition:background .15s,color .15s;display:flex}.choice-btn.selected-correct .choice-letter{color:#000;background:#fff;border-color:#fff}.choice-btn.selected-wrong .choice-letter{background:var(--red);color:#fff;border-color:var(--red)}.choice-btn.reveal-correct .choice-letter{color:#fff9;background:#ffffff1a;border-color:#ffffff2e}.choice-btn.selected-correct{color:var(--text);background:#ffffff0d;border-color:#fff3}.choice-btn.selected-wrong{color:#ff7878e6;background:#ff444412;border-color:#ff44444d}.choice-btn.reveal-correct{color:#ffffff80;background:#ffffff08;border-color:#ffffff21}.key-hint{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-3);border-radius:4px;align-items:center;margin-right:.15rem;padding:.1rem .35rem;font-size:.6rem;font-weight:700;display:inline-flex}.numeric-area{align-items:stretch;gap:.65rem;display:flex}.numeric-input{border:1px solid var(--border);color:var(--text);background:#ffffff08;border-radius:12px;outline:none;flex:1;padding:.9rem 1.2rem;font-family:Inter,monospace;font-size:1.15rem;font-weight:700;transition:border-color .15s,background .15s}.numeric-input:focus{background:#ffffff0d;border-color:#ffffff38}.numeric-input.correct{color:var(--text);border-color:#ffffff4d}.numeric-input.wrong{border-color:var(--red);color:var(--red)}.btn-submit{color:#000;cursor:pointer;white-space:nowrap;background:#fff;border:none;border-radius:12px;padding:.9rem 1.6rem;font-family:inherit;font-size:.95rem;font-weight:800;transition:background .15s,transform .1s}.btn-submit:hover{background:#e8e8e8;transform:translateY(-1px)}.btn-submit:active{transform:scale(.97)}.numeric-hint{color:var(--text-3);margin-top:.45rem;font-size:.72rem;font-style:italic}.feedback-row{border-radius:12px;align-items:flex-start;gap:.65rem;padding:.9rem 1.1rem;font-size:.86rem;line-height:1.6;animation:.22s fadeUp;display:flex}.feedback-row.correct-fb{background:#ffffff08;border:1px solid #ffffff1a}.feedback-row.wrong-fb{background:#ff44440f;border:1px solid #f443}.feedback-icon{flex-shrink:0;margin-top:.1rem;font-size:1rem}.correct-fb .feedback-text{color:var(--text-2)}.wrong-fb .feedback-text{color:#ff8c8ce6}.feedback-text strong{color:var(--text);font-weight:700}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.timer-wrap{color:var(--text-2);font-variant-numeric:tabular-nums;align-items:center;gap:.5rem;font-size:.8rem;font-weight:800;display:flex}.timer-bar-track{background:var(--bg-surface);border-radius:2px;width:64px;height:4px;overflow:hidden}.timer-bar{background:var(--green);border-radius:2px;height:100%;transition:width .9s linear}.timer-bar.warn{background:var(--yellow)}.timer-bar.danger{background:var(--red);animation:.5s infinite timerPulse}@keyframes timerPulse{0%,to{opacity:1}50%{opacity:.6}}.toggles{gap:.5rem;display:flex}.toggle-btn{border:1px solid var(--border);color:var(--text-3);cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-family:inherit;font-size:.72rem;font-weight:700;transition:all .15s;display:flex}.toggle-btn.on{color:var(--text);background:#ffffff12;border-color:#ffffff4d}.end-screen{text-align:center;width:100%;max-width:580px;margin-left:auto;margin-right:auto}.end-reveal{opacity:0;width:100%;transition:opacity .5s,transform .5s cubic-bezier(.22,1,.36,1);transform:translateY(18px)}.end-reveal.visible{opacity:1;transform:translateY(0)}.grandmaster-glow{pointer-events:none;z-index:0;background:radial-gradient(80% 60% at 50% 25%,#ffffff08 0%,#0000 65%);animation:2.5s ease-in-out infinite gmPulse;position:fixed;inset:0}@keyframes gmPulse{0%,to{opacity:1}50%{opacity:.45}}.gm-badge{color:#000;letter-spacing:.1em;text-transform:uppercase;background:#fff;border-radius:100px;margin-bottom:1.25rem;padding:.45rem 1.35rem;font-size:.82rem;font-weight:900;display:inline-block}.end-band-chip{color:#ffffff80;letter-spacing:.12em;text-transform:uppercase;background:0 0;border:1px solid #ffffff26;border-radius:100px;margin-bottom:1.25rem;padding:.35rem 1rem;font-size:.7rem;font-weight:800;display:inline-block}.end-grade{margin-bottom:.5rem;font-size:clamp(1.9rem,5.5vw,3rem);font-weight:900;line-height:1.1}.end-sub{color:var(--text-2);margin-bottom:.35rem;font-size:1rem}.end-flavor{color:var(--text-2);max-width:380px;margin-bottom:1.75rem;margin-left:auto;margin-right:auto;font-size:.88rem;font-style:italic}.new-best{color:var(--text);background:0 0;border:1px solid #fff3;border-radius:100px;margin-bottom:1.25rem;padding:.3rem .9rem;font-size:.8rem;font-weight:700;animation:.5s cubic-bezier(.22,1,.36,1) .3s both newBestPop;display:inline-block}@keyframes newBestPop{0%{transform:scale(0)}to{transform:scale(1)}}.end-stats{flex-wrap:wrap;justify-content:center;gap:2rem;margin-bottom:1.75rem;display:flex}.stat-box{text-align:center}.stat-num{font-variant-numeric:tabular-nums;font-size:3rem;font-weight:900;line-height:1}.stat-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.08em;margin-top:.2rem;font-size:.7rem;font-weight:700}.end-ladder{gap:3px;width:100%;max-width:380px;margin:0 auto 1.75rem;display:flex}.ladder-seg{border:1px solid #0000;border-radius:7px;flex:1;justify-content:center;align-items:center;height:30px;transition:all .4s cubic-bezier(.22,1,.36,1);display:flex;position:relative}.ladder-seg.current{box-shadow:0 0 12px}.ladder-num{font-size:.66rem;font-weight:900}.end-actions{flex-direction:column;align-items:center;gap:.7rem;margin-bottom:1.5rem;display:flex}.end-actions-row{flex-wrap:wrap;justify-content:center;gap:.6rem;display:flex}.review-screen{width:100%;max-width:600px}.review-back{align-self:flex-start;margin-bottom:1.5rem}.review-title{margin-bottom:.4rem;font-size:1.35rem;font-weight:900}.review-sub{color:var(--text-2);margin-bottom:1.75rem;font-size:.88rem}.review-card{background:var(--card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:20px;width:100%;margin-bottom:1.25rem;padding:1.6rem}.review-prompt{white-space:pre-line;margin-bottom:1.2rem;font-size:1.05rem;font-weight:600;line-height:1.55}.review-answer-row{flex-wrap:wrap;gap:.65rem;margin-bottom:1.2rem;display:flex}.review-answer-item{border-radius:8px;padding:.45rem .95rem;font-size:.88rem;font-weight:700}.review-answer-item.correct-ans{color:var(--text);background:#ffffff0d;border:1px solid #ffffff26}.review-explanation{color:var(--text-2);border-top:1px solid var(--border);padding-top:1.15rem;font-size:.88rem;line-height:1.7}.toast{background:var(--card-solid);color:var(--green);z-index:999;white-space:nowrap;border:1px solid #69f0ae4d;border-radius:12px;padding:.7rem 1.4rem;font-size:.88rem;font-weight:700;animation:.2s toastIn,.3s 2.3s forwards toastOut;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastOut{to{opacity:0;transform:translate(-50%)translateY(10px)}}@keyframes slideIn{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.slide-in{animation:.3s cubic-bezier(.22,1,.36,1) slideIn}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-surface);border-radius:3px}@media (width<=640px){.screen{padding:1.25rem .875rem}.question-card{padding:1.35rem 1.15rem}.game-screen{padding-top:1.25rem}.end-stats{gap:1.5rem}.stat-num{font-size:2.4rem}}
