:root{--bg: #e8e8ee;--bg-darker: #dddde5;--bg-lighter: #f2f2f8;--text: #2d2d3a;--text-muted: #5a5a6e;--text-dim: #75758a;--accent: #5b7cfa;--accent-hover: #4a6bef;--accent-soft: rgba(91, 124, 250, .1);--accent-glow: rgba(91, 124, 250, .25);--win: #2ecc71;--win-soft: rgba(46, 204, 113, .08);--loss: #e74c3c;--loss-soft: rgba(231, 76, 60, .08);--radius: 20px;--radius-sm: 14px;--radius-xs: 10px;--neu-out: 6px 6px 12px rgba(180, 180, 195, .45), -6px -6px 12px rgba(255, 255, 255, .9);--neu-out-sm: 4px 4px 8px rgba(180, 180, 195, .4), -4px -4px 8px rgba(255, 255, 255, .85);--neu-out-lg: 10px 10px 20px rgba(180, 180, 195, .5), -10px -10px 20px rgba(255, 255, 255, .95);--neu-in: inset 4px 4px 8px rgba(180, 180, 195, .4), inset -4px -4px 8px rgba(255, 255, 255, .85);--neu-in-sm: inset 3px 3px 6px rgba(180, 180, 195, .35), inset -3px -3px 6px rgba(255, 255, 255, .8);--neu-pressed: inset 2px 2px 5px rgba(180, 180, 195, .5), inset -2px -2px 5px rgba(255, 255, 255, .7);--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: #7b92fa;--accent-hover: #6a82ef;--accent-soft: rgba(123, 146, 250, .12);--accent-glow: rgba(123, 146, 250, .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: #7b92fa;--accent-hover: #6a82ef;--accent-soft: rgba(123, 146, 250, .12);--accent-glow: rgba(123, 146, 250, .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}.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:3.2rem;font-weight:700;letter-spacing:-.03em;margin:0 0 .4rem;text-align:center;color:var(--text);text-shadow:2px 2px 4px rgba(180,180,195,.3),-1px -1px 2px rgba(255,255,255,.8)}.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:4px 4px 10px #5b7cfa4d,-2px -2px 6px #ffffff4d}.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:6px 6px 14px #5b7cfa59,-3px -3px 8px #ffffff59;transform:translateY(-1px)}.btn.primary:not(:disabled):active{background:var(--accent-hover);box-shadow:inset 2px 2px 5px #283ca04d,inset -2px -2px 5px #82a0ff33;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,#4a6bef,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:8rem;font-weight:900;letter-spacing:-.04em;line-height:1;color:var(--text);text-shadow:8px 8px 16px rgba(180,180,195,.3),-4px -4px 8px rgba(255,255,255,.8)}.cutscene-go{font-size:5rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);text-shadow:6px 6px 12px rgba(91,124,250,.2),-3px -3px 6px rgba(255,255,255,.6)}@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:1.25rem .75rem}.title{font-size:2.4rem;letter-spacing:-.03em}.result h2{font-size:2.2rem}.timer{font-size:1.8rem}.reveal-cards,.mode-cards,.text-output-cards{grid-template-columns:1fr}.cmp-row{grid-template-columns:1fr;gap:.4rem}.cmp-row.cmp-head,.cmp-row.cmp-total{grid-template-columns:1fr 1fr;gap:1rem}.cmp-label{grid-column:1 / -1;font-size:.7rem}.cmp-row.cmp-head .cmp-label,.cmp-row.cmp-total .cmp-label{display:none}.cmp-bar{grid-template-columns:1fr 48px}}.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}.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}
