@import url("https://api.fontshare.com/v2/css?f[]=clash-display@400,500,600,700&f[]=satoshi@400,500,700&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:dark;--ink:255,255,255;--bg:#060607;--bg2:#0b0b0d;--surface:rgba(var(--ink),0.035);--surface-2:rgba(var(--ink),0.07);--border:rgba(var(--ink),0.08);--border-bright:rgba(var(--ink),0.2);--text:#f4f4f5;--text-dim:#85858e;--text-strong:#fff;--text-inverse:#060607;--nav-bg:rgba(6,6,7,.65);--modal-bg:rgba(14,14,16,.92);--overlay-bg:rgba(2,2,3,.7);--panel-rgb:9,9,11;--warn:#ff453a;--green:#30d158;--gold:#ffd60a;--cyan:#f4f4f5;--magenta:#ff453a;--font-display:"Clash Display","Avenir Next",sans-serif;--font-body:"Satoshi","Helvetica Neue",sans-serif;--font-mono:"Satoshi",sans-serif;--r-sm:10px;--r-md:16px;--r-lg:24px;--ease-out:cubic-bezier(0.22,1,0.36,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1)}html[data-theme=light]{color-scheme:light;--ink:9,9,11;--bg:#f6f6f7;--bg2:#fff;--surface:rgba(var(--ink),0.04);--surface-2:rgba(var(--ink),0.08);--border:rgba(var(--ink),0.12);--border-bright:rgba(var(--ink),0.3);--text:#141417;--text-dim:#6e6e76;--text-strong:#000;--text-inverse:#fff;--nav-bg:hsla(240,6%,97%,.72);--modal-bg:rgba(252,252,253,.94);--overlay-bg:rgba(20,20,23,.35);--panel-rgb:251,251,252;--warn:#d70015;--green:#1d8f45;--gold:#a07400;--cyan:#141417;--magenta:#d70015}html[data-theme=light] body:after{opacity:.025}html[data-theme=light] .cg-box,html[data-theme=light] .modal-box{box-shadow:0 30px 80px rgba(0,0,0,.18),inset 0 1px 0 hsla(0,0%,100%,.7)}html[data-theme=light] .lobby-card{box-shadow:0 24px 60px rgba(0,0,0,.1),inset 0 1px 0 hsla(0,0%,100%,.7)}html[data-theme=light] .mode-card:hover{box-shadow:0 20px 50px rgba(0,0,0,.1)}html[data-theme=light] .mode-card--featured:hover{box-shadow:0 24px 60px rgba(0,0,0,.12)}html[data-theme=light] .btn:hover:not(:disabled){box-shadow:0 8px 24px rgba(0,0,0,.16)}html[data-theme=light] .game-canvas{box-shadow:0 0 0 1px rgba(var(--ink),.12),0 30px 80px rgba(0,0,0,.18)}html[data-theme=light] .tc-stick-knob{background:radial-gradient(circle at 38% 32%,#3c3c44 0,#232329 45%,#0c0c0f 100%);border-color:rgba(0,0,0,.85);box-shadow:0 6px 20px rgba(0,0,0,.3),0 0 24px rgba(0,0,0,.12),inset 0 -4px 10px rgba(0,0,0,.35)}html[data-theme=light] .lobby-meta-tag.toxic{color:#65880f;border-color:rgba(101,136,15,.5)}html[data-theme=light] .lb-table td>span,html[data-theme=light] .profile-avatar,html[data-theme=light] .profile-name,html[data-theme=light] .profile-stats .stat-card:first-child .stat-value{filter:brightness(.62) saturate(1.6)}html{height:100%}body{min-height:100%;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased}body:before{inset:0;background:radial-gradient(900px 480px at 50% -120px,rgba(var(--ink),.05),transparent 70%);z-index:0}body:after,body:before{content:"";position:fixed;pointer-events:none}body:after{inset:-50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");opacity:.035;z-index:9999}::selection{background:rgba(var(--ink),.9);color:var(--bg)}@keyframes rise{0%{opacity:0;transform:translateY(16px);filter:blur(5px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pop-in{0%{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.navbar{position:fixed;top:0;left:0;right:0;z-index:200;height:64px;align-items:center;display:grid;grid-template-columns:1fr auto 1fr;padding:0 clamp(1.25rem,4vw,2.5rem);background:var(--nav-bg);border-bottom:1px solid var(--border);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4)}.navbar-logo{justify-self:start}.navbar-links{justify-self:center}.navbar-user{justify-self:end}.navbar--game{grid-template-columns:1fr 1fr}.navbar-logo{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--text);letter-spacing:.14em;text-decoration:none;transition:opacity .2s var(--ease-out)}.navbar-logo:hover{opacity:.7}.navbar-links{display:flex;gap:.4rem}.navbar-link{color:var(--text-dim);text-decoration:none;font-size:.82rem;font-weight:500;padding:.45rem .95rem;border-radius:999px;transition:color .2s var(--ease-out),background .2s var(--ease-out)}.navbar-link:hover{color:var(--text);background:var(--surface)}.navbar-link.active{color:var(--text);background:var(--surface-2)}.navbar-user{gap:.9rem}.navbar-user,.theme-toggle{display:flex;align-items:center}.theme-toggle{justify-content:center;width:34px;height:34px;border-radius:50%;background:transparent;border:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:color .2s var(--ease-out),background .2s var(--ease-out),border-color .2s var(--ease-out),transform .3s var(--ease-spring)}.theme-toggle:hover{color:var(--text);background:var(--surface-2);border-color:var(--border-bright);transform:rotate(20deg)}.theme-toggle svg{width:16px;height:16px}.navbar-pseudo{color:var(--text);font-size:.88rem;font-weight:700}.navbar-elo{color:var(--text-dim);font-size:.75rem;font-weight:500;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;padding:.15rem .55rem;border:1px solid var(--border);border-radius:999px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:var(--text);color:var(--text-inverse);border:1px solid var(--text);font-family:var(--font-body);font-weight:700;font-size:.85rem;letter-spacing:.01em;padding:.6rem 1.4rem;border-radius:999px;cursor:pointer;white-space:nowrap;transition:transform .25s var(--ease-spring),box-shadow .25s var(--ease-out),background .2s var(--ease-out),opacity .2s}.btn:hover:not(:disabled){transform:translateY(-1px) scale(1.02);box-shadow:0 8px 30px rgba(var(--ink),.18)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.3;cursor:not-allowed}.btn-lg{padding:.85rem 2.2rem;font-size:.95rem}.btn-outline{background:transparent;color:var(--text);border-color:var(--border-bright)}.btn-outline:hover:not(:disabled){background:var(--surface-2);border-color:rgba(var(--ink),.4);box-shadow:none}.btn-danger{background:transparent;color:var(--warn);border-color:rgba(255,69,58,.4)}.btn-danger:hover:not(:disabled){background:rgba(255,69,58,.1);box-shadow:none}.page-wrap{padding-top:64px;min-height:100vh;position:relative;z-index:1}.input-field{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-family:var(--font-body);font-size:.92rem;padding:.75rem 1rem;outline:none;transition:border-color .2s var(--ease-out),background .2s,box-shadow .2s}.input-field::placeholder{color:var(--text-dim)}.input-field:focus{border-color:rgba(var(--ink),.45);background:rgba(var(--ink),.05);box-shadow:0 0 0 4px rgba(var(--ink),.06)}.form-error{color:var(--warn);font-size:.8rem;min-height:1.2em}.modal-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;background:var(--overlay-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:fade-in .25s var(--ease-out) both;padding:1rem}.modal-box{position:relative;background:var(--modal-bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:2rem;width:380px;max-width:95vw;box-shadow:0 40px 100px rgba(0,0,0,.7),inset 0 1px 0 rgba(var(--ink),.06);animation:pop-in .35s var(--ease-spring) both}.modal-tabs{display:flex;gap:.25rem;background:var(--surface);border-radius:999px;padding:.25rem;margin-bottom:1.5rem}.modal-tab{flex:1 1;background:none;border:none;border-radius:999px;color:var(--text-dim);font-family:var(--font-body);font-weight:600;font-size:.82rem;padding:.5rem;cursor:pointer;transition:all .25s var(--ease-out)}.modal-tab.active{color:var(--text-inverse);background:var(--text)}.modal-close{position:absolute;top:1rem;right:1rem;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid transparent;color:var(--text-dim);font-size:.85rem;cursor:pointer;line-height:1;transition:all .2s var(--ease-out)}.modal-close:hover{color:var(--text);background:var(--surface-2);transform:rotate(90deg)}.auth-form{display:flex;flex-direction:column;gap:.8rem}.auth-form h3{font-family:var(--font-display);font-weight:600;color:var(--text);font-size:1.25rem;letter-spacing:-.01em;margin-bottom:.4rem}.auth-hint{color:var(--text-dim);font-size:.74rem;line-height:1.4;text-align:center;margin-top:.2rem}.lb-container{max-width:880px;margin:0 auto;padding:3rem 1.5rem;animation:rise .5s var(--ease-out) both}.page-title{font-family:var(--font-display);font-weight:600;color:var(--text);letter-spacing:-.02em;margin-bottom:2.5rem;font-size:clamp(1.8rem,4vw,2.6rem)}.lb-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.lb-table th{color:var(--text-dim);font-size:.68rem;text-transform:uppercase;font-weight:700;letter-spacing:.1em;padding:.9rem 1.1rem;text-align:left;border-bottom:1px solid var(--border);background:rgba(var(--ink),.02)}.lb-table td{padding:.8rem 1.1rem;font-size:.88rem;border-bottom:1px solid rgba(var(--ink),.04);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;transition:background .15s}.lb-table tr:last-child td{border-bottom:none}.lb-table tr:hover td{background:rgba(var(--ink),.03)}.lb-table tr.me td{background:rgba(var(--ink),.06)}.lb-rank-no{color:var(--text-dim);font-size:.8rem}.lb-pseudo{color:var(--text);font-weight:700;text-decoration:none;font-size:.88rem}.lb-pseudo:hover{text-decoration:underline;text-underline-offset:3px}.lb-elo{font-family:var(--font-display);font-weight:600;color:var(--text)}.profile-container{max-width:800px;margin:0 auto;padding:3rem 1.5rem;animation:rise .5s var(--ease-out) both}.profile-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2.5rem}.profile-avatar{width:76px;height:76px;border-radius:50%;border:1.5px solid var(--border-bright);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:1.7rem;color:var(--text);flex-shrink:0}.profile-avatar,.profile-name{font-family:var(--font-display);font-weight:600}.profile-name{font-size:1.6rem;letter-spacing:-.01em}.profile-rank{color:var(--text-dim);font-size:.85rem;margin-top:.25rem}.profile-stats{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:1.1rem 1.4rem;text-align:center;flex:1 1;min-width:104px;transition:transform .3s var(--ease-spring),border-color .2s}.stat-card:hover{transform:translateY(-3px);border-color:var(--border-bright)}.stat-value{font-family:var(--font-display);font-weight:600;font-size:1.55rem;display:block;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.stat-label{font-size:.66rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-top:.25rem}.match-list{display:flex;flex-direction:column}.match-row{display:flex;gap:1rem;align-items:center;padding:.7rem .25rem;border-bottom:1px solid rgba(var(--ink),.05);font-size:.85rem}.match-result{font-family:var(--font-display);font-weight:700;font-size:.75rem;width:22px}.match-result.W{color:var(--green)}.match-result.L{color:var(--warn)}.match-result.D{color:var(--gold)}.match-opponent{flex:1 1;color:var(--text-dim)}.match-delta{font-weight:700;font-size:.82rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.match-delta.pos{color:var(--green)}.match-delta.neg{color:var(--warn)}.match-date{color:var(--text-dim);font-size:.74rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.game-shell{position:fixed;inset:64px 0 0 0;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(ellipse at center,#0b0b0d 0,#050506 70%,#030304 100%)}html[data-theme=light] .game-shell{background:radial-gradient(ellipse at center,#fff 0,#f0f0f2 70%,#e8e8eb 100%)}.game-scaler{transform-origin:center center}.game-stage{width:800px;display:flex;flex-direction:column;align-items:center}.damage-overlay-fx{position:absolute;inset:0;pointer-events:none;opacity:0;background:radial-gradient(ellipse at center,rgba(255,50,40,0) 45%,rgba(255,50,40,.3) 80%,rgba(255,60,50,.65) 100%);box-shadow:inset 0 0 120px rgba(255,50,40,.55)}.damage-overlay-fx,.game-canvas{border-radius:0 0 var(--r-md) var(--r-md)}.game-canvas{display:block;cursor:none;box-shadow:0 0 0 1px rgba(var(--ink),.07),0 30px 80px rgba(0,0,0,.7)}.game-controls-hint{display:flex;gap:1.5rem;margin-top:.9rem;font-size:.72rem;color:var(--text-dim)}.game-controls-hint b{color:var(--text);font-weight:600;padding:.05rem .4rem;border:1px solid var(--border);border-radius:5px;background:var(--surface)}.sudden-death-banner{position:absolute;top:18px;left:50%;transform:translateX(-50%);font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:.3em;text-indent:.3em;color:#ff453a;text-shadow:0 0 24px rgba(255,69,58,.7);pointer-events:none;white-space:nowrap;animation:sd-flash .9s ease-in-out infinite}@keyframes sd-flash{0%,to{opacity:1}50%{opacity:.45}}.respawn-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;background:rgba(var(--panel-rgb),.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;text-align:center;border-radius:0 0 var(--r-md) var(--r-md)}.respawn-label{font-weight:600;font-size:.8rem;letter-spacing:.35em;text-indent:.35em;color:#ff6b61}.respawn-count,.respawn-label{font-family:var(--font-display)}.respawn-count{font-weight:700;font-size:clamp(3rem,9vw,5.5rem);line-height:1;color:var(--text-strong);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;animation:respawn-pop 1s var(--ease-out) infinite}@keyframes respawn-pop{0%{transform:scale(.82);opacity:.4}35%{transform:scale(1);opacity:1}to{transform:scale(1);opacity:1}}.respawn-sub{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}.bonus-announce{position:absolute;top:14px;left:50%;display:flex;align-items:center;gap:.7rem;padding:.5rem 1.1rem .5rem .85rem;background:rgba(var(--panel-rgb),.85);border:1px solid color-mix(in srgb,var(--bc) 60%,transparent);border-radius:999px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 30px rgba(0,0,0,.5),0 0 18px color-mix(in srgb,var(--bc) 30%,transparent);pointer-events:none;white-space:nowrap;z-index:6;animation:bonus-announce-in 2.8s var(--ease-out) forwards}@keyframes bonus-announce-in{0%{opacity:0;transform:translate(-50%,-18px) scale(.9)}9%{opacity:1;transform:translate(-50%) scale(1)}86%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-8px) scale(.97)}}.bonus-announce-icon{font-size:1.35rem;line-height:1;color:var(--bc);animation:bonus-icon-pop .6s var(--ease-spring) both}@keyframes bonus-icon-pop{0%{transform:scale(0) rotate(-30deg)}60%{transform:scale(1.3)}to{transform:scale(1)}}.bonus-announce-txt{display:flex;flex-direction:column;line-height:1.15}.bonus-announce-txt b{font-family:var(--font-display);font-weight:600;font-size:.85rem;color:var(--text-strong)}.bonus-announce-txt small{font-size:.62rem;letter-spacing:.1em;color:var(--text-dim);text-transform:uppercase}.fx-bar{position:absolute;top:12px;left:12px;display:flex;gap:.4rem;pointer-events:none;z-index:5}.fx-chip{display:flex;align-items:center;gap:.35rem;padding:.25rem .6rem;border:1px solid;border-radius:999px;background:rgba(var(--panel-rgb),.8);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-weight:700;animation:fx-chip-in .3s var(--ease-spring) both}.fx-icon{font-size:.85rem;line-height:1}.fx-sec{font-size:.66rem;opacity:.9;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}@keyframes fx-chip-in{0%{opacity:0;transform:translateY(-8px) scale(.9)}to{opacity:1;transform:none}}.game-hud{width:800px;justify-content:space-between;padding:.6rem 1.1rem;background:rgba(var(--panel-rgb),.92);border:1px solid var(--border);border-bottom:none;border-radius:var(--r-md) var(--r-md) 0 0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.game-hud,.hud-side{display:flex;align-items:center}.hud-side{gap:.75rem}.hud-side.right{flex-direction:row-reverse}.hud-name{font-family:var(--font-display);font-weight:600;font-size:.78rem;letter-spacing:.02em}.hud-hp{display:flex;gap:5px}.hp-dot{width:10px;height:10px;border-radius:50%;transition:all .25s var(--ease-out)}.hud-elo-badge{color:var(--text-dim);font-size:.7rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hud-timer{font-family:var(--font-display);font-weight:600;font-size:1.15rem;letter-spacing:.04em;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hud-center{display:flex;flex-direction:column;align-items:center;gap:1px}.hud-objective{font-weight:600;font-size:.66rem;letter-spacing:.1em;color:var(--gold);white-space:nowrap}.hud-kills,.hud-objective{font-family:var(--font-display)}.hud-kills{font-size:.82rem;font-weight:700;display:inline-flex;align-items:baseline;gap:1px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.hud-kills small{font-size:.6em;opacity:.7}.hud-side.team{flex-direction:column;align-items:flex-start;gap:.3rem}.hud-side.team.right{align-items:flex-end}.hud-member{display:flex;align-items:center;gap:.6rem}.hud-side.team.right .hud-member{flex-direction:row-reverse}.hud-team-label{font-family:var(--font-display);font-weight:600;font-size:.6rem;letter-spacing:.12em;opacity:.85;text-transform:uppercase}.lobby-screen{min-height:calc(100vh - 64px);align-items:center;justify-content:center;gap:1rem;padding:1rem}.lobby-card,.lobby-screen{display:flex;flex-direction:column}.lobby-card{width:min(680px,94vw);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem;gap:1.25rem;box-shadow:0 30px 80px rgba(0,0,0,.45),inset 0 1px 0 rgba(var(--ink),.05);animation:pop-in .4s var(--ease-spring) both}.lobby-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.lobby-mode{font-family:var(--font-display);font-weight:600;font-size:1.3rem;letter-spacing:-.01em}.lobby-tag{color:var(--text-dim);font-size:.8rem}.lobby-code{background:var(--surface);border:1px solid var(--border);border-radius:999px;color:var(--text);padding:.45rem .9rem;cursor:pointer;font-size:.82rem;font-family:var(--font-body);transition:all .2s var(--ease-out)}.lobby-code:hover{border-color:var(--border-bright);background:var(--surface-2)}.lobby-code b{font-family:var(--font-display);font-weight:600;font-size:1.02rem;letter-spacing:.2em}.lobby-copy{color:var(--text-dim);margin-left:.3rem}.lobby-teams{display:flex;gap:1rem}.lobby-team{flex:1 1;border:1px solid;border-radius:var(--r-md);padding:1.1rem;display:flex;flex-direction:column;gap:.5rem;align-items:center;background:rgba(var(--ink),.015)}.lobby-team-name{font-family:var(--font-display);font-weight:600;letter-spacing:.04em;font-size:.95rem}.lobby-slot{width:100%;min-height:40px;border:1px dashed var(--border);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:.85rem;font-weight:500;transition:border-color .2s}.lobby-slot.filled{border-style:solid;background:rgba(var(--ink),.03)}.lobby-empty{color:var(--text-dim);opacity:.5}.lobby-host,.lobby-you{font-size:.58rem;padding:1px 6px;border-radius:999px;background:rgba(var(--ink),.1);color:var(--text-dim);letter-spacing:.05em;text-transform:uppercase;font-weight:700}.lobby-join-btn{margin-top:.25rem;font-size:.72rem;padding:.35rem .9rem}.lobby-actions{display:flex;justify-content:space-between;align-items:center}.lobby-status{color:var(--text-dim);font-size:.85rem}.lobby-error{color:var(--warn);font-size:.85rem;text-align:center}.lobby-start-wrap{display:flex;align-items:center;gap:1rem}.lobby-header-l{display:flex;flex-direction:column;gap:.45rem}.lobby-meta{display:flex;gap:.4rem;flex-wrap:wrap}.lobby-meta-tag{font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--text-dim);border:1px solid var(--border);border-radius:999px;padding:2px 9px}.lobby-meta-tag.toxic{color:#a3e635;border-color:rgba(163,230,53,.4)}.lobby-ffa{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:.6rem;gap:.6rem}.lobby-ffa .lobby-slot{min-height:44px}.lobby-auto{font-size:.62rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;min-height:1.2em;margin-top:.25rem}.home{position:relative;min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:3rem 1.25rem}.home-bg{position:absolute;inset:0;pointer-events:none;opacity:.9}.home-inner{position:relative;z-index:1;width:min(980px,100%)}.home-hero,.home-inner{display:flex;flex-direction:column;align-items:center}.home-hero{text-align:center;margin-bottom:3rem}.home-eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:700;letter-spacing:.32em;text-indent:.32em;text-transform:uppercase;color:var(--text-dim);padding:.45rem 1.2rem .45rem 1rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);margin-bottom:2rem;animation:rise .7s var(--ease-out) both}.home-eyebrow-dot{width:6px;height:6px;border-radius:50%;flex:none;background:var(--green);animation:eyebrow-ping 2.4s ease-out infinite}@keyframes eyebrow-ping{0%{box-shadow:0 0 0 0 rgba(48,209,88,.5)}70%{box-shadow:0 0 0 9px rgba(48,209,88,0)}to{box-shadow:0 0 0 0 rgba(48,209,88,0)}}.home-title{font-family:var(--font-display);font-weight:600;font-size:clamp(4.5rem,16vw,10.5rem);letter-spacing:-.03em;line-height:.95;background:linear-gradient(180deg,var(--text-strong) 30%,rgba(var(--ink),.45) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:home-title-in 1s var(--ease-out) .1s both}@keyframes home-title-in{0%{opacity:0;transform:translateY(30px) scale(.97);filter:blur(14px)}to{opacity:1;transform:none;filter:blur(0)}}.home-tagline{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.55rem 1rem;margin-top:1.5rem;color:var(--text-dim);font-size:clamp(.85rem,2.2vw,1rem);font-weight:500;letter-spacing:.01em;animation:rise .7s var(--ease-out) .3s both}.home-tagline span{position:relative}.home-tagline span+span:before{content:"";position:absolute;left:-.62rem;top:50%;width:3px;height:3px;margin-top:-1.5px;border-radius:50%;background:rgba(var(--ink),.35)}.mode-grid{width:100%;display:grid;grid-template-columns:1.15fr 1fr;grid-gap:.9rem;gap:.9rem;align-items:stretch}@media (max-width:720px){.mode-grid{grid-template-columns:1fr}}.mode-card{position:relative;display:flex;flex-direction:column;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:1.2rem 1.3rem;color:var(--text);font-family:var(--font-body);cursor:pointer;overflow:hidden;transition:transform .35s var(--ease-spring),border-color .25s var(--ease-out),background .25s var(--ease-out),box-shadow .35s var(--ease-out);animation:rise .7s var(--ease-out) both}.mode-grid .mode-card--featured{animation-delay:.4s}.mode-team-col .mode-card:nth-child(2){animation-delay:.48s}.mode-team-col .mode-card:nth-child(3){animation-delay:.56s}.mode-team-col .mode-card:nth-child(4){animation-delay:.64s}.mode-card--custom{animation-delay:.72s}.mode-card:after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 30%,rgba(var(--ink),.06) 48%,transparent 65%);background-size:240% 100%;background-position:110% 0;opacity:0;pointer-events:none;transition:opacity .2s}.mode-card:hover:after{opacity:1;animation:card-sheen .9s var(--ease-out) both}@keyframes card-sheen{0%{background-position:110% 0}to{background-position:-60% 0}}.mode-card:hover{transform:translateY(-4px);border-color:var(--border-bright);background:rgba(var(--ink),.05);box-shadow:0 24px 60px rgba(0,0,0,.5)}.mode-card:active{transform:translateY(-1px) scale(.995)}.mode-card-head{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-bottom:.7rem}.mode-card-tag{font-size:.66rem;font-weight:700;letter-spacing:.18em;color:var(--text-dim);text-transform:uppercase}.mode-card-name{font-family:var(--font-display);font-weight:600;font-size:1.2rem;letter-spacing:-.01em;color:var(--text)}.mode-card-desc{color:var(--text-dim);font-size:.82rem;line-height:1.55;margin-top:.35rem}.mode-badge{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:999px;border:1px solid;white-space:nowrap}.mode-badge--ranked{color:var(--gold)}.mode-badge--public{color:var(--green)}.mode-badge--private{color:var(--text-dim)}.mode-badge--join{color:var(--text)}.mode-card--featured{border-color:rgba(var(--ink),.16);background:radial-gradient(120% 90% at 100% 0,rgba(var(--ink),.08),transparent 55%),var(--surface);padding:1.7rem;justify-content:space-between;min-height:290px}.mode-card--featured:hover{border-color:rgba(var(--ink),.35);box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 50px rgba(var(--ink),.05)}.mode-card--featured .mode-card-tag{color:var(--text);font-size:.74rem}.mode-card--featured .mode-card-name{font-size:clamp(2.1rem,5vw,3rem);letter-spacing:-.02em;color:var(--text-strong)}.mode-card--featured .mode-card-desc{font-size:.88rem;max-width:32ch}.mode-card-glow{position:absolute;right:-70px;top:-70px;width:240px;height:240px;background:radial-gradient(circle,rgba(var(--ink),.1),transparent 70%);pointer-events:none}.mode-card-cta{align-self:flex-start;margin-top:1.5rem;display:inline-flex;align-items:center;font-weight:700;font-size:.88rem;letter-spacing:.04em;color:var(--text-inverse);background:var(--text);padding:.7rem 1.7rem;border-radius:999px;transition:transform .3s var(--ease-spring),box-shadow .3s var(--ease-out)}.mode-card--featured:hover .mode-card-cta{transform:scale(1.04);box-shadow:0 10px 36px rgba(var(--ink),.22)}.mode-team-col{display:flex;flex-direction:column;gap:.7rem}.mode-team-label{color:var(--text-dim);font-size:.64rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding-left:.3rem;margin-bottom:.1rem;animation:rise .7s var(--ease-out) .44s both}.mode-card--team{flex:1 1;padding:1rem 1.2rem}.mode-card--team .mode-card-name{font-size:1.05rem}.mode-card--public:hover{border-color:rgba(48,209,88,.45)}.mode-card--private:hover{border-color:rgba(var(--ink),.3)}.mode-card--join{cursor:default}.mode-card--join:hover{transform:none;box-shadow:none;background:var(--surface)}.mode-card--join:hover:after{opacity:0;animation:none}.mode-join-row{display:flex;gap:.5rem;margin-top:.5rem}.mode-code-input{flex:1 1;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:999px;color:var(--text);padding:.55rem .7rem;letter-spacing:.4em;text-indent:.4em;text-align:center;font-family:var(--font-display);font-weight:600;font-size:1rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;outline:none;transition:border-color .2s,box-shadow .2s,background .2s}.mode-code-input::placeholder{color:var(--text-dim);opacity:.45}.mode-code-input:focus{border-color:rgba(var(--ink),.4);background:rgba(var(--ink),.05);box-shadow:0 0 0 4px rgba(var(--ink),.05)}.home-err{margin-top:1rem}.home-online{display:flex;align-items:center;gap:.55rem;color:var(--text-dim);font-size:.78rem;font-weight:500;margin-top:2rem;animation:rise .7s var(--ease-out) .85s both}.home-online-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:home-pulse 2s ease-in-out infinite}@keyframes home-pulse{0%,to{opacity:1}50%{opacity:.35}}.mode-card--custom{width:100%;margin-top:.9rem;flex-direction:row;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.mode-card-custom-l{flex:1 1;min-width:220px}.mode-card--custom .mode-card-cta{margin-top:0}.mode-card--custom:hover .mode-card-cta{transform:scale(1.04);box-shadow:0 10px 36px rgba(var(--ink),.18)}.hud-member.dead{opacity:.4;filter:grayscale(.6)}.hud-scoreboard{flex-wrap:wrap;gap:.4rem;flex:1 1;max-height:64px;overflow-y:auto}.hud-chip,.hud-scoreboard{display:flex;align-items:center}.hud-chip{gap:.45rem;padding:.22rem .6rem;border:1px solid var(--border);border-radius:999px;background:rgba(var(--ink),.03)}.hud-chip.me{background:rgba(var(--ink),.09)}.hud-chip.dead{opacity:.35;filter:grayscale(.7)}.hud-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.hud-chip-name{font-family:var(--font-display);font-weight:600;font-size:.64rem;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cg-box{background:var(--modal-bg);border:1px solid var(--border);border-radius:var(--r-lg);width:460px;max-width:95vw;max-height:min(92vh,760px);overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.7),inset 0 1px 0 rgba(var(--ink),.06);display:flex;flex-direction:column;animation:pop-in .35s var(--ease-spring) both}.cg-box,.cg-head{position:relative}.cg-head{flex-shrink:0;padding:1.5rem 1.75rem 1.1rem;border-bottom:1px solid var(--border)}.cg-head-eyebrow{font-size:.62rem;font-weight:700;letter-spacing:.28em;text-indent:.28em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.35rem}.cg-head-close{top:1.25rem;right:1.25rem}.cg-scroll{flex:1 1;min-height:0;overflow-y:auto;padding:1.35rem 1.75rem 1.5rem;display:flex;flex-direction:column;gap:1rem;scrollbar-width:thin}.cg-foot,.cg-scroll>*{flex-shrink:0}.cg-foot{padding:1rem 1.75rem 1.5rem;border-top:1px solid var(--border);background:var(--modal-bg)}.cg-title{font-family:var(--font-display);font-weight:600;color:var(--text);font-size:1.4rem;letter-spacing:-.02em;line-height:1.05}.cg-seg{display:flex;gap:.25rem;background:var(--surface);border-radius:999px;padding:.25rem}.cg-seg button{flex:1 1;background:transparent;border:none;border-radius:999px;cursor:pointer;color:var(--text-dim);font-family:var(--font-body);font-weight:600;font-size:.8rem;padding:.55rem .5rem;transition:all .25s var(--ease-out)}.cg-seg button.active{background:var(--text);color:var(--text-inverse)}.cg-seg.sm button{font-size:.72rem;padding:.42rem .3rem}.cg-row2{display:flex;gap:1rem}.cg-row2>.cg-field{flex:1 1}.cg-field{gap:.5rem}.cg-field,.cg-field-label{display:flex;flex-direction:column}.cg-field-label{font-size:.78rem;font-weight:600;color:var(--text)}.cg-hint{color:var(--text-dim);font-size:.66rem;font-weight:500;margin-top:2px}.cg-stepper{display:flex;align-items:center;border:1px solid var(--border);border-radius:999px;overflow:hidden;align-self:flex-start;background:var(--surface)}.cg-stepper button{width:38px;height:38px;background:transparent;border:none;cursor:pointer;color:var(--text);font-size:1.15rem;line-height:1;transition:background .15s}.cg-stepper button:hover:not(:disabled){background:var(--surface-2)}.cg-stepper button:disabled{opacity:.25;cursor:not-allowed}.cg-stepper-val{min-width:46px;text-align:center;font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--text);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.cg-total{font-size:.75rem;color:var(--text-dim);text-align:center}.cg-total.err{color:var(--warn)}.cg-mode-desc{font-size:.7rem;color:var(--text-dim);margin-top:.45rem;line-height:1.45}.cg-bonus{gap:.5rem}.cg-bonus-grid{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}.cg-bonus-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;border-radius:999px;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-family:var(--font-body);font-weight:600;font-size:.7rem;transition:all .2s var(--ease-out)}.cg-bonus-chip.on{background:rgba(var(--ink),.05)}.cg-bonus-chip:not(.on){opacity:.5}.cg-bonus-chip:hover{opacity:1}.cg-bonus-ic{font-size:.9rem}.cg-opts{flex-direction:column;border-top:1px solid var(--border);padding-top:1.1rem}.cg-opts,.cg-toggle{display:flex;gap:.7rem}.cg-toggle{align-items:center;background:none;border:none;cursor:pointer;text-align:left;padding:0}.cg-toggle-track{width:42px;height:24px;border-radius:999px;flex-shrink:0;background:rgba(var(--ink),.1);border:1px solid var(--border);position:relative;transition:background .25s var(--ease-out),border-color .25s}.cg-toggle-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--text-dim);transition:transform .3s var(--ease-spring),background .25s}.cg-toggle.on .cg-toggle-track{background:var(--text);border-color:var(--text)}.cg-toggle.on .cg-toggle-knob{transform:translateX(18px);background:var(--text-inverse)}.cg-toggle-text{font-size:.8rem;font-weight:600;color:var(--text);display:flex;flex-direction:column}.cg-create{margin-top:0;width:100%}.end-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);background-image:radial-gradient(ellipse 80% 60% at 50% 0,rgba(var(--ink),.05),transparent 70%)}.champion-card{position:relative;text-align:center;padding:2.5rem 3rem}.champion-trophy{font-size:4rem;line-height:1;filter:drop-shadow(0 0 25px var(--wc));animation:trophy-in .7s var(--ease-spring) both,trophy-float 3s ease-in-out .7s infinite}@keyframes trophy-in{0%{opacity:0;transform:scale(.2) rotate(-25deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes trophy-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.champion-label{margin-top:.75rem;font-size:.68rem;font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--text-dim);animation:rise .5s var(--ease-out) .25s both}.champion-name{font-family:var(--font-display);font-weight:700;font-size:clamp(2.5rem,7vw,4.5rem);letter-spacing:-.02em;line-height:1.05;margin:.3rem 0 .5rem;text-shadow:0 0 40px color-mix(in srgb,var(--wc) 50%,transparent);animation:champ-in .7s var(--ease-spring) .35s both}@keyframes champ-in{0%{opacity:0;transform:scale(.7) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.champion-verdict{font-family:var(--font-display);font-weight:600;font-size:.95rem;letter-spacing:.22em;text-indent:.22em;text-transform:uppercase;margin-bottom:1.75rem;animation:rise .5s var(--ease-out) .6s both}.champion-verdict.win{color:var(--green)}.champion-verdict.lose{color:var(--warn)}.champion-verdict.draw{color:var(--gold)}.champion-card .end-stats{animation:rise .5s var(--ease-out) .75s both}.champion-card .end-elo{animation:rise .5s var(--ease-out) .9s both}.champion-card .end-actions{animation:rise .5s var(--ease-out) 1.05s both}.end-card{text-align:center;padding:2rem}.end-result{font-family:var(--font-display);font-size:3.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}.end-result.win{color:var(--text)}.end-result.lose{color:var(--warn)}.end-result.draw{color:var(--gold)}.end-stats{display:flex;gap:2.25rem;justify-content:center;margin:1.5rem 0}.end-stat{display:flex;flex-direction:column;align-items:center}.end-stat-val{font-family:var(--font-display);font-weight:600;font-size:1.5rem;color:var(--text);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.end-stat-lbl{font-size:.66rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem}.end-elo{font-family:var(--font-display);font-weight:600;font-size:1.1rem;margin-bottom:2rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.end-elo.pos{color:var(--green)}.end-elo.neg{color:var(--warn)}.end-actions{gap:.75rem}.end-actions,.queue-screen{display:flex;justify-content:center}.queue-screen{flex-direction:column;align-items:center;min-height:100vh;gap:1.5rem}.queue-ring{position:relative;width:96px;height:96px;background:radial-gradient(circle,var(--text-strong) 4px,rgba(var(--ink),0) 5px)}.queue-ring:after,.queue-ring:before{content:"";position:absolute;inset:0;border:1.5px solid rgba(var(--ink),.55);border-radius:50%;animation:queue-ripple 2.4s var(--ease-out) infinite}.queue-ring:after{animation-delay:1.2s}@keyframes queue-ripple{0%{transform:scale(.18);opacity:1}to{transform:scale(1.15);opacity:0}}.queue-title{font-size:1.05rem;letter-spacing:.02em}.queue-elapsed,.queue-title{font-family:var(--font-display);font-weight:600;color:var(--text)}.queue-elapsed{font-size:2.6rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.queue-online{font-size:.8rem;color:var(--text-dim)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(var(--ink),.14);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:rgba(var(--ink),.25)}.game-shell.touch{inset:0;touch-action:none;overscroll-behavior:none}@property --tc-ang{syntax:"<angle>";inherits:false;initial-value:0deg}.tc-overlay{position:fixed;inset:0;z-index:60;pointer-events:none;touch-action:none;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.tc-stick-zone{position:absolute;left:0;bottom:0;width:46%;height:78%;pointer-events:auto;touch-action:none}.tc-stick{position:absolute;left:calc(env(safe-area-inset-left) + 86px);bottom:calc(env(safe-area-inset-bottom) + 86px);width:0;height:0;opacity:.5;transition:opacity .15s ease}.tc-stick.is-active{opacity:1}.tc-stick-ring,.tc-stick-ring--2{position:absolute;top:0;left:0;width:92px;height:92px;margin:-46px 0 0 -46px;border-radius:50%;border:1.5px solid rgba(var(--ink),.35);background:radial-gradient(circle at center,rgba(var(--ink),.07) 0,rgba(var(--ink),.03) 45%,transparent 72%);box-shadow:inset 0 0 20px rgba(var(--ink),.06)}.tc-stick-ring--2{width:116px;height:116px;margin:-58px 0 0 -58px;border-color:rgba(var(--ink),.14);background:none;box-shadow:none;animation:tc-sonar-idle 2.4s ease-out infinite}@keyframes tc-sonar-idle{0%{transform:scale(.78);opacity:.55}to{transform:scale(1.05);opacity:0}}.tc-stick-cross{width:92px;height:92px;margin:-46px 0 0 -46px;background:linear-gradient(rgba(var(--ink),.14),rgba(var(--ink),.14)) 50% /1px 56% no-repeat,linear-gradient(rgba(var(--ink),.14),rgba(var(--ink),.14)) 50% /56% 1px no-repeat}.tc-stick-cross,.tc-stick-knob{position:absolute;top:0;left:0;border-radius:50%}.tc-stick-knob{width:46px;height:46px;background:radial-gradient(circle at 38% 32%,#fff 0,#e8e8ec 45%,#9c9ca6 100%);border:1px solid rgba(var(--ink),.9);box-shadow:0 6px 20px rgba(0,0,0,.55),0 0 24px rgba(var(--ink),.25),inset 0 -4px 10px rgba(0,0,0,.25);will-change:transform}.tc-actions{position:absolute;right:max(22px,env(safe-area-inset-right));bottom:max(26px,env(safe-area-inset-bottom));pointer-events:none;display:grid;grid-template-columns:auto auto;align-items:end;grid-gap:16px;gap:16px}.tc-btn{position:relative;pointer-events:auto;touch-action:none;-webkit-tap-highlight-color:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border-radius:50%;background:rgba(var(--panel-rgb),.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-family:var(--font-display);letter-spacing:.1em;overflow:hidden;cursor:pointer;transition:transform .07s ease,box-shadow .18s ease,opacity .18s ease}.tc-btn:active{transform:scale(.92)}.tc-btn.is-cooling{opacity:.55}.tc-btn--fire{width:116px;height:116px;border:2px solid rgba(var(--ink),.9);color:var(--text);box-shadow:0 10px 36px rgba(0,0,0,.55),0 0 28px rgba(var(--ink),.15),inset 0 0 24px rgba(var(--ink),.08);margin-bottom:6px}.tc-btn--echo{width:96px;height:96px;align-self:start;border:1.5px solid rgba(var(--ink),.35);color:rgba(var(--ink),.85);box-shadow:0 10px 30px rgba(0,0,0,.5),inset 0 0 20px rgba(var(--ink),.05)}.tc-btn-label{font-size:.72rem;font-weight:600}.tc-btn--echo .tc-btn-label{font-size:.66rem}.tc-icon-fire{width:0;height:0;border-color:transparent transparent transparent currentcolor;border-style:solid;border-width:11px 0 11px 18px;filter:drop-shadow(0 0 6px rgba(var(--ink),.6))}.tc-icon-echo{position:relative;width:26px;height:16px}.tc-icon-echo:after,.tc-icon-echo:before{content:"";position:absolute;left:50%;bottom:0;border:2px solid rgba(var(--ink),.9);border-color:rgba(var(--ink),.9) transparent transparent transparent;border-radius:50%;transform:translateX(-50%)}.tc-icon-echo:before{width:12px;height:12px}.tc-icon-echo:after{width:24px;height:24px;opacity:.5}.tc-cooldown{position:absolute;inset:0;border-radius:50%;pointer-events:none;background:conic-gradient(rgba(var(--panel-rgb),.75) var(--tc-ang),transparent 0);animation-name:tc-sweep;animation-timing-function:linear;animation-fill-mode:forwards;animation-play-state:paused}@keyframes tc-sweep{0%{--tc-ang:360deg}to{--tc-ang:0deg}}.tc-ripple{position:absolute;inset:0;border-radius:50%;pointer-events:none;border:2px solid;opacity:0;animation:tc-ripple .5s ease-out}@keyframes tc-ripple{0%{opacity:.7;transform:scale(.85)}to{opacity:0;transform:scale(1.6)}}@media (max-height:430px){.tc-btn--fire{width:100px;height:100px}.tc-btn--echo{width:84px;height:84px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}