:root{--bg: #0d1014;--panel: #161b22;--card: #1b212b;--line: #2a323d;--text: #e6e9ee;--muted: #8b95a3;--accent: #cf6a3d;--green: #3fb27a;--red: #d6533f;--yellow: #e0c341}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px}.app{max-width:1360px;margin:0 auto;padding:12px 16px 40px}.topbar{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:14px}.topbar h1{font-size:20px;margin:0;letter-spacing:.3px}.topbar .sub{color:var(--muted);font-weight:400}.topbar-right{display:flex;align-items:center;gap:10px}.turnbadge{border:1px solid var(--line);border-radius:999px;padding:5px 14px;background:var(--panel)}.ghost-btn{font-size:12px;padding:6px 12px}.muted{color:var(--muted)}.small{font-size:12px}.big{font-size:22px;font-weight:700}.center{text-align:center}.panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:28px;max-width:560px;margin:40px auto}.handoff{max-width:480px}button{background:var(--card);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:8px 14px;cursor:pointer;font-size:13px}button:hover{border-color:var(--accent)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:#1a0e08;font-weight:600}button.primary:hover{filter:brightness(1.08)}.row{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.gameview{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start}.boardcol{display:flex;flex-direction:column;gap:14px;min-width:0}.piece-info{display:flex;gap:16px;align-items:center}.pi-text{flex:1;min-width:0}.pi-name{margin:0 0 4px;font-size:18px}.pi-meta{color:var(--text);font-size:13px;margin-bottom:8px}.pi-desc{margin:0;line-height:1.55;font-size:14px;color:var(--text)}.pi-art{flex:0 0 auto}.portrait-svg{width:116px;height:auto;display:block;filter:drop-shadow(0 6px 12px rgba(0,0,0,.55))}.portrait-face{stroke:#0a0d12;stroke-width:2}.portrait-rank{fill:#fff;font-size:54px;font-weight:800;text-anchor:middle;dominant-baseline:middle;paint-order:stroke;stroke:#00000080;stroke-width:1.5px}.portrait-name{fill:#fffffff2;font-size:13px;font-weight:600;text-anchor:middle}.alien-rank{fill:#fff;font-size:14px;font-weight:800;text-anchor:middle;dominant-baseline:middle}.alien-pulse{animation:tile-pulse 2s ease-in-out infinite}@media (max-width: 560px){.piece-info{flex-direction:column-reverse;align-items:stretch}}.boardwrap{position:relative;padding:12px;border:9px solid #20303d;border-radius:16px;background:#0a1016;box-shadow:inset 0 0 0 2px #0a1016,inset 0 0 0 3px #ffffff0f,inset 0 2px #ffffff0d,0 22px 44px #0000008c}.board{width:100%;height:auto;display:block;border-radius:6px}.sidebar{display:flex;flex-direction:column;gap:12px}.card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 14px}.card h3{margin:0 0 8px;font-size:14px}.board-bg{fill:url(#tableGrad)}.hex{stroke:#0a0d12;stroke-width:1;cursor:pointer;transition:filter .08s}.hex:hover{filter:brightness(1.22)}.hex-side{stroke:none}.hex-side-shade{fill:#00000080;stroke:none}.hex-sheen{fill:url(#hexLight);pointer-events:none}.hl{fill:none;pointer-events:none}.hex-zone{stroke:var(--accent);stroke-width:2}.hex-move{stroke:var(--green);stroke-width:3}.hex-attack{stroke:var(--red);stroke-width:3}.hex-ability{stroke:var(--yellow);stroke-width:3}.hex-selected{stroke:var(--yellow);stroke-width:3.5}.terrain-layer,.effect-layer{pointer-events:none}.rift-swirl{transform-box:fill-box;transform-origin:center;animation:rift-spin 14s linear infinite}.lava-glow{animation:tile-pulse 2.2s ease-in-out infinite;transform-box:fill-box;transform-origin:center}.nexus-glow{animation:tile-pulse 3s ease-in-out infinite;transform-box:fill-box;transform-origin:center}.conduit-pulse{animation:tile-pulse 1.8s ease-in-out infinite}.flame{transform-box:fill-box;transform-origin:50% 100%;animation:flame-flicker .85s ease-in-out infinite alternate}.flame-group g.flame:nth-of-type(2){animation-duration:1.1s}.flame-group g.flame:nth-of-type(3){animation-duration:.7s}@keyframes rift-spin{to{transform:rotate(360deg)}}@keyframes tile-pulse{0%,to{opacity:.7}50%{opacity:1}}@keyframes flame-flicker{0%{transform:scaleY(.86) scaleX(1.06);opacity:.82}to{transform:scaleY(1.1) scaleX(.95);opacity:1}}@media (prefers-reduced-motion: reduce){.rift-swirl,.lava-glow,.nexus-glow,.conduit-pulse,.flame{animation:none}}.piece{transition:filter .1s}.piece:hover{filter:brightness(1.12)}.piece-shadow{fill:#00000080}.piece-foot{stroke:none}.piece-foot-shade{fill:#0000006b;stroke:none}.piece-face{stroke:#0a0d12;stroke-width:1.4}.piece-revealed .piece-face{stroke:#f3d3b6;stroke-width:2}.piece-sheen{fill:url(#pieceFace);stroke:none;pointer-events:none}.piece-rank{fill:#fff;font-size:20px;font-weight:800;text-anchor:middle;dominant-baseline:middle;pointer-events:none;paint-order:stroke;stroke:#00000080;stroke-width:.8px}.piece-name{fill:#ffffffed;font-size:7px;font-weight:600;text-anchor:middle;pointer-events:none}.piece-hint{fill:#d9c08f;font-size:6.8px;text-anchor:middle;pointer-events:none}.tray{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto;margin:8px 0}.chip{display:flex;align-items:center;gap:8px;text-align:left}.chip-selected{border-color:var(--accent);background:#2a1a10}.chip-rank{display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;background:var(--accent);color:#1a0e08;border-radius:50%;font-weight:700;font-size:12px}.chip-name{flex:1}.chip-count{color:var(--muted)}.mode-toggle{display:inline-flex;margin:6px 0 4px;border:1px solid var(--line);border-radius:8px;overflow:hidden}.mode-toggle button{border:none;border-radius:0;background:var(--card);color:var(--muted);padding:7px 18px;font-size:13px}.mode-toggle button.active{background:var(--accent);color:#1a0e08;font-weight:600}.faction-pick{display:flex;gap:16px;justify-content:center;margin:18px 0 22px;flex-wrap:wrap}.picker{display:flex;flex-direction:column;gap:6px;text-align:left;min-width:220px}.picker-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.picker select{background:var(--card);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:14px}.picker select:hover{border-color:var(--accent)}.picker-id{font-size:12px;min-height:30px}.selinfo .selname{font-weight:600;margin-bottom:2px}.banner{position:absolute;left:50%;bottom:14px;transform:translate(-50%);background:#000000c7;border:1px solid var(--accent);padding:6px 14px;border-radius:8px;font-size:13px}.error{color:var(--red);font-size:12px;margin-bottom:6px}.grave{display:flex;flex-wrap:wrap;gap:4px}.tombstone{font-size:11px;padding:2px 6px;border-radius:4px;background:#11161d;border:1px solid var(--line)}.tombstone.p1{border-left:3px solid var(--accent)}.tombstone.p2{border-left:3px solid #6c7ddb}.log{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px;font-size:12px}.log li{color:var(--muted)}.log-combat,.log-win{color:var(--text)}.log-debuff{color:var(--red)}.log-ability,.log-reveal{color:var(--yellow)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}.modal{background:var(--panel);border:1px solid var(--accent);border-radius:14px;padding:24px 28px;min-width:420px;max-width:560px;text-align:center}.modal h2{margin:0 0 16px}.rules-modal{text-align:left;min-width:0;width:100%;max-width:660px}.rules-body{max-height:64vh;overflow-y:auto;padding-right:8px}.rules-body h3{font-size:14px;margin:16px 0 6px;color:var(--accent)}.rules-body h3:first-child{margin-top:0}.rules-body p{margin:6px 0;line-height:1.5}.rules-body ul{margin:6px 0;padding-left:20px;line-height:1.55}.rules-body li{margin:3px 0}.rules-table{width:100%;border-collapse:collapse;margin:8px 0}.rules-table td{border:1px solid var(--line);padding:6px 10px;font-size:13px;vertical-align:top}.rules-table td:first-child{color:var(--text);font-weight:600;width:46%}.rules-table td:last-child{color:var(--muted)}.rules-modal .primary{margin-top:16px}.legend-move{color:var(--green);font-weight:700}.legend-attack{color:var(--red);font-weight:700}.reveal-row{display:flex;align-items:center;justify-content:center;gap:16px;margin:12px 0}.reveal-card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 18px;min-width:130px}.reveal-role{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}.reveal-name{font-weight:700;font-size:15px;margin:4px 0}.reveal-rank{color:var(--accent);font-weight:600}.vs{color:var(--muted);font-weight:700}.combat-msg{margin:12px 0}.follow{list-style:none;padding:0;margin:10px 0;font-size:12px;display:flex;flex-direction:column;gap:3px}@media (max-width: 900px){.gameview{grid-template-columns:1fr}}
