:root{--blue:#0059c8;--blue-dark:#003f8e;--blue-soft:#e3edfa;--coral:#e8542f;--coral-soft:#fde9e3;--yellow:#ffc94d;--yellow-soft:#fff3d6;--green:#0fa36b;--green-soft:#e2f5ed;--ink:#10233f;--ink-soft:#5a6b84;--bg:#f2f6fc;--card:#fff;--line:#d9e3f0;--radius:16px;--radius-lg:24px;--shadow:0 2px 10px #10233f14;--shadow-lg:0 8px 30px #10233f24;--font:"Avenir Next", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html,body{background:var(--bg);height:100%;color:var(--ink);font-family:var(--font);-webkit-user-select:none;user-select:none;margin:0;overflow:hidden}body:before{content:"";z-index:-1;background:radial-gradient(60vmax 60vmax at 8% -10%,#0059c817,#0000 60%),radial-gradient(50vmax 50vmax at 105% 20%,#e8542f12,#0000 60%),radial-gradient(45vmax 45vmax at 50% 115%,#ffc94d1a,#0000 60%),linear-gradient(#10233f09 1px,#0000 1px) 0 0/44px 44px,linear-gradient(90deg,#10233f09 1px,#0000 1px) 0 0/44px 44px;position:fixed;inset:0}body{touch-action:manipulation}#app{flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}#fx{pointer-events:none;z-index:50;position:fixed;inset:0}button{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;font-family:inherit}input[type=text]{-webkit-user-select:text;user-select:text;font-family:inherit}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.btn{min-height:52px;color:var(--ink);background:#e9eef7;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:17px;font-weight:700;transition:transform 80ms,background .15s,box-shadow .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:default;transform:none}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 3px 0 var(--blue-dark)}.btn-primary:active{box-shadow:0 1px 0 var(--blue-dark)}.btn-coral{background:var(--coral);color:#fff;box-shadow:0 3px #b23a1c}.btn-ghost{border:2px solid var(--line);background:0 0}.btn-big{border-radius:18px;width:100%;min-height:64px;font-size:20px}.input{border:2px solid var(--line);width:100%;min-height:54px;color:var(--ink);background:#fff;border-radius:14px;outline:none;padding:12px 16px;font-size:18px;font-weight:600}.input:focus{border-color:var(--blue)}.pill{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:800;display:inline-flex}.pill-blue{background:var(--blue-soft);color:var(--blue)}.pill-coral{background:var(--coral-soft);color:var(--coral)}.pill-green{background:var(--green-soft);color:var(--green)}.pill-yellow{background:var(--yellow-soft);color:#8a6100}.muted{color:var(--ink-soft)}.stamp{letter-spacing:.08em;text-transform:uppercase;border:5px solid;border-radius:12px;padding:8px 22px;font-size:clamp(22px,4.5vw,48px);font-weight:900;animation:.35s cubic-bezier(.2,2.2,.4,1) both stamp-in;display:inline-block;transform:rotate(-6deg)}.stamp-green{color:var(--green);background:var(--green-soft)}.stamp-coral{color:var(--coral);background:var(--coral-soft)}.stamp-blue{color:var(--blue);background:var(--blue-soft)}.stamp-yellow{color:#8a6100;background:var(--yellow-soft)}@keyframes stamp-in{0%{opacity:0;transform:rotate(-6deg)scale(2.6)}to{opacity:1;transform:rotate(-6deg)scale(1)}}.shake{animation:.4s both shake}@keyframes shake{10%,90%{transform:translate(-1px,1px)}20%,80%{transform:translate(2px,-1px)}30%,50%,70%{transform:translate(-3px,2px)}40%,60%{transform:translate(3px,-2px)}}.topbar{flex:none;align-items:center;gap:10px;padding:10px 14px;display:flex}.topbar .code{letter-spacing:.14em;color:var(--blue);font-size:18px;font-weight:900}.main{flex-direction:column;flex:auto;gap:12px;padding:8px 14px 14px;animation:.32s cubic-bezier(.22,1,.36,1) both screen-in;display:flex;overflow:hidden auto}@keyframes screen-in{0%{opacity:0;transform:translateY(14px)scale(.99)}to{opacity:1;transform:none}}.main-center{text-align:center;justify-content:safe center;align-items:safe center}.reactrow{padding:8px 10px calc(10px + env(safe-area-inset-bottom));flex:none;justify-content:center;gap:6px;display:flex}.reactrow button{background:var(--card);box-shadow:var(--shadow);border-radius:999px;width:52px;height:52px;font-size:24px}.reactrow button:active{transform:scale(1.25)}.netbanner{z-index:60;background:var(--yellow);color:#5c4100;text-align:center;padding:8px;font-size:14px;font-weight:800;position:fixed;top:0;left:0;right:0}.toast{z-index:70;background:var(--ink);color:#fff;box-shadow:var(--shadow-lg);text-align:center;border-radius:999px;max-width:90vw;padding:10px 18px;font-weight:700;animation:.25s both toast-in;position:fixed;bottom:90px;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.timerwrap{flex:auto;align-items:center;gap:10px;min-width:0;display:flex}.timerbar{background:var(--line);border-radius:999px;flex:auto;height:12px;overflow:hidden}.timerbar>div{background:var(--blue);transform-origin:0;border-radius:999px;width:100%;height:100%}.timerbar.urgent>div{background:var(--coral)}.timernum{font-variant-numeric:tabular-nums;text-align:right;min-width:2ch;font-size:20px;font-weight:900}.avatar{image-rendering:pixelated;border-radius:10px;flex:none}.chip{background:var(--card);box-shadow:var(--shadow);border-radius:999px;align-items:center;gap:8px;padding:5px 12px 5px 6px;font-size:14px;font-weight:700;display:inline-flex}.chip.gone{opacity:.4}.chiprow{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.stage-body{font-size:clamp(16px,2.2vh,26px)}.stage-code{z-index:40;text-align:right;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:10px 16px;position:fixed;top:14px;right:18px}.stage-code .c{letter-spacing:.18em;color:var(--blue);font-size:clamp(22px,3.4vh,40px);font-weight:900}.stage-code .u{color:var(--ink-soft);font-size:clamp(11px,1.5vh,16px);font-weight:700}.stage-h1{letter-spacing:-.02em;margin:0;font-size:clamp(34px,7vh,84px);font-weight:900}.stage-h2{margin:0;font-size:clamp(22px,4vh,48px);font-weight:900}.bignum{font-variant-numeric:tabular-nums;font-size:clamp(44px,10vh,120px);font-weight:900;line-height:1}.kpi-row{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.kpi{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;min-width:180px;padding:20px 28px}.kpi .label{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-size:clamp(12px,1.6vh,18px);font-weight:800}.kpi .value{font-variant-numeric:tabular-nums;font-size:clamp(28px,5vh,64px);font-weight:900}.variants{justify-content:center;align-items:stretch;gap:20px;width:100%;max-width:1300px;display:flex}.variant{background:var(--card);border-radius:var(--radius-lg);max-width:560px;box-shadow:var(--shadow);text-align:center;border:4px solid #0000;flex-direction:column;flex:1 1 0;align-items:center;gap:12px;padding:24px;display:flex;position:relative}.variant .tag{letter-spacing:.1em;border-radius:10px;padding:4px 16px;font-size:clamp(16px,2.4vh,28px);font-weight:900}.variant.win{border-color:var(--green);box-shadow:var(--shadow-lg)}.variant.lose{opacity:.55}.bars{flex-direction:column;gap:10px;width:100%;max-width:1100px;display:flex}.bar-row{align-items:center;gap:12px;display:flex}.bar-row .name{white-space:nowrap;text-overflow:ellipsis;flex:0 0 clamp(120px,18vw,240px);align-items:center;gap:8px;font-size:clamp(14px,2.2vh,24px);font-weight:800;display:flex;overflow:hidden}.bar-row .track{background:var(--card);height:clamp(22px,3.6vh,44px);box-shadow:var(--shadow);border-radius:999px;flex:auto;overflow:hidden}.bar-row .fill{background:var(--blue);border-radius:999px;min-width:6px;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.bar-row .num{text-align:right;font-variant-numeric:tabular-nums;flex:0 0 clamp(64px,8vw,120px);font-size:clamp(16px,2.6vh,30px);font-weight:900}.float-react{z-index:55;pointer-events:none;font-size:44px;animation:2.6s ease-out forwards float-up;position:fixed;bottom:-60px}.float-react.small{font-size:26px;animation-duration:1.9s}@keyframes float-up{0%{opacity:1;transform:translateY(0)rotate(0)scale(.6)}12%{transform:translateY(-9vh)rotate(-6deg)scale(1.15)}to{opacity:0;transform:translateY(-70vh)rotate(14deg)scale(1)}}.reactrow button{transition:transform .12s cubic-bezier(.2,2.2,.4,1)}.reactrow button.sent{transform:scale(1.35)rotate(-8deg)}.choice-grid{flex-direction:column;gap:10px;width:100%;display:flex}.choice{border-radius:var(--radius);background:var(--card);width:100%;min-height:64px;box-shadow:var(--shadow);text-align:left;color:var(--ink);border:3px solid #0000;padding:14px 16px;font-size:17px;font-weight:700}.choice.sel{border-color:var(--blue);background:var(--blue-soft)}.chips-picker{justify-content:center;gap:10px;display:flex}.chips-picker .btn{flex:1 1 0}.chips-picker .btn.sel{background:var(--yellow);color:#5c4100;box-shadow:0 3px #c99a2e}.eyes{margin-bottom:6px;font-size:40px}.gamemenu{gap:10px;width:100%;display:grid}.gamecard{text-align:left;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:2px solid var(--line);border-left:6px solid var(--accent,var(--blue));color:var(--ink);grid-template-columns:44px 1fr auto;align-items:center;gap:12px;padding:12px 14px;transition:transform 80ms,box-shadow .15s;display:grid}.gamecard:not(:disabled):active{box-shadow:var(--shadow-lg);transform:scale(.98)}.gamecard .ic{background:color-mix(in srgb, var(--accent,var(--blue)) 14%, white);border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;font-size:24px;display:flex}.gamecard .mid{min-width:0}.gamecard .t{font-size:16px;font-weight:900;line-height:1.15}.gamecard .s{color:var(--ink-soft);margin-top:2px;font-size:12px;font-weight:600}.gamecard .go{letter-spacing:.06em;text-transform:uppercase;background:var(--accent,var(--blue));color:#fff;white-space:nowrap;border-radius:10px;padding:8px 12px;font-size:12px;font-weight:900}.gamecard.locked{border-left-color:var(--line);box-shadow:none;background:0 0;border-style:dashed}.gamecard.locked .ic{filter:grayscale();opacity:.7;background:#e9eef7}.gamecard.locked .t{color:var(--ink-soft)}.gamecard.locked .go{color:var(--ink-soft);border:2px solid var(--line);text-transform:none;letter-spacing:0;background:0 0}.gamecard.played .go{background:var(--green-soft);color:var(--green)}.gamecard.readonly{pointer-events:none}.gamecard.readonly .go{color:var(--ink-soft);text-transform:none;letter-spacing:0;background:#e9eef7}.hostbar{flex:none;justify-content:center;gap:8px;padding:6px 10px;display:flex}.hostbar .btn{background:var(--card);min-height:40px;box-shadow:var(--shadow);padding:6px 14px;font-size:13px}.lobby-grid{flex-wrap:wrap;justify-content:center;gap:14px;max-width:1200px;display:flex}.profile-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;align-items:center;gap:8px;width:clamp(110px,12vw,150px);padding:14px;animation:.3s cubic-bezier(.2,1.8,.4,1) both pop-in;display:flex}.profile-card .n{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:clamp(13px,1.9vh,19px);font-weight:800;overflow:hidden}@keyframes pop-in{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.trait-row{background:var(--blue-soft);border-radius:var(--radius);text-align:left;width:100%;padding:12px 20px}.trait-row .label{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-size:clamp(12px,1.6vh,18px);font-weight:800}.trait-row .value{overflow-wrap:anywhere;font-size:clamp(20px,3.6vh,44px);font-weight:900}.roster-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;width:100%;display:grid}.roster-btn{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);min-height:84px;color:var(--ink);border:3px solid #0000;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;font-size:13px;font-weight:800;display:flex}.roster-btn.sel{border-color:var(--blue);background:var(--blue-soft)}.roster-btn:disabled{opacity:.35;cursor:default}.roster-btn .n{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.fp-blank{border-bottom:4px solid var(--coral);background:var(--yellow-soft);border-radius:8px 8px 0 0;min-width:2.6em;display:inline-block}.fp-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;width:100%;max-width:1300px;display:grid}.fp-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);text-align:left;text-transform:uppercase;align-items:center;gap:12px;padding:14px 18px;font-weight:800;display:flex}.brieflabel{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:4px;font-size:12px;font-weight:800}.drawpad{aspect-ratio:1;border-radius:var(--radius);width:100%;max-width:min(88vw,440px);box-shadow:var(--shadow);border:2px solid var(--line);touch-action:none;background:#fff;flex:none;margin:0 auto;display:block}.swatches{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.swatch{border:3px solid var(--line);border-radius:999px;flex:none;width:42px;height:42px}.swatch.sel{border-color:var(--ink);box-shadow:0 0 0 3px var(--card) inset;transform:scale(1.12)}.drawtools{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;display:flex}.drawtools .btn{min-height:44px;padding:8px 16px;font-size:14px}.widthrow{gap:6px;display:flex}.widthbtn{background:var(--card);width:44px;height:44px;box-shadow:var(--shadow);border:3px solid #0000;border-radius:12px;justify-content:center;align-items:center;display:inline-flex}.widthbtn.sel{border-color:var(--blue);background:var(--blue-soft)}.widthbtn .dot{background:var(--ink);border-radius:999px;display:block}.inkrow{align-items:center;gap:10px;display:flex}.inklabel{color:var(--ink-soft);white-space:nowrap;font-size:13px;font-weight:800}.inkbar{background:var(--line);border-radius:999px;flex:auto;height:10px;overflow:hidden}.inkbar>div{background:var(--blue);border-radius:999px;width:0%;height:100%;transition:width .1s linear}.inkbar.low>div{background:var(--coral)}.variantgrid{grid-template-columns:1fr 1fr;gap:10px;width:100%;display:grid}.variantgrid .variantbtn:nth-child(3):last-child{grid-column:1/-1;justify-self:center;max-width:60%}.variantbtn{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);color:var(--ink);border:3px solid #0000;flex-direction:column;align-items:center;gap:8px;padding:10px;display:flex}.variantbtn.sel{border-color:var(--blue);background:var(--blue-soft)}.variantbtn:disabled{opacity:.7}.variantbtn canvas.drawing,.variantbtn .notfound{width:100%}canvas.drawing{aspect-ratio:1;border:2px solid var(--line);background:#fff;border-radius:10px;display:block}.variant canvas.drawing,.variant .notfound{width:100%;max-width:min(38vh,420px)}.notfound{aspect-ratio:1;border:2px dashed var(--line);color:var(--ink-soft);background:#fff;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex}.notfound .nf-code{font-size:clamp(28px,5vh,56px);font-weight:900}.notfound .nf-line{font-size:clamp(11px,1.6vh,16px);font-weight:700}.stamprow{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.stamprow .stamp{border-width:4px;font-size:clamp(15px,2.4vh,28px)}.wordmark{letter-spacing:-.03em;background:linear-gradient(100deg, var(--blue) 15%, #3579dc 55%, var(--coral) 110%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(40px,9vh,96px);font-weight:900;line-height:1}.wordmark .up{-webkit-text-fill-color:initial;color:var(--ink);background:0 0;display:inline-block;transform:translateY(-.06em)}.divider{width:100%;color:var(--ink-soft);letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:12px;font-size:12px;font-weight:800;display:flex}.divider:before,.divider:after{content:"";background:var(--line);border-radius:2px;flex:1;height:2px}.qr-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);background:#fff;flex-direction:column;align-items:center;gap:6px;padding:14px;display:flex}.qr-card .hint{color:var(--ink-soft);letter-spacing:.06em;text-transform:uppercase;font-size:clamp(11px,1.5vh,15px);font-weight:800}.invite-row{gap:8px;width:100%;display:flex}.invite-row .btn{flex:1;min-height:44px;font-size:14px}.mini-standings{flex-direction:column;gap:6px;width:100%;display:flex}.mini-row{background:var(--card);box-shadow:var(--shadow);border-radius:12px;align-items:center;gap:10px;padding:7px 12px;font-size:14px;font-weight:700;display:flex}.mini-row .rank{color:var(--ink-soft);font-variant-numeric:tabular-nums;min-width:2ch;font-weight:900}.mini-row .nm{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.mini-row .pts{font-variant-numeric:tabular-nums;font-weight:900}.mini-row.me{border:2px solid var(--blue);background:var(--blue-soft)}.gamestrip{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.gamestrip .g{background:var(--card);box-shadow:var(--shadow);border-bottom:4px solid var(--accent,var(--blue));border-radius:999px;align-items:center;gap:8px;padding:8px 16px 8px 10px;font-size:clamp(13px,1.9vh,19px);font-weight:800;display:flex}.gamestrip .g .ic{font-size:clamp(18px,2.6vh,26px)}.eyes{animation:2.4s ease-in-out infinite eyes-pulse}@keyframes eyes-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important}}
