:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--bg:#0e0d12;--panel:#18171f;--ink:#e7e3d8;--muted:#a9a5b8;--accent:#f0c040;--accent-soft:#a6842b;--danger:#ff7a86;--border:#2a2735;--cell-land:#2c3322;--cell-lake:#1d2a45;--cell-zone-a:#3a3222;--cell-zone-b:#3d2a25;--cell-border:#1a1922;--piece-own:#f0c04033;--piece-enemy:#ff7a8633;--my-turn:#9be084;--cell-size:min(8.5vw, 56px)}*{box-sizing:border-box}body{background-color:var(--bg);background-image:radial-gradient(ellipse at top, #1a1810 0%, var(--bg) 60%);color:var(--ink);min-height:100vh;margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif}.talon{flex-direction:column;gap:1rem;max-width:880px;margin:0 auto;padding:1.5rem .75rem 4rem;display:flex}@media (width>=640px){.talon{padding:2rem 1.25rem 4rem}}header{text-align:center;margin-bottom:.5rem}header h1{letter-spacing:-.02em;color:#fff;margin:0 0 .25rem;font-size:clamp(1.6rem,6vw,2.5rem)}.header-logo{vertical-align:middle;width:clamp(28px,6vw,36px);height:clamp(28px,6vw,36px);filter:drop-shadow(0 0 8px var(--accent-soft));border-radius:.4rem;margin-right:.3rem}.tagline{color:var(--muted);margin:0;font-size:.9rem}.status-bar{background:var(--panel);border:1px solid var(--border);border-radius:.6rem;flex-wrap:wrap;gap:.35rem;padding:.45rem .6rem;display:flex}@media (width>=640px){.status-bar{gap:.5rem;padding:.6rem .9rem}}.status-item{border-right:1px solid var(--border);flex-direction:column;flex:auto;min-width:0;padding:0 .5rem;display:flex}@media (width>=640px){.status-item{padding:0 .75rem}}.status-item.profile-group{display:none}@media (width>=480px){.status-item.profile-group{display:flex}}.status-item:last-child{border-right:0}.status-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.15rem;font-size:.7rem}.status-item strong,.status-item code{font-size:.95rem;font-weight:600}.status-item .my-turn{color:var(--my-turn)}.status-item code{color:var(--ink);background:0 0;font-family:ui-monospace,SFMono-Regular,monospace;font-weight:500}.err{color:var(--danger);margin:0}.muted{color:var(--muted)}.board-card{background:var(--panel);border:1px solid var(--border);border-radius:.75rem;justify-content:center;align-items:center;padding:.5rem;display:flex}@media (width>=640px){.board-card{padding:1rem}}.board{box-shadow:0 8px 24px #00000080, inset 0 0 0 1px var(--border);background:url(/board/wood.png) 0 0/64px 64px;border-radius:.4rem;flex-direction:column;padding:.4rem;display:flex}.board-row{display:flex}.cell{width:var(--cell-size);height:var(--cell-size);border:1px solid var(--cell-border);justify-content:center;align-items:center;display:flex;position:relative}.terrain-land.tile-1{background:url(/board/land-1.png) 50%/cover}.terrain-land.tile-2{background:url(/board/land-2.png) 50%/cover}.terrain-land.tile-3{background:url(/board/land-3.png) 50%/cover}.terrain-lake.tile-1{background:url(/board/lake-1.png) 50%/cover}.terrain-lake.tile-2{background:url(/board/lake-2.png) 50%/cover}.terrain-lake.tile-3{background:url(/board/lake-3.png) 50%/cover}.terrain-setupzonea.tile-1{background:linear-gradient(#a0781e4d,#a0781e4d),url(/board/land-1.png) 50%/cover}.terrain-setupzonea.tile-2{background:linear-gradient(#a0781e4d,#a0781e4d),url(/board/land-2.png) 50%/cover}.terrain-setupzonea.tile-3{background:linear-gradient(#a0781e4d,#a0781e4d),url(/board/land-3.png) 50%/cover}.terrain-setupzoneb.tile-1{background:linear-gradient(#8c502859,#8c502859),url(/board/land-1.png) 50%/cover}.terrain-setupzoneb.tile-2{background:linear-gradient(#8c502859,#8c502859),url(/board/land-2.png) 50%/cover}.terrain-setupzoneb.tile-3{background:linear-gradient(#8c502859,#8c502859),url(/board/land-3.png) 50%/cover}[data-biome=desert] .terrain-land.tile-1{background:url(/board/desert-1.png) 50%/cover}[data-biome=desert] .terrain-land.tile-2{background:url(/board/desert-2.png) 50%/cover}[data-biome=desert] .terrain-land.tile-3{background:url(/board/desert-3.png) 50%/cover}[data-biome=desert] .terrain-setupzonea.tile-1{background:linear-gradient(#a0781e4d,#a0781e4d),url(/board/desert-1.png) 50%/cover}[data-biome=desert] .terrain-setupzonea.tile-2{background:linear-gradient(#a0781e4d,#a0781e4d),url(/board/desert-2.png) 50%/cover}[data-biome=desert] .terrain-setupzonea.tile-3{background:linear-gradient(#a0781e4d,#a0781e4d),url(/board/desert-3.png) 50%/cover}[data-biome=desert] .terrain-setupzoneb.tile-1{background:linear-gradient(#8c502859,#8c502859),url(/board/desert-1.png) 50%/cover}[data-biome=desert] .terrain-setupzoneb.tile-2{background:linear-gradient(#8c502859,#8c502859),url(/board/desert-2.png) 50%/cover}[data-biome=desert] .terrain-setupzoneb.tile-3{background:linear-gradient(#8c502859,#8c502859),url(/board/desert-3.png) 50%/cover}[data-lake-style=dark] .terrain-lake.tile-1{background:url(/board/lake-dark-1.png) 50%/cover}[data-lake-style=dark] .terrain-lake.tile-2{background:url(/board/lake-dark-2.png) 50%/cover}[data-lake-style=dark] .terrain-lake.tile-3{background:url(/board/lake-dark-3.png) 50%/cover}.water-orb{object-fit:contain;opacity:.7;pointer-events:none;z-index:0;width:60%;height:60%;animation:3s ease-in-out infinite water-bob;position:absolute}@keyframes water-bob{0%,to{opacity:.7;transform:translateY(0)scale(1)}50%{opacity:.85;transform:translateY(-6%)scale(1.05)}}.cell.own:after,.cell.enemy:after{content:"";pointer-events:none;border-radius:4px;position:absolute;inset:0}.cell.own:after{box-shadow:inset 0 0 0 3px var(--accent), inset 0 0 8px #f0c0404d}.cell.enemy:after{box-shadow:inset 0 0 0 3px var(--danger), inset 0 0 8px #dc3c3c4d}.cell.own .piece{background:radial-gradient(circle,#f0c04026 0%,#f0c0400d 100%)}.cell.enemy .piece{background:radial-gradient(circle,#dc3c3c26 0%,#dc3c3c0d 100%)}.cell.selected{filter:brightness(1.3)}.cell.selected:after{box-shadow:inset 0 0 0 3px var(--accent), 0 0 12px var(--accent-soft);z-index:2}.cell.target{cursor:pointer}.cell.target:before{content:"";background:var(--my-turn);opacity:.65;pointer-events:none;z-index:0;border-radius:50%;width:28%;height:28%;position:absolute}.cell.target.enemy:before{background:var(--danger);opacity:.18;border-radius:0;width:100%;height:100%}button.cell{font:inherit;color:inherit;cursor:pointer;background-clip:padding-box;padding:0}button.cell.inert{cursor:default}button.cell:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;z-index:3}@keyframes cell-flash{0%{filter:brightness(2)saturate(1.5);box-shadow:inset 0 0 0 3px #ffe066}50%{filter:brightness(1.5)hue-rotate(20deg);box-shadow:inset 0 0 0 3px #ff7a86cc}to{filter:none;box-shadow:none}}.cell.flash{z-index:4;animation:.7s ease-out cell-flash}.toast-stack{z-index:50;flex-direction:column;gap:.5rem;max-width:min(360px,100vw - 2rem);display:flex;position:fixed;top:1rem;right:1rem}.toast{background:var(--panel);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:.5rem;padding:.6rem 2rem .6rem .85rem;animation:.22s ease-out toast-in;position:relative;box-shadow:0 6px 18px #0006}.toast-combat{border-left-color:#ffe066}.toast-win{border-left-color:var(--my-turn)}.toast-error{border-left-color:var(--danger)}.toast-title{margin:0 0 .1rem;font-size:.95rem;font-weight:600}.toast-body{color:var(--muted);font-size:.8rem}.toast-close{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:.25rem;width:auto;padding:.2rem .45rem;font-size:1.1rem;position:absolute;top:.3rem;right:.3rem}.toast-close:hover{color:var(--ink);filter:none;background:#ffffff0f}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.modal-backdrop{z-index:100;background:0 0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--border);text-align:center;border-radius:1rem;width:min(420px,100vw - 2rem);min-width:0;padding:1.5rem 1.25rem;animation:.22s cubic-bezier(.16,1,.3,1) modal-in;box-shadow:0 8px 32px #000000b3,0 0 80px #00000080}@media (width>=640px){.modal{min-width:320px;padding:2rem 2.25rem}}.modal.gameover h2{letter-spacing:-.02em;color:var(--accent);margin:0 0 .5rem;font-size:2rem}.gameover-reason{color:var(--muted);margin:0 0 .5rem;font-size:.95rem}.gameover-elo{letter-spacing:-.02em;margin:0 0 1.5rem;font-family:ui-monospace,SFMono-Regular,monospace;font-size:1.4rem;font-weight:700}.gameover-elo.elo-up{color:var(--my-turn)}.gameover-elo.elo-down{color:var(--danger)}.modal-actions{justify-content:center;gap:.6rem;display:flex}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:scale(.92)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.piece{z-index:1;border-radius:50%;justify-content:center;align-items:center;width:88%;height:88%;display:flex;position:relative}.piece-revealed img{object-fit:contain;filter:drop-shadow(0 1px 2px #0009);width:100%;height:100%}.rank-badge{border:1px solid var(--accent-soft);min-width:clamp(14px,3vw,18px);height:clamp(14px,3vw,18px);color:var(--ink);text-align:center;z-index:5;pointer-events:none;background:#0e0d12eb;border-radius:4px;padding:0 3px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:clamp(.5rem,1.4vw,.65rem);font-weight:700;line-height:clamp(14px,3vw,18px);position:absolute;bottom:-2px;right:-2px}.cell.own .piece-revealed{border:2px solid #f0c04080}.cell.enemy .piece-revealed{border:2px solid #dc3c3c80}.cell.enemy .piece-hidden{border:2px solid #dc3c3c66}.piece-hidden{background:linear-gradient(#2a2518 0%,#1a1610 100%)}.piece-hidden img{object-fit:contain;filter:drop-shadow(0 1px 2px #0009);opacity:.85;width:100%;height:100%}.board-empty{text-align:center;width:100%;color:var(--muted);padding:4rem 2rem}.setup-phase{flex-direction:column;align-items:center;gap:.75rem;width:100%;display:flex}.setup-header{text-align:center}.setup-header h2{color:var(--accent);letter-spacing:-.01em;margin:0 0 .25rem;font-size:clamp(1rem,3.5vw,1.3rem)}.setup-hint{color:var(--muted);margin:0;font-size:clamp(.7rem,2vw,.82rem)}.setup-counter{margin:.25rem 0 0;font-size:.95rem;font-weight:600}.setup-tray{border:1px solid var(--border);background:#0003;border-radius:.5rem;flex-wrap:wrap;justify-content:center;gap:.25rem;max-width:100%;padding:.35rem;display:flex}@media (width>=640px){.setup-tray{gap:.35rem;padding:.5rem}}.tray-piece{background:var(--panel);border:2px solid var(--border);cursor:pointer;border-radius:.4rem;flex-direction:column;justify-content:center;align-items:center;gap:.1rem;width:clamp(40px,8vw,52px);height:clamp(48px,10vw,60px);padding:.15rem;transition:border-color .12s,background .12s;display:flex;position:relative}.tray-piece img{object-fit:contain;filter:drop-shadow(0 1px 2px #00000080);width:clamp(22px,5vw,32px);height:clamp(22px,5vw,32px)}.tray-rank{color:var(--accent);font-family:ui-monospace,SFMono-Regular,monospace;font-size:.6rem;font-weight:700}.tray-count{color:var(--muted);font-size:.65rem;font-weight:700}.tray-piece:hover:not(:disabled){border-color:var(--accent-soft);background:#f0c04014}.tray-active{border-color:var(--accent);box-shadow:0 0 10px var(--accent-soft);background:#f0c04026}.tray-depleted{opacity:.3;cursor:not-allowed}.loadout-picker{-webkit-overflow-scrolling:touch;gap:.5rem;margin-bottom:.5rem;padding:.5rem 0;display:flex;overflow-x:auto}.loadout-chip{border:1px solid var(--border);background:var(--panel);color:var(--ink);cursor:pointer;border-radius:1rem;flex-shrink:0;padding:.35rem .75rem;font-size:.8rem;font-weight:600;transition:border-color .15s}.loadout-chip:hover{border-color:var(--accent)}.setup-actions,.actions-bar{flex-wrap:wrap;justify-content:center;gap:.6rem;display:flex}button{background:var(--accent);color:#0e0d12;cursor:pointer;border:0;border-radius:.5rem;min-height:44px;padding:.5rem .9rem;font-size:.85rem;font-weight:600;transition:filter .12s}@media (width>=640px){button{padding:.55rem 1.1rem;font-size:.9rem}}button:hover:not(:disabled){filter:brightness(1.1)}button:disabled{color:var(--muted);cursor:not-allowed;background:#3a3548}button[data-testid=leave-queue],button.ghost{border:1px solid var(--border);color:var(--ink);background:0 0}.card{background:var(--panel);border:1px solid var(--border);border-radius:.75rem;padding:.9rem 1.2rem}.card.debug summary{cursor:pointer;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;-webkit-user-select:none;user-select:none;font-size:.8rem}.card.debug h3{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:.75rem 0 .4rem;font-size:.75rem;font-weight:600}.card.debug ol{max-height:12rem;margin:0;padding-left:1.25rem;overflow-y:auto}.card.debug li{word-break:break-all;margin-bottom:.25rem}code{color:var(--muted);font-family:ui-monospace,SFMono-Regular,monospace;font-size:.78rem}.reconnecting-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background:#08070eb8;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.reconnecting-card{text-align:center;color:var(--ink);font-size:1.1rem;font-weight:600}.reconnecting-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;margin:0 auto 1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.avatar-btn{all:unset;cursor:pointer;border:2px solid var(--accent-soft);border-radius:50%;flex-shrink:0;align-items:center;width:32px;height:32px;margin-bottom:.2rem;transition:border-color .15s;display:flex;overflow:hidden}.avatar-btn:hover,.avatar-btn:focus-visible{border-color:var(--accent)}.avatar-thumb{object-fit:cover;width:100%;height:100%}.avatar-picker-backdrop{z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.avatar-picker{background:var(--panel);border:1px solid var(--border);border-radius:1rem;flex-direction:column;gap:1rem;width:100%;max-width:560px;max-height:80vh;padding:1.5rem;display:flex;overflow:hidden}.avatar-picker h2{text-align:center;margin:0;font-size:1.2rem}.avatar-tabs{-webkit-overflow-scrolling:touch;gap:.25rem;display:flex;overflow-x:auto}.avatar-tabs button{all:unset;cursor:pointer;color:var(--muted);white-space:nowrap;background:0 0;border-radius:.5rem;padding:.4rem .8rem;font-size:.85rem;font-weight:500;transition:background .15s,color .15s}.avatar-tabs button:hover{background:var(--border);color:var(--ink)}.avatar-tabs button.active{background:var(--accent-soft);color:var(--ink)}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.5rem;min-height:0;max-height:50vh;padding:.25rem;display:grid;overflow-y:auto}.avatar-option{appearance:none;font:inherit;color:inherit;box-sizing:border-box;cursor:pointer;aspect-ratio:1;background:0 0;border:2px solid #0000;border-radius:.5rem;width:100%;min-width:0;margin:0;padding:0;transition:border-color .15s,transform .1s;display:block;overflow:hidden}.avatar-option:hover{border-color:var(--accent-soft);transform:scale(1.05)}.avatar-option:focus-visible{border-color:var(--accent);outline:2px solid var(--accent);outline-offset:2px}.avatar-option.selected{border-color:var(--accent);box-shadow:0 0 8px var(--accent-soft)}.avatar-option img{object-fit:cover;width:100%;height:100%;display:block}.avatar-picker-close{align-self:center}.profile-group{gap:.35rem;min-width:0;border-right:0!important;flex-direction:column!important;display:flex!important}.profile-buttons{align-items:center;gap:.4rem;display:flex}.badge-btn{all:unset;cursor:pointer;border:2px solid var(--border);background:#0000004d;border-radius:.4rem;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:border-color .15s;display:flex;overflow:hidden}.badge-btn:hover,.badge-btn:focus-visible{border-color:var(--accent)}.badge-thumb{object-fit:contain;width:100%;height:100%;padding:2px}.theme-btn{all:unset;cursor:pointer;border:1px solid var(--border);color:var(--muted);white-space:nowrap;border-radius:.35rem;padding:.2rem .5rem;font-size:.75rem;font-weight:600;transition:border-color .15s,color .15s}.theme-btn:hover,.theme-btn:focus-visible{border-color:var(--accent-soft);color:var(--ink)}.display-name-input{all:unset;color:var(--ink);border:1px solid var(--border);background:#00000040;border-radius:.35rem;width:100%;min-width:0;padding:.2rem .4rem;font-family:inherit;font-size:.8rem;transition:border-color .15s}.display-name-input::placeholder{color:var(--muted);opacity:.6}.display-name-input:focus{border-color:var(--accent-soft)}.picker-subtitle{color:var(--muted);text-align:center;margin:-.5rem 0 0;font-size:.82rem}.theme-picker{max-width:620px}.theme-list{flex-direction:column;gap:.5rem;max-height:55vh;padding:.25rem;display:flex;overflow-y:auto}.theme-row{all:unset;cursor:pointer;border:2px solid var(--border);background:var(--bg);border-radius:.6rem;justify-content:space-between;align-items:center;gap:.75rem;padding:.6rem .75rem;transition:border-color .15s,background .15s;display:flex}.theme-row:hover{border-color:var(--accent-soft);background:#f0c0400d}.theme-row:focus-visible{border-color:var(--accent);outline:2px solid var(--accent);outline-offset:2px}.theme-row.selected{border-color:var(--accent);background:#f0c0401a}.theme-row-info{flex-direction:column;gap:.1rem;min-width:80px;display:flex}.theme-row-name{color:var(--ink);font-size:.95rem;font-weight:700}.theme-row-tag{text-transform:uppercase;letter-spacing:.06em;color:var(--my-turn);opacity:.8;font-size:.65rem;font-weight:600}.theme-row-previews{gap:.35rem;display:flex}.theme-row-previews img{border:1px solid var(--border);object-fit:cover;border-radius:50%;flex-shrink:0;width:40px;height:40px}@media (width<=480px){.theme-row-previews img{width:32px;height:32px}}.opponent-bar{background:var(--panel);border:1px solid var(--border);border-radius:.6rem;align-items:center;gap:.6rem;padding:.4rem .7rem;transition:border-color .2s;display:flex}.opponent-bar.their-turn{border-color:var(--danger)}.opponent-avatar{border:2px solid var(--border);object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.opponent-avatar.placeholder{background:var(--border)}.opponent-badge{object-fit:contain;opacity:.75;border-radius:.25rem;flex-shrink:0;width:24px;height:24px}.opponent-info{flex-direction:column;flex:1;min-width:0;display:flex}.opponent-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.opponent-elo{color:var(--muted);font-family:ui-monospace,SFMono-Regular,monospace;font-size:.72rem}.opponent-thinking{color:var(--danger);white-space:nowrap;font-size:.78rem;font-weight:500;animation:1.5s ease-in-out infinite pulse-opacity}@keyframes pulse-opacity{0%,to{opacity:1}50%{opacity:.4}}.card.history summary{cursor:pointer;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;-webkit-user-select:none;user-select:none;font-size:.85rem;font-weight:600}.history-loading{text-transform:none;color:var(--accent-soft);font-size:.75rem;font-weight:400}.history-count{color:var(--muted);font-size:.8rem;font-weight:400}.history-empty{padding:.5rem 0;font-size:.85rem}.history-list{flex-direction:column;gap:.3rem;max-height:320px;margin:.5rem 0 0;padding:0;list-style:none;display:flex;overflow-y:auto}.history-row-btn{all:unset;cursor:pointer;border:1px solid var(--border);background:var(--bg);border-radius:.45rem;align-items:center;gap:.6rem;width:100%;padding:.45rem .6rem;font-size:.82rem;transition:border-color .15s,background .15s;display:flex}.history-row-btn:hover{border-color:var(--accent-soft);background:#f0c0400d}.history-row-btn:focus-visible{border-color:var(--accent);outline:2px solid var(--accent);outline-offset:2px}.history-result{text-align:center;min-width:52px;font-weight:700}.history-win{color:var(--my-turn)}.history-loss{color:var(--danger)}.history-draw{color:var(--muted)}.history-opponent{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.history-moves{color:var(--muted);white-space:nowrap;font-size:.75rem}.history-elo{text-align:right;min-width:36px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:.8rem;font-weight:700}.history-elo.elo-up{color:var(--my-turn)}.history-elo.elo-down{color:var(--danger)}.history-date{color:var(--muted);white-space:nowrap;font-size:.72rem}.history-refresh{margin-top:.5rem;font-size:.78rem}.replay-modal{max-width:520px}.replay-info{margin:0 0 1rem;font-size:.9rem}.replay-viewer{background:var(--bg);border:1px solid var(--border);border-radius:.5rem;min-height:80px;margin-bottom:1rem;padding:1rem}.replay-step-label{margin:0;font-family:ui-monospace,SFMono-Regular,monospace;font-size:.9rem}.replay-combat{color:var(--accent);margin:.3rem 0 0;font-size:.82rem}.replay-controls{justify-content:center;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.replay-counter{color:var(--muted);text-align:center;min-width:60px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:.85rem}.active-games{text-align:left;margin-top:1rem}.active-games-title{color:var(--accent);margin:0 0 .5rem;font-size:.95rem}.active-games-list{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.active-game-row{background:var(--panel);border:1px solid var(--border);border-radius:.5rem;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.4rem .6rem;font-size:.85rem;display:flex}.active-game-players{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.active-game-moves,.active-game-viewers{white-space:nowrap;font-size:.75rem}.active-game-watch{margin-left:auto;padding:.2rem .6rem;font-size:.78rem}.cpu-buttons{gap:.5rem;margin-top:.5rem;display:flex}.loadout-manager-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.loadout-list{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.loadout-item{border:1px solid var(--border);background:var(--panel);border-radius:.5rem;justify-content:space-between;align-items:center;padding:.5rem .75rem;display:flex}.loadout-item-name{font-weight:600}.loadout-item-actions{gap:.25rem;display:flex}.loadout-empty{color:var(--muted);text-align:center;padding:2rem 0;font-size:.9rem}.loadout-editor-header{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.loadout-name-input{border:1px solid var(--border);background:var(--panel);color:var(--ink);border-radius:.5rem;flex:1;padding:.4rem .6rem;font-size:.9rem}.danger{color:#e06060}.theme-row.locked{opacity:.5;cursor:not-allowed}.theme-row.locked:hover{border-color:var(--border);background:0 0}.lock-badge{margin-left:auto;font-size:.9rem}.avatar-option.locked{opacity:.4;cursor:not-allowed}.avatar-option.locked:hover{border-color:#0000;transform:none}.lock-overlay{font-size:1.2rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.avatar-option{position:relative}
