﻿@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;
  --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}

/* ── 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(--blue-dim);color:var(--blue-light);border:1px solid var(--blue)}
#phase-badge.red{background:var(--red-dim);color:var(--red-light);border-color:var(--red)}
#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)}
.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)}
.unit-card.deployable{border-color:rgba(58,123,213,.3)}
.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--faction{background:rgba(100,180,255,.1);border-color:rgba(100,180,255,.3);color:#7ec8ff}
/* 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:rgba(58,123,213,.05);border-bottom:1px dashed rgba(58,123,213,.25);pointer-events:none;transition:all .3s}
#dz-blue.active{background:rgba(58,123,213,.12);border-bottom:2px dashed rgba(58,123,213,.6)}
#dz-blue.active::after{content:'BLUE DEPLOYMENT ZONE';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);font-family:'Share Tech Mono',monospace;font-size:10px;color:rgba(111,163,232,.5);letter-spacing:2px;pointer-events:none;white-space:nowrap}
#dz-red{position:absolute;background:rgba(213,58,58,.05);border-top:1px dashed rgba(213,58,58,.25);pointer-events:none;transition:all .3s}
#dz-red.active{background:rgba(213,58,58,.12);border-top:2px dashed rgba(213,58,58,.6)}
#dz-red.active::after{content:'RED DEPLOYMENT ZONE';position:absolute;top:4px;left:50%;transform:translateX(-50%);font-family:'Share Tech Mono',monospace;font-size:10px;color:rgba(232,112,112,.5);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-y:auto;padding:30px 20px}
#glossary-screen.show{display:flex}
#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:24px}
.glossary-cols{display:flex;gap:24px;width:100%;max-width:1200px;align-items:flex-start}
.glossary-col{flex:1}
.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.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}
#glossary-close{margin-top:24px;padding:8px 32px;background:rgba(200,168,75,.1);border:1px solid var(--gold);color:var(--gold);font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;letter-spacing:2px;cursor:pointer;text-transform:uppercase;border-radius:2px;transition:all .15s}
#glossary-close:hover{background:rgba(200,168,75,.2)}
/* ── 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}
.tile-deploy{background:rgba(58,123,213,.18);border:1px solid rgba(58,123,213,.4);pointer-events:auto;cursor:pointer}
.tile-deploy:hover{background:rgba(58,123,213,.35)!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,.06) 0,rgba(0,0,0,.06) 1px,transparent 1px,transparent 10px),
    repeating-linear-gradient(90deg,rgba(0,0,0,.06) 0,rgba(0,0,0,.06) 1px,transparent 1px,transparent 14px),
    rgba(46,41,36,.28);
  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 — small pieces of terrain that look like actual objects */
.scatter-piece{position:absolute;pointer-events:auto;cursor:default;z-index:3;box-sizing:border-box}

/* Barrel — brown oval with two metal band lines */
.scatter-piece.barrel{
  background:radial-gradient(ellipse 65% 88% at 50% 50%,#8a4215 20%,#5a2808 62%,#280e02 100%);
  border-radius:42% 42% 40% 40%/48% 48% 52% 52%;
  border:1.5px solid #1a0802;
  margin:3px;
  width:calc(var(--tile) - 6px);height:calc(var(--tile) - 6px);
  box-shadow:inset 0 -3px 5px rgba(0,0,0,.45),inset 0 2px 4px rgba(255,160,60,.1)}
.scatter-piece.barrel::before,.scatter-piece.barrel::after{
  content:'';position:absolute;left:10%;right:10%;height:1.5px;
  background:rgba(12,4,0,.7);border-radius:50%}
.scatter-piece.barrel::before{top:30%}
.scatter-piece.barrel::after{top:62%}

/* Sandbag pile — stacked earthy ovals */
.scatter-piece.sandbag{
  background:
    radial-gradient(ellipse 80% 45% at 25% 78%,#8b7355 60%,transparent 100%),
    radial-gradient(ellipse 80% 45% at 75% 78%,#856e4f 60%,transparent 100%),
    radial-gradient(ellipse 70% 45% at 50% 42%,#7a6545 60%,transparent 100%),
    radial-gradient(ellipse 55% 40% at 50% 15%,#6a5535 55%,transparent 100%);
  border-radius:4px;
  margin:2px;
  width:calc(var(--tile) - 4px);height:calc(var(--tile) - 4px);
  box-shadow:0 2px 4px rgba(0,0,0,.5);
  border:1px solid rgba(60,45,25,.5)}

/* Rubble pile — broken masonry chunks */
.scatter-piece.rubble{
  background:
    radial-gradient(ellipse 88% 55% at 28% 72%,#6b5a47 50%,transparent 100%),
    radial-gradient(ellipse 65% 50% at 72% 65%,#5a4a38 55%,transparent 100%),
    radial-gradient(ellipse 55% 42% at 55% 28%,#7a6850 65%,transparent 100%),
    rgba(36,30,22,.92);
  border-radius:3px;
  margin:2px;
  width:calc(var(--tile) - 4px);height:calc(var(--tile) - 4px);
  box-shadow:inset 0 1px 4px rgba(0,0,0,.55),0 1px 3px rgba(0,0,0,.45);
  border:1px solid rgba(38,28,16,.5)}
.scatter-piece.rubble::before{
  content:'';position:absolute;
  width:38%;height:28%;top:18%;left:12%;
  background:rgba(90,76,58,.8);border-radius:2px;
  box-shadow:18px 22px 0 rgba(75,62,46,.7),28px 8px 0 rgba(85,70,52,.6)}

/* Crate — wooden box with cross-brace */
.scatter-piece.crate{
  background:#8b6b14;
  border:2px solid #3a2808;
  border-radius:1px;
  margin:2px;
  width:calc(var(--tile) - 4px);height:calc(var(--tile) - 4px);
  background-image:
    linear-gradient(rgba(0,0,0,.35) 1.5px,transparent 1.5px),
    linear-gradient(90deg,rgba(0,0,0,.35) 1.5px,transparent 1.5px),
    linear-gradient(rgba(255,200,80,.06),rgba(0,0,0,.1));
  background-size:50% 50%,50% 50%,100% 100%;
  box-shadow:inset 0 0 5px rgba(0,0,0,.35),0 1px 3px rgba(0,0,0,.5)}

/* 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:rgba(58,123,213,.35);background:rgba(58,123,213,.06)}
.obj-marker.red::before{border-color:rgba(213,58,58,.35);background:rgba(213,58,58,.06)}
.obj-inner.blue{border-color:var(--blue);color:var(--blue-light);background:rgba(58,123,213,.25)}
.obj-inner.red{border-color:var(--red);color:var(--red-light);background:rgba(213,58,58,.25)}

/* 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(--blue-dim);color:var(--blue-light);border-color:var(--blue)}
.model-token.red .inner{background:var(--red-dim);color:var(--red-light);border-color:var(--red)}
/* 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:#8fc8ff}
.model-token.red.leader .inner{border-color:#ffaaaa}
.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 rgba(100,180,255,.55),0 0 10px rgba(100,180,255,.25)}
.model-token.red.squad-hover .inner{box-shadow:0 0 0 2px rgba(255,110,110,.55),0 0 10px rgba(255,110,110,.25)}
/* 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}
/* 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(--blue-light)}
.log-entry.red{color:var(--red-light)}
.log-entry.gold{color:var(--gold)}
.log-entry.green{color:var(--green)}
/* 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(--blue-light)}
.log-dice-label.red{color:var(--red-light)}
.log-dice-label.save-blue{color:var(--blue-light)}
.log-dice-label.save-red{color:var(--red-light)}
.log-dice-row{display:flex;flex-wrap:wrap;gap:3px}

/* ── 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(--blue-dim);color:var(--blue-light);border:1px solid var(--blue)}
.score-chip.red{background:var(--red-dim);color:var(--red-light);border:1px solid var(--red)}

/* ── 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(--blue-light)}
.builder-col h3.red{color:var(--red-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(--blue);background:rgba(58,123,213,.12);color:var(--blue-light)}
.faction-btn.selected.red-side{border-color:var(--red);background:rgba(213,58,58,.12);color:var(--red-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-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}
.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);margin-left:auto;white-space:nowrap}
.ru-stats{font-family:'Share Tech Mono',monospace;font-size:9px;color:var(--text-dim);margin-bottom:5px;letter-spacing:.3px}
.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.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(--blue-light)}
#handoff-title.red{color:var(--red-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(--blue-light)}.sred{color:var(--red-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(--blue);color:var(--blue-light);background:rgba(58,123,213,.08)}
.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}

/* ── 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(--blue-dim);color:var(--blue-light);border:1px solid var(--blue)}
.mael-card-scored.red{background:var(--red-dim);color:var(--red-light);border:1px solid var(--red)}
.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(--blue-dim);color:var(--blue-light);border:1px solid var(--blue)}
.mael-vp-chip.red{background:var(--red-dim);color:var(--red-light);border:1px solid var(--red)}
/* highlight scoring mode selector */
.mode-card.scoring-selected{border-color:var(--gold);background:rgba(200,168,75,.08)}

/* ── 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(--blue-light)}
.tact-side-label.red{color:var(--red-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:rgba(58,123,213,.35);background:rgba(58,123,213,.04)}
.tact-card.red-card{border-color:rgba(213,58,58,.35);background:rgba(213,58,58,.04)}
.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(--blue-dim);color:var(--blue-light);border:1px solid var(--blue)}
.tact-card-badge.scored-red{background:var(--red-dim);color:var(--red-light);border:1px solid var(--red)}
#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}
