:root{--tile:46px;--bg:#0f172a;--panel:#1e293b;--ink:#e2e8f0;--muted:#94a3b8;--line:#334155;--board-bg:#0b1220;--surface:#0b1220;--surface-2:#1a2335;--t-plains:#3f6212;--t-forest:#14532d;--t-hill:#92785a;--t-water:#1e3a8a}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.app{flex-direction:column;gap:10px;height:100%;padding:12px 16px;display:flex;overflow:hidden}header{flex:none}header h1{margin:0 0 2px;font-size:1.3rem}.tagline{color:var(--muted);max-height:2.7em;margin:0;font-size:.82rem;line-height:1.35;overflow:hidden}.tagline code{color:var(--ink);background:var(--surface);border-radius:4px;padding:1px 5px}.layout{flex:1;align-items:stretch;gap:16px;min-height:0;display:flex}.board{position:relative}.iso-svg{display:block}.iso-cell{cursor:pointer}.iso-tile{transition:filter .1s}.iso-cell:hover .iso-tile{filter:brightness(1.12)}.iso-tile.terrain-plains{fill:var(--t-plains)}.iso-tile.terrain-forest{fill:var(--t-forest)}.iso-tile.terrain-hill{fill:var(--t-hill)}.iso-tile.terrain-water{fill:var(--t-water)}.iso-tile.fog{cursor:default}.terrain-plains{background:var(--t-plains)}.terrain-forest{background:var(--t-forest)}.terrain-hill{background:var(--t-hill)}.terrain-water{background:var(--t-water)}.iso-glyph{text-anchor:middle;dominant-baseline:central;pointer-events:none;opacity:.92;font-size:20px}.iso-dot{fill:#fde047;opacity:.85;pointer-events:none}.iso-shove-cue{dominant-baseline:central;pointer-events:none;paint-order:stroke;stroke:#0f172ad9;stroke-width:2.5px;opacity:.95;font-size:11px;font-weight:700}.iso-highlight{pointer-events:none}.plan-mark{pointer-events:none;opacity:.92}.units{pointer-events:none;position:absolute;inset:0}.unit{width:0;height:0;transition:transform .35s ease-out,opacity .2s;position:absolute;top:0;left:0}.unit.acted{opacity:.4}.unit.dying{pointer-events:none}.unit.dying .pawn{transform-origin:bottom;animation:.5s ease-in forwards unit-dissolve}@keyframes unit-dissolve{0%{opacity:1;transform:scale(1)translateY(0)rotate(0)}to{opacity:0;filter:grayscale(.8)brightness(.65);transform:scale(.55)translateY(7px)rotate(10deg)}}@media (prefers-reduced-motion:reduce){@keyframes unit-dissolve{0%{opacity:1}to{opacity:0}}.unit{transition:opacity .2s}}.pawn{color:#fff;border-radius:50%;place-items:center;width:26px;height:26px;font-size:.8rem;font-weight:700;display:grid;position:absolute;top:-17px;left:-13px;box-shadow:0 2px 4px #0000008c}.pawn.counter{border-radius:5px}.pawn-sprite{fill:currentColor;pointer-events:none;width:19px;height:19px}.pawn.figure{width:28px;height:28px;box-shadow:none;background:0 0;border-radius:0;top:-20px;left:-14px}.unit-figure{pointer-events:none;width:100%;height:100%;overflow:visible}.swatch{border-radius:4px;flex:none;width:14px;height:14px;display:inline-block}.muted{color:var(--muted)}.scores{margin:0 0 14px;padding:0;list-style:none}.scores li{border-bottom:1px solid var(--line);align-items:center;gap:8px;padding:6px 0;display:flex}.scores li.score-row{flex-direction:column;align-items:stretch;gap:5px}.score-head{align-items:center;gap:8px;display:flex}.score-name{font-weight:600}.scores .count{margin-left:auto;font-size:1.05rem}.stat-chips{flex-wrap:wrap;gap:5px 10px;padding-left:22px;display:flex}.stat-chip{color:var(--muted);font-variant-numeric:tabular-nums;align-items:center;gap:3px;font-size:.78rem;display:inline-flex}.stat-chip svg{display:block}.stat-chip.tone-pos{color:#86efac}.stat-chip.tone-neg{color:#fca5a5}.research{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.research button{text-align:left;background:#7c3aed;font-size:.82rem}.research button:disabled{background:#475569}.techtree{margin-bottom:14px}.techtree-scroll{padding-bottom:4px;overflow-x:auto}.tech-edge{stroke:var(--line);stroke-width:1.5px}.tech-edge.done{stroke:#22c55e}.tech-node rect{fill:var(--surface);stroke:var(--line);stroke-width:1.5px}.tech-node .tech-name{fill:var(--ink);font-size:11px;font-weight:700}.tech-node .tech-sub{fill:var(--muted);font-size:9px}.tech-researched rect{fill:color-mix(in srgb, #22c55e 16%, var(--panel));stroke:#22c55e}.tech-locked{opacity:.55}.tech-node.affordable{cursor:pointer}.tech-node.affordable rect{fill:color-mix(in srgb, #a855f7 18%, var(--panel));stroke:#a855f7}.tech-node.affordable .tech-sub{fill:#7c3aed}.tech-node.affordable:hover rect{fill:color-mix(in srgb, #a855f7 28%, var(--panel));stroke:#c084fc}.tech-available:not(.affordable) rect{stroke:#b45309}.tech-available:not(.affordable) .tech-sub{fill:#b45309}.stance-tag{text-transform:uppercase;letter-spacing:.03em;border:1px solid var(--line);white-space:nowrap;border-radius:999px;padding:1px 6px;font-size:.62rem}.stance-hostile{color:#fca5a5;border-color:#7f1d1d}.stance-neutral{color:#fcd34d;border-color:#78350f}.stance-allied{color:#86efac;border-color:#14532d}.scores .stance-tag{margin-left:4px}.diplomacy{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.diplomacy-title{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:.7rem}.diplo-row{align-items:center;gap:6px;font-size:.82rem;display:flex}.diplo-name{text-overflow:ellipsis;white-space:nowrap;flex:auto;overflow:hidden}.diplo-actions{gap:4px;display:inline-flex}.diplo-btn{background:#334155;padding:2px 7px;font-size:.85rem;line-height:1.2}.diplo-btn.diplo-hostile{background:#7f1d1d}.diplo-btn.diplo-neutral{background:#78350f}.diplo-btn.diplo-allied{background:#14532d}.diplo-hint{color:var(--muted);margin:2px 0 0;font-size:.72rem}.difficulty{color:var(--muted);justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px;font-size:.85rem;display:flex}.difficulty select{background:var(--surface);color:var(--ink);border:1px solid var(--line);font:inherit;cursor:pointer;border-radius:6px;padding:5px 8px}.display-opts{flex-wrap:wrap;gap:6px 16px;margin-bottom:14px;display:flex}.display-opts .opt{color:var(--muted);cursor:pointer;align-items:center;gap:6px;font-size:.82rem;display:inline-flex}.display-opts .opt input{cursor:pointer}.modal.overlay-modal{width:100%;max-width:min(560px,100vw - 32px);max-height:calc(100vh - 64px);overflow:auto}.overlay-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.overlay-head strong{font-size:1.05rem}.overlay-close{color:var(--muted);background:0 0;padding:4px 8px;font-size:1.1rem;line-height:1}.overlay-close:hover{color:var(--ink)}.batch-btn{background:var(--surface-2);color:var(--ink);border:1px solid var(--line);padding:5px 10px;font-size:.82rem}.batch-btn:disabled{color:var(--muted);opacity:.6}button{font:inherit;color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;padding:8px 12px}button:disabled{cursor:not-allowed;background:#475569}.settings-title{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin:14px 0 4px;font-size:.78rem}.settings label{justify-content:space-between;align-items:center;gap:8px;margin:10px 0;font-size:.85rem;display:flex}.settings input{background:var(--surface);width:90px;color:var(--ink);border:1px solid var(--line);border-radius:4px;padding:4px 6px}.title-row{align-items:center;gap:12px;display:flex}.title-row select{background:var(--panel);color:var(--ink);border:1px solid var(--line);font:inherit;cursor:pointer;border-radius:6px;padding:4px 8px}.board-col{flex-direction:column;flex:360px;gap:8px;min-width:300px;min-height:0;display:flex}.zoom-bar{align-items:center;gap:8px;display:flex}.zoom-bar button{background:var(--panel);border:1px solid var(--line);width:30px;height:30px;padding:0;font-size:1.1rem;line-height:1}.zoom-bar button:disabled{background:var(--surface-2);color:var(--muted)}.zoom-label{text-align:center;min-width:48px;color:var(--muted);font-size:.85rem}.next-unit{background:var(--surface-2);color:var(--ink);border:1px solid var(--line);margin-left:auto;padding:5px 10px;font-size:.82rem}.next-unit:disabled{color:var(--muted);opacity:.6}.board-frame{background:var(--board-bg);border:1px solid var(--line);border-radius:10px;flex-direction:column;flex:1;min-height:320px;display:flex;position:relative}.board-wrap{border-radius:10px;flex:1;width:100%;min-height:0;padding:clamp(32px,8vmin,96px);display:flex;overflow:auto}.board-scale{flex:none;margin:auto;position:relative}.board-overlay{border:1px solid var(--line);pointer-events:none;background:#020617d1;border-radius:999px;align-items:center;gap:8px;padding:5px 10px;display:flex;position:absolute;top:8px;right:8px}.spinner{border:3px solid #ffffff40;border-top-color:#fff;border-radius:50%;flex:none;width:16px;height:16px;animation:.8s linear infinite spin}.overlay-label{color:var(--ink);font-size:.8rem}.toasts{pointer-events:none;z-index:60;flex-direction:column;align-items:center;gap:6px;display:flex;position:absolute;top:10px;left:50%;transform:translate(-50%)}.toast{color:var(--ink);border:1px solid var(--line);white-space:nowrap;background:#020617e0;border-radius:999px;padding:6px 12px;font-size:.82rem;font-weight:600;animation:2.6s ease-out forwards toast-pop;box-shadow:0 4px 14px #00000073}.toast-research{border-color:#a78bfa}@keyframes toast-pop{0%{opacity:0;transform:translateY(-8px)scale(.96)}8%{opacity:1;transform:translateY(0)scale(1)}88%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-6px)scale(.98)}}@media (prefers-reduced-motion:reduce){@keyframes toast-pop{0%{opacity:0}8%{opacity:1}88%{opacity:1}to{opacity:0}}}.hud{color:var(--ink);border:1px solid var(--line);pointer-events:none;background:#020617d1;border-radius:999px;align-items:center;gap:8px;max-width:calc(100% - 16px);padding:4px 6px 4px 10px;font-size:.78rem;display:flex;position:absolute;top:8px;left:8px}.hud-cell{white-space:nowrap;align-items:center;gap:5px;display:inline-flex}.hud-cell+.hud-cell{border-left:1px solid var(--line);padding-left:8px}.hud-active{font-weight:600}.hud-you{font-variant-numeric:tabular-nums;background:var(--surface-2);border-radius:999px;padding:1px 9px}.hud-claims{color:#fde047;font-weight:700;animation:1.2s ease-in-out infinite pending-pulse}.hud-cell.hud-research{pointer-events:auto;cursor:pointer;font:inherit;color:#a78bfa;background:0 0;border:none;padding:0;font-weight:700}.hud-cell.hud-research:hover{color:#c4b5fd}.board-controls{z-index:60;pointer-events:none;flex-direction:column;align-items:flex-end;gap:8px;display:flex;position:absolute;bottom:10px;right:10px}.board-controls>*{pointer-events:auto}.bc-row{border:1px solid var(--line);background:#020617d1;border-radius:999px;align-items:center;gap:8px;padding:6px;display:flex;box-shadow:0 8px 24px #0006}.bc-batch{flex-wrap:wrap;justify-content:flex-end;gap:6px;max-width:320px;display:flex}.bc-icon{background:var(--surface-2);border:1px solid var(--line);border-radius:50%;width:42px;height:42px;padding:0;font-size:1.1rem;line-height:1;transition:background .12s,transform .12s;position:relative}.bc-icon:hover{background:var(--surface)}.bc-icon:active{transform:scale(.93)}.bc-badge{color:#fff;background:#16a34a;border-radius:999px;padding:2px 5px;font-size:.66rem;font-weight:700;line-height:1;position:absolute;top:-2px;right:-2px}.bc-end{border-radius:999px;height:44px;padding:0 22px;font-size:.98rem;font-weight:700;transition:filter .12s,transform .12s;box-shadow:0 2px 10px #2563eb66}.bc-end:hover:not(:disabled){filter:brightness(1.08)}.bc-end:active:not(:disabled){transform:scale(.97)}.bc-end.confirm{background:#b45309;box-shadow:0 2px 10px #b4530973}.bc-clear{background:var(--surface-2);border:1px solid var(--line);border-radius:999px;height:42px;padding:0 14px}.board-hint{z-index:40;text-align:center;max-width:min(440px,100% - 220px);color:var(--ink);border:1px solid var(--line);pointer-events:none;background:#020617c7;border-radius:999px;padding:6px 12px;font-size:.85rem;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.board-banner{z-index:90;text-align:center;border:1px solid var(--line);background:#020617e6;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:20px 28px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 16px 48px #0009}.board-banner strong{font-size:1.4rem}.board-banner .sub{color:var(--muted);font-size:.9rem}@keyframes spin{to{transform:rotate(360deg)}}.pawn.lunge{animation:.3s lunge}@keyframes lunge{0%,to{transform:translate(0)}45%{transform:translate(var(--lx,0), var(--ly,0))}}.pawn.hit{animation:.3s shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-3px)}40%{transform:translate(3px)}60%{transform:translate(-2px)}80%{transform:translate(2px)}}.iso-flash{fill:#ef4444;pointer-events:none;animation:.45s iso-flash}@keyframes iso-flash{0%{opacity:.65}to{opacity:0}}.sheet{background:var(--surface);border:1px solid var(--line);border-radius:10px;width:100%;min-height:0;margin:0;padding:12px 14px 14px;position:relative;overflow:hidden}.sheet-wrap{z-index:70;width:min(340px,100% - 24px);animation:.2s sheet-slide-up;position:absolute;bottom:12px;left:12px}.sheet-wrap .sheet{max-height:min(60vh,460px);overflow-y:auto;box-shadow:0 14px 36px #00000080}.sheet-wrap.closing{animation:.18s forwards sheet-fade}@keyframes sheet-fade{0%{opacity:1}to{opacity:0}}@media (prefers-reduced-motion:reduce){.sheet-wrap,.sheet-wrap.closing{animation:none}}@keyframes sheet-up{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}.sheet-close{width:30px;height:30px;color:var(--muted);background:0 0;border-radius:8px;padding:0;font-size:1.2rem;line-height:1;position:absolute;top:10px;right:12px}.sheet-close:hover{background:var(--surface);color:var(--ink)}.sheet-head{align-items:center;gap:14px;margin-bottom:10px;display:flex}.sheet-icon{border-radius:8px;flex:none;place-items:center;width:56px;height:56px;display:grid;position:relative}.sheet-pawn{color:#fff;border-radius:50%;place-items:center;width:64%;height:64%;font-size:1rem;font-weight:700;display:grid;box-shadow:0 1px 3px #00000080}.sheet-glyph{font-size:1.9rem;line-height:1}.sheet-sprite{fill:currentColor;width:72%;height:72%}.sheet-glyph-svg{fill:currentColor;width:70%;height:70%}.sheet-claim{border-radius:6px;width:40%;height:40%}.sheet-hpbar{background:#0000008c;border-radius:3px;height:5px;position:absolute;bottom:5px;left:14%;right:14%}.sheet-hpfill{background:#22c55e;border-radius:3px;height:100%;transition:width .3s;display:block}.sheet-titles{flex-direction:column;gap:2px;display:flex}.sheet-titles strong{font-size:1.1rem}.sheet-titles .muted{font-size:.85rem}.sheet-desc{color:var(--ink);margin:0 0 12px;font-size:.9rem;line-height:1.45}.sheet-stats{flex-wrap:wrap;gap:8px;margin:0 0 14px;padding:0;list-style:none;display:flex}.sheet-stats li{background:var(--surface);border:1px solid var(--line);border-radius:8px;flex-direction:column;gap:1px;min-width:58px;padding:6px 10px;display:flex}.sheet-stats .muted{text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.sheet-actions{flex-wrap:wrap;gap:8px;display:flex}.sheet-actions button{background:#16a34a;flex:auto}.sheet-actions button:disabled{background:#475569}.modal-backdrop{z-index:100;background:#02061799;place-items:center;display:grid;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--line);border-radius:10px;max-width:320px;margin:16px;padding:20px}.modal strong{margin-bottom:6px;display:block}.modal p{color:var(--muted);margin:0 0 16px;font-size:.9rem}.modal-actions{justify-content:flex-end;gap:8px;display:flex}.modal-actions button{background:#475569}.modal-actions button.danger{background:#dc2626}.veteran-badge{color:#fde047;text-shadow:0 1px 2px #000c;pointer-events:none;font-size:11px;position:absolute;top:-20px;left:8px}.pending-badge{color:#fde047;text-shadow:0 0 5px #000000d9;pointer-events:none;font-size:13px;animation:1.2s ease-in-out infinite pending-pulse;position:absolute;top:-22px;left:50%;transform:translate(-50%)}.pending-badge-svg{fill:#fde047;text-anchor:middle;dominant-baseline:central;pointer-events:none;paint-order:stroke;stroke:#000000b3;stroke-width:2px;font-size:14px;font-weight:700;animation:1.2s ease-in-out infinite pending-pulse}@keyframes pending-pulse{0%,to{opacity:.5}50%{opacity:1}}@media (prefers-reduced-motion:reduce){@keyframes pending-pulse{0%,50%,to{opacity:1}}}.pawn.fortified{box-shadow:0 2px 4px #0000008c,0 0 0 2px #e2e8f0d9}.overwatch-badge{color:#f87171;text-shadow:0 1px 2px #000c;pointer-events:none;font-size:12px;position:absolute;top:-20px;right:8px}.poison-badge{color:#86efac;text-shadow:0 1px 2px #000000d9;pointer-events:none;font-size:11px;position:absolute;top:-8px;right:8px}.floats{pointer-events:none;z-index:50;position:absolute;inset:0}.float-anchor{position:absolute;top:0;left:0}.float{text-align:center;text-shadow:0 1px 3px #000000e6,0 0 2px #000000e6;width:28px;margin-top:-34px;margin-left:-14px;font-size:14px;font-weight:800;animation:1.1s ease-out forwards float-rise;position:absolute;top:0;left:0}.float-damage{color:#fca5a5}.float-heal{color:#86efac}.float-death{color:#e2e8f0}.float-gold{color:#fde047;width:56px;margin-left:-28px}.float-flourish{color:#fde047;width:80px;margin-left:-40px;font-size:13px}@keyframes float-rise{0%{opacity:0;transform:translateY(0)scale(.8)}15%{opacity:1}to{opacity:0;transform:translateY(-26px)scale(1.05)}}@media (prefers-reduced-motion:reduce){@keyframes float-rise{0%{opacity:0}15%{opacity:1}to{opacity:0}}}.shield-badge{text-shadow:0 1px 2px #000000d9;pointer-events:none;font-size:10px;position:absolute;top:-8px;left:8px}.hpbar{background:#0000008c;border-radius:2px;width:26px;height:4px;position:absolute;top:10px;left:-13px}.hpfill{background:#22c55e;border-radius:2px;height:100%;transition:width .3s;display:block}@media (width<=760px){html,body{overflow-x:hidden}.app{height:auto;min-height:100%;padding:8px 10px;overflow:visible}.layout{flex-direction:column;flex:none;gap:12px;max-width:100%;display:flex}.board-col{width:100%;min-width:0}.board-frame{height:56vh;min-height:280px}.board-wrap{min-width:0}.board-controls{top:8px;bottom:auto;right:8px}.board-hint{max-width:calc(100% - 24px)}.tagline{display:none}.title-row{flex-wrap:wrap;gap:8px}.title-row select{flex:140px;min-width:0}button,select,.settings input{min-height:42px}.zoom-bar button{min-width:42px}.diplo-btn{min-width:36px;min-height:36px}.diplo-row{flex-wrap:wrap}.techtree-scroll{max-width:100%}.sheet-wrap{z-index:80;margin:0;animation:.2s sheet-slide-up;display:block;position:fixed;bottom:8px;left:8px;right:8px}.sheet-wrap.closing{animation:none}.sheet{max-height:62vh;overflow-y:auto;box-shadow:0 10px 34px #0000008c}}@keyframes sheet-slide-up{0%{opacity:0;transform:translateY(110%)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){@keyframes sheet-slide-up{0%{opacity:0}to{opacity:1}}}.build-stamp{z-index:5;color:var(--muted);font-variant-numeric:tabular-nums;letter-spacing:.02em;opacity:.45;cursor:pointer;background:0 0;border:none;border-radius:5px;padding:2px 5px;font-size:10px;position:fixed;bottom:4px;left:6px}.build-stamp:hover{opacity:.95;background:var(--surface-2)}
