﻿@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Rajdhani:wght@400;600;700&display=swap');
:root {
  --bg:#0d0f14; --panel:#13161e; --border:#2a2f3d;
  --blue:#3a7bd5; --blue-light:#6fa3e8; --blue-dim:#1a3a6a;
  --red:#d53a3a;  --red-light:#e87070;  --red-dim:#6a1a1a;
  --gold:#c8a84b; --green:#3aad5e; --text:#c8cdd8; --text-dim:#6b7284;
  /* Team faction colors — overridden at runtime by applyFactionColors() */
  /* Defaults match Steel Covenant (A) vs Y'thrak Swarm (B) */
  --a-primary:#4a8fd4; --a-light:#7ab8e8; --a-dim:#1a3a6a; --a-leader:#a0d4ff;
  --b-primary:#9b3fbf; --b-light:#c27de0; --b-dim:#3a1248; --b-leader:#e0b8ff;
  --tile:22px; --grid-w:48; --grid-h:48;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:'Rajdhani',sans-serif;font-size:14px;height:100vh;display:flex;flex-direction:column;overflow:hidden}

/* ── GLOBAL SCROLLBARS ── */
*{
  scrollbar-width:thin;
  scrollbar-color:rgba(110,118,132,.55) rgba(255,255,255,.04);
}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
  border-left:1px solid rgba(255,255,255,.03);
}
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,rgba(104,112,124,.62),rgba(76,83,94,.78));
  border:2px solid rgba(13,15,20,.9);
  border-radius:999px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}
::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,rgba(124,132,146,.78),rgba(90,98,110,.9));
}
::-webkit-scrollbar-corner{background:rgba(255,255,255,.03)}

/* ── HEADER ── */
#header{background:var(--panel);border-bottom:1px solid var(--border);padding:6px 14px;display:flex;align-items:center;gap:12px;flex-shrink:0;z-index:10}
#header h1{font-family:'Share Tech Mono',monospace;font-size:15px;letter-spacing:3px;color:var(--gold);text-transform:uppercase}
#round-info{font-family:'Share Tech Mono',monospace;font-size:12px;color:var(--text-dim);letter-spacing:1px}
#phase-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:2px;letter-spacing:2px;text-transform:uppercase;background:var(--a-dim);color:var(--a-light);border:1px solid var(--a-primary)}
#phase-badge.red{background:var(--b-dim);color:var(--b-light);border-color:var(--b-primary)}
#phase-badge.ai{background:#2a1a3a;color:#b07ae8;border-color:#7a4ab8}
#ap-pips{display:flex;gap:4px;align-items:center;margin-left:4px}
.ap-pip{width:12px;height:12px;border-radius:50%;border:1px solid var(--gold);transition:background .15s}
.ap-pip.on{background:var(--gold)}
.ap-pip.off{background:#222}
#speed-control{display:flex;align-items:center;gap:6px;margin-left:auto;font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:1px}
#speed-control input[type=range]{width:70px;accent-color:var(--gold);cursor:pointer}
#pause-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:1px;padding:3px 10px;cursor:pointer;border-radius:2px;transition:all .15s}
#pause-btn:hover{border-color:rgba(60,200,60,.6);color:rgba(60,220,60,.9)}

/* ── LAYOUT ── */
#main{display:flex;flex:1;overflow:hidden}

/* ── LEFT PANEL ── */
#left-panel{width:210px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
.panel-section{padding:10px;border-bottom:1px solid var(--border)}
.panel-title{font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--text-dim);text-transform:uppercase;margin-bottom:6px}

/* unit cards in left panel */
/* ── UNIT CARD (shared between left panel and hover tooltip) ── */
.unit-card{padding:7px 9px;border-radius:3px;border:1px solid transparent;cursor:pointer;margin-bottom:4px;transition:all .15s;position:relative}
.unit-card:hover{border-color:var(--border);background:rgba(255,255,255,.03)}
/* Faction-colored base border — always visible; later rules (selected/placed/shaken) override via cascade */
.unit-card.blue{border-color:color-mix(in srgb, var(--a-primary) 20%, transparent)}
.unit-card.red{border-color:color-mix(in srgb, var(--b-primary) 20%, transparent)}
.unit-card.selected{border-color:var(--gold);background:rgba(200,168,75,.08)}
.unit-card.activated{opacity:.5}
.unit-card.shaken{border-color:#c8a84b!important}
.unit-card.placed{border-color:rgba(58,173,94,.3)}
/* Deployable — brighter faction border during deploy phase (higher specificity wins) */
.unit-card.blue.deployable{border-color:color-mix(in srgb, var(--a-primary) 45%, transparent)}
.unit-card.red.deployable{border-color:color-mix(in srgb, var(--b-primary) 45%, transparent)}
.uc-header{display:flex;align-items:center;gap:5px;margin-bottom:3px}
.uc-name{font-weight:700;font-size:11px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.uc-tags{display:flex;gap:3px;flex-wrap:wrap;margin-left:auto;flex-shrink:0}
.uc-tag{font-size:8px;font-family:'Share Tech Mono',monospace;letter-spacing:.5px;padding:1px 4px;border-radius:2px}
.uc-tag.status{color:var(--gold);border:1px solid rgba(200,168,75,.3)}
.uc-tag.ok{color:var(--green);border:1px solid rgba(58,173,94,.3)}
.uc-tag.bad{color:var(--red-light);border:1px solid rgba(213,58,58,.3)}
.uc-stats{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);margin-bottom:3px}
.uc-weapons{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);line-height:1.7;margin-bottom:3px}
.uc-weapon-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.uc-weapon-name{color:var(--text);font-size:9px}
.uc-wtag{font-size:7px;padding:0px 3px;border-radius:2px;font-weight:700}
.uc-wtag.ap{background:rgba(213,58,58,.15);border:1px solid rgba(213,58,58,.35);color:var(--red-light)}
.uc-keywords{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:3px}
.uc-keyword{font-size:7px;padding:1px 4px;border-radius:2px;background:rgba(200,168,75,.1);border:1px solid rgba(200,168,75,.25);color:var(--gold);font-family:'Share Tech Mono',monospace;cursor:default}
.uc-keyword.uc-keyword--buff{background:rgba(180,80,220,.12);border-color:rgba(180,80,220,.35);color:#d080ff}
.uc-keyword.uc-keyword--ability{background:rgba(120,80,220,.12);border-color:rgba(120,80,220,.35);color:#a080ff}
/* Floating keyword tooltip */
#kw-tooltip{position:fixed;z-index:9999;background:#12121f;border:1px solid rgba(200,168,75,.35);color:var(--text);font-size:9px;line-height:1.6;padding:6px 9px;border-radius:3px;max-width:220px;pointer-events:none;display:none;font-family:'Share Tech Mono',monospace;box-shadow:0 4px 16px rgba(0,0,0,.6)}
.uc-pips{display:flex;gap:2px;flex-wrap:wrap;margin-top:2px}
.model-pip{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}
.model-pip.dead{background:#333}

/* selected unit panel — matches tooltip card style */
#selected-unit-section{background:rgba(255,255,255,.02)}
#selected-unit-card{font-family:'Share Tech Mono',monospace}
#unit-tooltip{position:fixed;z-index:200;pointer-events:none;display:none;width:210px;background:var(--panel);border:1px solid var(--border);border-radius:4px;box-shadow:0 4px 20px rgba(0,0,0,.6);padding:0}
#unit-tooltip .unit-card{margin:0;border:none;border-radius:4px;cursor:default}
#unit-tooltip .unit-card:hover{background:transparent}

/* ── GRID ── */
#grid-viewport{flex:1;overflow:auto;position:relative;background:#090b10;display:flex;justify-content:center;align-items:flex-start}
#grid-container{position:relative;flex-shrink:0;width:calc(var(--grid-w)*var(--tile));height:calc(var(--grid-h)*var(--tile));background-image:linear-gradient(to right,#1a1f2e 1px,transparent 1px),linear-gradient(to bottom,#1a1f2e 1px,transparent 1px);background-size:var(--tile) var(--tile);overflow:visible}

/* deploy zones */
#dz-blue{position:absolute;background:color-mix(in srgb, var(--a-primary) 5%, transparent);border-bottom:1px dashed color-mix(in srgb, var(--a-primary) 25%, transparent);pointer-events:none;transition:all .3s;z-index:2}
#dz-blue.active{background:color-mix(in srgb, var(--a-primary) 12%, transparent);border-bottom:2px dashed color-mix(in srgb, var(--a-primary) 60%, transparent)}
#dz-blue.active::after{content:attr(data-label);position:absolute;bottom:4px;left:50%;transform:translateX(-50%);font-family:'Share Tech Mono',monospace;font-size:10px;color:color-mix(in srgb, var(--a-light) 50%, transparent);letter-spacing:2px;pointer-events:none;white-space:nowrap}
#dz-red{position:absolute;background:color-mix(in srgb, var(--b-primary) 5%, transparent);border-top:1px dashed color-mix(in srgb, var(--b-primary) 25%, transparent);pointer-events:none;transition:all .3s;z-index:2}
#dz-red.active{background:color-mix(in srgb, var(--b-primary) 12%, transparent);border-top:2px dashed color-mix(in srgb, var(--b-primary) 60%, transparent)}
#dz-red.active::after{content:attr(data-label);position:absolute;top:4px;left:50%;transform:translateX(-50%);font-family:'Share Tech Mono',monospace;font-size:10px;color:color-mix(in srgb, var(--b-light) 50%, transparent);letter-spacing:2px;pointer-events:none;white-space:nowrap}

/* ── GLOSSARY SCREEN ── */
#glossary-screen{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:210;flex-direction:column;align-items:center;overflow:hidden;padding:30px 20px}
#glossary-screen.show{display:flex}
#glossary-screen .glossary-shell{width:100%;max-width:1280px;height:100%;display:flex;flex-direction:column;min-height:0}
#glossary-screen h2{font-family:'Share Tech Mono',monospace;font-size:16px;letter-spacing:4px;color:var(--gold);margin-bottom:4px}
#glossary-screen .sub{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:2px;margin-bottom:0}
.glossary-topbar{margin-bottom:18px}
.glossary-cols{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;width:100%;align-items:stretch;min-height:0;flex:1}
.glossary-col{display:flex;flex-direction:column;min-height:0;padding:14px;border:1px solid var(--border);border-radius:6px;background:rgba(255,255,255,.02);overflow:auto}
.glossary-col h3{font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:3px;color:var(--gold);border-bottom:1px solid var(--border);padding-bottom:6px;margin-bottom:12px}
.glossary-entry{background:var(--panel);border:1px solid var(--border);border-radius:3px;padding:10px 12px;margin-bottom:8px}
.glossary-kw{font-family:'Share Tech Mono',monospace;font-size:12px;font-weight:700;color:var(--text);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.glossary-kw .kw-badge{font-size:8px;padding:1px 5px;border-radius:2px;background:rgba(200,168,75,.12);border:1px solid rgba(200,168,75,.3);color:var(--gold)}
.glossary-kw .kw-badge.weapon{background:rgba(213,58,58,.12);border-color:rgba(213,58,58,.35);color:var(--red-light)}
.glossary-kw .kw-badge.ability{background:rgba(120,80,220,.12);border-color:rgba(120,80,220,.35);color:#a080ff}
.glossary-kw .kw-badge.faction{background:rgba(100,180,255,.12);border-color:rgba(100,180,255,.35);color:#7ec8ff}
.glossary-desc{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);line-height:1.7}
/* ── UNIFIED BATTLE DRAFT ── */
#draft-screen{display:none;position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:185;flex-direction:column;overflow-y:auto}
#draft-screen.show{display:flex}
#draft-header{padding:20px 32px 12px;text-align:center;flex-shrink:0}
#draft-header h2{font-family:'Share Tech Mono',monospace;font-size:18px;letter-spacing:4px;color:var(--gold);margin-bottom:8px}
#draft-turn-banner{font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--text-dim)}
#draft-body{flex:1;padding:0 32px;display:flex;flex-direction:column;gap:20px;min-height:0;align-items:center;}
.draft-row{display:flex;align-items:flex-start;gap:16px;justify-content:center;max-width:900px;width:100%;}
.draft-row-label{width:88px;flex-shrink:0;padding-top:10px}
.draft-row-title{font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--gold);font-weight:700}
.draft-row-sub{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);margin-top:3px}
.draft-row-cards{display:flex;gap:10px;flex-wrap:wrap}
/* draft cards — compact version of deploy-card */
.draft-card{width:140px;background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:10px 12px;cursor:pointer;transition:all .2s;text-align:center;position:relative;flex-shrink:0}
.draft-card:hover:not(.vetoed):not(.locked){border-color:var(--gold);background:rgba(200,168,75,.06)}
.draft-card.highlighted{border-color:var(--red)!important;background:rgba(213,58,58,.08)!important}
.draft-card.leftmost{border-color:var(--green)!important;background:rgba(58,173,94,.06)!important}
.draft-card.vetoed{opacity:.3;pointer-events:none}
.draft-card.vetoed::after{content:'VETOED';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Share Tech Mono',monospace;font-size:11px;color:var(--red-light);letter-spacing:2px;pointer-events:none}
.draft-card.locked{cursor:default}
.draft-card.eligible{cursor:pointer;border-color:var(--gold)!important;background:rgba(200,168,75,.1)!important;box-shadow:0 0 12px rgba(200,168,75,.3)}
.draft-card-icon{font-size:20px;margin-bottom:6px}
.draft-card-name{font-size:11px;font-weight:700;color:var(--text);margin-bottom:4px;letter-spacing:.5px;line-height:1.3}
.draft-card-desc{font-family:'Share Tech Mono',monospace;font-size:8px;color:var(--text-dim);line-height:1.5}
.draft-card-tag{font-family:'Share Tech Mono',monospace;font-size:8px;color:var(--gold);margin-top:4px}
#draft-footer{padding:14px 32px 20px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:10px}
#draft-status{font-family:'Share Tech Mono',monospace;font-size:11px;color:var(--text-dim);text-align:center;min-height:18px}
/* keep old .deploy-card / .veto-btn for any remaining uses */
.deploy-card{width:160px;background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:12px 14px;cursor:pointer;transition:all .2s;text-align:center;position:relative}
.deploy-card:hover{border-color:var(--gold);background:rgba(200,168,75,.06)}
.deploy-card.vetoed{opacity:.35;pointer-events:none;border-color:var(--border)}
.deploy-card.vetoed::after{content:'VETOED';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Share Tech Mono',monospace;font-size:14px;color:var(--red-light);letter-spacing:3px}
.deploy-card.selected{border-color:var(--green);background:rgba(58,173,94,.08)}
.deploy-card-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:1px}
.deploy-card-desc{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);line-height:1.6;margin-bottom:8px}
.deploy-card-zones{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--gold)}
.veto-btn{padding:8px 28px;background:rgba(213,58,58,.12);border:1px solid var(--red);color:var(--red-light);font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;letter-spacing:2px;cursor:pointer;text-transform:uppercase;transition:all .15s;border-radius:2px}
.veto-btn:hover{background:rgba(213,58,58,.25)}

/* tile overlays */
.tile-overlay{position:absolute;pointer-events:none;z-index:4}
.tile-move{width:var(--tile);height:var(--tile);background:rgba(58,173,94,.22);border:1px solid rgba(58,173,94,.5);pointer-events:auto;cursor:pointer}
.tile-move:hover,.tile-move-hover{background:rgba(58,173,94,.4)!important}
.pivot-overlay{
  width:22px;height:22px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  padding:0;
  border:1px solid rgba(200,168,75,.7);
  background:rgba(26,24,20,.95);
  color:var(--gold);font-size:11px;line-height:1;
  pointer-events:auto;cursor:pointer;z-index:7;
  box-shadow:0 0 6px rgba(0,0,0,.6);
}
.pivot-overlay:hover{background:rgba(200,168,75,.22)}
.pivot-overlay.active{border-color:#fff0b0;background:rgba(200,168,75,.34)}
.pivot-preview{opacity:.45;pointer-events:none}
.tile-deploy{background:color-mix(in srgb, var(--a-primary) 18%, transparent);border:1px solid color-mix(in srgb, var(--a-primary) 40%, transparent);pointer-events:auto;cursor:pointer}
.tile-deploy:hover{background:color-mix(in srgb, var(--a-primary) 35%, transparent)!important}

/* terrain */
.terrain-piece{position:absolute;pointer-events:auto;z-index:2;cursor:default;border-radius:1px}
.terrain-piece.hard{
  background:repeating-linear-gradient(45deg,rgba(55,50,43,.94),rgba(55,50,43,.94) 4px,rgba(70,63,52,.94) 4px,rgba(70,63,52,.94) 8px);
  border:1px solid rgba(125,112,92,.6);box-shadow:inset 0 0 0 1px rgba(0,0,0,.25)}
.terrain-piece.cover{
  background:repeating-linear-gradient(-45deg,rgba(20,70,32,.65),rgba(20,70,32,.65) 5px,rgba(30,92,46,.65) 5px,rgba(30,92,46,.65) 10px);
  border:1px solid rgba(52,148,74,.55)}
.terrain-piece.difficult{
  background:repeating-linear-gradient(45deg,rgba(105,68,16,.6),rgba(105,68,16,.6) 4px,rgba(128,88,26,.6) 4px,rgba(128,88,26,.6) 8px);
  border:1px solid rgba(162,115,40,.6)}
.terrain-piece.water{
  background:repeating-linear-gradient(90deg,rgba(16,60,150,.8),rgba(16,60,150,.8) 5px,rgba(24,80,178,.8) 5px,rgba(24,80,178,.8) 10px);
  border:1px solid rgba(52,138,218,.78)}
.terrain-piece.hazardous{
  background:repeating-linear-gradient(-45deg,rgba(135,40,5,.78),rgba(135,40,5,.78) 5px,rgba(92,26,4,.78) 5px,rgba(92,26,4,.78) 10px);
  border:1px solid rgba(200,100,15,.78)}
.terrain-piece.dense{
  background:repeating-linear-gradient(135deg,rgba(20,5,36,.86),rgba(20,5,36,.86) 4px,rgba(40,10,65,.86) 4px,rgba(40,10,65,.86) 8px);
  border:1px solid rgba(138,42,192,.7)}

/* Paved street — cobblestone/flagstone pattern, purely aesthetic */
.terrain-piece.pave{
  background:
    repeating-linear-gradient(0deg,rgba(0,0,0,.18) 0,rgba(0,0,0,.18) 1px,transparent 1px,transparent 10px),
    repeating-linear-gradient(90deg,rgba(0,0,0,.18) 0,rgba(0,0,0,.18) 1px,transparent 1px,transparent 14px),
    rgba(58,52,44,.52);
  border:none;border-radius:0;z-index:1}

/* Building interior floor — renders as stone floor */
.terrain-piece.floor{
  background:
    linear-gradient(rgba(0,0,0,.12) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,0,0,.12) 1px,transparent 1px),
    rgba(42,38,34,.55);
  background-size:var(--tile) var(--tile);
  border:1px solid rgba(70,64,55,.25)}

/* Scatter objects — position-only from JS; each type sets its own size via CSS */
.scatter-piece{position:absolute;pointer-events:auto;cursor:default;z-index:3;box-sizing:border-box}

/* Barrel — top-down view: circular lid with concentric ring detail */
.scatter-piece.barrel{
  width:calc(var(--tile) * .68);height:calc(var(--tile) * .68);
  margin:calc(var(--tile) * .16);
  background:
    radial-gradient(circle 22% at 38% 38%, rgba(255,180,80,.18) 0%, transparent 100%),
    radial-gradient(circle at 50% 50%, #7a3810 0%, #5a2808 40%, #38160a 75%, #1a0802 100%);
  border-radius:50%;
  border:2px solid #120602;
  box-shadow:inset 0 0 0 3px rgba(90,40,12,.55),inset 0 0 0 5px rgba(40,14,2,.4),2px 3px 6px rgba(0,0,0,.7)}
.scatter-piece.barrel::before{
  content:'';position:absolute;left:20%;right:20%;top:20%;bottom:20%;
  border-radius:50%;border:1.5px solid rgba(60,22,4,.5)}
.scatter-piece.barrel::after{
  content:'';position:absolute;left:37%;right:37%;top:37%;bottom:37%;
  border-radius:50%;background:rgba(0,0,0,.25)}

/* Sandbag pile — olive/khaki military bags stacked in a crescent */
.scatter-piece.sandbag{
  width:calc(var(--tile) * .85);height:calc(var(--tile) * .7);
  margin:calc(var(--tile) * .08) calc(var(--tile) * .075) calc(var(--tile) * .22);
  background:
    radial-gradient(ellipse 70% 48% at 20% 72%, #6b7a40 55%, transparent 100%),
    radial-gradient(ellipse 70% 48% at 80% 72%, #627238 55%, transparent 100%),
    radial-gradient(ellipse 60% 45% at 50% 38%, #788048 55%, transparent 100%),
    radial-gradient(ellipse 45% 38% at 50% 10%, #5a6830 50%, transparent 100%),
    rgba(44,50,22,.6);
  border-radius:6px 6px 4px 4px;
  border:1px solid rgba(30,38,12,.6);
  box-shadow:0 2px 5px rgba(0,0,0,.55)}

/* Rubble pile — grey-blue broken stone and concrete chunks */
.scatter-piece.rubble{
  width:calc(var(--tile) * .88);height:calc(var(--tile) * .88);
  margin:calc(var(--tile) * .06);
  background:
    radial-gradient(ellipse 75% 45% at 25% 68%, #7e8088 55%, transparent 100%),
    radial-gradient(ellipse 60% 45% at 72% 58%, #6a6c74 55%, transparent 100%),
    radial-gradient(ellipse 50% 40% at 52% 25%, #8a8c94 60%, transparent 100%),
    rgba(42,44,50,.9);
  border-radius:3px;
  border:1px solid rgba(22,24,30,.6);
  box-shadow:inset 0 1px 4px rgba(0,0,0,.45),0 1px 3px rgba(0,0,0,.5)}
.scatter-piece.rubble::before{
  content:'';position:absolute;
  width:30%;height:22%;top:22%;left:15%;
  background:rgba(110,112,122,.85);border-radius:2px;
  transform:rotate(-18deg);
  box-shadow:16px 18px 0 rgba(88,92,102,.75),24px 5px 0 rgba(100,102,112,.65)}

/* Crate — wooden box viewed from above, cross-brace planking */
.scatter-piece.crate{
  width:calc(var(--tile) * .78);height:calc(var(--tile) * .78);
  margin:calc(var(--tile) * .11);
  background:
    linear-gradient(rgba(0,0,0,.32) 1.5px,transparent 1.5px),
    linear-gradient(90deg,rgba(0,0,0,.32) 1.5px,transparent 1.5px),
    linear-gradient(rgba(255,210,90,.06),rgba(0,0,0,.08)),
    #9a7818;
  background-size:50% 50%,50% 50%,100% 100%,100% 100%;
  border:2px solid #3a2408;border-radius:2px;
  box-shadow:inset 0 0 5px rgba(0,0,0,.35),2px 3px 5px rgba(0,0,0,.55)}

/* Bridge — stone crossing rendered above water tiles */
.terrain-piece.bridge{
  background:
    repeating-linear-gradient(0deg,rgba(0,0,0,.22) 0,rgba(0,0,0,.22) 1px,transparent 1px,transparent 5px),
    linear-gradient(rgba(148,136,112,.92),rgba(118,108,88,.92));
  border:1px solid rgba(70,60,44,.55);border-radius:0;z-index:3}

/* Broken pillar — top-down stone column cross-section */
.scatter-piece.pillar{
  width:calc(var(--tile) * .7);height:calc(var(--tile) * .7);
  margin:calc(var(--tile) * .15);
  background:
    radial-gradient(circle at 38% 36%,rgba(255,245,220,.22) 0%,transparent 55%),
    radial-gradient(circle at 50% 50%,#b0a898 0%,#8c8478 35%,#686058 65%,#3c3830 100%);
  border-radius:50%;
  border:2px solid #282420;
  box-shadow:inset 0 0 0 3px rgba(60,54,44,.5),inset 0 0 0 6px rgba(100,92,80,.3),2px 3px 6px rgba(0,0,0,.65)}
.scatter-piece.pillar::before{
  content:'';position:absolute;left:22%;right:22%;top:22%;bottom:22%;
  background:radial-gradient(circle at 42% 40%,rgba(255,245,220,.18) 0%,transparent 70%);
  border:1px solid rgba(60,54,44,.35);border-radius:50%}

/* Fallen log — top-down view of tree trunk, elongated oval */
.scatter-piece.log{
  width:calc(var(--tile) * .88);height:calc(var(--tile) * .46);
  margin:calc(var(--tile) * .27) calc(var(--tile) * .06);
  background:
    repeating-linear-gradient(90deg,transparent 0,transparent 3px,rgba(0,0,0,.07) 3px,rgba(0,0,0,.07) 4px),
    linear-gradient(180deg,#8a5828 0%,#6a3c18 30%,#7a4820 55%,#5a2e10 80%,#4a2410 100%);
  border-radius:50% / 40%;
  border:1.5px solid #1e0e04;
  box-shadow:0 2px 5px rgba(0,0,0,.55),inset 0 1px 0 rgba(180,120,60,.2)}
.scatter-piece.log::before{
  content:'';position:absolute;left:0;top:10%;width:18%;height:80%;
  background:radial-gradient(ellipse at 60% 50%,#3a1a06 0%,#2a1004 60%,transparent 100%);
  border-radius:50% 0 0 50%}
.scatter-piece.log::after{
  content:'';position:absolute;right:0;top:10%;width:18%;height:80%;
  background:radial-gradient(ellipse at 40% 50%,#3a1a06 0%,#2a1004 60%,transparent 100%);
  border-radius:0 50% 50% 0}

/* Cogitator console — dark panelling with a faint glowing readout */
.scatter-piece.console{
  background:linear-gradient(180deg,#1a2028 0,#0e1418 60%,#1a2028 100%);
  border:1.5px solid #0a0e12;
  border-radius:2px;
  margin:2px;
  width:calc(var(--tile) - 4px);height:calc(var(--tile) - 4px);
  box-shadow:0 0 6px rgba(0,180,130,.18),inset 0 0 4px rgba(0,0,0,.6)}
.scatter-piece.console::before{
  content:'';position:absolute;left:15%;right:15%;top:20%;height:30%;
  background:rgba(0,220,160,.14);border-radius:1px;
  box-shadow:0 0 4px rgba(0,220,160,.25)}
.scatter-piece.console::after{
  content:'';position:absolute;left:20%;right:20%;bottom:18%;height:4px;
  background:repeating-linear-gradient(90deg,rgba(0,200,140,.3) 0,rgba(0,200,140,.3) 2px,transparent 2px,transparent 5px);
  border-radius:1px}

/* Enclosed (fully sealed, inaccessible) areas */
.terrain-enclosed{position:absolute;pointer-events:none;z-index:1;background:rgba(12,12,14,.78)}

/* Edge walls — drawn as lines on tile edges */
.edge-wall{position:absolute;pointer-events:auto;cursor:default;z-index:4}
.edge-wall.full-wall{background:rgba(118,106,86,.98);box-shadow:0 0 4px rgba(0,0,0,.95),0 0 1px rgba(0,0,0,.7),inset 0 0 0 1px rgba(158,142,115,.3)}
.edge-wall.low-wall{background:rgba(95,84,66,.82);box-shadow:0 0 3px rgba(0,0,0,.7),0 0 1px rgba(0,0,0,.5)}
.edge-wall.window{background:rgba(72,96,118,.78);box-shadow:0 0 3px rgba(0,0,0,.55),inset 0 0 0 1px rgba(140,190,225,.22)}

/* objectives */
.obj-marker{position:absolute;width:var(--tile);height:var(--tile);display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:8}
.obj-inner{width:calc(var(--tile) - 2px);height:calc(var(--tile) - 2px);border-radius:50%;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--gold);background:rgba(200,168,75,.2);position:relative;z-index:4;font-family:'Share Tech Mono',monospace;pointer-events:auto;cursor:default}
.obj-marker::before{content:'';position:absolute;width:132px;height:132px;border-radius:50%;border:1px dashed rgba(200,168,75,.3);background:rgba(200,168,75,.04);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:2}
.obj-marker.blue::before{border-color:color-mix(in srgb, var(--a-primary) 35%, transparent);background:color-mix(in srgb, var(--a-primary) 6%, transparent)}
.obj-marker.red::before{border-color:color-mix(in srgb, var(--b-primary) 35%, transparent);background:color-mix(in srgb, var(--b-primary) 6%, transparent)}
.obj-inner.blue{border-color:var(--a-primary);color:var(--a-light);background:color-mix(in srgb, var(--a-primary) 25%, transparent)}
.obj-inner.red{border-color:var(--b-primary);color:var(--b-light);background:color-mix(in srgb, var(--b-primary) 25%, transparent)}

/* model tokens */
.model-token{position:absolute;width:var(--tile);height:var(--tile);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;transition:transform .1s;border-radius:3px;overflow:visible}
.model-token.base-large{width:calc(var(--tile)*2);height:calc(var(--tile)*2);z-index:6}
.model-token:hover{transform:scale(1.08);z-index:10}
.model-token .inner{width:calc(var(--tile) - 4px);height:calc(var(--tile) - 4px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Share Tech Mono',monospace;font-size:10px;font-weight:700;border:1.5px solid;transition:box-shadow .2s,opacity .2s,filter .2s;position:relative}
.model-token.base-large .inner{width:calc(var(--tile)*2 - 4px);height:calc(var(--tile)*2 - 4px);border-radius:50%;font-size:13px;border-width:2px}
.model-token.blue .inner{background:var(--a-dim);color:var(--a-light);border-color:var(--a-primary)}
.model-token.red .inner{background:var(--b-dim);color:var(--b-light);border-color:var(--b-primary)}
/* activated — subtle crosshatch overlay, stays readable */
.model-token.activated .inner{filter:brightness(0.45) saturate(0.4)}
.model-token.activated .inner::after{content:'✓';position:absolute;font-size:8px;bottom:0;right:0;color:rgba(255,255,255,.5);pointer-events:none}
/* selected — gold pulse on the leader token only */
.model-token.selected.leader .inner{border-color:var(--gold);border-width:2.5px;animation:token-pulse 1.2s ease-in-out infinite}
@keyframes token-pulse{0%,100%{box-shadow:0 0 4px rgba(200,168,75,.4)}50%{box-shadow:0 0 12px rgba(200,168,75,.9),0 0 20px rgba(200,168,75,.3)}}
/* follower of selected unit — subtle gold tint border */
.model-token.selected-follower .inner{border-color:rgba(200,168,75,.5);border-width:2px}
.model-token.leader .inner{border-width:2px}
.model-token.blue.leader .inner{border-color:var(--a-leader)}
.model-token.red.leader .inner{border-color:var(--b-leader)}
.model-token.dead{display:none}
.model-token.targetable:hover .inner{box-shadow:0 0 0 2px rgba(213,58,58,.9),0 0 10px rgba(213,58,58,.6);cursor:crosshair}
.model-token.highlighted .inner{box-shadow:0 0 0 2px rgba(213,58,58,.9),0 0 8px rgba(213,58,58,.5)}
.model-token.coherency-bad .inner{box-shadow:0 0 0 2px rgba(200,168,75,.9)!important}
/* Squad hover — all models in a unit glow when any is hovered */
.model-token.blue.squad-hover .inner{box-shadow:0 0 0 2px color-mix(in srgb, var(--a-primary) 55%, transparent),0 0 10px color-mix(in srgb, var(--a-primary) 25%, transparent)}
.model-token.red.squad-hover .inner{box-shadow:0 0 0 2px color-mix(in srgb, var(--b-primary) 55%, transparent),0 0 10px color-mix(in srgb, var(--b-primary) 25%, transparent)}
/* Brightness boost only on live (non-activated) tokens so dimmed ones stay dim */
.model-token.squad-hover:not(.activated) .inner{filter:brightness(1.18)}
/* Charge-target highlight — enemy units that will be engaged if you click this tile */
.model-token.charge-target .inner{box-shadow:0 0 0 2px rgba(255,80,80,.9),0 0 14px rgba(255,80,80,.5);animation:charge-pulse .6s ease-in-out infinite alternate}
@keyframes charge-pulse{from{box-shadow:0 0 0 2px rgba(255,80,80,.9),0 0 8px rgba(255,80,80,.4)}to{box-shadow:0 0 0 3px rgba(255,120,120,1),0 0 20px rgba(255,80,80,.7)}}
.model-token.draggable-follower{cursor:grab}
.model-token.draggable-follower:active{cursor:grabbing}
/* leader token is slightly larger */
.model-token.leader .inner{width:calc(var(--tile) - 2px);height:calc(var(--tile) - 2px);font-size:11px}

/* wound pips on tough models */
.wound-pips{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);display:flex;gap:2px;padding-bottom:2px;pointer-events:none;z-index:7}
.wound-pip{width:5px;height:5px;border-radius:50%;background:var(--red);border:1px solid rgba(213,58,58,.6);flex-shrink:0}
.wound-pip.empty{background:#333;border-color:#555}
/* follower token label — same abbrev as leader but dim */
.model-token .inner.follower-label{font-size:7px;opacity:.55;letter-spacing:0}
.model-token.fortified .inner{box-shadow:0 0 0 2px rgba(58,123,213,0.7),0 0 6px rgba(58,123,213,0.3)!important}

/* fortified indicator */
.fortify-badge{position:absolute;top:-6px;right:-4px;font-size:8px;background:rgba(58,123,213,.85);border:1px solid var(--blue-light);border-radius:2px;padding:0 2px;color:var(--blue-light);pointer-events:none;z-index:8;font-family:'Share Tech Mono',monospace;line-height:12px}
.fallback-badge{position:absolute;top:-6px;left:-4px;font-size:8px;background:rgba(213,120,58,.85);border:1px solid #e8a070;border-radius:2px;padding:0 2px;color:#e8a070;pointer-events:none;z-index:8;font-family:'Share Tech Mono',monospace;line-height:12px}
.vehicle-facing-arrow{
  position:absolute;left:50%;top:-8px;
  width:2px;height:10px;background:var(--gold);
  border-radius:1px;
  box-shadow:0 0 2px rgba(0,0,0,.9),0 0 5px rgba(0,0,0,.7);
  transform:translateX(-50%) rotate(0deg);
  transform-origin:50% calc(100% + 8px);
  transition:transform .16s ease-out;
  pointer-events:none;z-index:9;
}
.vehicle-facing-arrow.facing-n{transform:translateX(-50%) rotate(0deg)}
.vehicle-facing-arrow.facing-ne{transform:translateX(-50%) rotate(45deg)}
.vehicle-facing-arrow.facing-e{transform:translateX(-50%) rotate(90deg)}
.vehicle-facing-arrow.facing-se{transform:translateX(-50%) rotate(135deg)}
.vehicle-facing-arrow.facing-s{transform:translateX(-50%) rotate(180deg)}
.vehicle-facing-arrow.facing-sw{transform:translateX(-50%) rotate(225deg)}
.vehicle-facing-arrow.facing-w{transform:translateX(-50%) rotate(270deg)}
.vehicle-facing-arrow.facing-nw{transform:translateX(-50%) rotate(315deg)}
.vehicle-facing-arrow::after{
  content:'';
  position:absolute;left:-3px;top:-6px;
  width:0;height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-bottom:7px solid var(--gold);
  filter:drop-shadow(0 0 1px rgba(0,0,0,.8));
}
/* War Cry buff token */
.war-cry-badge{position:absolute;bottom:-6px;right:-4px;font-size:8px;background:rgba(200,168,75,.92);border:1px solid var(--gold);border-radius:2px;padding:0 2px;color:#111;pointer-events:none;z-index:8;font-family:'Share Tech Mono',monospace;line-height:12px}
.model-token.war-cry-buffed .inner{animation:war-cry-pulse .7s ease-in-out infinite alternate}
@keyframes war-cry-pulse{from{box-shadow:0 0 0 2px rgba(200,168,75,.7),0 0 5px rgba(200,168,75,.4)}to{box-shadow:0 0 0 3px rgba(255,225,100,1),0 0 12px rgba(200,168,75,.7)}}
/* War Cry action buttons */
#btn-war-cry{background:rgba(200,168,75,.1);border-color:rgba(200,168,75,.5);color:var(--gold)}
#btn-war-cry:not(:disabled):hover{background:rgba(200,168,75,.2)}
.war-cry-move-btn{background:rgba(200,168,75,.2)!important;border-color:var(--gold)!important;color:var(--gold)!important;font-weight:700;animation:war-cry-btn-pulse .7s ease-in-out infinite alternate}
@keyframes war-cry-btn-pulse{from{background:rgba(200,168,75,.15)!important}to{background:rgba(200,168,75,.35)!important}}
/* LOS hover lines drawn into #target-line SVG */
.los-hover-line{stroke-dasharray:4 3;animation:none;opacity:.6}

/* ── RIGHT PANEL ── */
#right-panel{width:225px;flex-shrink:0;background:var(--panel);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
/* Top sections (actions, unit card) can scroll internally if they grow */
#right-panel>.panel-section{overflow-y:auto;flex-shrink:0}
.action-btn{width:100%;padding:7px 10px;margin-bottom:4px;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;border-radius:2px;cursor:pointer;text-align:left;transition:all .15s}
.action-btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold);background:rgba(200,168,75,.08)}
.action-btn:disabled{opacity:.3;cursor:not-allowed}
.action-btn.active{border-color:var(--green);color:var(--green);background:rgba(58,173,94,.1)}
.action-btn.danger{border-color:var(--red);color:var(--red-light);background:rgba(213,58,58,.08)}
.action-btn.gold{border-color:var(--gold);color:var(--gold);background:rgba(200,168,75,.1)}
.action-btn.aim-active{border-color:#b07ae8;color:#b07ae8;background:rgba(176,122,232,.1)}

/* ── WEAPON PICKER ── */
#weapon-picker{display:none;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:3px;padding:7px 8px;margin-bottom:6px}
#weapon-picker.show{display:block}
#weapon-picker .wp-title{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);letter-spacing:1px;margin-bottom:6px}
.wp-btn{width:100%;text-align:left;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:2px;padding:5px 7px;margin-bottom:4px;cursor:pointer;font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text);transition:all .15s;display:flex;justify-content:space-between;align-items:center}
.wp-btn:hover{border-color:var(--gold);background:rgba(200,168,75,.06)}
.wp-btn.active{border-color:var(--green);background:rgba(58,173,94,.08);color:var(--green)}
.wp-btn.fired{opacity:.4;pointer-events:none;text-decoration:line-through}
.wp-btn.no-targets{opacity:.5;pointer-events:none;border-color:rgba(213,58,58,.3)}
.wp-btn-stats{font-size:8px;color:var(--text-dim)}
.wp-btn.active .wp-btn-stats{color:rgba(58,173,94,.8)}
#wp-done{width:100%;margin-top:2px;padding:5px;background:transparent;border:1px solid var(--border);color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:1px;cursor:pointer;border-radius:2px;transition:all .15s}
#wp-done:hover{border-color:var(--gold);color:var(--gold)}
#dice-area{padding:10px;display:none}
.dice-result{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}
#save-label{border-top:1px solid var(--border);padding-top:6px}
.die{width:22px;height:22px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-family:'Share Tech Mono',monospace;font-size:12px;font-weight:700;border:1px solid}
/* Blue attacking — green hits, red misses */
.die.hit  {background:rgba(58,173,94,.2); border-color:var(--green);      color:var(--green)}
.die.miss {background:rgba(213,58,58,.15);border-color:var(--red);        color:var(--red-light)}
/* Red attacking — red hits, dim misses */
.die.hit-enemy  {background:rgba(213,58,58,.25);border-color:var(--red-light);  color:var(--red-light)}
.die.miss-enemy {background:rgba(40,40,50,.4);  border-color:var(--border);     color:var(--text-dim)}
/* Save dice — green saved, red failed (same regardless of attacker side) */
.die.save {background:rgba(58,173,94,.2); border-color:var(--green);      color:var(--green)}
.die.fail {background:rgba(213,58,58,.15);border-color:var(--red);        color:var(--red-light)}

/* ── LOG PANEL ── */
#combat-panel{flex:1;display:flex;flex-direction:column;min-height:0;border-top:1px solid var(--border)}
.combat-tab-bar{display:flex;align-items:center;flex-shrink:0;border-bottom:1px solid var(--border)}
.ctab{flex:1;padding:7px 4px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:1.5px;cursor:pointer;transition:color .15s,border-color .15s;text-transform:uppercase}
.ctab.ctab-active{color:var(--gold);border-bottom:2px solid var(--gold)}
#copy-log-btn{flex:0 0 auto;padding:7px 10px;background:transparent;border:none;color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:1px;cursor:pointer;transition:color .15s;text-transform:uppercase}
#copy-log-btn:hover{color:var(--gold)}
/* log */
#log-area{flex:1;overflow-y:auto;padding:8px 10px;font-family:'Share Tech Mono',monospace;font-size:11px;line-height:1.6}
.log-entry{color:var(--text-dim);margin-bottom:2px}
.log-entry.important{color:var(--text)}
.log-entry.blue{color:var(--a-light)}
.log-entry.red{color:var(--b-light)}
.log-entry.gold{color:var(--gold)}
.log-entry.green{color:var(--green)}
/* Activation header — visual separator before each unit's turn */
.log-entry.activation{color:var(--text);border-top:1px solid rgba(255,255,255,.07);margin-top:7px;padding-top:5px}
.log-entry.activation.blue{color:var(--a-light);border-top-color:var(--a-dim)}
.log-entry.activation.red{color:var(--b-light);border-top-color:var(--b-dim)}
/* Active buff list shown under the activation header */
.log-entry.buff-active{color:var(--text-dim);font-size:10px;letter-spacing:.5px}
/* Attack declaration lines — left accent bar, slightly brighter */
.log-entry.attack{color:var(--text);border-left:2px solid rgba(255,255,255,.15);padding-left:5px;margin:2px 0 1px}
.log-entry.attack.blue{color:var(--a-light);border-left-color:var(--a-primary)}
.log-entry.attack.red{color:var(--b-light);border-left-color:var(--b-primary)}
/* inline dice blocks in log */
.log-dice{margin:3px 0 5px 0;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:3px;padding:5px 7px;display:inline-block;min-width:100%}
.log-dice-label{font-size:9px;color:var(--text-dim);letter-spacing:.5px;margin-bottom:4px}
.log-dice-label.blue{color:var(--a-light)}
.log-dice-label.red{color:var(--b-light)}
.log-dice-label.save-blue{color:var(--a-light)}
.log-dice-label.save-red{color:var(--b-light)}
.log-dice-row{display:flex;flex-wrap:wrap;gap:3px}

/* ── MANUAL DICE ROLL PROMPTS ── */
/* Highlight 1s awaiting reroll */
.die.die-one{outline:2px solid var(--gold);outline-offset:1px}
/* Roll / Reroll buttons inside dice zone */
.roll-dice-btn{display:inline-block;margin-top:6px;padding:5px 14px;font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:1px;cursor:pointer;border-radius:2px;transition:all .12s;background:rgba(200,168,75,.14);border:1px solid rgba(200,168,75,.55);color:var(--gold)}
.roll-dice-btn:hover{background:rgba(200,168,75,.28);border-color:var(--gold)}
.reroll-1s-btn{margin-left:6px;background:rgba(58,173,94,.12);border-color:rgba(58,173,94,.5);color:var(--green)}
.reroll-1s-btn:hover{background:rgba(58,173,94,.26);border-color:var(--green)}
/* Dice zone — live roll prompt between actions and log */
#dice-zone{flex-shrink:0;padding:0;border-bottom:0 solid var(--border);overflow:hidden;transition:padding .12s,border-bottom-width .12s}
#dice-zone:not(:empty){padding:8px 10px;border-bottom-width:1px;background:rgba(200,168,75,.04)}
#dice-zone .log-dice{background:transparent;border:none;padding:0;margin:0}
/* AUTO ROLL toggle in log tab bar */
#manual-dice-label{display:flex;align-items:center;gap:4px;font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:1px;color:var(--text-dim);cursor:pointer;user-select:none;padding:2px 6px;border:1px solid transparent;border-radius:2px;transition:all .12s}
#manual-dice-label:hover{color:var(--gold);border-color:rgba(200,168,75,.3)}
#manual-dice-label input{accent-color:var(--gold);cursor:pointer}

/* ── BOTTOM BAR ── */
#bottom-bar{background:var(--panel);border-top:1px solid var(--border);padding:5px 14px;display:flex;align-items:center;gap:16px;flex-shrink:0;font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:1px}
.score-chip{padding:2px 10px;border-radius:2px;font-size:12px;font-weight:700}
.score-chip.blue{background:var(--a-dim);color:var(--a-light);border:1px solid var(--a-primary)}
.score-chip.red{background:var(--b-dim);color:var(--b-light);border:1px solid var(--b-primary)}

/* ── VFX ── */
#target-line{position:absolute;top:0;left:0;pointer-events:none;z-index:20;width:100%;height:100%}
.shot-line{stroke-dasharray:6 4;animation:dash-travel .2s linear forwards,line-fade .5s ease-out .2s forwards}
@keyframes dash-travel{from{stroke-dashoffset:60}to{stroke-dashoffset:0}}
@keyframes line-fade{from{opacity:1}to{opacity:0}}
.hitsplat{position:absolute;pointer-events:none;z-index:30;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Share Tech Mono',monospace;font-size:11px;font-weight:700;border:2px solid;animation:splat-pop .75s ease-out forwards}
.hitsplat.wound{background:rgba(213,58,58,.9);border-color:#ff7070;color:#fff}
.hitsplat.saved{background:rgba(58,173,94,.9);border-color:#60ff90;color:#fff}
.hitsplat.miss{background:rgba(50,50,60,.8);border-color:#666;color:#aaa}
@keyframes splat-pop{0%{transform:scale(.3) translateY(0);opacity:1}35%{transform:scale(1.3) translateY(-6px);opacity:1}65%{transform:scale(1) translateY(-12px);opacity:1}100%{transform:scale(.8) translateY(-20px);opacity:0}}
.melee-flash{position:absolute;pointer-events:none;z-index:25;border-radius:50%;border:3px solid var(--gold);animation:melee-ring .5s ease-out forwards}
@keyframes melee-ring{0%{transform:scale(.2);opacity:1}60%{transform:scale(2);opacity:.7}100%{transform:scale(2.8);opacity:0}}
.uplink-effect{position:absolute;pointer-events:none;z-index:31;padding:2px 5px;border-radius:4px;font-family:'Share Tech Mono',monospace;font-size:10px;font-weight:700;border:1px solid;white-space:nowrap;animation:uplink-rise 1.1s ease-out forwards}
.uplink-effect.fire{background:rgba(20,60,80,.9);border-color:#50c8ff;color:#50c8ff}
.uplink-effect.shield{background:rgba(20,70,60,.9);border-color:#32dcb4;color:#32dcb4}
.uplink-effect.boost{background:rgba(50,70,20,.9);border-color:#a0e650;color:#a0e650}
@keyframes uplink-rise{0%{transform:translateY(0) scale(.8);opacity:1}40%{transform:translateY(-14px) scale(1);opacity:1}100%{transform:translateY(-32px) scale(.9);opacity:0}}

/* ── MODE SELECT ── */
#mode-screen{position:fixed;inset:0;background:var(--bg);z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0}
#mode-screen h1{font-family:'Share Tech Mono',monospace;font-size:28px;letter-spacing:6px;color:var(--gold);margin-bottom:6px}
#mode-screen .subtitle{font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:3px;color:var(--text-dim);margin-bottom:40px}
.mode-card{width:340px;margin-bottom:10px;padding:16px 22px;background:var(--panel);border:1px solid var(--border);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:16px}
.mode-card:hover{border-color:var(--gold);background:rgba(200,168,75,.06)}
.mode-card .mode-icon{font-size:26px;width:32px;text-align:center;flex-shrink:0}
.mode-card .mode-title{font-size:15px;font-weight:700;color:var(--text);letter-spacing:1px;margin-bottom:2px}
.mode-card .mode-desc{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:1px}

/* ── ARMY BUILDER ── */
#builder-screen{position:fixed;inset:0;background:var(--bg);z-index:190;display:none;flex-direction:column;align-items:center;overflow-y:auto;padding:30px 20px}
#builder-screen.show{display:flex}
#builder-screen h2{font-family:'Share Tech Mono',monospace;font-size:18px;letter-spacing:4px;color:var(--gold);margin-bottom:6px}
#builder-screen .sub{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:2px;margin-bottom:24px}
.size-cards{display:flex;gap:12px;margin-bottom:28px}
.size-card{width:120px;padding:14px;background:var(--panel);border:1px solid var(--border);cursor:pointer;text-align:center;transition:all .15s;border-radius:3px}
.size-card:hover,.size-card.selected{border-color:var(--gold);background:rgba(200,168,75,.08)}
.size-card .sc-name{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}
.size-card .sc-pts{font-family:'Share Tech Mono',monospace;font-size:11px;color:var(--gold)}
.size-card .sc-desc{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);margin-top:3px}
.builder-cols{display:flex;gap:20px;width:100%;max-width:1100px}
.builder-col{flex:1;background:var(--panel);border:1px solid var(--border);padding:14px;border-radius:3px}
.builder-col h3{font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:2px;margin-bottom:4px;text-transform:uppercase}
.builder-col h3.blue{color:var(--a-light)}
.builder-col h3.red{color:var(--b-light)}
.faction-picker{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.faction-btn{flex:1;min-width:100px;padding:6px 8px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:3px;cursor:pointer;text-align:center;transition:all .15s;font-family:'Share Tech Mono',monospace;color:var(--text-dim)}
.faction-btn:hover{border-color:var(--gold)}
.faction-btn.selected.blue-side{border-color:var(--a-primary);background:color-mix(in srgb, var(--a-primary) 12%, transparent);color:var(--a-light)}
.faction-btn.selected.red-side{border-color:var(--b-primary);background:color-mix(in srgb, var(--b-primary) 12%, transparent);color:var(--b-light)}
/* Neutral selected state for faction buttons in builder (color assigned later) */
.faction-btn.selected{border-color:var(--gold);background:rgba(200,168,75,.12);color:var(--gold)}
/* Builder column army header */
.col-army-header{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.col-army-label{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--text-dim);flex:1}
.army-io-btn{padding:3px 8px;background:transparent;border:1px solid var(--border);color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:8px;letter-spacing:1px;cursor:pointer;border-radius:2px;transition:all .15s}
.army-io-btn:hover{border-color:var(--gold);color:var(--gold)}
/* Neutral h3 in builder (no side color) */
#col-blue-h3,#col-red-h3{color:var(--text);font-size:13px;margin:0 0 8px}
/* Quick Battle screen */
.qb-section{margin-bottom:22px}
.qb-section-title{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--text-dim);margin-bottom:8px;border-bottom:1px solid var(--border);padding-bottom:4px}
.qb-cards{display:flex;gap:8px;flex-wrap:wrap}
.qb-card{flex:1;min-width:120px;padding:10px 12px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:3px;cursor:pointer;transition:all .15s;text-align:center}
.qb-card:hover{border-color:var(--gold)}
.qb-card.qb-selected{border-color:var(--gold);background:rgba(200,168,75,.1)}
/* Deploy row — taller cards to fit the 96×96 SVG zone diagram */
#qb-deploy-cards .qb-card{min-width:110px;padding:8px}
#qb-deploy-cards .qb-card svg{display:block;margin:0 auto 4px}
.qb-points-row{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:14px 12px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:4px;text-align:center}
.qb-points-label{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--text-dim)}
.qb-points-input{width:110px;background:var(--panel);border:1px solid var(--gold);color:var(--gold);font-family:'Share Tech Mono',monospace;font-size:16px;font-weight:700;text-align:center;padding:8px 10px;border-radius:3px;outline:none}
.qb-points-help{max-width:420px;font-family:'Share Tech Mono',monospace;font-size:8px;line-height:1.6;color:var(--text-dim)}
.qb-army-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.qb-army-picker{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:4px;padding:12px}
.qb-army-label{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--text-dim);margin-bottom:8px}
.qb-army-inline-actions{display:flex;justify-content:center;margin:8px 0}
.qb-inline-btn{padding:7px 14px;background:rgba(200,168,75,.12);border:1px solid rgba(200,168,75,.55);color:var(--gold);font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:1px;cursor:pointer;border-radius:2px;transition:all .15s}
.qb-inline-btn:hover{background:rgba(200,168,75,.2);border-color:var(--gold);color:#f6df9a}
.qb-army-select{width:100%;background:var(--panel);border:1px solid var(--border);color:var(--text);font-family:'Share Tech Mono',monospace;font-size:10px;padding:8px;border-radius:3px;outline:none}
.qb-army-select:focus{border-color:var(--gold)}
.qb-army-preview{margin-top:8px;min-height:56px;font-family:'Share Tech Mono',monospace;font-size:8px;line-height:1.6;color:var(--text-dim);white-space:pre-line}
.qb-army-actions{margin-top:10px;display:flex;justify-content:flex-end}
.qb-subtle-btn{padding:7px 12px;background:transparent;border:1px solid var(--border);color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:1px;cursor:pointer;border-radius:2px;transition:all .15s}
.qb-subtle-btn:hover{border-color:var(--gold);color:var(--gold)}
.page-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:4px}
.page-back-btn{padding:8px 12px;background:transparent;border:1px solid var(--border);color:var(--text-dim);font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:1px;cursor:pointer;border-radius:3px;transition:all .15s;white-space:nowrap}
.page-back-btn:hover{border-color:var(--gold);color:var(--gold)}
.qb-icon{font-size:16px;display:block;margin-bottom:4px}
.qb-name{font-family:'Share Tech Mono',monospace;font-size:9px;font-weight:700;letter-spacing:1px;color:var(--gold);margin-bottom:2px}
.qb-desc{font-family:'Share Tech Mono',monospace;font-size:8px;color:var(--text-dim);line-height:1.4}
.army-forge-shell{max-width:1440px;height:100vh;margin:0 auto;padding:28px 20px 24px;display:grid;grid-template-columns:320px minmax(0,1fr);grid-template-rows:auto minmax(0,1fr);gap:20px}
.army-forge-page-head{grid-column:1 / -1;display:flex;justify-content:space-between;align-items:flex-end;gap:16px}
.army-forge-page-head h2{font-family:'Share Tech Mono',monospace;font-size:22px;letter-spacing:5px;color:var(--gold);margin:0 0 6px}
.army-forge-page-actions{display:flex;align-items:center;gap:10px;justify-content:flex-end}
.army-forge-sidebar,.army-forge-main{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:6px}
.army-forge-sidebar{padding:0;display:flex;flex-direction:column;min-height:0;overflow:auto}
.army-forge-sub{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--text-dim)}
.army-forge-new-btn,.army-forge-action{padding:8px 12px;background:transparent;border:1px solid var(--border);color:var(--text);font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:1px;cursor:pointer;border-radius:3px;transition:all .15s}
.army-forge-new-btn:hover,.army-forge-action:hover{border-color:var(--gold);color:var(--gold)}
.army-forge-action.gold{border-color:var(--gold);color:var(--gold);background:rgba(200,168,75,.08)}
.army-forge-action.gold:hover{background:rgba(200,168,75,.16)}
.army-forge-action.danger:hover{border-color:var(--red);color:var(--red-light)}
.army-forge-status{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:1px;color:var(--text-dim);text-align:right;max-width:320px}
.army-forge-list{display:flex;flex-direction:column;gap:8px;overflow:auto;padding-right:4px;max-height:280px}
.army-forge-list-item{padding:10px 12px;background:rgba(0,0,0,.24);border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:all .15s}
.army-forge-list-item:hover{border-color:var(--gold)}
.army-forge-list-item.active{border-color:var(--gold);background:rgba(200,168,75,.08)}
.army-forge-list-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}
.army-forge-list-meta{font-family:'Share Tech Mono',monospace;font-size:8px;letter-spacing:1px;color:var(--text-dim);line-height:1.6}
.army-forge-empty{padding:18px 14px;border:1px dashed var(--border);border-radius:4px;font-family:'Share Tech Mono',monospace;font-size:9px;line-height:1.7;color:var(--text-dim)}
.army-forge-main{padding:18px;min-height:0;overflow:auto}
.army-forge-toolbar{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.army-forge-fields{display:grid;grid-template-columns:minmax(220px,2fr) minmax(180px,1fr) 120px;gap:12px;flex:1}
.army-forge-field{display:flex;flex-direction:column;gap:6px}
.army-forge-field span{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--text-dim)}
.army-forge-field input,.army-forge-field select{background:var(--panel);border:1px solid var(--border);border-radius:3px;padding:10px 12px;color:var(--text);font-family:'Share Tech Mono',monospace;font-size:11px;outline:none}
.army-forge-field input:focus,.army-forge-field select:focus{border-color:var(--gold)}
.army-forge-toolbar-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}
.army-forge-summary{padding:14px 16px;margin-bottom:16px;border:1px solid var(--border);border-radius:4px;background:rgba(255,255,255,.02)}
.army-forge-summary-sidebar{margin:0;flex:1;display:flex;flex-direction:column;min-height:0;padding:18px;border:0;border-radius:0;background:transparent}
.army-forge-summary-title{font-family:'Share Tech Mono',monospace;font-size:15px;letter-spacing:3px;color:var(--gold);margin-bottom:6px}
.army-forge-summary-meta{font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:1px;color:var(--text);margin-bottom:6px}
.army-forge-summary-error{color:#ff6b6b}
.army-forge-summary-units{display:flex;flex-direction:column;gap:8px;overflow:auto;padding-right:4px}
.army-forge-summary-empty{padding:16px;border:1px dashed var(--border);border-radius:4px;font-family:'Share Tech Mono',monospace;font-size:9px;line-height:1.7;color:var(--text-dim)}
.army-forge-summary-group{display:flex;flex-direction:column;gap:8px}
.army-forge-summary-group-header{display:flex;justify-content:space-between;align-items:center;font-family:'Share Tech Mono',monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);padding-top:4px}
.army-forge-summary-group-header span{color:var(--gold);font-size:9px}
.army-forge-summary-card{padding:10px 12px;border:1px solid rgba(255,255,255,.08);border-radius:4px;background:rgba(255,255,255,.025);transition:border-color .15s}
.army-forge-summary-card:hover{border-color:rgba(200,168,75,.28)}
.army-forge-summary-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px}
.army-forge-summary-card-name{font-size:13px;font-weight:700;color:var(--text)}
.army-forge-summary-card-subtotal{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:1px;color:var(--gold);white-space:nowrap}
.army-forge-summary-card-meta{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:6px}
.army-forge-summary-card-qty{font-family:'Share Tech Mono',monospace;font-size:8px;letter-spacing:1px;color:var(--text-dim)}
.army-forge-summary-card-stats{font-family:'Share Tech Mono',monospace;font-size:8px;color:var(--text-dim);line-height:1.5}
.army-forge-summary-card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}
.army-forge-summary-card-tags .ru-tag{font-size:7px}
.army-forge-summary-card-controls{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:8px}
.army-forge-summary-card-controls .army-forge-qty button{width:24px;height:24px}
.army-forge-summary-card-controls .army-forge-qty span{font-size:11px}
.army-forge-roster{display:flex;flex-direction:column;gap:12px}
.army-forge-category{width:100%}
.army-forge-category-body{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start}
.army-forge-category-header{display:flex;align-items:center;gap:8px;margin:0 0 10px;padding:0;cursor:pointer;list-style:none;font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim)}
.army-forge-category-header::-webkit-details-marker{display:none}
.army-forge-category-header::before{content:'▾';font-size:10px;color:var(--text-dim);transition:transform .15s ease}
.army-forge-category:not([open]) .army-forge-category-header::before{transform:rotate(-90deg)}
.army-forge-unit{flex:0 0 280px;max-width:280px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:4px;padding:12px;display:flex;flex-direction:column;gap:8px}
.army-forge-unit-header{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.army-forge-unit-name-wrap{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;width:100%}
.army-forge-unit-name{font-size:14px;font-weight:700;color:var(--text)}
.army-forge-unit-pricing{display:flex;flex-direction:column;gap:5px;align-items:flex-end}
.army-forge-unit-pts{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:1px;color:var(--gold);white-space:nowrap}
.army-forge-unit-estimate{font-family:'Share Tech Mono',monospace;font-size:9px;font-weight:700;color:#fff;background:linear-gradient(90deg,rgba(45,200,255,.95),rgba(35,150,255,.95));padding:4px 7px;border-radius:4px;white-space:nowrap;box-shadow:0 0 0 1px rgba(255,255,255,.08)}
.army-forge-unit-stats,.army-forge-unit-weapons,.army-forge-unit-rules,.army-forge-unit-summary{font-family:'Share Tech Mono',monospace;font-size:8px;line-height:1.6;color:var(--text-dim)}
.army-forge-unit-summary{color:var(--cyan);background:rgba(29,150,255,.06);padding:5px 8px;border-radius:4px;border:1px solid rgba(29,150,255,.15)}
.army-forge-unit-weapons{white-space:normal}
.army-forge-unit-rules{display:flex;gap:4px;flex-wrap:wrap;white-space:normal}
.army-forge-unit-rules .ru-tag{font-size:7px}
.army-forge-unit-controls{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:auto}
.army-forge-qty{display:flex;align-items:center;gap:8px}
.army-forge-qty button{width:28px;height:28px;background:transparent;border:1px solid var(--border);color:var(--text);font-family:'Share Tech Mono',monospace;font-size:14px;cursor:pointer;border-radius:3px}
.army-forge-qty button:hover{border-color:var(--gold);color:var(--gold)}
.army-forge-qty span{min-width:18px;text-align:center;font-family:'Share Tech Mono',monospace;font-size:12px;color:var(--gold)}
.army-forge-unit-limit{font-family:'Share Tech Mono',monospace;font-size:8px;color:var(--text-dim)}
.army-forge-illegal{border-color:rgba(213,58,58,.45);background:rgba(213,58,58,.06)}
.army-forge-load-modal{width:min(760px,100%);max-height:min(80vh,760px);background:var(--panel);border:1px solid var(--border);border-radius:6px;padding:18px;display:flex;flex-direction:column}
.army-forge-load-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}
.army-forge-load-title{font-family:'Share Tech Mono',monospace;font-size:14px;letter-spacing:4px;color:var(--gold);margin-bottom:4px}
.army-forge-load-sub{font-family:'Share Tech Mono',monospace;font-size:8px;letter-spacing:1px;color:var(--text-dim)}
.army-forge-load-list{max-height:none;flex:1;min-height:120px}
.faction-btn .fb-icon{font-size:14px;display:block;margin-bottom:2px}
.faction-btn .fb-name{font-size:9px;font-weight:700;letter-spacing:1px;display:block}
.faction-btn .fb-desc{font-size:8px;color:var(--text-dim);margin-top:2px;line-height:1.4;display:block}
.pts-bar{font-family:'Share Tech Mono',monospace;font-size:10px;margin-bottom:10px;padding:4px 8px;border-radius:2px;border:1px solid var(--border)}
.pts-bar.ok{color:var(--green);border-color:var(--green)}
.pts-bar.over{color:var(--red-light);border-color:var(--red)}
.roster-unit{padding:10px 12px;border:1px solid var(--border);border-radius:3px;margin-bottom:8px;background:rgba(255,255,255,.02);transition:border-color .15s}
.roster-unit:hover{border-color:rgba(255,255,255,.15)}
.roster-unit.selected{border-color:var(--gold);background:rgba(200,168,75,.04)}
.ru-header{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.ru-name{font-size:13px;font-weight:700}
.ru-pts-tag{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--gold);white-space:nowrap}
.ru-estimate-tag{font-family:'Share Tech Mono',monospace;font-size:10px;font-weight:700;color:#ffffff;background:linear-gradient(90deg,rgba(45,200,255,.95),rgba(35,150,255,.95));padding:4px 7px;border-radius:4px;margin-left:auto;white-space:nowrap;box-shadow:0 0 0 1px rgba(255,255,255,.08)}
.ru-stats{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);margin-bottom:5px;letter-spacing:.3px}
.ru-cost-summary{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--cyan);margin:4px 0 10px;letter-spacing:.1px;background:rgba(29,150,255,.06);padding:5px 8px;border-radius:4px;border:1px solid rgba(29,150,255,.15)}
.ru-weapons{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);margin-bottom:5px;line-height:1.6}
.ru-weapon-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.ru-weapon-name{color:var(--text)}
.ru-tag{font-size:8px;padding:1px 5px;border-radius:2px;letter-spacing:.5px;font-weight:700;white-space:nowrap}
.ru-tag.ap{background:rgba(213,58,58,.15);border:1px solid rgba(213,58,58,.4);color:var(--red-light)}
.ru-tag.special{background:rgba(200,168,75,.12);border:1px solid rgba(200,168,75,.35);color:var(--gold)}
.ru-tag.ability{background:rgba(120,80,220,.12);border:1px solid rgba(120,80,220,.35);color:#a080ff}
.ru-tag.faction{background:rgba(100,180,255,.1);border:1px solid rgba(100,180,255,.3);color:#7ec8ff}
.ru-tag.grenade{background:rgba(176,122,232,.15);border:1px solid rgba(176,122,232,.4);color:#c9a0f8}
.ru-rules{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:5px}
.ru-qty-row{display:flex;align-items:center;gap:8px;margin-top:4px}
.qty-ctrl{display:flex;align-items:center;gap:5px}
.qty-btn{width:22px;height:22px;border-radius:2px;border:1px solid var(--border);background:rgba(255,255,255,.05);color:var(--text);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .15s}
.qty-btn:hover{border-color:var(--gold);color:var(--gold)}
.qty-val{font-family:'Share Tech Mono',monospace;font-size:12px;width:18px;text-align:center}
#builder-confirm{margin-top:20px;padding:12px 40px;background:rgba(58,173,94,.15);border:1px solid var(--green);color:var(--green);font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;letter-spacing:3px;cursor:pointer;border-radius:2px;transition:all .15s;text-transform:uppercase}
#builder-confirm:hover{background:rgba(58,173,94,.3)}
#builder-confirm:disabled{opacity:.3;cursor:not-allowed}

/* ── HANDOFF BANNER ── */
#handoff-banner{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:150;align-items:center;justify-content:center;flex-direction:column;gap:16px}
#handoff-banner.show{display:flex}
#handoff-title{font-family:'Share Tech Mono',monospace;font-size:22px;letter-spacing:4px}
#handoff-title.blue{color:var(--a-light)}
#handoff-title.red{color:var(--b-light)}
#handoff-msg{font-size:14px;color:var(--text-dim)}
#handoff-banner button{padding:10px 32px;background:var(--blue-dim);border:1px solid var(--blue);color:var(--blue-light);font-family:'Rajdhani',sans-serif;font-size:15px;font-weight:700;letter-spacing:2px;cursor:pointer;text-transform:uppercase;transition:all .15s}
#handoff-banner button:hover{background:var(--blue);color:#fff}

/* ── ROUND SUMMARY ── */
#round-summary{display:none;position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:120;align-items:center;justify-content:center}
#round-summary.show{display:flex}
#rs-box{background:var(--panel);border:1px solid var(--border);padding:24px 32px;min-width:340px;max-width:460px;font-family:'Share Tech Mono',monospace}
#rs-box h2{font-size:14px;letter-spacing:3px;color:var(--gold);margin-bottom:16px;text-align:center}
.summary-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:11px}
.summary-row .slabel{color:var(--text-dim)}
.sblue{color:var(--a-light)}.sred{color:var(--b-light)}.sgold{color:var(--gold)}.sgreen{color:var(--green)}
#rs-box button{width:100%;margin-top:16px;padding:9px;font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border-radius:2px;border:1px solid var(--gold);background:rgba(200,168,75,.1);color:var(--gold)}
#rs-box button:hover{background:rgba(200,168,75,.25)}

/* ── MODAL ── */
#modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:100;align-items:center;justify-content:center}
#modal-overlay.show{display:flex}
#modal-box{background:var(--panel);border:1px solid var(--gold);padding:24px 32px;max-width:420px;width:90%;text-align:center}
#modal-box h2{font-size:22px;color:var(--gold);margin-bottom:10px;letter-spacing:2px}
#modal-box p{color:var(--text-dim);font-size:13px;margin-bottom:16px;line-height:1.6}
#modal-box button{padding:8px 24px;background:var(--blue-dim);border:1px solid var(--blue);color:var(--blue-light);font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;letter-spacing:2px;cursor:pointer;text-transform:uppercase}
#modal-box button:hover{background:var(--blue);color:#fff}

/* auto deploy buttons */
#auto-deploy-panel{display:none;padding:10px;border-bottom:1px solid var(--border)}
#auto-deploy-panel.visible{display:block}
.formation-btn{width:100%;padding:6px 10px;margin-bottom:5px;background:rgba(255,255,255,.03);border:1px solid var(--border);color:var(--text-dim);font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;border-radius:2px;cursor:pointer;text-align:left;transition:all .15s;display:flex;align-items:center;gap:8px}
.formation-btn:hover{border-color:var(--a-primary);color:var(--a-light);background:color-mix(in srgb, var(--a-primary) 8%, transparent)}
.formation-btn .f-icon{font-size:13px;width:16px;text-align:center;flex-shrink:0}
.formation-btn .f-desc{font-size:9px;font-family:'Share Tech Mono',monospace;color:var(--text-dim);letter-spacing:0;text-transform:none;margin-top:1px}
#btn-start-battle{display:none;width:calc(100% - 20px);margin:8px 10px;padding:10px;background:rgba(58,173,94,.15);border:1px solid var(--green);color:var(--green);font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:all .15s}
#btn-start-battle.ready{display:block;animation:pulse-green 1.5s ease-in-out infinite}
@keyframes pulse-green{0%,100%{box-shadow:0 0 4px rgba(58,173,94,.3)}50%{box-shadow:0 0 12px rgba(58,173,94,.7)}}

/* coherency drag highlight */
.tile-coherency{width:var(--tile);height:var(--tile);background:rgba(200,168,75,.15);border:1px dashed rgba(200,168,75,.5);pointer-events:auto;cursor:pointer}
.coh-score{position:absolute;bottom:1px;right:2px;font-size:7px;line-height:1;color:rgba(200,168,75,.9);pointer-events:none;user-select:none}

/* ── MAELSTROM CARDS ── */
#maelstrom-tray{background:var(--panel);border-top:1px solid var(--border);padding:6px 12px;display:none;flex-shrink:0;gap:8px;align-items:stretch}
#maelstrom-tray.show{display:flex}
.mael-card{flex:1;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:4px;padding:7px 10px;font-family:'Share Tech Mono',monospace;position:relative;min-width:0}
.mael-card-name{font-size:11px;font-weight:700;color:var(--gold);margin-bottom:3px;letter-spacing:.5px}
.mael-card-desc{font-size:9px;color:var(--text-dim);line-height:1.4;margin-bottom:4px}
.mael-card-vp{font-size:10px;color:var(--gold);font-weight:700}
.mael-card-scored{position:absolute;top:4px;right:4px;font-size:9px;padding:1px 5px;border-radius:2px}
.mael-card-scored.blue{background:var(--a-dim);color:var(--a-light);border:1px solid var(--a-primary)}
.mael-card-scored.red{background:var(--b-dim);color:var(--b-light);border:1px solid var(--b-primary)}
.mael-discard-btn{width:100%;margin-top:4px;padding:2px 0;background:rgba(213,58,58,.1);border:1px solid rgba(213,58,58,.3);color:rgba(213,58,58,.7);font-family:'Share Tech Mono',monospace;font-size:8px;letter-spacing:1px;cursor:pointer;border-radius:2px;transition:all .15s}
.mael-discard-btn:hover{background:rgba(213,58,58,.25);color:var(--red-light)}
.mael-discard-btn:disabled{opacity:.3;cursor:not-allowed}
#mael-vp{display:flex;flex-direction:column;justify-content:center;gap:4px;flex-shrink:0;padding:0 4px}
.mael-vp-chip{font-family:'Share Tech Mono',monospace;font-size:11px;font-weight:700;padding:3px 8px;border-radius:2px;white-space:nowrap}
.mael-vp-chip.blue{background:var(--a-dim);color:var(--a-light);border:1px solid var(--a-primary)}
.mael-vp-chip.red{background:var(--b-dim);color:var(--b-light);border:1px solid var(--b-primary)}
/* highlight scoring mode selector */
.mode-card.scoring-selected{border-color:var(--gold);background:rgba(200,168,75,.08)}

@media (max-width: 980px){
  .army-forge-shell{height:auto;min-height:100vh;grid-template-columns:1fr;grid-template-rows:auto auto auto}
  .army-forge-page-head{gap:10px;align-items:flex-start;flex-direction:column}
  .army-forge-page-actions,.page-topbar{width:100%;justify-content:space-between}
  .army-forge-sidebar{min-height:0}
  .army-forge-fields{grid-template-columns:1fr}
  .qb-army-grid{grid-template-columns:1fr}
  .glossary-cols{grid-template-columns:1fr}
  #glossary-screen{overflow-y:auto}
  #glossary-screen .glossary-shell{height:auto}
  .glossary-col{overflow:visible}
}

/* ── TACTICAL ORDERS TRAY ── */
#tactical-tray{background:var(--panel);border-top:1px solid var(--border);padding:6px 12px;display:none;flex-shrink:0;gap:8px;align-items:stretch}
#tactical-tray.show{display:flex}
.tact-side-label{font-family:'Share Tech Mono',monospace;font-size:9px;letter-spacing:2px;writing-mode:vertical-rl;text-orientation:mixed;display:flex;align-items:center;padding:0 2px;flex-shrink:0}
.tact-side-label.blue{color:var(--a-light)}
.tact-side-label.red{color:var(--b-light)}
.tact-cards{display:flex;gap:6px;flex:1;align-items:stretch}
.tact-card{flex:1;min-width:0;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:4px;padding:7px 10px;font-family:'Share Tech Mono',monospace;position:relative;cursor:default}
.tact-card.blue-card{border-color:color-mix(in srgb, var(--a-primary) 35%, transparent);background:color-mix(in srgb, var(--a-primary) 4%, transparent)}
.tact-card.red-card{border-color:color-mix(in srgb, var(--b-primary) 35%, transparent);background:color-mix(in srgb, var(--b-primary) 4%, transparent)}
.tact-card.scored{opacity:.45}
.tact-card-name{font-size:11px;font-weight:700;color:var(--gold);margin-bottom:3px;letter-spacing:.5px}
.tact-card-desc{font-size:9px;color:var(--text-dim);line-height:1.4;margin-bottom:4px}
.tact-card-vp{font-size:10px;color:var(--gold);font-weight:700}
.tact-card-badge{position:absolute;top:4px;right:4px;font-size:9px;padding:1px 5px;border-radius:2px}
.tact-card-badge.scored-blue{background:var(--a-dim);color:var(--a-light);border:1px solid var(--a-primary)}
.tact-card-badge.scored-red{background:var(--b-dim);color:var(--b-light);border:1px solid var(--b-primary)}
#tact-vp{display:flex;flex-direction:column;justify-content:center;gap:4px;flex-shrink:0;padding:0 4px}

/* ── TACTICAL DRAFT SCREEN ── */
#tactical-draft-screen{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:180;flex-direction:column;align-items:center;justify-content:center;gap:16px}
#tactical-draft-screen.show{display:flex}
#tactical-draft-screen h2{font-family:'Share Tech Mono',monospace;font-size:18px;letter-spacing:4px;color:var(--gold)}
.tact-draft-sub{font-family:'Share Tech Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:2px}
#tact-draft-cards{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;max-width:860px}
.tact-draft-card{width:150px;background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:12px;cursor:pointer;transition:all .2s;font-family:'Share Tech Mono',monospace}
.tact-draft-card:hover{border-color:var(--gold);background:rgba(200,168,75,.06)}
.tact-draft-card.selected-discard{border-color:var(--red);background:rgba(213,58,58,.1);opacity:.6}
.tact-draft-card.selected-keep{border-color:var(--green);background:rgba(58,173,94,.08)}
.tact-draft-card-name{font-size:11px;font-weight:700;color:var(--gold);margin-bottom:4px}
.tact-draft-card-desc{font-size:9px;color:var(--text-dim);line-height:1.5;margin-bottom:6px}
.tact-draft-card-vp{font-size:10px;color:var(--gold)}
#tact-draft-confirm{padding:10px 32px;background:rgba(58,173,94,.12);border:1px solid var(--green);color:var(--green);font-family:'Rajdhani',sans-serif;font-size:15px;font-weight:700;letter-spacing:3px;cursor:pointer;text-transform:uppercase;border-radius:2px;transition:all .15s}
#tact-draft-confirm:hover:not(:disabled){background:rgba(58,173,94,.25)}
#tact-draft-confirm:disabled{opacity:.3;cursor:not-allowed}

/* ── SIMULATION ── */
.sim-section-title{font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--gold);margin-bottom:8px;text-transform:uppercase}
.sim-table{width:100%;border-collapse:collapse;font-family:'Share Tech Mono',monospace;font-size:11px}
.sim-table th{text-align:left;color:var(--text-dim);font-size:9px;letter-spacing:1.5px;padding:4px 8px;border-bottom:1px solid var(--border)}
.sim-table td{padding:5px 8px;border-bottom:1px solid rgba(255,255,255,.04)}
.sim-table tr:hover td{background:rgba(255,255,255,.03)}
.sim-matchup{color:var(--text)}
.sim-pct{color:var(--text-dim);font-size:9px}
.sim-toggle{font-family:'Share Tech Mono',monospace;font-size:10px;padding:5px 12px;border:1px solid var(--border);color:var(--text-dim);background:transparent;cursor:pointer;border-radius:2px;transition:all .15s}
.sim-toggle:hover{border-color:var(--gold);color:var(--gold)}
.sim-toggle-active{border-color:var(--gold)!important;color:var(--gold)!important;background:rgba(200,160,60,.1)!important}

/* ── TUTORIAL ── */
#tutorial-panel{position:fixed;bottom:44px;left:50%;transform:translateX(-50%);width:min(520px,92vw);background:var(--panel);border:1px solid var(--gold);border-radius:4px;box-shadow:0 4px 24px rgba(0,0,0,.75),0 0 18px rgba(200,168,75,.12);z-index:90;font-family:'Share Tech Mono',monospace}
.tut-inner{padding:14px 16px}
.tut-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.tut-counter{font-size:9px;color:var(--text-dim);letter-spacing:2px}
.tut-skip{background:transparent;border:none;color:var(--text-dim);font-size:9px;font-family:'Share Tech Mono',monospace;cursor:pointer;letter-spacing:1px;padding:0;transition:color .15s}
.tut-skip:hover{color:var(--red-light)}
.tut-title{font-size:11px;letter-spacing:3px;color:var(--gold);margin-bottom:8px}
.tut-body{font-size:11px;color:var(--text);line-height:1.75;margin-bottom:12px}
.tut-blue{color:var(--a-light)}
.tut-gold{color:var(--gold)}
.tut-btn{width:100%;padding:8px;background:rgba(200,168,75,.1);border:1px solid var(--gold);color:var(--gold);font-family:'Share Tech Mono',monospace;font-size:11px;letter-spacing:2px;cursor:pointer;border-radius:2px;transition:background .15s}
.tut-btn:hover{background:rgba(200,168,75,.22)}
.tut-waiting{font-size:9px;color:var(--text-dim);text-align:center;letter-spacing:1px;padding:4px 0}
/* Spotlight highlight — pulsing gold ring around the pointed-to element */
.tutorial-spotlight{box-shadow:0 0 0 2px var(--gold),0 0 16px rgba(200,168,75,.35)!important;border-radius:3px;animation:tut-pulse 1.6s ease-in-out infinite;position:relative;z-index:6}
@keyframes tut-pulse{0%,100%{box-shadow:0 0 0 2px var(--gold),0 0 16px rgba(200,168,75,.35)}50%{box-shadow:0 0 0 3px var(--gold),0 0 28px rgba(200,168,75,.55)}}
