: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:minmax(0,760px) 300px;gap:16px;align-items:start;justify-content:center}.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;overflow:hidden;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}.board-stage-host{position:relative}.board-stage{transform-origin:center center;touch-action:none;cursor:grab;will-change:transform}.board-stage:active{cursor:grabbing}.board-controls{position:absolute;right:6px;bottom:6px;display:flex;gap:4px;z-index:5;background:#080c12b8;border:1px solid var(--line);border-radius:8px;padding:4px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.board-controls button{min-width:26px;height:26px;padding:0 6px;font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.board-controls button.reset{font-size:11px}.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}.hex-lastmove{stroke:#ffd24a;stroke-width:4;fill:#ffd24a24;animation:lastmove-pulse 1.3s ease-in-out infinite}@keyframes lastmove-pulse{0%,to{opacity:.55}50%{opacity:1}}.move-arrow{animation:move-arrow-in .35s ease-out both}.move-arrow-line{stroke:#ffd24a;stroke-width:4.5;stroke-linecap:round}.move-arrow-head{fill:#ffd24a;stroke:#0006;stroke-width:.6}@keyframes move-arrow-in{0%{opacity:0}to{opacity:1}}.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}.flat-tok-face{stroke:#0a0d12;stroke-width:2}.flat-tok.piece-revealed .flat-tok-face{stroke:#f3d3b6;stroke-width:2.5}.flat-tok-sheen{fill:url(#tokenSheen);stroke:none;pointer-events:none}.flat-tok-label{fill:#fff;font-size:24px;font-weight:800;text-anchor:middle;dominant-baseline:middle;pointer-events:none;paint-order:stroke;stroke:#00000080;stroke-width:1px}.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)}.hero{position:relative;margin:-12px -16px 0;min-height:calc(100vh - 24px);padding:48px 20px 64px;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 22%,#16203a,#0a0d16 58%,#05060a)}.hero-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 40%,transparent 45%,rgba(0,0,0,.55) 100%)}.hero-stars{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1.5px 1.5px at 25% 15%,rgba(255,255,255,.9),transparent),radial-gradient(1.5px 1.5px at 75% 35%,rgba(255,255,255,.7),transparent),radial-gradient(1px 1px at 50% 60%,rgba(255,255,255,.85),transparent),radial-gradient(1px 1px at 15% 80%,rgba(255,255,255,.6),transparent),radial-gradient(1.5px 1.5px at 90% 75%,rgba(255,255,255,.7),transparent),radial-gradient(1px 1px at 35% 45%,rgba(255,255,255,.5),transparent),radial-gradient(1px 1px at 60% 10%,rgba(255,255,255,.6),transparent),radial-gradient(1px 1px at 5% 50%,rgba(255,255,255,.5),transparent);background-repeat:repeat;background-size:320px 320px;animation:stars-pan 90s linear infinite;opacity:.7}.hero-stars2{background-size:540px 540px;opacity:.45;animation-duration:150s}@keyframes stars-pan{0%{background-position:0 0}to{background-position:320px 640px}}.nebula{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;pointer-events:none}.nebula-a{width:460px;height:460px;left:-90px;top:-70px;background:radial-gradient(circle,#cf6a3d,transparent 70%);animation:float-a 20s ease-in-out infinite}.nebula-b{width:520px;height:520px;right:-120px;top:30px;background:radial-gradient(circle,#7a6fe0,transparent 70%);animation:float-b 26s ease-in-out infinite}.nebula-c{width:420px;height:420px;left:38%;bottom:-160px;background:radial-gradient(circle,#1d9b81,transparent 70%);animation:float-c 32s ease-in-out infinite}@keyframes float-a{0%,to{transform:translate(0)}50%{transform:translate(30px,24px)}}@keyframes float-b{0%,to{transform:translate(0)}50%{transform:translate(-36px,30px)}}@keyframes float-c{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,-28px)}}.hero-content{position:relative;z-index:1;width:100%;max-width:860px;display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}.hero-head{display:flex;flex-direction:column;align-items:center;gap:6px}.hero-eyebrow{text-transform:uppercase;letter-spacing:4px;font-size:12px;font-weight:600;color:var(--accent);opacity:.9}.hero-title{margin:2px 0 0;font-size:clamp(42px,8.5vw,88px);font-weight:800;line-height:1.02;letter-spacing:1px;text-transform:uppercase;background:linear-gradient(180deg,#ffffff 0%,#ffdcc6 42%,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 48px rgba(207,106,61,.35)}.hero-subtitle{font-size:clamp(15px,3vw,24px);font-weight:600;letter-spacing:clamp(6px,1.6vw,12px);text-transform:uppercase;color:#d8def0;padding-left:clamp(6px,1.6vw,12px)}.hero-tag{max-width:620px;margin:12px 0 0;color:var(--muted);font-size:15px;line-height:1.6}.hero-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:16px}.hero-chip{font-size:12.5px;color:#c7cedd;padding:6px 14px;border-radius:999px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.mode-seg{display:inline-flex;gap:4px;padding:4px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mode-seg button{border:none;background:transparent;color:var(--muted);padding:9px 24px;border-radius:999px;font-size:13.5px;font-weight:600;transition:color .15s}.mode-seg button:hover{color:var(--text)}.mode-seg button.active{background:var(--accent);color:#1a0e08;box-shadow:0 4px 16px #cf6a3d73}.vs-arena{display:flex;align-items:stretch;justify-content:center;gap:18px;flex-wrap:wrap}.fcard{position:relative;width:264px;padding:16px 18px 18px;border-radius:16px;background:linear-gradient(180deg,#ffffff0d,#00000040);border:1px solid var(--line);border-top:2px solid var(--fc);box-shadow:0 12px 34px #00000073;transition:transform .16s ease,box-shadow .16s ease}.fcard:hover{transform:translateY(-4px);box-shadow:0 18px 44px #0000008c,0 0 0 1px var(--fc)}.fcard:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;pointer-events:none;background:radial-gradient(circle at 50% 0%,color-mix(in srgb,var(--fc) 32%,transparent),transparent 62%)}.fcard>*{position:relative}.fcard-side{text-transform:uppercase;letter-spacing:1.5px;font-size:11px;font-weight:700;color:var(--fc)}.fcard-portrait{width:124px;margin:10px auto 8px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.6))}.fcard-portrait .portrait-svg{width:124px;height:auto;display:block}.fcard-name{font-size:18px;font-weight:700}.fcard-id{margin:6px 0 12px;font-size:12px;line-height:1.45;color:var(--muted);min-height:52px}.fcard-select select{width:100%;background:#00000059;color:var(--text);border:1px solid var(--line);border-radius:9px;padding:9px 10px;font-size:13.5px;cursor:pointer}.fcard-select select:hover{border-color:var(--fc)}.vs-badge{align-self:center}.vs-badge span{display:grid;place-items:center;width:50px;height:50px;border-radius:50%;font-weight:800;font-size:15px;letter-spacing:1px;color:var(--accent);background:var(--bg);border:1px solid var(--line);box-shadow:0 0 0 5px #0000004d,0 0 26px #cf6a3d59}.hero-cta{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:4px}.launch{font-size:16px;padding:15px 42px;border-radius:999px;letter-spacing:.5px;box-shadow:0 10px 26px #cf6a3d80;animation:launch-pulse 2.8s ease-in-out infinite}.launch:hover{transform:translateY(-1px)}@keyframes launch-pulse{0%,to{box-shadow:0 10px 26px #cf6a3d66}50%{box-shadow:0 10px 38px #cf6a3dbf}}@media (max-width: 560px){.vs-badge{order:-1}.fcard{width:100%;max-width:320px}}@media (prefers-reduced-motion: reduce){.hero-stars,.nebula,.launch{animation:none!important}}.go-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:28px;overflow:hidden;animation:go-fade .45s ease both}@keyframes go-fade{0%{opacity:0}to{opacity:1}}.go-overlay.win{background:radial-gradient(ellipse at 50% 38%,#302406e6,#050509f5)}.go-overlay.lose{background:radial-gradient(ellipse at 50% 40%,#300806eb,#040202f7);animation:go-fade .45s ease both,go-redpulse 3.2s ease-in-out .45s infinite}@keyframes go-redpulse{0%,to{background:radial-gradient(ellipse at 50% 40%,#300806eb,#040202f7)}50%{background:radial-gradient(ellipse at 50% 40%,#460c09f0,#060202fa)}}.go-rays{position:absolute;top:38%;left:50%;width:1100px;height:1100px;transform:translate(-50%,-50%);pointer-events:none;background:repeating-conic-gradient(from 0deg,rgba(255,211,74,.12) 0deg 5deg,transparent 5deg 17deg);-webkit-mask-image:radial-gradient(circle,#000 6%,transparent 62%);mask-image:radial-gradient(circle,#000 6%,transparent 62%);animation:go-spin 26s linear infinite}@keyframes go-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.confetti i{position:absolute;top:-8%;border-radius:1px;opacity:.9;animation-name:confetti-fall;animation-timing-function:linear;animation-iteration-count:infinite}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0)}to{transform:translateY(115vh) rotate(720deg)}}.go-card{position:relative;z-index:1;text-align:center;max-width:560px;display:flex;flex-direction:column;align-items:center;gap:14px}.go-eyebrow{text-transform:uppercase;letter-spacing:4px;font-size:13px;font-weight:700}.win .go-eyebrow{color:#e6b23e}.lose .go-eyebrow{color:#e23b2f}.go-title{margin:0;font-size:clamp(58px,15vw,138px);font-weight:900;letter-spacing:4px;line-height:.95;text-transform:uppercase}.win .go-title{background:linear-gradient(180deg,#fff,#ffe79a 42%,#e0a93a);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 60px rgba(224,169,58,.55);animation:go-pop .6s cubic-bezier(.2,1.4,.4,1) both}.lose .go-title{color:#e23b2f;text-shadow:0 0 50px rgba(226,59,47,.55),0 4px 0 #5a0d08;animation:go-shake .65s ease both}@keyframes go-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}@keyframes go-shake{0%{transform:translate(0) scale(.9);opacity:0}20%{opacity:1}30%{transform:translate(-12px)}45%{transform:translate(9px)}60%{transform:translate(-6px)}75%{transform:translate(4px)}to{transform:translate(0) scale(1)}}.go-portrait{width:188px}.go-portrait .portrait-svg{width:188px;height:auto;display:block}.win .go-portrait{filter:drop-shadow(0 0 28px rgba(224,169,58,.5));animation:go-bob 3s ease-in-out infinite}.lose .go-portrait{transform:scale(1.12);filter:drop-shadow(0 0 30px rgba(226,59,47,.5)) grayscale(.25);animation:go-loom 4.5s ease-in-out infinite}@keyframes go-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes go-loom{0%,to{transform:scale(1.12)}50%{transform:scale(1.17)}}.go-sub{margin:4px 0 0;font-size:clamp(15px,3.5vw,20px);line-height:1.5;max-width:480px}.win .go-sub{color:#e9e0c4}.lose .go-sub{color:#f0b9b3}.go-actions{margin-top:12px}@media (prefers-reduced-motion: reduce){.go-rays,.confetti i,.go-portrait,.go-overlay.lose{animation:none!important}}.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:flex-start;justify-content:center;gap:14px;margin:10px 0;flex-wrap:wrap}.reveal-card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:10px 14px 12px;min-width:116px;max-width:230px;text-align:center}.reveal-role{color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px}.reveal-portrait{margin:6px auto 4px}.reveal-portrait .portrait-svg{width:72px;height:auto;display:block;margin:0 auto;filter:drop-shadow(0 4px 9px rgba(0,0,0,.55))}.reveal-name{font-weight:700;font-size:14px;margin:3px 0 1px}.reveal-rank{color:var(--accent);font-weight:600;font-size:13px}.reveal-ability{margin-top:5px;font-size:12px;font-weight:600;color:var(--text)}.reveal-desc{margin:4px 0 0;font-size:11.5px;line-height:1.4;color:var(--muted);text-align:left}.vs{color:var(--muted);font-weight:700;align-self:center}.combat-msg{margin:12px 0}.combat-panel{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 8px 28px #0006}.combat-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.combat-panel-head h3{margin:0}.combat-panel-title{display:flex;flex-direction:column;gap:2px}.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}}
