:root{--bg: #f3f5f9;--panel: #ffffff;--panel-border: rgba(30, 45, 80, .14);--text: #1d2433;--muted: #66728c;--cyan: #2f6fed;--magenta: #ef6a3d;--shadow: rgba(25, 40, 80, .12);--glass-bg: rgba(255, 255, 255, .55);--glass-border: rgba(255, 255, 255, .65)}:root[data-theme=dark]{--bg: #121620;--panel: #1b2230;--panel-border: rgba(150, 170, 210, .16);--text: #e6ecf7;--muted: #9aa7c2;--cyan: #4f8cff;--magenta: #ff8159;--shadow: rgba(0, 0, 0, .4);--glass-bg: rgba(34, 42, 61, .5);--glass-border: rgba(150, 170, 210, .22)}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}html{overflow:hidden}body{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:hidden;overscroll-behavior:none;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}#root{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.app{height:100%;display:flex;align-items:center;justify-content:center;position:relative}.app:before,.app:after{content:"";position:absolute;width:65vmax;height:65vmax;border-radius:50%;filter:blur(70px);opacity:.16;pointer-events:none;z-index:0;will-change:transform}.app:before{background:radial-gradient(circle,var(--cyan),transparent 62%);top:-16vmax;left:-14vmax;animation:blobDrift1 19s ease-in-out infinite alternate}.app:after{background:radial-gradient(circle,var(--magenta),transparent 62%);bottom:-16vmax;right:-14vmax;animation:blobDrift2 24s ease-in-out infinite alternate}@keyframes blobDrift1{0%{transform:translate(0) scale(1)}to{transform:translate(10vmax,8vmax) scale(1.18)}}@keyframes blobDrift2{0%{transform:translate(0) scale(1.05)}to{transform:translate(-9vmax,-7vmax) scale(1)}}.menu{z-index:2;text-align:center;padding:18px 24px 24px;max-width:560px;width:100%;min-height:100dvh;max-height:100dvh;overflow-y:auto;display:flex;flex-direction:column;align-items:center}.menu-hero{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.menu-bar{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:22px;padding:5px 8px 5px 5px;border-radius:999px;background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(14px) saturate(1.3);-webkit-backdrop-filter:blur(14px) saturate(1.3);box-shadow:0 6px 20px var(--shadow)}.profile-chip{display:flex;align-items:center;gap:10px;padding:4px 14px 4px 4px;border:none;border-radius:999px;background:none;color:var(--text);cursor:pointer;transition:background .15s ease}.profile-chip:hover{background:color-mix(in srgb,var(--text) 8%,transparent)}.avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--cyan);color:#fff;font-weight:800;font-size:16px;flex:none}.profile-meta{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15}.profile-name{font-weight:700;font-size:14px}.profile-elo{font-size:11px;color:var(--muted);letter-spacing:.5px}.menu-nav{display:flex;align-items:center;gap:2px;padding-left:8px;border-left:1px solid var(--glass-border)}.nav-btn,.icon-btn{display:inline-flex;align-items:center;gap:6px;border:none;background:none;color:var(--muted);cursor:pointer;border-radius:999px;transition:color .15s ease,background .15s ease}.nav-btn{padding:8px 10px;font-size:13px;font-weight:600;letter-spacing:.3px}.icon-btn{width:40px;height:40px;justify-content:center}.nav-btn:hover,.icon-btn:hover{color:var(--text);background:color-mix(in srgb,var(--text) 7%,var(--panel))}.nav-btn svg{width:18px;height:18px}.icon-btn svg{width:20px;height:20px}@media(max-width:460px){.nav-label{display:none}.nav-btn{width:40px;height:40px;padding:0;justify-content:center}}.menu-cards{display:flex;flex-direction:column;gap:14px;margin:8px auto 0;width:75%;max-width:360px}.menu-card{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;padding:22px;border-radius:14px;border:1px solid var(--panel-border);background:var(--panel);color:var(--text);cursor:pointer;transition:all .15s ease}.menu-card:hover{transform:translateY(-1px)}.menu-card{box-shadow:0 6px 20px var(--shadow)}.menu-card.online .menu-card-title{color:var(--cyan)}.menu-card.single .menu-card-title{color:var(--magenta)}.menu-card.daily .menu-card-title{color:#d99a17}.menu-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px var(--shadow);border-color:color-mix(in srgb,var(--text) 22%,var(--glass-border))}.menu-card:after{content:"";position:absolute;top:0;bottom:0;left:-80%;width:55%;background:linear-gradient(100deg,transparent,color-mix(in srgb,var(--text) 10%,transparent),transparent);transform:skew(-18deg);pointer-events:none}.menu-card:hover:after{animation:cardSweep .65s ease-out}@keyframes cardSweep{0%{left:-80%}to{left:130%}}.menu-card:active,.play-btn:active,.choice:active,.opt:active,.nav-btn:active,.icon-btn:active,.wall-handle:active{transform:translateY(0) scale(.97);transition-duration:.06s}.menu-card-title{font-size:24px;font-weight:800;letter-spacing:3px}.menu-card-sub{font-size:13px;color:var(--muted)}.menu-section{position:relative;display:flex;flex-direction:column;align-items:center}.section-title{font-size:22px;letter-spacing:2px;margin:4px 0 10px}.back-btn{position:static;align-self:flex-start;margin-bottom:8px;padding:7px 16px;border-radius:999px;border:1px solid var(--glass-border);background:var(--glass-bg);backdrop-filter:blur(12px) saturate(1.3);-webkit-backdrop-filter:blur(12px) saturate(1.3);box-shadow:0 2px 10px var(--shadow);color:var(--text);cursor:pointer;font-size:13px;letter-spacing:.5px;transition:border-color .12s ease,color .12s ease}.back-btn:hover{border-color:var(--cyan);color:var(--cyan)}.divider{margin:22px 0 12px;color:var(--muted);font-size:12px;letter-spacing:2px;text-transform:uppercase;width:100%;display:flex;align-items:center;gap:10px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--panel-border)}.choice.block{width:100%;max-width:320px;justify-content:center;font-weight:700;letter-spacing:1px}.small{font-size:12px;margin-top:6px}.title{font-size:54px;font-weight:800;letter-spacing:8px;margin:0 0 4px;color:var(--text);background:linear-gradient(105deg,var(--text) 38%,var(--cyan) 48%,var(--magenta) 52%,var(--text) 62%);background-size:280% 100%;background-position:110% 0;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:titleSheen 7.5s ease-in-out infinite}@keyframes titleSheen{0%,58%{background-position:110% 0}88%,to{background-position:-60% 0}}@media(prefers-reduced-motion:reduce){.title{animation:none;background:none;-webkit-text-fill-color:currentColor}}.subtitle{color:var(--muted);margin:0 0 28px;letter-spacing:1px}.label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:2px;margin:18px 0 10px}.choice-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.choice{display:flex;flex-direction:column;gap:2px;padding:10px 18px;border-radius:10px;border:1px solid var(--panel-border);background:var(--panel);color:var(--text);cursor:pointer;transition:all .15s ease}.choice.compact{flex-direction:row;padding:10px 20px;letter-spacing:1px}.choice-main{font-weight:700;letter-spacing:1px}.choice-sub{font-size:11px;color:var(--muted)}.choice:hover{border-color:var(--cyan)}.choice.active{border-color:var(--cyan);background:color-mix(in srgb,var(--cyan) 12%,var(--panel));color:var(--text)}.custom-panel{width:100%;max-width:360px;margin:12px auto 0;padding:14px 16px;border:1px solid var(--panel-border);border-radius:12px;background:color-mix(in srgb,var(--text) 4%,var(--panel))}.opt-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:1.5px;margin:10px 0 6px;text-align:left}.opt-label:first-child{margin-top:0}.opt-row{display:flex;gap:6px;flex-wrap:wrap}.opt{flex:1;min-width:44px;padding:7px 6px;border-radius:8px;border:1px solid var(--panel-border);background:var(--panel);color:var(--text);cursor:pointer;font-size:13px;transition:all .12s ease}.opt:hover{border-color:var(--cyan)}.opt.active{border-color:var(--cyan);background:color-mix(in srgb,var(--cyan) 14%,var(--panel));color:var(--text);font-weight:700}.toggle{display:inline-flex;align-items:center;gap:8px;margin:22px 0 6px;color:var(--text);cursor:pointer;font-size:14px}.muted{color:var(--muted)}.play-btn{display:block;margin:26px auto 0;padding:14px 48px;font-size:18px;font-weight:700;letter-spacing:3px;border-radius:12px;border:1px solid transparent;cursor:pointer;color:#fff;background:var(--cyan);box-shadow:0 4px 14px var(--shadow);transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.play-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px var(--shadow)}.play-btn:disabled{opacity:.5;cursor:not-allowed}.play-btn.secondary{background:var(--panel);color:var(--text);border-color:var(--panel-border);box-shadow:none}.play-btn.secondary:hover:not(:disabled){border-color:var(--cyan);box-shadow:0 2px 10px var(--shadow)}.help{margin-top:26px;color:var(--muted);font-size:13px;line-height:1.7}.game-wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;padding:8px;max-width:100vw}.board-host{border-radius:14px;overflow:hidden;box-shadow:0 8px 30px var(--shadow),0 0 0 1px var(--panel-border);cursor:pointer;touch-action:none;line-height:0;animation:boardIn .5s cubic-bezier(.2,.85,.3,1.15) both}@keyframes boardIn{0%{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.board-host{animation:none}}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;align-items:center;justify-content:center;pointer-events:none;overflow:hidden}.menu-backdrop-board{line-height:0;opacity:.5;filter:blur(1.4px) saturate(1.05);transform:perspective(1100px) rotateX(28deg) scale(1.18);mask-image:radial-gradient(ellipse 62% 58% at 50% 46%,black 30%,transparent 76%);-webkit-mask-image:radial-gradient(ellipse 62% 58% at 50% 46%,black 30%,transparent 76%);animation:backdropFloat 16s ease-in-out infinite alternate;will-change:transform}:root[data-theme=dark] .menu-backdrop-board{opacity:.55}@keyframes backdropFloat{0%{transform:perspective(1100px) rotateX(28deg) scale(1.18) translateY(-10px)}to{transform:perspective(1100px) rotateX(28deg) scale(1.18) translateY(12px)}}@media(prefers-reduced-motion:reduce){.menu-backdrop-board{animation:none}}.hud{width:100%;max-width:560px;display:flex;align-items:center;justify-content:space-between;gap:8px}.hud-side{flex:1;display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--panel-border);border-radius:10px;padding:8px 12px;font-size:13px;opacity:.7;transition:opacity .15s ease,box-shadow .15s ease}.hud-side.active{opacity:1;border-color:var(--cyan);box-shadow:0 2px 10px var(--shadow)}.hud-side .dot{width:10px;height:10px;border-radius:50%}.hud-side .who{font-weight:700;letter-spacing:1px}.hud-side-info{display:flex;flex-direction:column;gap:1px;min-width:0}.hud-side .meta{color:var(--muted);font-size:11px}.wall-stack{display:flex;align-items:center;gap:6px;margin-left:auto}.wall-stack-bars{display:flex;flex-direction:column-reverse;gap:2px;height:22px;justify-content:center}.ws-bar{width:24px;height:5px;border-radius:3px;opacity:0;transform:scaleX(.25);filter:blur(2px);transform-origin:left center;transition:opacity .35s ease,transform .35s ease,filter .35s ease}.ws-bar.on{opacity:1;transform:none;filter:none}.wall-stack-num{font-size:15px;min-width:14px;text-align:right;color:var(--text)}.hud-status{width:150px;flex:0 0 150px;text-align:center;font-weight:600;letter-spacing:1px;color:var(--text);display:flex;flex-direction:column;align-items:center;gap:2px}.status-line{min-height:18px}.clock-line{min-height:24px;display:flex;gap:8px;align-items:center}.hud-side{min-width:0}.turn-clock{font-size:20px;font-weight:800;color:var(--cyan)}.turn-clock.urgent{color:var(--magenta);display:inline-block;animation:heartbeat .9s infinite}@keyframes heartbeat{0%,to{transform:scale(1);opacity:1}12%{transform:scale(1.22)}24%{transform:scale(1)}36%{transform:scale(1.14)}48%{transform:scale(1);opacity:.8}}.status-text{display:inline-block;animation:statusPop .32s cubic-bezier(.2,.9,.3,1.5)}@keyframes statusPop{0%{transform:scale(.82);opacity:.4}to{transform:scale(1);opacity:1}}.game-clock{font-size:12px;color:var(--muted);letter-spacing:1px}.toolbar{width:100%;max-width:560px;display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}.wall-dock{display:flex;gap:10px;align-items:center;padding:8px 12px;border-radius:12px;border:1px solid var(--panel-border);background:var(--panel)}.dock-hint{color:var(--muted);font-size:12px;letter-spacing:.5px}.wall-handle{width:46px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:9px;border:1px solid var(--panel-border);background:#7f7f7f14;cursor:grab;touch-action:none;transition:all .12s ease}.wall-handle:hover{border-color:var(--cyan)}.wall-handle:active{cursor:grabbing}.wall-handle.off{opacity:.35;cursor:not-allowed}.bar-h{width:30px;height:8px;border-radius:4px;background:var(--cyan)}.bar-v{width:8px;height:30px;border-radius:4px;background:var(--cyan)}.float-wall{position:fixed;transform:translate(-50%,-50%);border-radius:999px;pointer-events:none;z-index:40;opacity:.92;box-shadow:0 5px 16px var(--shadow),inset 0 2px #ffffff59,inset 0 -1px #0003}.walls-left{color:var(--muted);letter-spacing:1px;font-size:13px}.walls-left b{color:var(--text);font-size:17px}.forfeit-btn{padding:9px 16px;border-radius:10px;border:1px solid rgba(224,36,122,.5);background:var(--panel);color:var(--magenta);cursor:pointer;letter-spacing:1px;transition:all .12s ease}.forfeit-btn:hover:not(:disabled){background:#e0247a1f}.forfeit-btn:disabled{opacity:.4;cursor:not-allowed}.forfeit-confirm{display:flex;align-items:center;gap:8px}.forfeit-ask{color:var(--magenta);font-size:13px;letter-spacing:1px;font-weight:600}.forfeit-yes,.forfeit-no{padding:8px 14px;border-radius:9px;cursor:pointer;letter-spacing:1px;font-size:13px;transition:all .12s ease}.forfeit-yes{border:none;background:var(--magenta);color:#fff}.forfeit-yes:hover:not(:disabled){filter:brightness(1.05)}.forfeit-no{border:1px solid var(--panel-border);background:var(--panel);color:var(--text)}.forfeit-no:hover{border-color:var(--cyan)}.friend-list{width:100%;max-width:360px;display:flex;flex-direction:column;gap:6px;margin-top:4px}.friend-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;background:color-mix(in srgb,var(--text) 4%,var(--panel));font-size:14px}.friend-name{font-weight:600}.friend-row .muted{font-size:12px}.friend-row .mini-btn{margin-left:auto}.friend-row .mini-btn+.mini-btn{margin-left:6px}.presence{width:9px;height:9px;border-radius:50%;background:var(--muted);opacity:.4;flex:none}.presence.on{background:#21a366;opacity:1;box-shadow:0 0 8px #21a36699}.mini-btn{padding:5px 12px;border-radius:8px;border:1px solid var(--panel-border);background:var(--panel);color:var(--text);cursor:pointer;font-size:12px;letter-spacing:.5px;transition:all .12s ease}.mini-btn:hover{border-color:var(--cyan)}.mini-btn.ok{border-color:#21a366;color:#21a366}.mini-btn.danger:hover{border-color:var(--magenta);color:var(--magenta)}.howto-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:16px;background:#141c2d80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.howto{background:var(--panel);border:1px solid var(--panel-border);border-radius:18px;box-shadow:0 16px 50px var(--shadow);width:100%;max-width:460px;max-height:90dvh;overflow-y:auto;padding:22px 24px 26px;text-align:center}.howto-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.howto-head h2{margin:0;font-size:26px;letter-spacing:2px}.howto-close{border:none;background:transparent;color:var(--muted);font-size:20px;cursor:pointer;line-height:1;padding:4px 8px;border-radius:8px}.howto-close:hover{color:var(--text);background:color-mix(in srgb,var(--text) 8%,var(--panel))}.howto-slide{display:flex;flex-direction:column;align-items:center;text-align:center;padding:18px 4px 6px;min-height:232px}.howto-diagram{line-height:0;margin-bottom:14px}.mini-board{display:block}.howto-slide h3{margin:0 0 6px;font-size:19px;letter-spacing:.5px}.howto-slide p{margin:0;font-size:14px;line-height:1.55;color:var(--muted);max-width:320px}.howto-slide b{color:var(--text)}.howto-dots{display:flex;justify-content:center;gap:7px;margin:16px 0 14px}.howto-dot{width:8px;height:8px;border-radius:50%;background:var(--panel-border);transition:all .2s ease}.howto-dot.on{background:var(--cyan);transform:scale(1.25)}.howto-nav{display:flex;gap:10px}.howto-nav .play-btn{margin:0;flex:1;padding:13px 0}.help-fab{position:fixed;left:calc(14px + env(safe-area-inset-left));bottom:calc(14px + env(safe-area-inset-bottom));z-index:30;width:38px;height:38px;border-radius:50%;border:1px solid var(--panel-border);background:var(--panel);color:var(--text);font-size:18px;font-weight:800;cursor:pointer;box-shadow:0 4px 14px var(--shadow)}.help-fab:hover{border-color:var(--cyan);color:var(--cyan)}.howto-link{margin-top:14px;background:none;border:none;color:var(--cyan);cursor:pointer;font-size:14px;letter-spacing:.5px;text-decoration:underline;text-underline-offset:3px}.menu-foot-links{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}.howto.legal{max-width:600px;text-align:left}.legal-body{text-align:left;font-size:14px;line-height:1.6;color:var(--text)}.legal-body h3{margin:18px 0 6px;font-size:15px;color:var(--text)}.legal-body p{margin:0 0 10px;color:var(--muted)}.legal-body ul{margin:0 0 10px;padding-left:18px;color:var(--muted)}.legal-body li{margin-bottom:6px}.legal-body b{color:var(--text)}.legal-body a{color:var(--cyan)}.legal-body .play-btn{margin-top:18px}.invite-stack{position:fixed;top:calc(16px + env(safe-area-inset-top));right:calc(16px + env(safe-area-inset-right));z-index:70;display:flex;flex-direction:column;gap:8px;max-width:300px}.invite-toast{background:var(--panel);border:1px solid var(--panel-border);border-radius:12px;padding:12px 14px;box-shadow:0 8px 24px var(--shadow);font-size:14px;animation:toastIn .18s ease}.invite-toast.notice,.invite-toast.muted{color:var(--muted);font-size:13px}.invite-text{margin-bottom:8px}.invite-actions{display:flex;gap:8px;justify-content:flex-end}@keyframes toastIn{0%{opacity:0;transform:translateY(-6px)}}.coin-balance{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:18px;color:var(--text);margin:2px 0}.coin-dot{width:16px;height:16px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffe08a,#f5a623 70%);box-shadow:inset 0 0 0 1.5px #00000026}.skin-grid{width:100%;max-width:360px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:6px auto 0}.skin-cell{position:relative;display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 8px 10px;border:2px solid var(--panel-border);border-radius:2px;background:var(--panel);color:var(--text);cursor:pointer;transition:border-color .12s ease,transform .12s ease}.skin-cell:hover:not(.locked){border-color:var(--cyan)}.skin-cell.active{border-color:var(--cyan);background:color-mix(in srgb,var(--cyan) 12%,var(--panel))}.skin-cell.locked{cursor:not-allowed;opacity:.6}.skin-pawn{width:34px;height:34px;border-radius:50%;box-shadow:inset 0 0 0 2px #0000001f}.banner-grid{width:100%;max-width:360px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:6px auto 0}.banner-cell{position:relative;display:flex;flex-direction:column;align-items:center;gap:7px;padding:10px 8px;border:2px solid var(--panel-border);border-radius:12px;background:var(--panel);color:var(--text);cursor:pointer;transition:border-color .15s ease,transform .15s ease}.banner-cell:hover{transform:translateY(-2px)}.banner-cell.active{border-color:var(--cyan)}.banner-cell.locked{opacity:.78}.banner-swatch{width:100%;height:46px;border-radius:8px;border:1px solid var(--glass-border)}.skin-name{font-size:12px;font-weight:600;letter-spacing:.5px}.skin-tag{position:absolute;top:4px;right:4px;font-size:8px;font-weight:700;letter-spacing:1px;color:var(--muted);border:1px solid var(--panel-border);border-radius:2px;padding:1px 4px}.skin-tag.real{color:#fff;background:linear-gradient(135deg,#1ea672,#11885b);border-color:transparent}.skin-tag.level{color:#fff;background:linear-gradient(135deg,var(--magenta),#7a3df0);border-color:transparent}.lobby-list{width:100%;max-width:360px;display:flex;flex-direction:column;gap:6px;margin:4px auto 10px}.lobby-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border:2px solid var(--panel-border);border-radius:2px;background:var(--panel);font-size:14px}.lobby-host{font-weight:700}.lobby-meta{font-size:11px}.lobby-row .mini-btn{margin-left:auto}.move-history{width:100%;max-width:560px;background:var(--panel);border:1px solid var(--panel-border);border-radius:12px;padding:8px 12px}.mh-title{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:4px}.mh-list{list-style:none;margin:0;padding:0;max-height:108px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.mh-row{display:flex;align-items:center;gap:8px;font-size:13px;padding:3px 6px;border-radius:6px}.mh-row:nth-child(odd){background:color-mix(in srgb,var(--text) 4%,var(--panel))}.mh-ply{color:var(--muted);font-size:11px;min-width:18px;text-align:right}.mh-dot{width:9px;height:9px;border-radius:50%;flex:none}.mh-who{font-weight:700;min-width:30px}.mh-text{color:var(--muted)}.join-row{display:flex;gap:10px;justify-content:center;align-items:center;margin-top:12px}.code-input{padding:10px 14px;border-radius:10px;border:1px solid var(--panel-border);background:color-mix(in srgb,var(--text) 4%,var(--panel));color:var(--text);font-size:16px;letter-spacing:4px;text-align:center;width:160px;text-transform:uppercase}.code-input::placeholder{color:var(--muted);letter-spacing:2px}.online-panel{z-index:3;text-align:center;background:var(--panel);border:1px solid var(--panel-border);border-radius:18px;padding:40px 56px;box-shadow:0 10px 40px var(--shadow);display:flex;flex-direction:column;align-items:center;gap:16px}.online-title{font-size:22px;letter-spacing:2px}.online-title.err{color:var(--magenta)}.room-code{font-size:64px;font-weight:800;letter-spacing:12px;padding-left:12px;color:var(--cyan)}.opp-banner{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:5;background:color-mix(in srgb,var(--magenta) 16%,var(--panel));border:1px solid var(--magenta);color:var(--text);padding:8px 18px;border-radius:10px;letter-spacing:1px;font-size:13px}.opp-banner.reconnecting{background:color-mix(in srgb,var(--cyan) 16%,var(--panel));border-color:var(--cyan);animation:reconnectPulse 1.1s ease-in-out infinite}@keyframes reconnectPulse{0%,to{opacity:.65}50%{opacity:1}}.spectate-bar{position:absolute;top:0;left:0;right:0;z-index:7;display:flex;align-items:center;gap:8px;justify-content:center;padding:8px 14px;font-size:13px;letter-spacing:.5px;color:var(--text);background:color-mix(in srgb,var(--cyan) 14%,var(--panel));border-bottom:1px solid var(--glass-border)}.spectate-eye{font-size:15px}.spectate-done{color:var(--muted)}.spectate-leave{margin-left:10px;border:1px solid var(--panel-border);background:var(--panel);color:var(--text);border-radius:2px;padding:3px 12px;cursor:pointer;font-size:12px}.results-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;display:flex;align-items:center;justify-content:center;background:#141c2d66;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.rematch-note{margin:6px 0 2px;letter-spacing:1px;font-size:14px;color:var(--cyan)}.rematch-note.muted{color:var(--muted)}.results{z-index:3;text-align:center;background:var(--panel);border:1px solid var(--panel-border);border-radius:18px;padding:36px 52px;box-shadow:0 10px 40px var(--shadow)}.results h2{font-size:42px;margin:0 0 6px;letter-spacing:4px}.results .reason{color:var(--muted);margin-bottom:26px;letter-spacing:.5px}.actions{display:flex;flex-direction:column;gap:10px;align-items:stretch;width:240px;margin:0 auto}.actions .play-btn{margin:0;width:100%;padding:13px 0;text-align:center}.topbar{display:flex;justify-content:center;gap:10px;margin-bottom:10px}.chip{padding:7px 14px;border-radius:999px;border:1px solid var(--panel-border);background:var(--panel);color:var(--text);cursor:pointer;font-size:13px;letter-spacing:.5px}.chip:hover{border-color:var(--cyan)}.account-card{border:1px solid var(--panel-border);background:var(--panel);border-radius:18px;padding:18px;margin-bottom:14px;width:100%;max-width:380px;box-shadow:0 8px 26px var(--shadow)}.profile-head{display:flex;align-items:center;gap:14px;margin:-6px -6px 16px;padding:14px;border-radius:14px;border:1px solid var(--glass-border);text-align:left;overflow:hidden}.profile-head.banner-nebula,.profile-head.banner-inferno,.profile-head.banner-aurora,.profile-head.banner-circuit,.profile-head.banner-royal,.profile-head.banner-carbon,.profile-head.banner-graffiti,.profile-head.banner-abyss,.profile-head.banner-synthwave,.profile-head.banner-nebula .account-name,.profile-head.banner-inferno .account-name,.profile-head.banner-aurora .account-name,.profile-head.banner-circuit .account-name,.profile-head.banner-royal .account-name,.profile-head.banner-carbon .account-name,.profile-head.banner-graffiti .account-name,.profile-head.banner-abyss .account-name,.profile-head.banner-synthwave .account-name{color:#fff}.profile-avatar-big{flex:none;width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:#fff;background:linear-gradient(140deg,var(--cyan),var(--magenta));box-shadow:0 6px 18px var(--shadow),inset 0 2px #ffffff59}.profile-id{min-width:0}.account-name{font-size:20px;font-weight:800;letter-spacing:.5px;display:flex;align-items:center;gap:8px;overflow:hidden;text-overflow:ellipsis}.guest-chip{font-size:9px;font-weight:800;letter-spacing:1.5px;color:var(--muted);border:1px solid var(--panel-border);border-radius:999px;padding:2px 8px}.profile-badges{display:flex;gap:8px;margin-top:6px}.badge{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:800;border-radius:999px;padding:4px 12px}.badge-elo{color:var(--cyan);background:color-mix(in srgb,var(--cyan) 12%,transparent);border:1px solid color-mix(in srgb,var(--cyan) 35%,transparent)}.badge-coins{color:#d99a17;background:color-mix(in srgb,#f2b441 14%,transparent);border:1px solid color-mix(in srgb,#f2b441 40%,transparent)}.badge-level{color:var(--magenta);background:color-mix(in srgb,var(--magenta) 12%,transparent);border:1px solid color-mix(in srgb,var(--magenta) 35%,transparent)}.xp-bar{margin-top:8px;height:6px;width:100%;max-width:220px;border-radius:999px;background:color-mix(in srgb,var(--text) 12%,transparent);overflow:hidden}.xp-fill{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--magenta));transition:width .4s ease}.lb-level{font-size:11px}.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.stat-tile{display:flex;flex-direction:column;align-items:center;gap:1px;padding:10px 4px 8px;border-radius:12px;background:color-mix(in srgb,var(--text) 4%,var(--panel));border:1px solid var(--panel-border)}.stat-tile b{font-size:18px;color:var(--text)}.stat-tile.tile-win b{color:#21a366}.stat-tile.tile-loss b{color:var(--magenta)}.stat-tile.tile-draw b{color:var(--muted)}.stat-tile span{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.auth-box{width:100%;max-width:320px;display:flex;flex-direction:column;gap:10px;margin-top:8px}.settings-box{width:100%;max-width:380px;display:flex;flex-direction:column;gap:8px;text-align:left;border:1px solid var(--panel-border);background:var(--panel);border-radius:18px;padding:16px 18px 18px;box-shadow:0 8px 26px var(--shadow)}.settings-box .opt-label{margin-top:12px}.settings-toggle{margin:0}.settings-toggle .muted{font-size:12px}.settings-ok{color:var(--cyan);font-size:13px}.tab-row{display:flex;gap:8px}.tab{flex:1;padding:8px;border-radius:8px;border:1px solid var(--panel-border);background:var(--panel);color:var(--muted);cursor:pointer}.tab.active{color:var(--text);border-color:var(--cyan)}.field{padding:11px 14px;border-radius:9px;border:1px solid var(--panel-border);background:color-mix(in srgb,var(--text) 4%,var(--panel));color:var(--text);font-size:15px}.auth-error{color:var(--magenta);font-size:13px}.history{width:100%;max-width:360px;display:flex;flex-direction:column;gap:6px}.history-row{display:flex;gap:10px;align-items:center;font-size:13px;padding:8px 10px;border-radius:10px;background:color-mix(in srgb,var(--text) 4%,var(--panel));border:1px solid var(--panel-border)}.history-row .win,.lb-row .win{color:#21a366;font-weight:700}.history-row .loss{color:var(--magenta);font-weight:700}.history-row .draw{color:var(--muted);font-weight:700}.history-row .muted{margin-left:auto}.result-pill{flex:none;font-size:10px;font-weight:800;letter-spacing:1px;border-radius:999px;padding:3px 10px;min-width:46px;text-align:center}.result-pill.win{color:#21a366;background:color-mix(in srgb,#21a366 14%,transparent);border:1px solid color-mix(in srgb,#21a366 40%,transparent)}.result-pill.loss{color:var(--magenta);background:color-mix(in srgb,var(--magenta) 12%,transparent);border:1px solid color-mix(in srgb,var(--magenta) 38%,transparent)}.result-pill.draw{color:var(--muted);background:color-mix(in srgb,var(--muted) 12%,transparent);border:1px solid color-mix(in srgb,var(--muted) 36%,transparent)}.history-opp{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-meta{margin-left:auto;display:inline-flex;align-items:center;gap:6px}.size-chip{font-size:11px;color:var(--muted);border:1px solid var(--panel-border);border-radius:6px;padding:1px 6px}.ranked-star{color:#d99a17;font-size:13px}.lb{width:100%;max-width:420px;display:flex;flex-direction:column;gap:4px}.lb-row{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:8px;background:color-mix(in srgb,var(--text) 4%,var(--panel))}.lb-row.me{border:1px solid var(--cyan);background:color-mix(in srgb,var(--cyan) 10%,var(--panel))}.lb-rank{width:26px;color:var(--muted);font-weight:700}.lb-rank.top{font-size:17px}.lb-name{flex:1;text-align:left;display:inline-flex;align-items:center;gap:7px;min-width:0;overflow:hidden}.lb-elo{font-weight:800;color:var(--cyan);font-size:12px;padding:3px 10px}.lb-banner{flex:none;width:26px;height:16px;border-radius:4px;border:1px solid var(--glass-border)}.lb-wl{font-size:12px}.rating-delta{font-size:18px;font-weight:800;margin-bottom:6px}.coin-toast{display:inline-flex;align-items:center;gap:7px;font-size:16px;font-weight:800;color:#d99a17;background:color-mix(in srgb,#f2b441 16%,transparent);border:1px solid color-mix(in srgb,#f2b441 45%,transparent);border-radius:999px;padding:6px 16px;margin-bottom:6px;opacity:0;animation:coinPop .45s cubic-bezier(.2,.9,.3,1.45) .55s forwards}.coin-icon{color:#f2b441;font-size:14px;text-shadow:0 0 6px color-mix(in srgb,#f2b441 60%,transparent)}@keyframes coinPop{0%{opacity:0;transform:scale(.6) translateY(8px)}to{opacity:1;transform:none}}@media(max-width:600px){.title{font-size:40px;letter-spacing:5px}.menu{padding:18px 14px}.hud-side{padding:6px 9px;font-size:11px}.hud-side .meta{font-size:10px}.hud-status{min-width:0;font-size:13px}.tool-btn{padding:9px 14px;font-size:13px}.results{padding:28px 26px}.results h2{font-size:34px}.room-code{font-size:48px;letter-spacing:8px}.online-panel{padding:30px 24px}.menu-card-title{font-size:20px}.move-history{display:none}}.vs-intro{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;overflow:hidden;pointer-events:auto}.vs-half{position:absolute;top:0;bottom:0;width:56%;display:flex;align-items:center;justify-content:center;will-change:transform}.vs-left{left:0;background:linear-gradient(120deg,color-mix(in srgb,var(--c) 36%,var(--panel)),color-mix(in srgb,var(--c) 14%,var(--panel)));clip-path:polygon(0 0,100% 0,82% 100%,0 100%);animation:vsLeftIn var(--vs-dur, 4s) cubic-bezier(.16,1,.3,1) forwards,bannerKen 19s ease-in-out infinite alternate}.vs-right{right:0;background:linear-gradient(120deg,color-mix(in srgb,var(--c) 14%,var(--panel)),color-mix(in srgb,var(--c) 36%,var(--panel)));clip-path:polygon(18% 0,100% 0,100% 100%,0 100%);animation:vsRightIn var(--vs-dur, 4s) cubic-bezier(.16,1,.3,1) forwards,bannerKen 19s ease-in-out infinite alternate}.vs-half:after{content:"";position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;background:repeating-linear-gradient(100deg,transparent 0 44px,color-mix(in srgb,var(--c) 30%,transparent) 44px 47px,transparent 47px 110px);opacity:0;pointer-events:none;animation:vsLines var(--vs-dur, 4s) ease-out forwards}@keyframes vsLines{0%{opacity:0;transform:translate(-14%)}8%{opacity:.55}26%{opacity:.18;transform:translate(5%)}42%,to{opacity:0;transform:translate(8%)}}@keyframes bannerKen{0%{background-position:42% 50%}to{background-position:58% 50%}}.vs-half:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;background:linear-gradient(100deg,transparent 38%,rgba(255,255,255,.24) 50%,transparent 62%);mix-blend-mode:screen;transform:translate(-130%);animation:vsSheen var(--vs-dur, 4s) cubic-bezier(.4,0,.2,1) forwards}@keyframes vsSheen{0%{transform:translate(-130%);opacity:0}18%{opacity:1}55%,to{transform:translate(130%);opacity:0}}.vs-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:30px 44px;max-width:min(86%,360px);border-radius:20px;overflow:hidden;background:color-mix(in srgb,var(--panel) 64%,transparent);backdrop-filter:blur(8px) saturate(1.2);-webkit-backdrop-filter:blur(8px) saturate(1.2);border:1px solid color-mix(in srgb,var(--c) 45%,var(--glass-border));box-shadow:0 14px 40px var(--shadow),inset 0 1px #ffffff24;animation:vsCard var(--vs-dur, 4s) cubic-bezier(.2,.9,.3,1.3) forwards}.vs-half.banner-nebula .vs-sub,.vs-half.banner-inferno .vs-sub,.vs-half.banner-aurora .vs-sub,.vs-half.banner-circuit .vs-sub,.vs-half.banner-royal .vs-sub,.vs-half.banner-carbon .vs-sub,.vs-half.banner-graffiti .vs-sub,.vs-half.banner-abyss .vs-sub,.vs-half.banner-synthwave .vs-sub{color:#ffffffd1}.banner-default{background:repeating-linear-gradient(125deg,transparent 0 18px,color-mix(in srgb,var(--c) 9%,transparent) 18px 20px),linear-gradient(150deg,color-mix(in srgb,var(--c) 34%,var(--panel)),color-mix(in srgb,var(--c) 10%,var(--panel)) 70%)}.banner-duotone{background:linear-gradient(115deg,color-mix(in srgb,var(--c) 48%,var(--panel)) 0,color-mix(in srgb,var(--c) 48%,var(--panel)) 52%,color-mix(in srgb,var(--c) 12%,var(--panel)) 52%,color-mix(in srgb,var(--c) 12%,var(--panel)))}.banner-stripes{background:repeating-linear-gradient(-50deg,transparent 0 26px,color-mix(in srgb,var(--c) 30%,transparent) 26px 44px),linear-gradient(160deg,color-mix(in srgb,var(--c) 16%,var(--panel)),var(--panel))}.banner-nebula{background:#0a0a1e url(/banners/nebula.webp) center / cover}.banner-inferno{background:#160404 url(/banners/inferno.webp) center / cover}.banner-aurora{background:#06121f url(/banners/aurora.webp) center / cover}.banner-circuit{background:#04121a url(/banners/circuit.webp) center / cover}.banner-holo{background:#1a1330 url(/banners/holo.webp) center / cover}.banner-royal{background:#0a0a0a url(/banners/royal.webp) center / cover}.banner-carbon{background:#131313 url(/banners/carbon.webp) center / cover}.banner-graffiti{background:#2a2622 url(/banners/graffiti.webp) center / cover}.banner-abyss{background:#05121c url(/banners/abyss.webp) center / cover}.banner-synthwave{background:#1a0a2e url(/banners/synthwave.webp) center / cover}.banner-swatch.banner-holo,.profile-head.banner-holo{background-size:200% auto;animation:holoFlow 7s ease-in-out infinite alternate}@keyframes holoFlow{0%{background-position:0% 50%}to{background-position:100% 50%}}.vs-half.banner-holo .vs-name,.vs-half.banner-holo .vs-sub{text-shadow:0 1px 6px rgba(0,0,0,.45)}@keyframes vsCard{0%,16%{opacity:0;transform:scale(.72) rotate(-3deg)}26%{opacity:1;transform:scale(1.06) rotate(1deg)}33%,82%{opacity:1;transform:scale(1) rotate(0)}to{opacity:0;transform:scale(.96)}}.vs-avatar,.vs-name,.vs-sub{animation:vsItem var(--vs-dur, 4s) cubic-bezier(.2,.9,.3,1.4) forwards}.vs-name{animation-delay:calc(var(--vs-dur, 4s) * .02)}.vs-sub{animation-delay:calc(var(--vs-dur, 4s) * .04)}@keyframes vsItem{0%,18%{opacity:0;transform:translateY(16px) scale(.85)}30%{opacity:1;transform:translateY(-2px) scale(1.04)}38%,to{opacity:1;transform:none}}.vs-avatar{width:110px;height:110px;border-radius:50%;border:6px solid;background:var(--panel)}.vs-shock{position:absolute;top:50%;left:50%;width:12px;height:12px;margin:-6px 0 0 -6px;border-radius:50%;border:3px solid var(--text);opacity:0;pointer-events:none;animation:vsShock var(--vs-dur, 4s) ease-out forwards}@keyframes vsShock{0%,26%{opacity:0;transform:scale(1)}30%{opacity:.7;border-width:3px}58%,to{opacity:0;transform:scale(60);border-width:.5px}}.vs-name{font-size:30px;font-weight:800;letter-spacing:2px;text-transform:uppercase;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vs-sub{font-size:14px;letter-spacing:2px;color:var(--muted);text-transform:uppercase}.vs-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:64px;font-weight:900;font-style:italic;letter-spacing:2px;color:var(--text);text-shadow:0 0 24px var(--cyan),0 0 48px var(--magenta);animation:vsBadge var(--vs-dur, 4s) ease forwards}@keyframes vsLeftIn{0%{transform:translate(-110%)}18%{transform:translate(0)}80%{transform:translate(0)}to{transform:translate(-115%)}}@keyframes vsRightIn{0%{transform:translate(110%)}18%{transform:translate(0)}80%{transform:translate(0)}to{transform:translate(115%)}}@keyframes vsBadge{0%,22%{transform:translate(-50%,-50%) scale(0);opacity:0}32%{transform:translate(-50%,-50%) scale(1.35);opacity:1}40%,80%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(1.4);opacity:0}}@media(max-width:600px){.vs-avatar{width:84px;height:84px;border-width:5px}.vs-card{padding:18px 20px;gap:8px}.vs-name{font-size:22px}.vs-badge{font-size:48px}.vs-left{padding-right:4%}.vs-right{padding-left:4%}}.play-btn{border-radius:14px}.menu-card,.choice,.opt,.chip,.mini-btn,.wall-handle,.code-input,.field,.tab,.wall-dock,.hud-side,.lobby-row,.skin-cell,.friend-row,.online-panel,.results,.howto,.move-history,.invite-toast{border-radius:14px;border:1px solid var(--glass-border);background:var(--glass-bg);backdrop-filter:blur(12px) saturate(1.3);-webkit-backdrop-filter:blur(12px) saturate(1.3)}.menu-card,.online-panel,.results,.howto{border-radius:18px}.chip,.mini-btn,.forfeit-yes,.forfeit-no{border-radius:999px}.menu-page{width:100%;min-height:100dvh;display:flex;justify-content:center;align-items:flex-start;position:relative;z-index:2}.menu-page.in{animation:pageIn .22s ease both}.menu-page.out{animation:pageOut .15s ease both}@keyframes pageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@keyframes pageOut{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.stat-corner{position:fixed;top:calc(8px + env(safe-area-inset-top));z-index:20;max-width:36vw;pointer-events:none}.stat-corner.left{left:calc(8px + env(safe-area-inset-left))}.stat-corner.right{right:calc(8px + env(safe-area-inset-right))}.turn-banner{position:fixed;top:calc(10px + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:20;max-width:26vw;display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center;font-weight:600;letter-spacing:1px;white-space:nowrap;pointer-events:none}.thinking{display:inline-flex;gap:3px;margin-left:6px;vertical-align:middle}.thinking span{width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.25;animation:thinkPulse 1.1s infinite ease-in-out}.thinking span:nth-child(2){animation-delay:.18s}.thinking span:nth-child(3){animation-delay:.36s}@keyframes thinkPulse{0%,60%,to{opacity:.25;transform:none}30%{opacity:.9;transform:translateY(-2px)}}.race{display:flex;flex-direction:column;gap:3px;width:110px;max-width:24vw;margin-top:4px}.race-track{height:4px;border-radius:2px;background:var(--shadow);overflow:hidden}.race-fill{display:block;height:100%;border-radius:2px;transition:width .35s ease}.toolbar{justify-content:center;flex-wrap:nowrap}.forfeit-corner{position:fixed;left:calc(10px + env(safe-area-inset-left));bottom:calc(10px + env(safe-area-inset-bottom));z-index:21}.forfeit-btn.forfeit-corner{width:40px;height:40px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;font-size:17px;letter-spacing:0}.help-fab{left:auto;right:calc(14px + env(safe-area-inset-right));bottom:calc(14px + env(safe-area-inset-bottom));display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.move-history{position:fixed;left:calc(10px + env(safe-area-inset-left));top:50%;transform:translateY(-50%);width:220px;max-width:24vw;z-index:15}@media(max-width:1040px){.move-history{display:none}}.puzzle-badge{position:fixed;top:calc(76px + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:19;display:flex;flex-direction:column;align-items:center;gap:1px;padding:6px 16px;border-radius:999px;border:1px solid color-mix(in srgb,#f2b441 40%,var(--glass-border));background:color-mix(in srgb,#f2b441 10%,var(--glass-bg));pointer-events:none;white-space:nowrap}.puzzle-badge-title{font-size:12px;font-weight:800;letter-spacing:2px;color:#d99a17}.puzzle-badge-sub{font-size:11px;color:var(--muted)}.puzzle-streak{font-size:22px;font-weight:800}.puzzle-streak b{color:#d99a17}.daily-streak-banner{font-size:20px;font-weight:800;border:1px solid color-mix(in srgb,#f2b441 40%,var(--glass-border));background:color-mix(in srgb,#f2b441 10%,var(--glass-bg));border-radius:999px;padding:8px 22px;margin-bottom:14px}.daily-streak-banner b{color:#d99a17}.daily-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;width:100%;max-width:340px;margin:6px auto 4px}.daily-cell{position:relative;aspect-ratio:1;border-radius:10px;border:1px solid var(--panel-border);background:color-mix(in srgb,var(--text) 4%,var(--panel));color:var(--muted);font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .12s ease,border-color .12s ease}.daily-cell:hover{transform:translateY(-2px);border-color:var(--cyan)}.daily-cell.solved{background:color-mix(in srgb,#f2b441 16%,var(--panel));border-color:color-mix(in srgb,#f2b441 45%,transparent);color:#d99a17}.daily-cell.today{border:2px solid var(--cyan);color:var(--text)}.daily-cell-fire{position:absolute;top:-5px;right:-4px;font-size:11px}.chat-fab-group{position:fixed;right:calc(14px + env(safe-area-inset-right));bottom:calc(64px + env(safe-area-inset-bottom));z-index:31;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.chat-fab{position:relative;width:38px;height:38px;border-radius:50%;border:1px solid var(--panel-border);background:var(--panel);font-size:17px;cursor:pointer;box-shadow:0 4px 14px var(--shadow);display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.chat-fab:active{transform:scale(.94)}.chat-unread{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;border-radius:999px;background:var(--magenta);color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 4px}.emoji-strip{display:flex;gap:4px;padding:6px 8px;border-radius:999px;border:1px solid var(--glass-border);background:var(--glass-bg);backdrop-filter:blur(12px) saturate(1.3);-webkit-backdrop-filter:blur(12px) saturate(1.3);box-shadow:0 6px 18px var(--shadow);animation:stripIn .18s cubic-bezier(.2,.9,.3,1.4) both}@keyframes stripIn{0%{opacity:0;transform:translateY(6px) scale(.92)}to{opacity:1;transform:none}}.emoji-btn{border:none;background:transparent;font-size:20px;line-height:1;cursor:pointer;padding:3px;border-radius:8px;transition:transform .1s ease}.emoji-btn:hover{transform:scale(1.25)}.emoji-btn.small{font-size:16px}.chat-panel{position:fixed;right:calc(14px + env(safe-area-inset-right));bottom:calc(112px + env(safe-area-inset-bottom));z-index:32;width:250px;max-width:calc(100vw - 28px);display:flex;flex-direction:column;border-radius:14px;border:1px solid var(--glass-border);background:var(--panel);box-shadow:0 14px 40px var(--shadow);overflow:hidden;animation:stripIn .18s ease both}.chat-head{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--panel-border)}.chat-close{border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:13px;padding:2px 4px}.chat-list{height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:5px;padding:10px}.chat-row{align-self:flex-start;max-width:85%;padding:5px 10px;border-radius:12px 12px 12px 3px;background:color-mix(in srgb,var(--text) 7%,var(--panel));font-size:13px;overflow-wrap:anywhere}.chat-row.mine{align-self:flex-end;border-radius:12px 12px 3px;background:color-mix(in srgb,var(--cyan) 16%,var(--panel))}.chat-row.emoji{font-size:24px;background:transparent;padding:0 4px}.chat-emoji-row{display:flex;justify-content:space-between;padding:4px 8px;border-top:1px solid var(--panel-border)}.chat-input-row{display:flex;gap:6px;padding:8px;border-top:1px solid var(--panel-border)}.chat-input{flex:1;min-width:0;border:1px solid var(--panel-border);border-radius:999px;background:color-mix(in srgb,var(--text) 4%,var(--panel));color:var(--text);font-size:13px;padding:7px 12px;outline:none}.chat-input:focus{border-color:var(--cyan)}.chat-send{border:none;border-radius:50%;width:32px;height:32px;background:var(--cyan);color:#fff;cursor:pointer;font-size:13px}.chat-send:disabled{opacity:.4;cursor:default}.chat-float{position:fixed;top:calc(64px + env(safe-area-inset-top));z-index:25;max-width:40vw;padding:7px 14px;border-radius:14px;border:1px solid var(--glass-border);background:var(--panel);box-shadow:0 8px 24px var(--shadow);font-size:14px;overflow-wrap:anywhere;pointer-events:none;animation:floatBubble 3.6s ease both}.chat-float.mine{left:calc(10px + env(safe-area-inset-left));border-top-left-radius:3px}.chat-float.theirs{right:calc(10px + env(safe-area-inset-right));border-top-right-radius:3px}.chat-float.emoji{font-size:30px;padding:4px 10px}@keyframes floatBubble{0%{opacity:0;transform:translateY(-8px) scale(.9)}8%,82%{opacity:1;transform:none}to{opacity:0;transform:translateY(-4px)}}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;top:-14vh;border-radius:2px;opacity:0;animation-name:confettiFall;animation-timing-function:linear;animation-fill-mode:forwards;will-change:transform,opacity}.confetti-piece.round{border-radius:50%}@keyframes confettiFall{0%{transform:translateY(-2vh) rotate(0);opacity:1}25%{transform:translate(calc(var(--drift) * .6),28vh) rotate(calc(var(--rot) * .3))}50%{transform:translate(calc(var(--drift) * -.45),56vh) rotate(calc(var(--rot) * .6))}75%{transform:translate(calc(var(--drift) * .5),84vh) rotate(calc(var(--rot) * .85))}90%{opacity:1}to{transform:translate(calc(var(--drift) * -.2),116vh) rotate(var(--rot));opacity:0}}.results h2{animation:resultPop .45s cubic-bezier(.18,1.3,.4,1) both}@keyframes resultPop{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
