:root{--bg: oklch(.165 .006 60);--bg-2: oklch(.205 .008 62);--surface: oklch(.235 .01 64);--line: oklch(.32 .012 66);--line-soft: oklch(.28 .01 66);--text: oklch(.965 .004 85);--muted: oklch(.7 .012 75);--faint: oklch(.55 .01 72);--accent: #ff7a45;--ok: oklch(.8 .15 150);--warn: oklch(.82 .14 80);--danger: oklch(.68 .2 25);--sans: "Space Grotesk", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace}*{box-sizing:border-box}.stage{position:relative;min-height:100vh;display:flex;flex-direction:column;padding:clamp(20px,3.5vw,40px) clamp(20px,5vw,72px);isolation:isolate;background:radial-gradient(120% 90% at 50% 8%,oklch(.22 .02 50 / .55),transparent 60%),var(--bg)}.arena-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-2;width:100%;height:100%}.vignette{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(110% 80% at 50% 42%,transparent 38%,var(--bg) 92%),linear-gradient(to bottom,transparent 60%,oklch(.13 .006 60 / .6))}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.net-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 13px;border:1px solid var(--line);border-radius:999px;background:#19151299;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-size:11px;letter-spacing:.08em;color:var(--muted)}.net-badge__dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px #6ed88926}.hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:22px;padding:clamp(24px,5vh,56px) 0}.fox{position:relative;width:clamp(132px,17vw,208px);aspect-ratio:1;display:grid;place-items:center;margin-bottom:2px}.fox__img{position:relative;z-index:2;width:78%;height:78%;object-fit:contain;filter:drop-shadow(0 0 26px color-mix(in srgb,var(--accent) 55%,transparent)) drop-shadow(0 12px 26px oklch(.1 .01 50 / .7));animation:foxFloat 5.5s ease-in-out infinite}.fox__glow{position:absolute;top:-8%;right:-8%;bottom:-8%;left:-8%;z-index:1;border-radius:50%;background:radial-gradient(circle at 50% 48%,color-mix(in srgb,var(--accent) 42%,transparent) 0%,color-mix(in srgb,var(--accent) 12%,transparent) 38%,transparent 66%);filter:blur(2px);animation:foxPulse 3.4s ease-in-out infinite}.fox__ring{position:absolute;top:2%;right:2%;bottom:2%;left:2%;z-index:0;border-radius:50%;border:1px solid color-mix(in srgb,var(--accent) 32%,transparent);box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 7%,transparent);animation:foxRing 3.4s ease-out infinite}@keyframes foxFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes foxPulse{0%,to{opacity:.78;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}@keyframes foxRing{0%{transform:scale(.92);opacity:.7}70%{transform:scale(1.18);opacity:0}to{transform:scale(1.18);opacity:0}}.eyebrow{font-size:12px;letter-spacing:.34em;color:var(--accent);text-transform:uppercase}.headline{margin:0;font-weight:600;font-size:clamp(40px,7.4vw,92px);line-height:.98;letter-spacing:-.025em;max-width:16ch}.headline__accent{color:var(--accent)}.subhead{margin:0;max-width:56ch;font-size:clamp(15px,1.4vw,18px);line-height:1.6;color:var(--muted)}.cta-block{margin-top:10px;display:flex;flex-direction:column;align-items:center;gap:16px;width:min(440px,100%)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--sans);font-weight:600;font-size:16px;line-height:1;padding:17px 28px;border-radius:13px;border:1px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap;transition:transform .12s ease,box-shadow .2s ease,background .2s ease,filter .2s ease}.btn--primary{background:var(--accent);color:#211209;box-shadow:0 0 0 1px #ffffff0f inset,0 14px 40px -14px var(--accent),0 2px #3e281b66}.btn--primary:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 0 0 1px #ffffff14 inset,0 22px 50px -16px var(--accent)}.btn--primary:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.75;cursor:default}.btn__ext{opacity:.6;font-weight:500}.cta-note{margin:0;font-size:13px;color:var(--faint);line-height:1.5}.cta-note--err{color:var(--danger)}.spinner{width:16px;height:16px;border-radius:50%;border:2px solid oklch(.2 .03 50 / .35);border-top-color:#211209;animation:spin .7s linear infinite;display:inline-block;flex-shrink:0}.alert{display:flex;gap:12px;align-items:flex-start;text-align:left;width:100%;padding:14px 16px;border-radius:12px;border:1px solid var(--line);background:#1e1a16b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.alert--warn{border-color:#f3b94c66}.alert--err{border-color:#fc585573}.alert__icon{flex:none;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;font-weight:700;font-size:14px;margin-top:1px}.alert--warn .alert__icon{background:#f3b94c2e;color:var(--warn)}.alert--err .alert__icon{background:#fc58552e;color:var(--danger)}.alert__title{font-weight:600;font-size:14px;margin-bottom:2px}.alert__body{font-size:13px;color:var(--muted);line-height:1.5}.alert__body strong{color:var(--text);font-weight:600}.how{border-top:1px solid var(--line-soft);padding-top:22px;display:flex;flex-direction:column;gap:16px}.how__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.how__step{display:flex;align-items:baseline;gap:12px}.how__num{font-size:13px;color:var(--accent);font-weight:500;flex:none}.how__text{font-size:14px;color:var(--muted);line-height:1.5}@media(max-width:680px){.how__list{grid-template-columns:1fr;gap:12px}}.lobby-stage{position:relative;min-height:100vh;display:flex;flex-direction:column;isolation:isolate;background:radial-gradient(120% 90% at 50% -10%,oklch(.22 .02 50 / .45),transparent 55%),var(--bg)}.vignette{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(120% 80% at 50% 30%,transparent 45%,var(--bg) 95%)}.lobby-hero{position:relative;width:100%;border-radius:22px;overflow:hidden;aspect-ratio:16 / 6;margin-bottom:40px;box-shadow:0 24px 60px -20px #000000b3}.lobby-hero__video{width:100%;height:100%;object-fit:cover;display:block}.lobby-hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,#00000040,#00000073,#070504eb)}.lobby-hero__text{position:absolute;bottom:clamp(20px,4%,32px);left:clamp(22px,4%,40px);z-index:1}.lobby-hero__text .lobby__eyebrow{margin-bottom:6px}.lobby-hero__text .lobby__greeting{font-size:clamp(22px,3.5vw,38px);margin:0}.lobby-hero__text .lobby__sub{margin:6px 0 0;font-size:14px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px clamp(20px,4vw,56px);border-bottom:1px solid var(--line-soft);background:#14110f8c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.brand{display:flex;align-items:center;gap:12px}.brand__name{font-weight:600;font-size:18px;letter-spacing:-.01em}.brand-mark{position:relative;width:26px;height:26px;display:inline-grid;place-items:center}.brand-mark__diamond{width:18px;height:18px;border:1.8px solid var(--accent);transform:rotate(45deg);border-radius:4px}.brand-mark__dot{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}.wallet-cluster{display:flex;align-items:center;gap:10px}.balance{display:flex;align-items:baseline;gap:6px;padding:9px 14px;border:1px solid var(--line);border-radius:10px;background:#1b181599}.balance__num{font-size:14px;font-weight:500}.balance__sym{font-size:11px;color:var(--muted);letter-spacing:.06em}.addr-chip{display:flex;align-items:center;gap:9px;padding:7px 13px 7px 8px;border:1px solid var(--line);border-radius:999px;background:#1b181599;font-size:13px}.identicon{width:22px;height:22px;border-radius:50%;flex:none;box-shadow:0 0 0 1px #ffffff14 inset}.net-dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px #6ed88926;margin-left:2px}.icon-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border:1px solid var(--line);border-radius:10px;background:transparent;color:var(--muted);cursor:pointer;font-family:var(--sans);font-size:13px;font-weight:500;transition:color .15s,border-color .15s,background .15s}.icon-btn:hover{color:var(--text);border-color:#fc585580;background:#fc585514}.lobby{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:clamp(28px,5vw,56px) clamp(20px,4vw,56px) 48px;display:flex;flex-direction:column}.lobby__eyebrow{font-size:12px;letter-spacing:.3em;color:var(--accent);text-transform:uppercase}.lobby__greeting{margin:12px 0 0;font-size:clamp(28px,4vw,44px);font-weight:600;letter-spacing:-.02em}.lobby__greeting .accent{color:var(--accent)}.lobby__sub{margin:8px 0 0;color:var(--muted);font-size:15px}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}.card{position:relative;text-align:left;display:flex;flex-direction:column;gap:14px;padding:26px 24px 22px;border-radius:18px;border:1px solid var(--line);background:var(--surface);cursor:pointer;color:inherit;font-family:var(--sans);transition:border-color .2s,box-shadow .2s,background .2s;overflow:hidden}.card:hover{border-color:#564b42;box-shadow:0 24px 50px -28px #000c}.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card__tile{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:var(--surface-2, oklch(.255 .011 66));border:1px solid var(--line);color:var(--muted)}.card__title{font-size:21px;font-weight:600;letter-spacing:-.01em}.card__desc{font-size:13.5px;color:var(--muted);line-height:1.5}.card__arrow{position:absolute;top:22px;right:22px;color:var(--faint);transition:color .18s}.card:hover .card__arrow{color:var(--text)}.card--primary{background:linear-gradient(165deg,color-mix(in srgb,var(--accent) 20%,var(--surface)),var(--surface) 70%);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}.card--primary:hover{border-color:var(--accent);box-shadow:0 26px 60px -28px color-mix(in srgb,var(--accent) 70%,transparent)}.card--primary .card__tile{background:var(--accent);border-color:transparent;color:#211209;box-shadow:0 0 24px -4px var(--accent)}.card__glow{position:absolute;inset:-40% 30% auto -10%;height:120%;pointer-events:none;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 22%,transparent),transparent 60%)}.admin-row{margin-top:18px}.admin-btn{display:inline-flex;align-items:center;gap:11px;padding:13px 18px;border-radius:12px;cursor:pointer;border:1px dashed oklch(.5 .1 280 / .55);background:#2325461f;color:#bfbef0;font-family:var(--sans);font-size:14px;font-weight:500;transition:background .2s,border-color .2s}.admin-btn:hover{background:#27295033;border-color:#6568b6cc}.admin-btn__badge{font-family:var(--mono);font-size:10px;letter-spacing:.08em;padding:3px 7px;border-radius:6px;background:#4a4b964d;color:#d3d3fe}.records{margin-top:44px}.records__head{display:flex;align-items:center;gap:18px;color:var(--faint)}.records__head .label{font-family:var(--mono);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;white-space:nowrap}.records__head .rule{flex:1;height:1px;background:var(--line-soft)}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}.stat{padding:20px 22px;border-radius:14px;border:1px solid var(--line);background:#19151280}.stat__label{font-size:12px;color:var(--muted);letter-spacing:.04em}.stat__value{margin-top:8px;font-family:var(--mono);font-size:30px;font-weight:700;letter-spacing:-.01em}.stat__value .unit{font-size:14px;font-weight:500;color:var(--faint);margin-left:4px}.stat--rank .stat__value{color:var(--accent)}@media(max-width:860px){.cards,.stats{grid-template-columns:1fr}.balance{display:none}}.spinner{width:15px;height:15px;border-radius:50%;border:2px solid oklch(1 0 0 / .25);border-top-color:currentColor;animation:spin .7s linear infinite;display:inline-block;flex-shrink:0}.nft-wallet{display:flex;align-items:center;gap:12px;padding:9px 16px 9px 13px;border-radius:12px;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));background:linear-gradient(160deg,color-mix(in srgb,var(--accent) 12%,var(--surface)),var(--surface))}.nft-wallet__icon{color:var(--accent);display:grid;place-items:center}.nft-wallet__meta{display:flex;flex-direction:column;line-height:1.1}.nft-wallet__label{font-size:11px;color:var(--muted)}.nft-wallet__num{font-size:19px;font-weight:700}.shop{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:clamp(26px,4vw,44px) clamp(20px,4vw,56px) 40px;display:flex;flex-direction:column}.shop__intro{max-width:64ch}.shop__lede{margin:0;color:var(--muted);font-size:15px;line-height:1.6}.shop__lede strong{color:var(--text);font-weight:600}.char-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}.char-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:18px;background:var(--surface);overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .2s}.char-card:hover{border-color:#564b42;transform:translateY(-3px);box-shadow:0 26px 54px -30px #000000d9}.char-card--owned{border-color:color-mix(in srgb,var(--ok) 40%,var(--line))}.char-art{position:relative;aspect-ratio:16/11;display:grid;place-items:center;border-bottom:1px solid var(--line-soft);overflow:hidden}.char-art__img{width:62%;height:62%;object-fit:contain;position:relative;z-index:1;animation:char-float 3.2s ease-in-out infinite}.char-art__floor{position:absolute;left:50%;bottom:14%;transform:translate(-50%);width:58%;height:14px;border-radius:50%;background:radial-gradient(closest-side,oklch(0 0 0 / .5),transparent);z-index:0}@keyframes char-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.char-art__aura{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);width:64%;aspect-ratio:1;border-radius:50%;z-index:0;pointer-events:none;animation:aura-pulse 2.6s ease-in-out infinite}@keyframes aura-pulse{0%,to{opacity:.45;transform:translate(-50%,-50%) scale(1);filter:blur(18px)}50%{opacity:.75;transform:translate(-50%,-50%) scale(1.18);filter:blur(22px)}}.char-art__particle{position:absolute;border-radius:50%;width:5px;height:5px;z-index:2;pointer-events:none;animation:particle-rise var(--dur, 2.2s) ease-in infinite;animation-delay:var(--delay, 0s);bottom:22%;left:var(--x, 50%);box-shadow:0 0 6px 2px var(--color, white);background:var(--color, white)}@keyframes particle-rise{0%{transform:translateY(0) scale(1);opacity:0}15%{opacity:.9}80%{opacity:.6}to{transform:translateY(-52px) scale(.2);opacity:0}}.char-card__body{padding:18px;display:flex;flex-direction:column;gap:12px;flex:1}.char-card__head{display:flex;align-items:center;justify-content:space-between;gap:10px}.char-card__name{margin:0;font-size:19px;font-weight:600;letter-spacing:-.01em}.owned-tag{font-size:9.5px;letter-spacing:.1em;color:var(--ok);border:1px solid oklch(.8 .15 150 / .4);padding:3px 7px;border-radius:6px}.char-card__blurb{margin:-2px 0 2px;font-size:12.5px;color:var(--faint);line-height:1.45;min-height:2.6em}.char-card__stats{display:flex;flex-direction:column;gap:7px;padding:12px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}.pip{width:20px;height:6px;border-radius:3px;background:#36322e}.char-card__foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}.price{display:inline-flex;align-items:center;gap:6px;color:var(--text)}.price svg{color:var(--accent)}.price__num{font-size:14px;font-weight:700}.buy-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 18px;border-radius:11px;cursor:pointer;font-family:var(--sans);font-size:13.5px;font-weight:600;border:1px solid var(--line);background:#27221d;color:var(--text);transition:transform .12s,filter .2s,background .2s,border-color .2s;min-width:104px}.buy-btn--primary{background:var(--accent);color:#211209;border-color:transparent;box-shadow:0 12px 28px -14px var(--accent)}.buy-btn--primary:hover{transform:translateY(-2px);filter:brightness(1.06)}.buy-btn--owned{background:transparent;border-color:#6ed88980;color:var(--ok)}.buy-btn:disabled{cursor:default;opacity:.7}@media(max-width:920px){.char-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.char-grid{grid-template-columns:1fr}}.arena-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-2;width:100%;height:100%;opacity:.45}.spinner{width:16px;height:16px;border-radius:50%;border:2px solid oklch(1 0 0 / .25);border-top-color:currentColor;animation:spin .7s linear infinite;display:inline-block;flex-shrink:0}.page-title__name{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em}.owned-count{font-size:11px;letter-spacing:.12em;color:var(--muted);border:1px solid var(--line);padding:7px 12px;border-radius:999px;background:#1b181599}.select{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:clamp(24px,3.5vw,40px) clamp(20px,4vw,56px) 44px;display:grid;grid-template-columns:340px 1fr;gap:32px;align-items:start}.preview{position:sticky;top:96px;border:1px solid var(--line);border-radius:20px;background:var(--surface);overflow:hidden}.preview__body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:14px}.preview__name{margin:0;font-size:26px;font-weight:600;letter-spacing:-.02em}.preview__blurb{margin:-6px 0 0;font-size:13.5px;color:var(--muted);line-height:1.5}.preview__stats{display:flex;flex-direction:column;gap:8px;padding:14px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}.preview__hint{margin:0;font-size:12px;color:var(--faint);text-align:center}.preview__hint .mono{color:var(--muted)}.start-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 22px;border-radius:13px;cursor:pointer;font-family:var(--sans);font-size:16px;font-weight:600;background:var(--accent);color:#211209;border:1px solid transparent;box-shadow:0 14px 36px -14px var(--accent);transition:transform .12s,filter .2s}.start-btn:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.06)}.start-btn:disabled{cursor:default;opacity:.9}.start-btn--busy{cursor:default;opacity:.92}.roster__head{display:flex;align-items:center;gap:16px;color:var(--faint);margin-bottom:18px}.roster__head .label{font-size:11px;letter-spacing:.2em;white-space:nowrap}.roster__head .rule{flex:1;height:1px;background:var(--line-soft)}.pick-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.pick-card{position:relative;text-align:left;padding:0;cursor:pointer;border:1px solid var(--line);border-radius:16px;background:var(--surface);overflow:hidden;font-family:var(--sans);color:inherit;transition:border-color .2s,box-shadow .2s,transform .2s}.pick-card:hover{transform:translateY(-3px);border-color:#564b42;box-shadow:0 22px 46px -28px #000000d9}.pick-card--sel{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 22px 50px -26px color-mix(in srgb,var(--accent) 70%,transparent)}.pick-card__check{position:absolute;top:12px;right:12px;z-index:3;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:#1c0d06;box-shadow:0 4px 14px -2px var(--accent)}.pick-card__foot{display:flex;align-items:center;justify-content:space-between;padding:13px 16px}.pick-card__name{font-size:16px;font-weight:600}.pick-card__state{font-size:12px;color:var(--muted);font-weight:500}.pick-card__state.is-sel{color:var(--accent)}.char-art{position:relative;aspect-ratio:16/11;display:grid;place-items:center;overflow:hidden}.char-art--big{aspect-ratio:4/3;border-bottom:1px solid var(--line-soft)}.char-art__img{width:60%;height:60%;object-fit:contain;position:relative;z-index:1}.char-art--big .char-art__img{width:52%;height:52%}.char-art__floor{position:absolute;left:50%;bottom:15%;transform:translate(-50%);width:56%;height:14px;border-radius:50%;background:radial-gradient(closest-side,oklch(0 0 0 / .5),transparent);z-index:0}.char-art__tag{position:absolute;top:12px;left:12px;z-index:2;font-size:9.5px;letter-spacing:.12em;padding:4px 8px;border-radius:6px;background:#080503a8;color:#f5eee0;border:1px solid oklch(1 0 0 / .12);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.stat-row{display:flex;align-items:center;justify-content:space-between}.stat-row__label{font-size:12.5px;color:var(--muted)}.pips{display:inline-flex;gap:5px}.pip{width:22px;height:6px;border-radius:3px;background:#36322e}.pip--on{background:var(--accent);box-shadow:0 0 8px -1px color-mix(in srgb,var(--accent) 70%,transparent)}.launch-veil{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;background:#070504c7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fade .25s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.launch-veil__core{width:70px;height:70px;border-radius:50%;background:radial-gradient(circle,var(--accent),color-mix(in srgb,var(--accent) 20%,transparent) 70%);box-shadow:0 0 60px -4px var(--accent);animation:pulse 1.1s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(.85);opacity:.85}50%{transform:scale(1.12);opacity:1}}.launch-veil__txt{position:absolute;bottom:38%;font-size:12px;letter-spacing:.28em;color:var(--text)}@media(max-width:860px){.select{grid-template-columns:1fr}.preview{position:static}}@media(max-width:520px){.pick-grid{grid-template-columns:1fr}}.arena-root{position:fixed;top:0;right:0;bottom:0;left:0}#game{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}#game canvas{display:block}.arena-vignette{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;background:radial-gradient(120% 120% at 50% 50%,transparent 58%,oklch(.1 .006 60 / .85) 100%)}.hud{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;pointer-events:none}.hud__top{position:absolute;top:0;left:0;right:0;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:clamp(14px,2.4vw,26px) clamp(16px,3vw,36px);background:linear-gradient(to bottom,oklch(.12 .006 60 / .72),transparent)}.hud__stats{display:flex;flex-direction:column;gap:10px}.hp-row{display:flex;align-items:center;gap:14px}.hearts{display:flex;gap:5px}.heart{width:26px;height:26px;filter:drop-shadow(0 2px 4px oklch(0 0 0 / .5))}.hp-readout{display:flex;align-items:baseline;gap:8px}.hp-readout__label{font-size:11px;letter-spacing:.14em;color:var(--muted)}.hp-readout__val{font-family:var(--mono);font-size:16px;font-weight:700}.level-badge{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:4px 10px;border-radius:8px}.meta-row{display:flex;align-items:center;gap:18px}.meta{display:inline-flex;align-items:center;gap:8px;color:var(--text)}.meta svg{color:var(--accent)}.meta__val{font-family:var(--mono);font-size:18px;font-weight:700;letter-spacing:.01em}.meta__val--time{font-size:20px}.meta__divider{width:1px;height:18px;background:#ffffff29}.btn-pause{pointer-events:auto;width:46px;height:46px;border-radius:12px;cursor:pointer;display:grid;place-items:center;border:1px solid var(--line);background:#14110eb3;color:var(--text);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:border-color .15s,background .15s,transform .1s}.btn-pause:hover{border-color:var(--accent);background:#1e1a16cc}.btn-pause:active{transform:scale(.94)}.btn-pause .ic-play,.btn-pause.is-paused .ic-pause{display:none}.btn-pause.is-paused .ic-play{display:block}.hud__exp{position:absolute;left:0;right:0;bottom:0;padding:0 clamp(16px,3vw,36px) clamp(14px,2vw,22px);background:linear-gradient(to top,oklch(.12 .006 60 / .72),transparent)}.exp-wrap{display:flex;align-items:center;gap:12px}.exp-label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--muted)}.exp-track{flex:1;height:10px;border-radius:6px;overflow:hidden;background:#221e1bcc;border:1px solid var(--line-soft)}.exp-fill{height:100%;width:0%;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 70%,#fff 0%),var(--accent));box-shadow:0 0 12px -1px var(--accent);transition:width .18s ease-out}.levelup{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%) scale(.8);z-index:6;pointer-events:none;opacity:0;font-family:var(--mono);font-size:clamp(22px,4vw,40px);font-weight:700;letter-spacing:.16em;color:var(--accent);text-shadow:0 0 24px var(--accent);transition:opacity .2s,transform .2s}.levelup.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:none;place-items:center;text-align:center;background:#040302b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.overlay.show{display:grid}.panel{width:min(440px,88vw);border:1px solid var(--line);border-radius:20px;background:#14110ef5;padding:34px 32px;box-shadow:0 40px 90px -30px #000000e6}.panel__eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--accent)}.panel__title{margin:10px 0 6px;font-size:30px;font-weight:600;letter-spacing:-.02em}.panel__sub{margin:0 0 22px;color:var(--muted);font-size:14px;line-height:1.5}.end-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.end-stat{padding:14px 10px;border:1px solid var(--line);border-radius:12px;background:#1b181599}.end-stat__label{font-size:10.5px;letter-spacing:.1em;color:var(--muted)}.end-stat__val{margin-top:6px;font-family:var(--mono);font-size:22px;font-weight:700}.end-stat--score .end-stat__val{color:var(--accent)}.panel__actions{display:flex;flex-direction:column;gap:10px}.pbtn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 20px;border-radius:12px;cursor:pointer;font-family:var(--sans);font-size:15px;font-weight:600;text-decoration:none;border:1px solid var(--line);background:transparent;color:var(--text);transition:transform .12s,filter .2s,background .2s,border-color .2s}.pbtn:hover{transform:translateY(-2px)}.pbtn--primary{background:var(--accent);color:#211209;border-color:transparent;box-shadow:0 12px 30px -14px var(--accent)}.pbtn--ghost:hover{border-color:#564b42;background:var(--surface)}.end-mint-note{margin:16px 0 0;font-size:11.5px;color:var(--faint);line-height:1.5}.panel--result{width:min(460px,90vw);text-align:left;padding:30px 30px 26px}.result-head{text-align:center;margin-bottom:22px}.result-end-img{width:140px;height:140px;object-fit:contain;display:block;margin:0 auto 12px;filter:drop-shadow(0 0 18px oklch(.68 .2 25 / .6))}.result-badge{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.2em;padding:5px 12px;border-radius:999px;margin-bottom:12px}.result-badge--win{color:var(--ok);border:1px solid oklch(.8 .15 150 / .45);background:#6ed8891f}.result-badge--lose{color:var(--danger);border:1px solid oklch(.68 .2 25 / .45);background:#fc58551f}.panel--result .panel__title{margin:0 0 4px}.panel--result .panel__sub{margin:0}.result-block{margin-top:22px}.result-block__label{display:flex;align-items:center;gap:12px;font-size:10.5px;letter-spacing:.2em;color:var(--faint);margin-bottom:12px}.result-block__label .ln{flex:1;height:1px;background:var(--line-soft)}.result-list{margin:0;display:flex;flex-direction:column}.rrow{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--line-soft)}.rrow:last-child{border-bottom:none}.rrow dt{margin:0;font-size:13.5px;color:var(--muted)}.rrow dd{margin:0;font-size:16px;font-weight:500}.rrow--score{margin-top:4px;padding-top:14px;border-top:1px solid var(--line)}.rrow--score dt{color:var(--text);font-size:15px;font-weight:600}.rrow--score dd{font-size:26px;font-weight:700;color:var(--accent);letter-spacing:-.01em}.submit{border:1px solid var(--line);border-radius:12px;background:#1915128c;padding:14px 16px;min-height:58px;display:flex;align-items:center}.submit__pending{display:flex;align-items:center;gap:11px;font-size:13.5px;color:var(--muted)}.submit__done{display:flex;align-items:center;gap:12px;width:100%}.submit__check{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#6ed8892e;color:var(--ok)}.submit__meta{flex:1}.submit__rankline{font-size:14px;font-weight:500}.rank-num{color:var(--accent);font-family:var(--mono);font-weight:700}.submit__prev{font-size:12px;color:var(--faint);margin-top:2px}.newrec-badge{flex:none;font-size:9.5px;letter-spacing:.1em;color:#211209;background:var(--accent);padding:4px 8px;border-radius:6px;align-self:center}.result-actions{margin-top:24px}.result-actions .pbtn{width:100%}.end-hint{margin:12px 0 0;text-align:center;font-size:12px;color:var(--faint);min-height:1em}.overlay--upgrade{z-index:15}.up-panel{width:min(820px,92vw);border:1px solid var(--line);border-radius:22px;background:#120f0cf7;padding:30px clamp(20px,3vw,36px) clamp(22px,3vw,34px);box-shadow:0 50px 110px -34px #000000eb;animation:upIn .26s cubic-bezier(.2,.8,.3,1)}@keyframes upIn{0%{transform:translateY(16px) scale(.98)}to{transform:none}}.up-panel__head{text-align:center;position:relative;padding-bottom:22px}.up-panel__spark{width:46px;height:46px;margin:0 auto 12px;display:block;border-radius:50%;background:radial-gradient(circle,var(--accent),color-mix(in srgb,var(--accent) 18%,transparent) 70%);box-shadow:0 0 34px -2px var(--accent);animation:sparkPulse 1.4s ease-in-out infinite}@keyframes sparkPulse{0%,to{transform:scale(.9);opacity:.85}50%{transform:scale(1.08);opacity:1}}.up-panel__eyebrow{font-size:11px;letter-spacing:.28em;color:var(--accent)}.up-panel__title{margin:8px 0 4px;font-size:28px;font-weight:600;letter-spacing:-.02em}.up-panel__sub{margin:0;color:var(--muted);font-size:14px}.up-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.up-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:24px 16px 18px;cursor:pointer;font-family:var(--sans);color:var(--text);border:1px solid var(--line);border-radius:16px;background:var(--surface);transition:transform .14s,border-color .2s,box-shadow .2s,background .2s}.up-card:hover{transform:translateY(-4px);border-color:var(--accent);background:#1c1714;box-shadow:0 24px 50px -26px color-mix(in srgb,var(--accent) 70%,transparent)}.up-card__rank{font-size:10px;letter-spacing:.12em;color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 12%,transparent);padding:3px 9px;border-radius:999px}.up-card__icon{width:54px;height:54px;display:grid;place-items:center;border-radius:14px;background:#25211d;color:var(--accent);margin-top:4px}.up-card__icon svg{width:28px;height:28px}.up-card:hover .up-card__icon{background:var(--accent);color:#1c0d06}.up-card__name{font-size:16px;font-weight:600;line-height:1.2;white-space:nowrap}.up-card__desc{font-size:12.5px;color:var(--muted);line-height:1.45;min-height:2.7em}.up-card__pick{margin-top:4px;font-size:12.5px;font-weight:600;color:var(--faint);border-top:1px solid var(--line-soft);padding-top:12px;width:100%;transition:color .2s}.up-card:hover .up-card__pick{color:var(--accent)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@media(max-width:620px){.up-cards{grid-template-columns:1fr;gap:10px}.up-card{flex-direction:row;text-align:left;padding:14px;gap:14px}.up-card__desc{min-height:0}.up-card__pick{display:none}}@media(max-width:560px){.meta-row{gap:12px}.heart{width:22px;height:22px}.meta__val{font-size:16px}}.arena-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-2;width:100%;height:100%;opacity:.4}.spinner{width:16px;height:16px;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;animation:spin .7s linear infinite;display:inline-block}.back-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px 9px 11px;border:1px solid var(--line);border-radius:10px;background:#1b181599;color:var(--muted);font-size:13.5px;font-weight:500;cursor:pointer;font-family:var(--sans);transition:color .15s,border-color .15s,background .15s}.back-btn:hover{color:var(--text);border-color:#564b42;background:var(--surface)}.title-trophy{color:var(--accent);display:inline-flex}.net-pill{font-size:11px;letter-spacing:.12em;color:var(--muted);border:1px solid var(--line);padding:7px 12px;border-radius:999px;background:#1b181599}.rank{flex:1;width:100%;max-width:880px;margin:0 auto;padding:clamp(24px,4vw,40px) clamp(16px,4vw,56px) 44px;display:flex;flex-direction:column;gap:18px}.board{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#19151280}.col{display:flex;align-items:center}.col--rank{width:78px;flex:none}.col--player{flex:1;gap:12px;min-width:0}.col--score{width:120px;flex:none;justify-content:flex-end;font-weight:700}.col--date{width:84px;flex:none;justify-content:flex-end;color:var(--faint)}.board__head{display:flex;align-items:center;gap:16px;padding:13px clamp(16px,2.4vw,24px);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);border-bottom:1px solid var(--line-soft);background:#14110f80}.board__body{display:flex;flex-direction:column}.row{display:flex;align-items:center;gap:16px;padding:13px clamp(16px,2.4vw,24px);border-bottom:1px solid var(--line-soft);transition:background .15s}.row:last-child{border-bottom:none}.row:hover{background:#231e1a80}.row .col--score{font-size:16px}.row--top .col--score{color:var(--accent)}.row--me{background:color-mix(in srgb,var(--accent) 10%,transparent);box-shadow:inset 3px 0 0 var(--accent)}.row--me:hover{background:color-mix(in srgb,var(--accent) 14%,transparent)}.identicon{width:26px;height:26px;border-radius:50%;flex:none;box-shadow:0 0 0 1px #ffffff14 inset}.addr{font-size:13.5px;overflow:hidden;text-overflow:ellipsis}.you-tag{flex:none;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;color:#211209;background:var(--accent);padding:3px 7px;border-radius:6px}.rank-num{color:var(--muted);font-size:14px;font-weight:500;padding-left:9px}.rank-medal{display:inline-grid;place-items:center}.rank-medal__disc{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-size:13px;font-weight:700;color:#171008;background:radial-gradient(circle at 35% 30%,color-mix(in srgb,var(--medal) 80%,#fff),var(--medal));box-shadow:0 0 0 1px color-mix(in srgb,var(--medal) 60%,#000 0%),0 2px 8px -2px var(--medal)}.myrank{display:flex;align-items:center;gap:20px;padding:16px 22px;border-radius:14px;border:1px solid color-mix(in srgb,var(--accent) 26%,var(--line));background:linear-gradient(160deg,color-mix(in srgb,var(--accent) 9%,var(--surface)),var(--surface))}.myrank__cell{display:flex;flex-direction:column;gap:3px}.myrank__label{font-size:11.5px;color:var(--muted);letter-spacing:.02em}.myrank__val{font-size:22px;font-weight:700}.myrank__val--score{color:var(--accent)}.myrank__div{width:1px;height:34px;background:var(--line)}.myrank__play{margin-left:auto;display:inline-flex;align-items:center;padding:11px 18px;border-radius:10px;background:var(--accent);color:#211209;font-weight:600;font-size:14px;font-family:var(--sans);border:none;cursor:pointer;box-shadow:0 12px 28px -14px var(--accent);transition:transform .12s,filter .2s}.myrank__play:hover{transform:translateY(-2px);filter:brightness(1.06)}@media(max-width:560px){.col--date{display:none}.col--score{width:92px}.myrank{flex-wrap:wrap;gap:14px}.myrank__play{margin-left:0;width:100%;justify-content:center}}.stage{position:relative;min-height:100vh;display:flex;flex-direction:column;isolation:isolate;background:radial-gradient(120% 90% at 50% -10%,oklch(.22 .02 50 / .45),transparent 55%),var(--bg)}.arena-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-2;width:100%;height:100%;opacity:.35}.vignette{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(120% 80% at 50% 24%,transparent 48%,var(--bg) 96%)}.spinner{width:14px;height:14px;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;animation:spin .7s linear infinite;display:inline-block;flex-shrink:0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px clamp(20px,4vw,56px);border-bottom:1px solid var(--line-soft);background:#14110f99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:20}.topbar__left{display:flex;align-items:center;gap:20px}.back-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px 9px 11px;border:1px solid var(--line);border-radius:10px;background:#1b181599;color:var(--muted);font-size:13.5px;font-weight:500;cursor:pointer;font-family:var(--sans);transition:color .15s,border-color .15s}.back-btn:hover{color:var(--text);border-color:#564b42}.page-title{display:flex;flex-direction:column;gap:3px}.page-title__eyebrow{font-size:10.5px;letter-spacing:.22em;color:var(--accent)}.page-title__name{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:9px}.shield-icon{color:var(--accent);display:inline-flex}.owner-chip{display:inline-flex;align-items:center;gap:9px;padding:7px 13px 7px 10px;border:1px solid oklch(.5 .1 280 / .45);border-radius:999px;background:#2325461f;font-size:13px}.owner-chip__dot{width:7px;height:7px;border-radius:50%;background:#bfbef0;box-shadow:0 0 0 3px #bfbef026}.owner-chip__badge{font-family:var(--mono);font-size:10px;letter-spacing:.08em;padding:3px 7px;border-radius:6px;background:#4a4b964d;color:#d3d3fe}.admin{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:clamp(24px,4vw,40px) clamp(20px,4vw,56px) 48px;display:flex;flex-direction:column;gap:40px}.admin-section{display:flex;flex-direction:column;gap:16px}.section-head{display:flex;align-items:center;gap:14px}.section-head__label{font-family:var(--mono);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);white-space:nowrap}.section-head__rule{flex:1;height:1px;background:var(--line-soft)}.icon-btn-sm{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s}.icon-btn-sm:hover{color:var(--text);border-color:var(--line)}.danger-label{color:var(--danger)!important}.rank-table{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#19151280}.rank-table__head{display:flex;align-items:center;gap:12px;padding:11px 18px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);border-bottom:1px solid var(--line-soft);background:#14110f80}.rank-table__body{display:flex;flex-direction:column}.rank-row{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--line-soft);transition:background .15s}.rank-row:last-child{border-bottom:none}.rank-row:hover{background:#231e1a66}.rank-row--top{background:color-mix(in srgb,var(--accent) 5%,transparent)}.table-empty{padding:24px 18px;color:var(--faint);font-size:14px;display:flex;align-items:center;gap:8px}.col{display:flex;align-items:center;flex-shrink:0}.col--rank{width:54px}.col--addr{flex:1;min-width:0}.col--score{width:100px;justify-content:flex-end;font-weight:700;font-size:14px}.col--date{width:80px;justify-content:flex-end;color:var(--faint);font-size:12px}.col--action{width:120px;justify-content:flex-end}.medal{font-size:18px}.rank-num{font-size:14px;color:var(--muted);padding-left:6px}.addr-full{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grant-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:8px;cursor:pointer;font-family:var(--sans);font-size:12.5px;font-weight:600;background:color-mix(in srgb,var(--accent) 15%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);color:var(--accent);transition:background .15s,border-color .15s}.grant-btn:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 22%,var(--surface))}.grant-btn:disabled{opacity:.6;cursor:default}.grant-done{font-size:12px;color:var(--ok);font-weight:600}.grant-na{font-size:13px;color:var(--faint)}.danger-zone .admin-section{gap:14px}.danger-content{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 22px;border:1px solid oklch(.68 .2 25 / .35);border-radius:14px;background:#fc58550f}.danger-title{font-size:15px;font-weight:600;margin-bottom:4px}.danger-desc{font-size:13px;color:var(--muted);line-height:1.5;max-width:500px}.reset-btn{display:inline-flex;align-items:center;gap:8px;flex-shrink:0;padding:11px 18px;border-radius:10px;cursor:pointer;font-family:var(--sans);font-size:14px;font-weight:600;background:#fc585526;border:1px solid oklch(.68 .2 25 / .5);color:var(--danger);transition:background .15s,border-color .15s}.reset-btn:hover{background:#fc585540;border-color:var(--danger)}@media(max-width:700px){.col--date{display:none}.danger-content{flex-direction:column;align-items:flex-start}.reset-btn{width:100%;justify-content:center}}:root{--bg: oklch(.165 .006 60);--bg-arena: #1a1410;--surface: oklch(.225 .01 64);--line: oklch(.32 .012 66);--line-soft: oklch(.27 .01 66);--text: oklch(.965 .004 85);--muted: oklch(.7 .012 75);--faint: oklch(.55 .01 72);--accent: #ff7a45;--ok: oklch(.8 .15 150);--danger: oklch(.68 .2 25);--sans: "Space Grotesk", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased}#root{min-height:100vh}.mono{font-family:var(--mono);font-feature-settings:"tnum" 1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:12px;font-family:var(--sans);font-size:15px;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,transform .1s;text-decoration:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--accent);color:var(--bg)}.btn--primary:hover:not(:disabled){opacity:.88}.btn--ghost{background:transparent;color:var(--text);border:1px solid var(--line)}.btn--ghost:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page{min-height:100vh;display:flex;flex-direction:column}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{padding:12px 20px;border-radius:10px;font-size:14px;font-weight:500;pointer-events:auto;animation:toast-in .25s ease-out}.toast--success{background:var(--ok);color:#fff}.toast--error{background:var(--danger);color:#fff}.toast--info{background:var(--surface);color:var(--text);border:1px solid var(--line)}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
