:root{--bg: #f1f2f6;--bg-darker: #d6d7de;--bg-lighter: #f8f9fc;--text: #1a1a1f;--text-muted: #555568;--text-dim: #707084;--accent: #ff5722;--accent-hover: #e64a19;--accent-soft: rgba(255, 87, 34, .1);--accent-glow: rgba(255, 87, 34, .25);--win: #2ecc71;--win-soft: rgba(46, 204, 113, .08);--loss: #e74c3c;--loss-soft: rgba(231, 76, 60, .08);--radius: 16px;--radius-sm: 12px;--radius-xs: 8px;--neu-out: 6px 6px 14px rgba(163, 177, 198, .55), -6px -6px 14px rgba(255, 255, 255, .95);--neu-out-sm: 3px 3px 7px rgba(163, 177, 198, .5), -3px -3px 7px rgba(255, 255, 255, .9);--neu-out-lg: 12px 12px 28px rgba(163, 177, 198, .65), -10px -10px 24px rgba(255, 255, 255, 1);--neu-in: inset 5px 5px 10px rgba(163, 177, 198, .55), inset -5px -5px 10px rgba(255, 255, 255, .95);--neu-in-sm: inset 3px 3px 6px rgba(163, 177, 198, .5), inset -3px -3px 6px rgba(255, 255, 255, .9);--neu-pressed: inset 3px 3px 6px rgba(163, 177, 198, .55), inset -3px -3px 6px rgba(255, 255, 255, .9);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg: #1e1e2e;--bg-darker: #161622;--bg-lighter: #282840;--text: #e0e0f0;--text-muted: #9898b0;--text-dim: #6868a0;--accent: #ff7043;--accent-hover: #ff8559;--accent-soft: rgba(255, 112, 67, .14);--accent-glow: rgba(255, 112, 67, .3);--win: #3ddc84;--win-soft: rgba(61, 220, 132, .1);--loss: #ff5c5c;--loss-soft: rgba(255, 92, 92, .1);--neu-out: 6px 6px 14px rgba(10, 10, 18, .7), -6px -6px 14px rgba(50, 50, 75, .25);--neu-out-sm: 4px 4px 8px rgba(10, 10, 18, .6), -4px -4px 8px rgba(50, 50, 75, .2);--neu-out-lg: 10px 10px 22px rgba(10, 10, 18, .8), -10px -10px 22px rgba(50, 50, 75, .3);--neu-in: inset 4px 4px 8px rgba(10, 10, 18, .6), inset -4px -4px 8px rgba(50, 50, 75, .2);--neu-in-sm: inset 3px 3px 6px rgba(10, 10, 18, .5), inset -3px -3px 6px rgba(50, 50, 75, .15);--neu-pressed: inset 2px 2px 5px rgba(10, 10, 18, .6), inset -2px -2px 5px rgba(50, 50, 75, .15)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--bg: #1e1e2e;--bg-darker: #161622;--bg-lighter: #282840;--text: #e0e0f0;--text-muted: #9898b0;--text-dim: #6868a0;--accent: #ff7043;--accent-hover: #ff8559;--accent-soft: rgba(255, 112, 67, .14);--accent-glow: rgba(255, 112, 67, .3);--win: #3ddc84;--win-soft: rgba(61, 220, 132, .1);--loss: #ff5c5c;--loss-soft: rgba(255, 92, 92, .1);--neu-out: 6px 6px 14px rgba(10, 10, 18, .7), -6px -6px 14px rgba(50, 50, 75, .25);--neu-out-sm: 4px 4px 8px rgba(10, 10, 18, .6), -4px -4px 8px rgba(50, 50, 75, .2);--neu-out-lg: 10px 10px 22px rgba(10, 10, 18, .8), -10px -10px 22px rgba(50, 50, 75, .3);--neu-in: inset 4px 4px 8px rgba(10, 10, 18, .6), inset -4px -4px 8px rgba(50, 50, 75, .2);--neu-in-sm: inset 3px 3px 6px rgba(10, 10, 18, .5), inset -3px -3px 6px rgba(50, 50, 75, .15);--neu-pressed: inset 2px 2px 5px rgba(10, 10, 18, .6), inset -2px -2px 5px rgba(50, 50, 75, .15)}}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100vh;background:var(--bg);color:var(--text);font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#78788c40;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#78788c66}#root{display:flex;justify-content:center;padding:2.5rem 1.25rem}.app{width:100%;max-width:760px;display:flex;flex-direction:column;gap:1.75rem}.app>*,.app>*>*{animation:screen-enter .5s var(--ease-out) both}@keyframes screen-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-bar{display:flex;justify-content:flex-end;margin-bottom:.5rem;animation-delay:.05s}.auth-user{display:flex;align-items:center;gap:.6rem}.auth-avatar{width:36px;height:36px;border-radius:50%;box-shadow:var(--neu-out-sm)}.auth-name{font-size:.82rem;font-weight:600;color:var(--text-muted)}.auth-btn{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;padding:.6rem 1.1rem;font-weight:600;border-radius:var(--radius-sm);background:var(--bg);box-shadow:var(--neu-out-sm);color:var(--text-muted);border:none;transition:all .2s var(--ease-smooth);font-family:inherit}.auth-btn:hover{box-shadow:var(--neu-in-sm);color:var(--text)}.auth-buttons{display:flex;gap:.5rem;justify-content:flex-end}.auth-btn-google{background:var(--bg-lighter);color:var(--text);box-shadow:var(--neu-out-sm)}.auth-btn-google:hover{box-shadow:var(--neu-in-sm);color:#333}.auth-btn-github{background:var(--bg);color:var(--text);box-shadow:var(--neu-out-sm)}.auth-btn-github:hover{box-shadow:var(--neu-in-sm)}.auth-icon{flex-shrink:0}.link-discord{color:var(--accent);font-weight:700;text-decoration:none;border-bottom:1px solid var(--accent-glow);transition:color .15s var(--ease-smooth),border-color .15s var(--ease-smooth)}.link-discord:hover{color:var(--accent-hover);border-bottom-color:var(--accent)}.auth-gate{background:var(--bg);border-radius:var(--radius);padding:2.75rem 2.25rem;display:flex;flex-direction:column;align-items:center;gap:1.75rem;text-align:center;box-shadow:var(--neu-out-lg);animation-delay:.1s}.auth-gate-label{font-size:.9rem;font-weight:700;color:var(--text);margin:0}.auth-buttons-gate{flex-direction:column;width:100%;max-width:340px;gap:.75rem}.auth-btn-lg{width:100%;justify-content:center;font-size:.88rem;padding:.9rem 1.4rem;border-radius:var(--radius-sm)}.auth-divider{display:flex;align-items:center;gap:1rem;width:100%;max-width:340px;color:var(--text-dim);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:2px;background:var(--bg-darker);border-radius:2px}.auth-mode-toggle{display:flex;gap:0;background:var(--bg);border-radius:var(--radius-sm);width:100%;max-width:340px;padding:5px;box-shadow:var(--neu-in-sm)}.auth-mode-btn{flex:1;padding:.65rem 1rem;font-size:.82rem;font-weight:700;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);transition:all .2s var(--ease-smooth);font-family:inherit}.auth-mode-btn:hover{color:var(--text)}.auth-mode-btn.active{background:var(--bg);box-shadow:var(--neu-out-sm);color:var(--accent)}.auth-form{width:100%;max-width:340px;display:flex;flex-direction:column;gap:.75rem}.auth-form .input-shell{position:relative}.auth-form .input-icon{position:absolute;left:.95rem;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none;z-index:1}.auth-form .input-icon-btn{position:absolute;right:.65rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-dim);cursor:pointer;padding:.25rem;display:flex;align-items:center;transition:color .12s ease}.auth-form .input-icon-btn:hover{color:var(--text-muted)}.auth-form .auth-input{padding-left:2.6rem}.auth-form .auth-input[type=password],.auth-form .auth-input[type=text]{padding-right:2.6rem}.auth-submit{margin-top:.25rem}.auth-form-hint{color:var(--text-dim);font-size:.72rem;margin:0;text-align:center}.username-subtitle{color:var(--text-muted);font-size:.85rem;margin:0;font-weight:400}.username-form{width:100%;max-width:340px;display:flex;flex-direction:column;gap:.75rem}.username-input{text-align:center;font-weight:700;font-size:1.1rem;letter-spacing:.02em}.username-error{color:var(--loss);font-size:.78rem;margin:0;text-align:center;font-weight:700}.username-hint{color:var(--text-dim);font-size:.75rem;margin:0;text-align:center}.username-cta{margin-top:.25rem}.username-signout{font-size:.78rem;margin-top:.75rem;font-weight:600}.mode-select{margin-top:1.25rem;animation-delay:.15s}.mode-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.mode-card{background:var(--bg);border:none;border-radius:var(--radius);padding:1.75rem 1.5rem;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:.4rem;transition:all .3s var(--ease-out);box-shadow:var(--neu-out)}.mode-card:hover{box-shadow:var(--neu-out-lg);transform:translateY(-2px)}.mode-card.active{box-shadow:var(--neu-in);border-radius:var(--radius)}.mode-card.active .mode-icon{color:var(--accent)}.mode-icon{font-size:1.8rem;line-height:1;margin-bottom:.15rem;color:var(--text-muted);display:flex;align-items:center;transition:color .2s var(--ease-smooth)}.icon{display:inline-flex;align-items:center;vertical-align:middle;line-height:1}.icon-sm{font-size:1rem}.icon-md{font-size:1.25rem}.icon-lg{font-size:1.6rem}.icon-xl{font-size:2rem}.icon-title{font-size:2.6rem}.icon-result{font-size:2.8rem}.icon-inline{display:inline-flex;align-items:center;vertical-align:middle;margin-right:.35rem;position:relative;top:-.05em}.icon-inline-sm{display:inline-flex;align-items:center;vertical-align:middle;margin-right:.25rem;position:relative;top:-.05em}.mode-title{font-size:1rem;font-weight:700;letter-spacing:-.01em;color:var(--text)}.mode-tagline{font-size:.7rem;font-weight:700;color:var(--accent);letter-spacing:.02em}.mode-desc{font-size:.8rem;line-height:1.55;color:var(--text-muted);margin-top:.25rem;font-weight:400}.lobby-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem;animation-delay:.2s}.lobby-cta{width:100%;text-align:center}.text-output-section{background:var(--bg);border:none;border-radius:var(--radius);padding:1.75rem;box-shadow:var(--neu-out)}.text-output-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.text-output-card{background:var(--bg);border:none;border-radius:var(--radius-sm);padding:1.25rem;display:flex;flex-direction:column;gap:.5rem;box-shadow:var(--neu-in-sm)}.text-output-card.yours{box-shadow:var(--neu-in-sm),inset 3px 0 0 var(--accent)}.text-output-card.theirs{box-shadow:var(--neu-in-sm),inset 3px 0 0 var(--loss)}.text-output-label{font-size:.72rem;font-weight:700;letter-spacing:.02em;color:var(--text-muted)}.text-output-card.yours .text-output-label{color:var(--accent)}.text-output-body{font-size:.85rem;line-height:1.65;color:var(--text);white-space:pre-wrap;word-break:break-word}.title{font-size:2.8rem;font-weight:700;letter-spacing:-.03em;margin:0 0 .3rem;text-align:center;color:var(--text);text-shadow:3px 3px 6px rgba(163,177,198,.45),-2px -2px 4px rgba(255,255,255,.85)}.subtitle{color:var(--text-muted);text-align:center;margin:0 0 1.5rem;font-size:.85rem;letter-spacing:.04em;font-weight:500}.lobby-form,.prompt-form,.challenge,.result,.eval-table{background:var(--bg);border:none;border-radius:var(--radius);padding:1.75rem;box-shadow:var(--neu-out)}.label{font-size:.78rem;color:var(--text-muted);font-weight:600;letter-spacing:.01em}.input,.textarea{background:var(--bg);border:none;color:var(--text);padding:.9rem 1.1rem;border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;width:100%;box-shadow:var(--neu-in-sm);transition:box-shadow .2s var(--ease-smooth)}.textarea{min-height:160px;resize:vertical;font-family:JetBrains Mono,SF Mono,Menlo,Consolas,monospace;font-size:.95rem;line-height:1.55}.input:focus,.textarea:focus{outline:none;box-shadow:var(--neu-in),0 0 0 2px var(--accent-soft)}.input::placeholder,.textarea::placeholder{color:var(--text-dim)}.input-shell{position:relative;display:flex;align-items:center}.input-shell .input{width:100%;padding-right:3rem}.input-arrow{position:absolute;right:.65rem;top:50%;transform:translateY(-50%);width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:var(--bg);border:none;border-radius:50%;color:var(--text-muted);font-size:1.15rem;font-weight:700;line-height:1;cursor:pointer;box-shadow:var(--neu-out-sm);transition:all .2s var(--ease-smooth)}.input-arrow:not(:disabled):hover{color:var(--accent);box-shadow:var(--neu-in-sm)}.input-arrow:not(:disabled):active{box-shadow:var(--neu-pressed)}.input-arrow:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.btn{font-size:.88rem;padding:.9rem 1.5rem;border-radius:var(--radius-sm);cursor:pointer;border:none;font-weight:700;letter-spacing:.01em;transition:all .25s var(--ease-smooth);font-family:inherit;background:var(--bg);box-shadow:var(--neu-out-sm);color:var(--text)}.btn:hover{box-shadow:var(--neu-in-sm)}.btn.primary{background:var(--accent);color:#fff;box-shadow:0 4px 14px #ff57224d,0 1px 2px #ff572233}.btn.primary:disabled{background:var(--bg);color:var(--text-dim);box-shadow:var(--neu-out-sm);cursor:not-allowed}.btn.primary:not(:disabled):hover{background:var(--accent-hover);box-shadow:0 6px 18px #ff572261,0 2px 4px #ff572238;transform:translateY(-1px)}.btn.primary:not(:disabled):active{background:var(--accent-hover);box-shadow:inset 0 2px 5px #8c280559;transform:translateY(0)}.btn.cancel{background:var(--bg);color:var(--text-muted);box-shadow:var(--neu-out-sm);font-weight:600}.btn.cancel:hover{color:var(--text);box-shadow:var(--neu-in-sm)}.share-link{display:flex;gap:.75rem;width:100%}.share-link .input{flex:1;font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-size:.85rem}.share-code{color:var(--text-muted);font-size:.85rem;margin:0}.share-code strong{color:var(--accent);font-family:JetBrains Mono,SF Mono,Menlo,monospace;letter-spacing:.1em}.waiting{background:var(--bg);border:none;padding:3.5rem;border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;gap:1.25rem;box-shadow:var(--neu-out-lg)}.waiting h2{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.waiting p{color:var(--text-muted);margin:0;font-size:.9rem}.spinner{width:48px;height:48px;border:3px solid var(--bg);border-top-color:var(--accent);border-radius:50%;animation:spin .9s linear infinite;box-shadow:var(--neu-out-sm)}@keyframes spin{to{transform:rotate(360deg)}}.battle{position:relative;display:flex;flex-direction:column;gap:1rem}.battle-header{display:flex;justify-content:space-between;align-items:center;background:var(--bg);border:none;padding:1.1rem 1.4rem;border-radius:var(--radius);gap:1rem;box-shadow:var(--neu-out)}.timer{font-family:JetBrains Mono,SF Mono,Menlo,Monaco,monospace;font-size:2.4rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.04em;color:var(--text);line-height:1}.timer.low{color:var(--loss);animation:pulse 1s ease-in-out infinite}@keyframes pulse{50%{opacity:.5}}.opp-status{font-size:.82rem;color:var(--text-muted);font-weight:600;text-align:right}.opp-status.ready{color:var(--win)}.challenge{background:var(--bg);border:none;border-left:none;box-shadow:var(--neu-out)}.challenge p{margin:.5rem 0 0;font-size:1.1rem;line-height:1.55;color:var(--text)}.badge{display:inline-block;font-size:.72rem;color:var(--accent);font-weight:700;letter-spacing:.02em}.judging-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--bg) 90%,transparent);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;border-radius:var(--radius);z-index:10}.judging-overlay p{color:var(--text-muted);margin:0;font-size:.9rem;font-weight:600}.error-banner{background:var(--bg);color:var(--loss);padding:.9rem 1.2rem;border-radius:var(--radius-sm);font-weight:700;font-size:.88rem;box-shadow:var(--neu-in-sm);transition:all .2s var(--ease-smooth)}.error-banner:hover{box-shadow:var(--neu-out-sm)}.result{display:flex;flex-direction:column;gap:1.5rem;animation-delay:.05s}.result h2{margin:0;font-size:2.8rem;font-weight:700;letter-spacing:-.03em;text-align:center;color:var(--text)}.result h2.win{color:var(--win)}.result h2.loss{color:var(--loss)}.result h2.draw{color:var(--text-muted)}.result-heading{animation:result-pop .6s cubic-bezier(.34,1.56,.64,1) both}@keyframes result-pop{0%{opacity:0;transform:scale(.5) rotate(-3deg)}60%{opacity:1;transform:scale(1.08) rotate(1deg)}to{opacity:1;transform:scale(1) rotate(0)}}.result-home{align-self:flex-start;display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;padding:.5rem .9rem;margin-bottom:-.5rem}.rematch-btn{width:100%;font-size:1rem;padding:1rem;letter-spacing:.02em}.result-banner{display:flex;flex-direction:column;align-items:center;gap:.7rem;padding:1.75rem;border-radius:var(--radius);background:var(--bg);border:none;text-align:center;box-shadow:var(--neu-out)}.result-banner.banner-win{box-shadow:var(--neu-out),inset 4px 0 0 var(--win)}.result-banner.banner-loss{box-shadow:var(--neu-out),inset 4px 0 0 var(--loss)}.result-banner.banner-draw{box-shadow:var(--neu-out),inset 4px 0 0 var(--text-dim)}.banner-row{display:flex;align-items:baseline;justify-content:center;gap:.9rem;flex-wrap:wrap}.banner-you{font-weight:700;font-size:1.05rem;color:var(--text)}.banner-you-tag{font-size:.7rem;font-weight:600;opacity:.55}.banner-vs{font-size:.7rem;text-transform:uppercase;letter-spacing:.22em;color:var(--text-dim);font-weight:800}.banner-opp{font-weight:900;font-size:1.5rem;color:var(--text);letter-spacing:-.02em}.result-banner.banner-win .banner-opp{color:var(--loss)}.result-banner.banner-loss .banner-opp{color:var(--win)}.result-banner.banner-draw .banner-opp{color:var(--text)}.banner-verdict{font-size:.8rem;font-weight:600;color:var(--text-muted)}.eval-table{display:flex;flex-direction:column;gap:.7rem;padding:1.5rem}.cmp-row{display:grid;grid-template-columns:110px 1fr 1fr;gap:1.25rem;align-items:center}.cmp-row.cmp-head,.cmp-row.cmp-total{font-size:.75rem;font-weight:700;color:var(--text-muted)}.cmp-row.cmp-head{padding-bottom:.6rem;border-bottom:2px solid var(--bg-darker);margin-bottom:.4rem}.cmp-head-name{text-align:right}.cmp-row.cmp-total{padding-top:.8rem;margin-top:.4rem;border-top:2px solid var(--bg-darker);color:var(--text);font-size:.8rem}.cmp-row.cmp-total .cmp-num{font-size:1rem}.cmp-label{font-size:.8rem;font-weight:600;color:var(--text-muted)}.cmp-bar{display:grid;grid-template-columns:1fr 56px;gap:.6rem;align-items:center}.cmp-bar-track{height:10px;background:var(--bg);border-radius:5px;box-shadow:var(--neu-in-sm);overflow:hidden;position:relative}.cmp-bar-fill{height:100%;border-radius:5px;transition:width .7s cubic-bezier(.2,.7,.2,1)}.cmp-bar.cmp-a .cmp-bar-fill{background:linear-gradient(90deg,var(--accent-hover),var(--accent))}.cmp-bar.cmp-b .cmp-bar-fill{background:linear-gradient(90deg,#d04030,var(--loss))}.cmp-num{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-variant-numeric:tabular-nums;font-weight:700;font-size:.95rem;text-align:right;color:var(--text)}.cmp-row.hl-a{background:var(--accent-soft);border-radius:8px;padding:.4rem .6rem;margin:0 -.6rem}.cmp-row.hl-b{background:var(--loss-soft);border-radius:8px;padding:.4rem .6rem;margin:0 -.6rem}.cmp-row.hl-a .cmp-bar.cmp-a .cmp-num{color:var(--accent)}.cmp-row.hl-b .cmp-bar.cmp-b .cmp-num{color:var(--loss)}.player-feedback{background:var(--bg);border:none;padding:1rem 1.25rem;border-radius:var(--radius-sm);box-shadow:var(--neu-in-sm)}.player-feedback>summary{list-style:none;font-size:.82rem;font-weight:700;color:var(--accent);padding:.4rem 0}.player-feedback>summary::-webkit-details-marker{display:none}.player-feedback>summary:before{content:"▸";color:var(--accent);margin-right:.3rem}.player-feedback[open]>summary:before{content:"▾"}details summary{cursor:pointer;color:var(--text-muted);font-weight:700;font-size:.82rem;padding:.5rem 0;-webkit-user-select:none;user-select:none}details summary:hover{color:var(--text)}details pre{background:var(--bg);padding:1.1rem;border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word;font-family:JetBrains Mono,SF Mono,Menlo,Consolas,monospace;font-size:.85rem;margin:.6rem 0;line-height:1.55;color:var(--text);box-shadow:var(--neu-in-sm)}details code{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-size:.75rem;color:var(--accent);background:var(--accent-soft);padding:.15rem .4rem;border-radius:4px}details.reasoning{background:var(--bg);border:none;border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--neu-out-sm)}details.reasoning[open] summary{color:var(--text);border-bottom:2px solid var(--bg-darker);margin-bottom:.6rem;padding-bottom:.6rem}.cutscene{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;min-height:60vh;padding:2rem}.cutscene-challenge{background:var(--bg);border:none;border-radius:var(--radius);padding:2.25rem 2.75rem;max-width:560px;width:100%;text-align:center;animation:cutscene-reveal .8s var(--ease-out) both;box-shadow:var(--neu-out-lg)}.cutscene-challenge.compact{padding:1rem 1.5rem;animation:cutscene-shrink .5s cubic-bezier(.16,1,.3,1) both}.cutscene-badge{display:block;font-size:.72rem;color:var(--accent);font-weight:700;margin-bottom:.6rem}.cutscene-text{margin:0;font-size:1.15rem;line-height:1.6;color:var(--text)}.cutscene-challenge.compact .cutscene-text{font-size:.95rem;line-height:1.5}.cutscene-vs{display:flex;align-items:center;gap:1.25rem}.cutscene-you{font-size:1.4rem;font-weight:800;color:var(--accent)}.cutscene-vs-text{font-size:.75rem;color:var(--text-dim);font-weight:700;letter-spacing:.08em}.cutscene-opp{font-size:1.4rem;font-weight:800;color:var(--loss)}.cutscene-number{font-family:JetBrains Mono,SF Mono,Menlo,Monaco,monospace;font-size:7.5rem;font-weight:900;letter-spacing:-.04em;line-height:1;color:var(--text);text-shadow:5px 5px 10px rgba(163,177,198,.55),-3px -3px 6px rgba(255,255,255,.9)}.cutscene-go{font-size:5rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);text-shadow:4px 4px 8px rgba(163,177,198,.45),-2px -2px 4px rgba(255,255,255,.85)}@keyframes cutscene-reveal{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes cutscene-shrink{0%{transform:scale(1);opacity:1}to{transform:scale(.88);opacity:.85}}.pop{animation:number-pop .4s cubic-bezier(.34,1.56,.64,1) 80ms both}@keyframes number-pop{0%{opacity:0;transform:scale(2.5)}60%{opacity:1}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeIn .5s ease both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.reveal{display:flex;flex-direction:column;gap:1.25rem}.reveal-header{display:flex;flex-direction:column;gap:.6rem;align-items:center}.reveal-title{font-size:.75rem;color:var(--accent);font-weight:700;letter-spacing:.03em}.reveal-progress-track{width:100%;height:4px;background:var(--bg);border-radius:2px;box-shadow:var(--neu-in-sm);overflow:hidden}.reveal-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .2s linear}.reveal-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.reveal-card{background:var(--bg);border:none;border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;animation:cutscene-reveal .6s var(--ease-out) both;box-shadow:var(--neu-out)}.reveal-card.yours{box-shadow:var(--neu-out),inset 4px 0 0 var(--accent)}.reveal-card.theirs{box-shadow:var(--neu-out),inset 4px 0 0 var(--loss);animation-delay:.3s}.reveal-card-label{font-size:.75rem;font-weight:700;letter-spacing:.02em;color:var(--text-muted)}.reveal-card.yours .reveal-card-label{color:var(--accent)}.reveal-card.theirs .reveal-card-label{color:var(--loss)}.reveal-card-body{font-size:.9rem;line-height:1.65;color:var(--text);white-space:pre-wrap;word-break:break-word}.reveal-skip{align-self:center;margin-top:.5rem}.reveal-ratings{background:var(--bg);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--neu-out);display:flex;flex-direction:column;gap:1rem}.reveal-ratings-grid{display:flex;flex-direction:column;gap:.6rem}.reveal-rating-row{display:grid;grid-template-columns:1fr 60px 60px;gap:1rem;align-items:center;font-size:.85rem}.reveal-rating-row.reveal-rating-total{padding-top:.6rem;border-top:2px solid var(--bg-darker);margin-top:.2rem;font-weight:700;font-size:.95rem}.reveal-rating-label{font-weight:600;color:var(--text-muted)}.reveal-rating-total .reveal-rating-label{color:var(--text)}.reveal-rating-a,.reveal-rating-b{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-variant-numeric:tabular-nums;font-weight:700;text-align:center}.reveal-rating-a{color:var(--accent)}.reveal-rating-b{color:var(--loss)}.reveal-rating-header{padding-bottom:.5rem;border-bottom:2px solid var(--bg-darker);margin-bottom:.2rem}.reveal-rating-name-a,.reveal-rating-name-b{font-size:.72rem;font-weight:700;text-align:center;letter-spacing:.02em}.reveal-rating-name-a{color:var(--accent)}.reveal-rating-name-b{color:var(--loss)}@media (max-width: 540px){#root{padding:.75rem .75rem 1rem}.app{gap:.85rem}.title{font-size:1.85rem;margin-bottom:.1rem;letter-spacing:-.03em}.subtitle{font-size:.72rem;margin-bottom:.5rem;letter-spacing:.03em}.result h2{font-size:1.85rem}.lobby-form,.prompt-form,.challenge,.result,.eval-table,.auth-gate,.text-output-section{padding:1.1rem 1.15rem;border-radius:var(--radius-sm)}.auth-bar{margin-bottom:.25rem}.auth-avatar{width:30px;height:30px}.auth-name{font-size:.74rem}.auth-btn{font-size:.72rem;padding:.45rem .85rem}.no-access-actions{gap:.55rem}.no-access-actions>*{width:100%;flex:1 1 100%}.lobby-stats{padding:.55rem .85rem;gap:.75rem}.stat-value{font-size:.85rem}.stat-label{font-size:.62rem}.lobby-stat-divider{height:14px}.mode-select{margin-top:.5rem}.mode-cards{grid-template-columns:1fr;gap:.55rem}.mode-card{padding:.85rem 1rem;gap:.2rem;border-radius:var(--radius-sm)}.mode-icon{font-size:1.2rem;margin-bottom:0}.mode-title{font-size:.88rem}.mode-tagline{font-size:.6rem}.mode-desc{font-size:.7rem;line-height:1.4;margin-top:.15rem}.lobby-actions{margin-top:.6rem;gap:.45rem}.btn{padding:.7rem 1rem;font-size:.8rem}.rematch-btn{padding:.85rem;font-size:.9rem}.activity-list{gap:.35rem;margin-top:.4rem}.activity-item{padding:.55rem .85rem}.activity-result{font-size:.76rem}.activity-hype{font-size:.68rem}.activity-time{font-size:.6rem}.battle{gap:.6rem}.battle-header{padding:.75rem 1rem;gap:.6rem;border-radius:var(--radius-sm)}.timer{font-size:1.55rem}.opp-status{font-size:.72rem}.challenge{padding:1rem 1.15rem}.challenge p{font-size:.92rem;line-height:1.45;margin-top:.3rem}.badge{font-size:.62rem}.prompt-form .label{font-size:.72rem;margin-bottom:.3rem}.textarea{min-height:110px;font-size:.88rem;padding:.75rem .9rem}.result{gap:.85rem}.result-home{margin-bottom:-.25rem}.result-banner{padding:1rem 1.15rem;gap:.35rem;border-radius:var(--radius-sm)}.banner-row{gap:.6rem}.banner-opp{font-size:1.15rem}.banner-you{font-size:.88rem}.banner-you-tag{font-size:.6rem}.banner-vs{font-size:.6rem;letter-spacing:.18em}.banner-verdict{font-size:.7rem}.text-output-cards{grid-template-columns:1fr;gap:.55rem}.text-output-card{padding:.8rem 1rem}.text-output-body{font-size:.78rem;line-height:1.5}.cmp-row{grid-template-columns:1fr;gap:.35rem}.cmp-row.cmp-head,.cmp-row.cmp-total{grid-template-columns:1fr 1fr;gap:.75rem}.cmp-row.cmp-head{padding-bottom:.4rem;margin-bottom:.2rem}.cmp-row.cmp-total{padding-top:.6rem;margin-top:.2rem}.cmp-label{grid-column:1 / -1;font-size:.68rem}.cmp-row.cmp-head .cmp-label,.cmp-row.cmp-total .cmp-label{display:none}.cmp-bar{grid-template-columns:1fr 42px}.cmp-bar-track{height:8px}.cmp-num{font-size:.78rem}.cmp-row.hl-a,.cmp-row.hl-b{padding:.3rem .45rem;margin:0 -.45rem}details summary{font-size:.74rem;padding:.4rem 0}details pre{padding:.8rem .9rem;font-size:.76rem;line-height:1.45}details.reasoning{padding:.85rem 1rem;border-radius:var(--radius-sm)}.player-feedback{padding:.85rem 1rem}.player-feedback>summary{font-size:.74rem}.reveal{gap:.85rem}.reveal-cards{grid-template-columns:1fr;gap:.55rem}.reveal-card{padding:.9rem 1rem;gap:.4rem;border-radius:var(--radius-sm)}.reveal-card-body{font-size:.82rem;line-height:1.5}.reveal-ratings{padding:1rem;gap:.6rem;border-radius:var(--radius-sm)}.reveal-rating-row{grid-template-columns:1fr 44px 44px;gap:.4rem;font-size:.78rem}.reveal-rating-a,.reveal-rating-b{font-size:.78rem}.reveal-rating-name-a,.reveal-rating-name-b{font-size:.62rem}.reveal-skip{margin-top:.25rem}.cutscene{min-height:50vh;gap:1.25rem;padding:1.5rem .5rem}.cutscene-challenge{padding:1rem 1.15rem;border-radius:var(--radius-sm)}.cutscene-text{font-size:.95rem;line-height:1.45}.cutscene-challenge.compact .cutscene-text{font-size:.85rem}.cutscene-vs{gap:.85rem}.cutscene-you,.cutscene-opp{font-size:1.15rem}.cutscene-number{font-size:5rem}.cutscene-go{font-size:3.4rem}.cutscene-trash-talk{font-size:.78rem}.waiting{padding:2rem 1.25rem;gap:.8rem;border-radius:var(--radius-sm)}.waiting h2{font-size:1.05rem}.waiting p{font-size:.82rem}.share-link{gap:.5rem}.share-link .input{font-size:.74rem;padding:.7rem .85rem}.prelaunch-gate{gap:1rem}.prelaunch-countdown-block{padding:1.5rem 1.15rem;gap:.85rem;border-radius:var(--radius)}.prelaunch-tagline{font-size:.85rem;line-height:1.5}.prelaunch-invite-card{gap:.75rem}.prelaunch-invite-title{font-size:1.15rem}.countdown-timer{gap:.6rem;padding:.5rem 0}.countdown-bucket{min-width:48px}.countdown-value{font-size:2.4rem;min-width:48px;padding:.45rem .6rem}.countdown-label{font-size:.58rem;letter-spacing:.1em}.no-access-card{padding:1.5rem 1.15rem;gap:.85rem}.mute-toggle,.theme-toggle{width:32px;height:32px;box-shadow:var(--neu-out-sm)}.mute-toggle{top:.65rem;right:.65rem}.theme-toggle{top:.65rem;right:3rem}.mode-card,.reveal-card,.reveal-ratings,.lobby-form,.prompt-form,.challenge,.result,.eval-table,.text-output-section,.no-access-card,.match-modal,.battle-header,.result-banner,.text-output-card,.lobby-stats,.activity-item{box-shadow:var(--neu-out-sm)}.auth-gate,.prelaunch-countdown-block,.cutscene-challenge,.waiting{box-shadow:var(--neu-out)}.site-footer{padding:1rem 0 .25rem;gap:.3rem}.footer-links a{font-size:.68rem}.footer-copy{font-size:.6rem}.hype-feed{gap:.6rem}.hype-counter{padding:.5rem .95rem;font-size:.7rem}.hype-counter-value{font-size:.92rem}.hype-feed-card{padding:.95rem 1rem;gap:.5rem}.hype-entry{padding:.45rem .7rem;font-size:.78rem}.hype-time{font-size:.62rem}.app>*,.app>*>*{animation-duration:.35s}}.site-footer{text-align:center;padding:2rem 0 .5rem;display:flex;flex-direction:column;gap:.4rem;align-items:center;animation-delay:.3s}.footer-links{display:flex;align-items:center;gap:.6rem}.footer-links a{color:var(--text-dim);text-decoration:none;font-size:.78rem;font-weight:600;transition:color .15s var(--ease-smooth)}.footer-links a:hover{color:var(--accent)}.footer-dot{color:var(--bg-darker);font-size:.65rem}.cutscene-trash-talk{color:var(--text-muted);font-size:.85rem;font-style:italic;text-align:center;margin-top:.5rem;max-width:400px}.hype-line{font-size:1.1rem;font-weight:600;color:var(--accent);text-align:center;margin:-.5rem 0 1rem;letter-spacing:.02em}.mute-toggle{position:fixed;top:1rem;right:1rem;z-index:100;background:var(--bg);border:1px solid var(--bg-darker);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;box-shadow:var(--neu-out-sm);transition:color .15s ease,box-shadow .15s ease}.mute-toggle:hover{color:var(--accent);box-shadow:var(--neu-out)}.lobby-stats{display:flex;align-items:center;justify-content:center;gap:1.25rem;padding:.9rem 1.5rem;background:var(--bg);border-radius:var(--radius-sm);box-shadow:var(--neu-out-sm);animation-delay:.1s}.lobby-stat{display:flex;align-items:center;gap:.35rem}.stat-icon{color:var(--accent);flex-shrink:0}.stat-value{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-variant-numeric:tabular-nums;font-weight:700;font-size:1rem;color:var(--text)}.stat-label{font-size:.72rem;color:var(--text-muted);font-weight:500}.lobby-stat-divider{width:1px;height:20px;background:var(--bg-darker)}.activity-feed{animation-delay:.25s}.activity-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.6rem}.activity-item{display:flex;flex-direction:column;gap:.2rem;padding:.75rem 1rem;background:var(--bg);border-radius:var(--radius-xs);box-shadow:var(--neu-out-sm);transition:box-shadow .2s var(--ease-smooth)}.activity-item:hover{box-shadow:var(--neu-out)}.activity-result{font-size:.82rem;font-weight:600;color:var(--text);display:flex;align-items:center}.activity-hype{font-size:.75rem;color:var(--accent);font-style:italic;font-weight:500}.activity-time{font-size:.68rem;color:var(--text-dim);font-weight:500}.footer-copy{color:var(--text-dim);font-size:.68rem;margin:0;opacity:.7}.hype-feed{display:flex;flex-direction:column;gap:.85rem;animation-delay:.18s}.hype-counter{display:inline-flex;align-self:center;align-items:center;gap:.5rem;background:var(--bg);padding:.65rem 1.25rem;border-radius:999px;box-shadow:var(--neu-out-sm);font-size:.78rem;color:var(--text-muted);font-weight:600}.hype-counter-icon{color:var(--accent);flex-shrink:0}.hype-counter-value{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-variant-numeric:tabular-nums;font-weight:800;font-size:1rem;color:var(--text);letter-spacing:-.02em}.hype-counter-label{letter-spacing:.02em}.hype-feed-card{background:var(--bg);border-radius:var(--radius);padding:1.25rem 1.4rem;box-shadow:var(--neu-out);display:flex;flex-direction:column;gap:.65rem}.hype-feed-header{display:flex;align-items:center;gap:.45rem;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.hype-feed-header-far{margin-left:auto;color:var(--text-dim)}.hype-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.hype-entry{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:.55rem .85rem;background:var(--bg);border-radius:var(--radius-sm);box-shadow:var(--neu-in-sm);font-size:.85rem;animation:hype-slide-in .42s var(--ease-out) both}.hype-name{font-weight:700;color:var(--text);letter-spacing:-.01em}.hype-time{font-size:.7rem;font-weight:600;color:var(--text-dim);font-variant-numeric:tabular-nums}@keyframes hype-slide-in{0%{opacity:0;transform:translate(-14px) translateY(-2px)}to{opacity:1;transform:translate(0) translateY(0)}}.match-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#00000073;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .2s ease both}.match-modal{position:relative;background:var(--bg);border-radius:var(--radius);padding:2rem;max-width:680px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--neu-out-lg);animation:cutscene-reveal .3s var(--ease-out) both}.match-modal-close{position:absolute;top:1rem;right:1rem;padding:.5rem;z-index:1}.match-detail-content{display:flex;flex-direction:column;gap:1.25rem}.theme-toggle{position:fixed;top:1rem;right:3.25rem;z-index:100;background:var(--bg);border:1px solid var(--bg-darker);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;box-shadow:var(--neu-out-sm);transition:color .15s ease,box-shadow .15s ease}.theme-toggle:hover{color:var(--accent);box-shadow:var(--neu-out)}.prelaunch-gate{display:flex;flex-direction:column;gap:2rem}.prelaunch-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.prelaunch-beta-chip{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.3rem .75rem;border-radius:999px;margin-top:.25rem;animation-delay:.05s}.prelaunch-countdown-block{background:var(--bg);border:none;border-radius:var(--radius);padding:3rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center;box-shadow:var(--neu-out-lg);animation-delay:.1s}.prelaunch-heading{margin:0;font-size:.85rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted)}.prelaunch-launch-date{margin:-.5rem 0 0;font-size:1.05rem;color:var(--text)}.prelaunch-tagline{margin:0;font-size:1rem;color:var(--text-muted);line-height:1.55;max-width:460px}.prelaunch-invite-card{display:flex;flex-direction:column;gap:1.25rem;width:100%;max-width:400px;margin-top:.5rem}.prelaunch-invite-header{display:flex;flex-direction:column;align-items:center;gap:.25rem}.prelaunch-invite-badge{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim)}.prelaunch-invite-title{margin:0;font-size:1.4rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.prelaunch-invite-card .auth-gate{background:transparent;box-shadow:none;padding:0;animation:none;width:100%}.prelaunch-note{margin:.75rem 0 0;font-size:.85rem;color:var(--text-muted);line-height:1.55;max-width:460px}.countdown-timer{display:flex;align-items:stretch;justify-content:center;gap:1.25rem;padding:1rem 0 .25rem;font-variant-numeric:tabular-nums}.countdown-bucket{display:flex;flex-direction:column;align-items:center;gap:.35rem;min-width:64px}.countdown-value{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-size:3.4rem;font-weight:700;letter-spacing:-.04em;line-height:1;color:var(--text);background:var(--bg);padding:.6rem .9rem;border-radius:var(--radius-sm);min-width:64px;text-align:center;box-shadow:var(--neu-out)}.countdown-label{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim)}.no-access-card{width:100%;max-width:460px;display:flex;flex-direction:column;align-items:center;gap:1.25rem;background:var(--bg);border:none;border-radius:var(--radius);padding:2rem 1.75rem;box-shadow:var(--neu-in-sm),inset 4px 0 0 var(--loss);margin-top:.5rem}.no-access-body{margin:0;font-size:.92rem;line-height:1.55;color:var(--text);text-align:center}.no-access-body code{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-size:.82rem;background:var(--accent-soft);color:var(--accent);padding:.15rem .4rem;border-radius:4px;word-break:break-all}.no-access-actions{display:flex;flex-direction:row;gap:.75rem;flex-wrap:wrap;justify-content:center;align-items:center;width:100%;margin-top:.25rem}.no-access-actions>*{flex:0 1 auto;min-width:140px}.btn-discord{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none}
