:root{--bg: #0c1e2c;--bg-grad-1: #10283a;--bg-grad-2: #0a1f30;--bg-grad-3: #163245;--glass: rgba(255, 255, 255, .05);--glass-strong: rgba(255, 255, 255, .1);--glass-soft: rgba(255, 255, 255, .03);--border: rgba(168, 216, 185, .2);--border-strong: rgba(168, 216, 185, .38);--text: #e6f0ea;--muted: #88a8b3;--accent: #a8d8b9;--accent-strong: #7ec39a;--accent-soft: rgba(168, 216, 185, .15);--good: #7ec39a;--bad: #d68b8b;--warn: #e0c08a;--shadow: 0 8px 32px rgba(0, 0, 0, .45);--shadow-soft: 0 4px 16px rgba(0, 0, 0, .3)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:clamp(11.5px,calc(1px + 1.45vh),17px);line-height:1.5}#root{height:100dvh}body{background:radial-gradient(circle at 15% 10%,var(--bg-grad-1) 0%,transparent 45%),radial-gradient(circle at 85% 85%,var(--bg-grad-3) 0%,transparent 50%),radial-gradient(circle at 50% 50%,var(--bg-grad-2) 0%,transparent 70%),var(--bg);background-attachment:fixed}a{color:inherit;text-decoration:none}.app-shell{display:flex;flex-direction:column;min-height:100%}.topbar{display:flex;align-items:center;gap:1.5rem;padding:.85rem 1.7rem;background:var(--glass-strong);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.brand{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.2rem;letter-spacing:-.01em}.brand-mark{font-size:1.55rem;color:var(--accent)}.brand-text{background:linear-gradient(135deg,var(--accent),#5fa8c4);background-clip:text;-webkit-background-clip:text;color:transparent}.topnav{display:flex;gap:1.2rem;margin-left:.85rem}.topnav a{padding:.5rem .85rem;border-radius:7px;color:var(--muted)}.topnav a:hover{color:var(--text)}.topnav a.active{color:var(--accent-strong);background:var(--accent-soft)}.user-chip{margin-left:auto;display:flex;align-items:center;gap:.7rem;padding:.5rem .85rem;border-radius:999px;background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border)}.user-chip-avatar{width:1.9rem;height:1.9rem;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border-strong);background:var(--glass-strong);display:inline-flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--accent)}.user-chip .handle{font-weight:600}.user-chip .handle.muted{font-weight:400;color:var(--muted)}.user-chip .rating{font-variant-numeric:tabular-nums;color:var(--accent)}.main{flex:1;padding:1.9rem;max-width:1320px;margin:0 auto;width:100%;min-width:0}.footer{padding:.7rem 1.7rem;color:var(--muted);border-top:1px solid var(--border);text-align:center;font-size:.78rem}.version-tag{position:fixed;left:10px;bottom:8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;color:var(--muted);opacity:.6;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:50}.page-narrow{max-width:520px;margin:3.8rem auto}.page{display:flex;flex-direction:column;gap:1.65rem}.page-title{font-size:1.9rem;font-weight:700;letter-spacing:-.01em;margin:0}.muted{color:var(--muted)}.small{font-size:.78rem}.mono{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace}.break{word-break:break-all}.pos{color:var(--good)}.neg{color:var(--bad)}.hero{display:flex;flex-direction:column;gap:.5rem}.text-input{background:var(--glass-strong);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);color:var(--text);padding:.7rem .95rem;border-radius:9px;font-size:.95rem;width:100%;outline:none;transition:border-color .12s,box-shadow .12s}.text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.signup-form{display:flex;gap:.6rem;margin-top:.95rem}.primary-btn,.secondary-btn{font:inherit;border-radius:9px;padding:.7rem 1.3rem;cursor:pointer;border:1px solid transparent;white-space:nowrap;transition:filter .12s,background .12s,border-color .12s,transform 80ms}.primary-btn{background:linear-gradient(180deg,var(--accent),var(--accent-strong));color:#0c1e2c;font-weight:600;box-shadow:0 4px 14px #a8d8b940}.primary-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.primary-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.secondary-btn{background:var(--glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text);border-color:var(--border)}.secondary-btn:hover{background:var(--glass-strong);border-color:var(--border-strong)}.primary-btn.big,.secondary-btn.big{padding:.95rem 1.9rem;font-size:1.12rem}.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;padding:0 .35rem;font:inherit}.link-btn:hover{text-decoration:underline}.home-play-area{display:grid;grid-template-columns:minmax(260px,580px) minmax(280px,1fr);gap:1.4rem;align-items:start}@media (max-width: 900px){.home-play-area{grid-template-columns:1fr}}.free-play-board{display:flex;flex-direction:column;gap:.7rem;min-width:0;--max-board: max(15rem, min(34rem, calc(100dvh - 22rem) ))}.free-play-board-wrap{position:relative;width:100%;max-width:var(--max-board);aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;box-shadow:0 8px 24px #0003}.free-play-header{width:100%;max-width:var(--max-board);display:flex;align-items:center;justify-content:space-between;gap:.85rem;padding:.6rem .95rem;background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-soft)}.free-play-turn-group{display:flex;align-items:center;gap:.6rem}.free-play-turn{display:flex;align-items:center;gap:.6rem;font-size:.82rem;color:var(--muted);font-weight:600}.free-play-select{font:inherit;font-size:.79rem;font-weight:600;padding:.4rem 1.65rem .4rem .7rem;border-radius:7px;background-color:var(--glass-strong);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%2388a8b3' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:9px 6px;border:1px solid var(--border);color:var(--text);cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;transition:border-color .12s,background-color .12s,color .12s,box-shadow .12s}.free-play-select:hover{border-color:var(--accent);background-color:var(--glass);color:var(--accent-strong)}.free-play-select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.free-play-select option{background-color:#10283a;color:var(--text)}.free-play-placeholder{aspect-ratio:1 / 1;width:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;border-radius:8px;background:var(--glass);border:1px dashed var(--border-strong);color:var(--muted);font-size:14px}.turn-swatch{display:inline-block;width:.7rem;height:1.8rem;border-radius:3px;border:1px solid var(--border-strong)}.turn-swatch.white{background:#fff}.turn-swatch.black{background:#102025}.free-play-header-actions{display:flex;gap:.6rem}.free-play-btn{font:inherit;font-size:.79rem;font-weight:600;padding:.4rem .85rem;border-radius:7px;background:var(--glass-strong);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:border-color .1s,background .1s,color .1s}.free-play-btn:hover:not(:disabled){border-color:var(--accent);background:var(--glass);color:var(--accent-strong)}.free-play-btn:disabled{opacity:.45;cursor:not-allowed}.history-nav-row{display:flex;gap:.5rem;justify-content:flex-end}.home-controls{display:flex;flex-direction:column;gap:1.05rem;min-width:0}.time-mode-box{display:flex;flex-direction:column;gap:.6rem;background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px;padding:.6rem;box-shadow:var(--shadow-soft)}.time-mode-section{border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--glass-soft)}.time-mode-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.7rem .95rem;background:transparent;border:none;cursor:pointer;font:inherit;color:var(--text);text-align:left}.time-mode-section-header:hover{background:var(--glass-strong)}.time-mode-section-title{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.time-mode-section-chevron{color:var(--muted);font-size:.82rem;margin-left:.5rem;display:inline-block;transition:transform .15s}.time-mode-section-chevron.open{transform:rotate(90deg)}.time-mode-section-body{padding:.6rem 1.9rem 1.1rem}.time-mode-blurb{margin-bottom:.95rem}.time-mode-grid{display:flex;gap:.95rem;flex-wrap:wrap}.time-mode-grid .time-mode-cell{flex:1 1 0;min-width:0}.time-mode-btn{background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);color:var(--text);padding:.8rem .3rem;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .1s,transform .1s,background .1s}.time-mode-btn:hover{border-color:var(--accent);transform:translateY(-1px);background:var(--glass-strong)}.time-mode-btn.selected{border-color:var(--accent);background:linear-gradient(180deg,#a8d8b929,#a8d8b90a);box-shadow:0 4px 16px #a8d8b926}.time-mode-btn:disabled{cursor:not-allowed;opacity:.5}.time-mode-btn:disabled:hover{border-color:var(--border);transform:none;background:var(--glass)}.time-mode-cell{display:flex;flex-direction:column;gap:.35rem}.time-mode-cell .time-mode-btn{width:100%}.time-mode-count{text-align:center;font-size:.82rem}.play-row{display:flex;gap:1.05rem;align-items:center;margin-top:.85rem;flex-wrap:wrap}.status-msg{color:var(--muted);font-size:.88rem}.status-msg.error{color:var(--bad)}.lobby-panel{margin-top:1.2rem;display:flex;flex-direction:column;gap:.7rem;background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px;padding:1.05rem 1.2rem;box-shadow:var(--shadow-soft)}.lobby-label{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.share-row{display:flex;gap:.6rem;align-items:center}.share-row .text-input{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem}.game-layout{display:grid;grid-template-columns:minmax(280px,1fr) minmax(380px,440px);gap:1.4rem;align-items:start;position:relative}@media (max-width: 980px){.game-layout{grid-template-columns:1fr}}.disconnect-banner{grid-column:1 / -1;padding:10px 16px;border-radius:8px;background:linear-gradient(180deg,#d68b8b2e,#d68b8b14);border:1px solid rgba(214,139,139,.32);color:var(--bad);font-weight:600;text-align:center;font-variant-numeric:tabular-nums}.board-column{display:flex;flex-direction:column;gap:.85rem;min-width:0;--max-board: max(17rem, min(56rem, calc(100dvh - 12rem) ))}.board-wrap{position:relative;width:100%;max-width:var(--max-board);aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;box-shadow:0 8px 24px #00000059;transition:box-shadow .22s}@keyframes board-finish-fade{0%{opacity:0}15%{opacity:1}65%{opacity:1}to{opacity:0}}@keyframes board-start-fade{0%{opacity:0;transform:scale(.94)}18%{opacity:1;transform:scale(1)}72%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.04)}}.board-start-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#080c18c7;color:#f5f7ff;border-radius:8px;text-align:center;pointer-events:none;opacity:0;animation:board-start-fade 3.5s ease-in-out forwards;text-shadow:0 2px 16px rgba(0,0,0,.55);z-index:6}.start-vs{display:flex;align-items:center;justify-content:center;gap:clamp(.8rem,4vw,2.4rem);padding:0 1rem}.start-player{display:flex;flex-direction:column;align-items:center;gap:.45rem;min-width:0}.start-divider{font-size:clamp(1.1rem,2.6vw,1.9rem);font-weight:800;opacity:.55;letter-spacing:.18em;text-transform:uppercase}.start-handle{font-size:clamp(.95rem,2vw,1.35rem);font-weight:700;max-width:9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.start-rating{font-size:clamp(.7rem,1.4vw,.95rem);opacity:.75;font-variant-numeric:tabular-nums}.start-color-banner{margin-top:.35rem;font-size:clamp(.65rem,1.3vw,.85rem);letter-spacing:.18em;text-transform:uppercase;font-weight:700;padding:.3rem .85rem;border-radius:999px;border:1px solid rgba(255,255,255,.22)}.start-color-banner.white-banner{background:#ffffffe0;color:#102025;border-color:#ffffffb3}.start-color-banner.black-banner{background:#102025eb;color:#f5f7ff}.board-finish-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#080c189e;color:#f5f7ff;border-radius:8px;text-align:center;pointer-events:none;opacity:0;animation:board-finish-fade 4s ease-in-out forwards;text-shadow:0 2px 16px rgba(0,0,0,.55);z-index:5}.board-finish-overlay .victor{font-size:clamp(28px,5.5vw,56px);font-weight:800;letter-spacing:.5px;line-height:1.1;padding:0 16px}.board-finish-overlay .reason{font-size:clamp(14px,1.8vw,18px);opacity:.85}.board-finish-overlay .finish-avatars{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:6px}.finish-avatar{width:clamp(56px,9vw,96px);height:clamp(56px,9vw,96px);border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.35);background:#ffffff14;display:inline-flex;align-items:center;justify-content:center;font-size:clamp(22px,3.5vw,36px);font-weight:700;color:#f5f7ff;box-shadow:0 4px 14px #00000073}.result-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1px solid var(--border-strong);background:var(--glass-strong);display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--accent);flex-shrink:0}.game-result-strip .result-line .title-group{display:flex;align-items:center;gap:12px}.game-result-strip{display:flex;flex-direction:row;align-items:center;gap:.95rem;padding:.95rem 1.05rem;background:var(--glass);border:1px solid var(--border);border-radius:14px}.game-result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.6rem}.game-result-buttons{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0;align-items:stretch}.game-result-buttons .primary-btn,.game-result-buttons .secondary-btn{white-space:nowrap}.game-result-strip .result-line{display:flex;justify-content:space-between;align-items:baseline;gap:.85rem}.game-result-strip .result-line .title{font-size:18px;font-weight:700}.game-result-strip .result-line .reason{font-size:14px;opacity:.75}.game-result-strip .rating-delta{margin:0;font-size:22px;gap:12px}.game-result-strip .rating-delta .delta{font-size:15px}.board-wrap.viewing-history{box-shadow:0 0 0 3px #e0c08ab3,0 0 32px 6px #e0c08a80}.player-card{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px;transition:background .2s,border-color .2s,box-shadow .2s}.player-card.active{border-color:var(--accent);background:linear-gradient(180deg,#a8d8b924,#a8d8b90a);box-shadow:0 4px 16px #a8d8b926}.player-card.low.active{border-color:var(--warn);background:linear-gradient(180deg,#e0c08a2e,#e0c08a0a);box-shadow:0 4px 16px #e0c08a2e}.player-avatar{width:56px;height:56px;border-radius:50%;overflow:hidden;background:var(--accent-soft);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}.player-avatar img{width:100%;height:100%;object-fit:cover}.player-avatar.large{width:108px;height:108px}.player-avatar-initial{font-size:25px;font-weight:600;color:var(--accent-strong)}.player-avatar.large .player-avatar-initial{font-size:44px}.player-meta{display:flex;flex-direction:column;flex-grow:1;min-width:0}.player-handle{font-weight:600;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-rating{color:var(--muted);font-size:13.5px}.player-clock-time{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:32px;font-weight:600;font-variant-numeric:tabular-nums}.voice-indicator{display:flex;align-items:center;gap:.6rem;padding:.3rem .7rem .3rem .4rem;border-radius:24px;background:var(--accent-soft);flex-shrink:0;transition:background .15s,color .15s,opacity .15s}.voice-indicator.state-off{color:var(--bad);background:#d68b8b12;opacity:.65}.voice-indicator.state-muted{color:var(--bad);background:#d68b8b1a}.voice-indicator.state-active{color:var(--accent-strong)}.voice-indicator.vibrating{animation:voice-vibrate 70ms infinite}@keyframes voice-vibrate{0%{transform:translate(0)}25%{transform:translate(-1px,1px)}50%{transform:translate(1px,-1px)}75%{transform:translate(-1px,-1px)}to{transform:translate(1px,1px)}}.voice-icon{position:relative;width:2.12rem;height:2.12rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.voice-slash{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.voice-slash:after{content:"";position:absolute;left:4px;right:4px;top:50%;height:2.5px;background:var(--bad);transform:translateY(-50%) rotate(-45deg);border-radius:2px}.volume-track{position:relative;width:4.95rem;height:.55rem;border-radius:4px;background:#00000014;overflow:hidden;flex-shrink:0}.voice-indicator.state-muted .volume-track{opacity:.5}.volume-fill{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;background:var(--vol-color, #16a34a);clip-path:inset(0 calc((1 - var(--vol, 0)) * 100%) 0 0);transition:clip-path 60ms linear,background 80ms linear}.avatar-edit{display:flex;gap:.95rem;align-items:center;margin-top:.35rem}.avatar-actions{display:flex;gap:.5rem;align-items:center}.side-panel{display:flex;flex-direction:column;gap:.85rem}.game-meta{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:12px;padding:.82rem 1.05rem;box-shadow:var(--shadow-soft)}.game-meta-title{font-weight:600;font-size:.95rem}.voice-controls{display:flex;flex-wrap:wrap;gap:.6rem;background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:12px;padding:.7rem}.voice-btn{font:inherit;background:var(--glass-strong);border:1px solid var(--border);color:var(--text);padding:.6rem .82rem;border-radius:8px;cursor:pointer;font-size:.82rem}.voice-btn:hover{border-color:var(--accent)}.voice-btn.primary{background:linear-gradient(180deg,var(--accent),var(--accent-strong));border-color:var(--accent-strong);color:#0c1e2c;flex:1;box-shadow:0 2px 10px #a8d8b938}.voice-btn.on{border-color:var(--good)}.voice-btn.off{border-color:var(--bad);color:var(--muted)}.moves-panel{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:12px;padding:.82rem 1.05rem;max-height:min(11rem,max(6rem,calc(100dvh - 50rem)));overflow-y:auto;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.85rem}.moves-line{padding:2px 0}.action-row{display:flex;gap:.6rem;flex-wrap:wrap}.chat-panel{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:12px;padding:.82rem;display:flex;flex-direction:column;gap:.6rem}.chat-log{max-height:min(10rem,max(3.5rem,calc(100dvh - 60rem)));overflow-y:auto;font-size:.85rem;display:flex;flex-direction:column;gap:.3rem}.chat-msg.opp{color:var(--accent)}.chat-msg.me{color:var(--text)}.chat-from{font-weight:600;margin-right:.25rem}.chat-input-row{display:flex;gap:.6rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c1e2c8c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--glass-strong);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid var(--border-strong);border-radius:16px;padding:1.9rem 2.12rem;min-width:21rem;text-align:center;box-shadow:var(--shadow)}.modal h2{margin-top:0;font-size:1.41rem}.rating-delta{margin:1.2rem 0;font-size:1.88rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:.95rem}.rating-delta .delta{font-size:1.18rem}.settings-card{background:var(--glass);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid var(--border);border-radius:14px;padding:.6rem 1.55rem;display:flex;flex-direction:column;box-shadow:var(--shadow-soft);max-width:720px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:1.65rem;padding:1.05rem 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-label{display:flex;flex-direction:column;gap:.18rem;min-width:0}.settings-title{font-weight:600;font-size:.97rem}.settings-control{display:flex;align-items:center;gap:.82rem;flex-shrink:0}.volume-control input[type=range]{width:11.8rem;accent-color:var(--accent)}.volume-readout{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.82rem;min-width:2.5rem;text-align:right}.settings-toggle{position:relative;width:2.95rem;height:1.65rem;border-radius:999px;border:1px solid var(--border-strong);background:var(--glass-strong);cursor:pointer;padding:0;transition:background .15s,border-color .15s}.settings-toggle.on{background:linear-gradient(180deg,var(--accent),var(--accent-strong));border-color:var(--accent-strong)}.settings-toggle-knob{position:absolute;top:2px;left:2px;width:1.3rem;height:1.3rem;border-radius:50%;background:#f3faf5;box-shadow:0 1px 4px #00000073;transition:transform .15s}.settings-toggle.on .settings-toggle-knob{transform:translate(1.3rem)}.profile-card{background:var(--glass);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid var(--border);border-radius:14px;padding:1.55rem;display:flex;flex-direction:column;gap:1.3rem;box-shadow:var(--shadow-soft)}.profile-row{display:flex;gap:2.12rem;flex-wrap:wrap}.profile-field{display:flex;flex-direction:column;gap:.3rem}.profile-field.grow{flex:1;min-width:0}.profile-value{font-size:1.03rem;font-weight:600;display:flex;align-items:center;gap:.6rem}.profile-value.big{font-size:1.76rem;color:var(--accent)}.identity-actions{gap:.82rem;align-items:flex-end}.import-block{background:var(--glass-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:.82rem 1.05rem;border-radius:10px;border:1px solid var(--border)}.import-block summary{cursor:pointer;-webkit-user-select:none;user-select:none}.import-block textarea{margin:.5rem 0}.history-section h2{margin:1.65rem 0 .82rem;font-size:1.3rem;font-weight:600}.history-table{width:100%;border-collapse:collapse;background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:14px;overflow:hidden}.history-table th,.history-table td{padding:.7rem .95rem;text-align:left;border-bottom:1px solid var(--border)}.history-table th{background:var(--accent-soft);font-weight:600;font-size:.79rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.history-table tr:last-child td{border-bottom:none}.result-win{color:var(--good);font-weight:700}.result-loss{color:var(--bad);font-weight:700}.result-draw{color:var(--muted);font-weight:700}.board-column.with-cash-shop{position:relative}.cash-side-shop{position:absolute;top:0;right:calc(100% + 12px);width:200px}@media (max-width: 1200px){.cash-side-shop{position:static;width:100%;margin-bottom:12px}}.free-play-board.with-shop{position:relative}.free-play-shop-col{position:absolute;top:0;right:calc(100% + .7rem);width:14rem;display:flex;flex-direction:column;gap:.7rem}@media (max-width: 1200px){.free-play-shop-col{position:static;width:100%}}.cash-shop{display:flex;flex-direction:column;gap:.7rem;padding:.7rem;background:var(--glass);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-soft);min-width:0}.cash-shop.compact{padding:.6rem;gap:.6rem}.cash-shop-header{display:flex;flex-direction:column;gap:.5rem}.cash-shop-title{font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}.cash-gold-row{display:flex;gap:.5rem;flex-wrap:wrap}.cash-gold{display:flex;flex-direction:column;gap:.12rem;padding:.35rem .6rem;background:var(--glass-soft);border:1px solid var(--border);border-radius:8px;flex:1 1 0;min-width:3.5rem}.cash-gold.highlight{background:var(--accent-soft);border-color:var(--border-strong)}.cash-gold-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.cash-gold-amount{display:inline-flex;align-items:center;gap:.35rem;font-size:1rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text)}.cash-gold-coin{display:inline-block;width:.7rem;height:.7rem;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffe7a0,#b88836 70%);box-shadow:0 0 0 1px #0006 inset,0 1px 2px #00000073}.cash-shop-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.cash-shop-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .25rem .35rem;background:var(--glass-soft);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;transition:background .1s,border-color .1s,transform 80ms}.cash-shop-item:hover:not(:disabled){background:var(--glass-strong);border-color:var(--border-strong)}.cash-shop-item:active:not(:disabled){transform:translateY(1px)}.cash-shop-item:disabled{opacity:.4;cursor:not-allowed}.cash-shop-item.selected{background:var(--accent-soft);border-color:var(--accent-strong);box-shadow:0 0 0 1px var(--accent-strong) inset}.cash-shop-piece{display:inline-flex;align-items:center;justify-content:center;height:2.24rem}.cash-shop-price{font-size:.7rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--accent)}.cash-shop-hint{min-height:1.65rem;line-height:1.3}.game-layout.hero-game-layout{grid-template-columns:minmax(200px,240px) minmax(320px,640px) minmax(260px,340px)}@media (max-width: 1180px){.game-layout.hero-game-layout{grid-template-columns:minmax(320px,640px) minmax(260px,340px)}.game-layout.hero-game-layout .hero-side-column{grid-column:1 / -1;order:-1}}@media (max-width: 980px){.game-layout.hero-game-layout{grid-template-columns:1fr}}.hero-side-column{display:flex;flex-direction:column;gap:12px;min-width:0}.hero-side-placeholder{padding:12px;background:var(--glass);border:1px solid var(--border);border-radius:12px;text-align:center}.hero-picker-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#080c18db;border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:6;padding:16px}.hero-picker{width:100%;max-width:560px;display:flex;flex-direction:column;gap:12px}.hero-picker.inline{background:var(--glass);border:1px solid var(--border);border-radius:12px;padding:10px}.hero-picker-title{font-weight:700;font-size:16px;color:var(--accent);text-align:center}.hero-picker-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.hero-card{--hero-color: var(--accent);display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 10px;background:var(--glass-soft);border:1px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;transition:background .1s,border-color .1s,transform 80ms}.hero-card:hover{background:var(--glass-strong);border-color:var(--hero-color)}.hero-card.selected{background:color-mix(in srgb,var(--hero-color) 20%,transparent);border-color:var(--hero-color);box-shadow:0 0 0 1px var(--hero-color) inset,0 0 18px color-mix(in srgb,var(--hero-color) 50%,transparent)}.hero-card-king{filter:drop-shadow(0 0 10px var(--hero-color))}.hero-card-name{font-weight:700;font-size:15px}.hero-card-blurb{font-size:12.5px;color:var(--muted);text-align:center;line-height:1.3}.hero-card-cd{font-size:11.5px;color:var(--hero-color);font-weight:600}.hero-picker-status{text-align:center}.hero-panel{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--glass);border:1px solid var(--border);border-radius:12px}.hero-panel.compact{padding:10px;gap:8px}.hero-panel-title{font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}.hero-card-row{--hero-color: var(--accent);display:flex;align-items:center;gap:10px;padding:8px;background:var(--glass-soft);border:1px solid var(--border);border-radius:8px}.hero-card-row.highlight{background:color-mix(in srgb,var(--hero-color) 15%,transparent);border-color:var(--hero-color)}.hero-card-row .hero-card-king.small{filter:drop-shadow(0 0 8px var(--hero-color));flex-shrink:0}.hero-card-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.hero-card-row .hero-card-name{font-size:14px}.hero-card-name-row{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;min-width:0;width:100%}.hero-card-name-row .hero-card-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hero-card-cd-line{color:var(--hero-color);font-weight:600;font-variant-numeric:tabular-nums;flex-shrink:0;margin-left:auto}.hero-action-row{display:flex;justify-content:center}.hero-action-row .primary-btn,.hero-action-row .secondary-btn{width:100%;padding:8px 14px}.hero-panel-hint{min-height:1.65rem;line-height:1.3}.hero-side-pickers{display:flex;flex-direction:column;gap:.5rem;padding:.7rem .95rem .7rem .85rem;background:var(--glass);border:1px solid var(--border);border-radius:10px}.hero-side-picker{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.hero-side-picker .free-play-select{max-width:8.5rem}.frozen-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;background:linear-gradient(135deg,#b4e6ff73,#50a0dc4d);box-shadow:inset 0 0 0 2px #dcf0ffbf,inset 0 0 12px #8cd2ffb3;display:flex;align-items:center;justify-content:center;animation:frozen-pulse 2.4s ease-in-out infinite}.frozen-flake{color:#f0fafff2;text-shadow:0 0 6px rgba(140,210,255,.9),0 0 12px rgba(80,160,220,.7);font-weight:700;pointer-events:none;-webkit-user-select:none;user-select:none}@keyframes frozen-pulse{0%,to{opacity:.85}50%{opacity:1}}.ability-flight,.ability-necromancer,.ability-knight,.ability-frost{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:12}.ability-flight-body{position:absolute;width:var(--size);height:var(--size);margin-left:calc(var(--size) * -.5);margin-top:calc(var(--size) * -.5);display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 0 .4rem rgba(135,206,235,.95)) drop-shadow(0 0 1rem rgba(135,206,235,.7));animation:ability-flight-fly .95s cubic-bezier(.45,0,.55,1) forwards}@keyframes ability-flight-fly{0%{left:var(--from-x);top:var(--from-y);transform:scale(.92);opacity:.4}18%{transform:scale(1.05);opacity:1}82%{left:var(--to-x);top:var(--to-y);transform:scale(1.05);opacity:1}to{left:var(--to-x);top:var(--to-y);transform:scale(.95);opacity:0}}.ability-flight-king{position:relative;display:inline-flex;z-index:1}.ability-flight-wing{position:absolute;top:12%;width:48%;height:76%;background:linear-gradient(135deg,#fffffff2,#b4dcff8c 60%,#87ceeb00);filter:drop-shadow(0 0 6px rgba(255,255,255,.9));z-index:0}.ability-flight-wing.left{left:-16%;clip-path:polygon(100% 10%,100% 90%,30% 100%,0 60%,25% 25%);transform-origin:100% 50%;animation:ability-flight-wing-l .22s ease-in-out infinite}.ability-flight-wing.right{right:-16%;clip-path:polygon(0 10%,0 90%,70% 100%,100% 60%,75% 25%);transform-origin:0% 50%;animation:ability-flight-wing-r .22s ease-in-out infinite}@keyframes ability-flight-wing-l{0%,to{transform:rotate(-8deg) scaleY(1)}50%{transform:rotate(-32deg) scaleY(.85)}}@keyframes ability-flight-wing-r{0%,to{transform:rotate(8deg) scaleY(1)}50%{transform:rotate(32deg) scaleY(.85)}}.ability-necro-burst,.ability-necro-ring{position:absolute;left:var(--cx);top:var(--cy);border-radius:50%;pointer-events:none}.ability-necro-burst{width:var(--size);height:var(--size);margin-left:calc(var(--size) * -.5);margin-top:calc(var(--size) * -.5);background:radial-gradient(circle,rgba(196,132,232,.95) 0%,rgba(155,77,202,.7) 35%,rgba(120,50,170,.25) 65%,transparent 85%);box-shadow:0 0 1.4rem #9b4dcae6,0 0 3rem #9b4dca8c;animation:ability-necro-burst .95s ease-out forwards}.ability-necro-ring{width:var(--size);height:var(--size);margin-left:calc(var(--size) * -.5);margin-top:calc(var(--size) * -.5);border:3px solid rgba(196,132,232,.85);box-shadow:0 0 14px #9b4dcae6;animation:ability-necro-ring .95s ease-out forwards}@keyframes ability-necro-burst{0%{transform:scale(.2);opacity:0}20%{transform:scale(.85);opacity:1}60%{transform:scale(1.25);opacity:.75}to{transform:scale(1.55);opacity:0}}@keyframes ability-necro-ring{0%{transform:scale(.3);opacity:0}25%{transform:scale(.9);opacity:1}to{transform:scale(2);opacity:0}}.ability-knight-shake{position:absolute;left:var(--cx);top:var(--cy);width:var(--size);height:var(--size);margin-left:calc(var(--size) * -.5);margin-top:calc(var(--size) * -.5);border-radius:50%;background:radial-gradient(circle,rgba(196,30,30,.55) 0%,rgba(196,30,30,.3) 45%,transparent 75%);box-shadow:0 0 1rem #c41e1ecc,0 0 2.4rem #c41e1e8c;animation:ability-knight-shake .6s cubic-bezier(.36,.07,.19,.97) forwards}@keyframes ability-knight-shake{0%{transform:translate(0) scale(.9);opacity:0}10%{transform:translate(-6px,1px) scale(1);opacity:1}20%{transform:translate(7px,-1px)}30%{transform:translate(-7px,2px)}40%{transform:translate(6px,-2px)}55%{transform:translate(-5px,1px)}70%{transform:translate(4px,-1px)}85%{transform:translate(-2px);opacity:.8}to{transform:translate(0);opacity:0}}.ability-frost-burst{position:absolute;left:var(--cx);top:var(--cy);width:var(--size);height:var(--size);margin-left:calc(var(--size) * -.5);margin-top:calc(var(--size) * -.5);border-radius:50%;background:radial-gradient(circle,rgba(220,240,255,.95) 0%,rgba(140,210,255,.7) 35%,rgba(80,160,220,.25) 65%,transparent 85%);box-shadow:0 0 1rem #8cd2ffd9,0 0 2.4rem #50a0dc99;animation:ability-frost-burst .7s ease-out forwards}@keyframes ability-frost-burst{0%{transform:scale(.3);opacity:0}25%{transform:scale(.95);opacity:1}to{transform:scale(1.4);opacity:0}}
