:root{
  --bg:#0b0b0d;
  --panel:#101014;
  --line:#22242a;
  --text:#e7e7ea;
  --muted:#a6a6b0;
  --btn:#14151a;
  --btn2:#1a1c22;
  --focus:#79a7ff;
  --accent:#d8bd7e;
  --combat-h:176px;
  --hud-h:72px;
  --side-w:336px;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
  --ui-font:'Source Sans 3', 'Segoe UI', Tahoma, sans-serif;
}

*{box-sizing:border-box;}
html,body{
  height:100%;
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--ui-font);
  font-size:16px;
  -webkit-text-size-adjust:100%;
}
body{
  padding:var(--safe-top) var(--safe-right) var(--safe-bottom) var(--safe-left);
}

body.intro-open #hud,
body.intro-open #layout,
body.intro-open #combatRail{
  filter:blur(3px) saturate(0.92);
  pointer-events:none;
  user-select:none;
}

.introOverlay{
  position:fixed;
  inset:0;
  z-index:360;
  display:none;
  align-items:center;
  justify-content:center;
  padding:clamp(14px, 3vw, 34px);
  background:radial-gradient(120% 90% at 50% 0%, rgba(25,28,38,0.60), rgba(6,8,12,0.88));
  backdrop-filter:blur(6px) saturate(106%);
  -webkit-backdrop-filter:blur(6px) saturate(106%);
}

.introOverlay.open{
  display:flex;
}

.introCard{
  width:min(1040px, 95vw);
  max-height:min(92dvh, 920px);
  overflow:auto;
  border:1px solid rgba(216,189,126,0.42);
  border-radius:16px;
  padding:clamp(20px, 3vw, 34px);
  background:linear-gradient(180deg, rgba(16,18,24,0.97), rgba(11,13,18,0.97));
  box-shadow:0 22px 70px rgba(0,0,0,0.56);
}

.introTitle{
  margin:0 0 10px;
  text-align:center;
  font-family:'Cinzel','Trajan Pro','Times New Roman',serif;
  font-weight:700;
  letter-spacing:0.09em;
  text-transform:uppercase;
  color:#efe4c7;
  font-size:clamp(42px, 2.2vw + 12px, 64px);
}

.introLead{
  margin:0 auto 16px;
  max-width:70ch;
  text-align:center;
  color:#d8dbe3;
  font-size:clamp(17px, 0.8vw + 13px, 22px);
  line-height:1.5;
}

.introActions{
  display:grid;
  gap:10px;
}

.introActionBtn{
  width:100%;
  padding:14px 16px;
  min-height:84px;
  text-align:left;
  border-color:rgba(216,189,126,0.24);
  background:linear-gradient(180deg, rgba(24,27,36,0.94), rgba(16,18,25,0.94));
}

.introActionTitle{
  display:block;
  font-size:22px;
  font-weight:700;
  color:#f0e3bf;
  letter-spacing:0.02em;
}

.introActionSub{
  display:block;
  margin-top:3px;
  font-size:15px;
  color:#cbd0db;
  line-height:1.35;
}

.introTutorialPanel{
  margin-top:12px;
  border:1px solid rgba(216,189,126,0.3);
  border-radius:12px;
  padding:12px;
  background:rgba(8,10,16,0.72);
}

.introTutorialPanel h2{
  margin:0 0 8px;
  font-family:'Cinzel','Trajan Pro','Times New Roman',serif;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:#e6d29d;
  font-size:18px;
}

.introTutorialPanel p,
.introTutorialPanel li{
  color:#d4d9e2;
  font-size:15px;
  line-height:1.45;
}

.introTutorialPanel ul{
  margin:8px 0 12px;
  padding-left:18px;
}

.tutorialGuideOverlay{
  position:fixed;
  z-index:320;
  left:calc(var(--safe-left) + 10px);
  right:auto;
  top:calc(var(--safe-top) + 98px);
  width:min(580px, calc(100vw - var(--side-w) - 34px));
  max-width:min(580px, calc(100vw - var(--side-w) - 34px));
  pointer-events:none;
}

.tutorialGuideCard{
  pointer-events:auto;
  border:1px solid rgba(216,189,126,0.48);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(14,16,23,0.96), rgba(10,12,18,0.94));
  box-shadow:0 20px 54px rgba(0,0,0,0.45);
  padding:16px 18px;
  max-height:min(80dvh, 760px);
  overflow:auto;
}

.tutorialGuideHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}

.tutorialGuideHeadRight{
  display:flex;
  align-items:center;
  gap:6px;
  justify-content:flex-end;
  flex-wrap:wrap;
}

.tutorialGuideHeadBtn{
  min-height:28px;
  padding:5px 9px;
  font-size:13px;
  border-radius:999px;
  background:rgba(255,255,255,0.03);
}

.tutorialGuideHead h2{
  margin:0;
  font-family:'Cinzel','Trajan Pro','Times New Roman',serif;
  font-size:21px;
  letter-spacing:0.07em;
  text-transform:uppercase;
  color:#e8d8aa;
}

.tutorialGuideStepMeta{
  font-size:13px;
  color:#c6cedd;
  padding:3px 8px;
  border:1px solid rgba(216,189,126,0.35);
  border-radius:999px;
  white-space:nowrap;
}

.tutorialGuideStepTitle{
  margin:10px 0 6px;
  font-size:24px;
  line-height:1.25;
  color:#f2f5fb;
}

.tutorialGuideStepText{
  margin:0;
  color:#d9dee9;
  font-size:19px;
  line-height:1.45;
}

.tutorialGuideLearn{
  margin:10px 0 4px;
  padding-left:18px;
  color:#d8deea;
  font-size:15px;
  line-height:1.35;
}

.tutorialGuideLearn li{
  margin:0 0 4px;
}

.tutorialGuideUnitWrap{
  margin-top:10px;
  border:1px solid rgba(216,189,126,0.34);
  border-radius:10px;
  padding:8px 10px;
  background:linear-gradient(180deg, rgba(33,28,20,0.46), rgba(21,18,13,0.42));
}

.tutorialGuideUnitLabel{
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#f0ddae;
  font-weight:700;
}

.tutorialGuideUnitMove,
.tutorialGuideUnitRole{
  margin-top:5px;
  color:#e7ecf8;
  font-size:15px;
  line-height:1.35;
}

.tutorialGuideUnitNotes{
  margin:7px 0 0;
  padding-left:18px;
  color:#d6dcea;
  font-size:14px;
  line-height:1.3;
}

.tutorialGuideUnitNotes li{
  margin:0 0 4px;
}

.tutorialGuideOverlay.is-minimized{
  width:min(360px, calc(100vw - 16px));
  max-width:min(360px, calc(100vw - 16px));
}

.tutorialGuideOverlay.is-minimized .tutorialGuideCard{
  padding:10px 12px;
  max-height:none;
}

.tutorialGuideOverlay.is-minimized .tutorialGuideCard > :not(.tutorialGuideHead){
  display:none !important;
}

.tutorialGuideTaskWrap{
  margin-top:10px;
  border:1px solid rgba(173, 147, 236, 0.5);
  border-radius:10px;
  padding:8px 10px;
  background:linear-gradient(180deg, rgba(44,35,67,0.72), rgba(21,17,37,0.72));
}

.tutorialGuideTaskLabel{
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#d2c3ff;
  font-weight:700;
}

.tutorialGuideTaskText{
  margin-top:3px;
  color:#f3f5fb;
  font-size:17px;
  line-height:1.35;
}

.tutorialGuideTaskStatus{
  margin-top:5px;
  font-size:14px;
  color:#c6cee0;
}

.tutorialGuideTaskStatus.done{
  color:#9be1a6;
}

.tutorialGuideControls{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
}

.tutorialGuideFooter{
  margin-top:8px;
  display:flex;
  justify-content:flex-end;
}

.tutorialGuideOverlay[hidden]{
  display:none !important;
}

.introEgg{
  margin:14px 0 0;
  text-align:center;
  color:#9098a8;
  font-style:italic;
  letter-spacing:0.02em;
  font-size:12px;
}

@media (max-width: 980px){
  .tutorialGuideOverlay{
    left:8px;
    right:8px;
    top:auto;
    bottom:calc(var(--combat-h) + 8px);
    width:auto;
  }
  .tutorialGuideStepTitle{
    font-size:20px;
  }
  .tutorialGuideStepText{
    font-size:16px;
  }
  .tutorialGuideLearn{
    font-size:14px;
  }
  .tutorialGuideTaskText{
    font-size:15px;
  }
  .tutorialGuideControls{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

#hud{
  position:relative;
  padding:10px 14px;
  border-bottom:1px solid var(--line);
}
#hudTitle{
  font-family:'Cinzel','Trajan Pro','Times New Roman',serif;
  font-weight:700;
  letter-spacing:0.09em;
  font-size:clamp(48px, 2.6vw + 10px, 74px);
  text-transform:uppercase;
  text-align:center;
  width:calc(100% - var(--side-w));
  margin:0 auto 0 0;
}
#hudMeta{
  position:absolute;
  right:16px;
  top:8px;
  margin-top:0;
  color:#ece5cf;
  font-size:15px;
  line-height:1.3;
  font-weight:700;
  text-align:right;
  white-space:nowrap;
  padding:4px 8px;
  border:1px solid rgba(216,189,126,0.25);
  border-radius:10px;
  background:rgba(11,14,20,0.55);
}
#hudLast{
  margin-top:8px;
  font-size:13px;
  border-top:1px dashed rgba(255,255,255,0.08);
  padding-top:7px;
  display:none;
}

#layout{
  display:grid;
  grid-template-columns: 1fr var(--side-w);
  height: calc(100% - var(--hud-h) - var(--combat-h));
  height: calc(100dvh - var(--hud-h) - var(--combat-h));
  min-height:0;
}

/* Tutorial mode defaults to focused board view. */
body.tutorial-active{
  overflow-x:hidden;
}

body.tutorial-active #layout{
  grid-template-columns:1fr;
}

body.tutorial-active #side{
  display:none !important;
}

body.tutorial-active #canvasWrap{
  padding-left:min(46vw, 700px);
}

/* Optional tutorial UI view: horizontal pan between board and setup panel. */
body.tutorial-active.tutorial-show-side{
  overflow-x:auto;
}

body.tutorial-active.tutorial-show-side #layout{
  grid-template-columns: minmax(980px, 1fr) var(--side-w);
  min-width:calc(100vw + var(--side-w));
}

body.tutorial-active.tutorial-show-side #side{
  display:flex !important;
}

body.tutorial-active.tutorial-show-side #canvasWrap{
  padding-left:0;
}

#canvasWrap{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:6px;
  min-height:0;
}
#boardStage{
  position:relative;
  min-height:0;
  flex:1 1 auto;
}
#c{
  display:block;
  width:100%;
  height:100%;
  touch-action:manipulation;
  -webkit-user-select:none;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}

#cornerDiceHud{
  position:absolute;
  top:8px;
  left:8px;
  z-index:6;
  pointer-events:none;
  display:none;
  padding:4px 6px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(8,10,14,0.5);
  backdrop-filter:blur(2px);
}

#boardDiceDock{
  position:relative;
  z-index:5;
  width:min(90%, 700px);
  margin:0 auto 4px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  pointer-events:none;
}

#boardDiceDock .physicalDiceRow{
  width:100%;
  min-height:72px;
  padding:10px 12px;
  border-color:rgba(216,189,126,0.28);
  background:rgba(8,10,14,0.62);
  backdrop-filter:blur(2px);
}

#boardDiceResult{
  min-height:16px;
  font-size:13px;
  color:#d3d9e4;
  letter-spacing:0.02em;
  text-align:center;
}

#boardDiceDock .physicalDie{
  width:66px;
  height:66px;
}

#cornerDiceHud.combat-active{
  border-color:rgba(216,189,126,0.92);
  box-shadow:0 0 0 1px rgba(216,189,126,0.2), 0 0 20px rgba(216,189,126,0.25);
}

body[data-combat="on"] #hudMeta{
  color:#d8bd7e;
}

#cornerDiceRow{
  min-height:0;
  padding:0;
  gap:5px;
  border:none;
  background:transparent;
}

#cornerDiceRow .cornerDie{
  width:24px;
  height:24px;
  border-radius:6px;
}

#cornerDiceRow .cornerDie .physicalFace{
  inset:3px;
  border-radius:4px;
}

#cornerDiceRow .cornerDie .physicalPip{
  width:4px;
  height:4px;
}

#side{
  position:relative;
  border-left:1px solid var(--line);
  padding:8px;
  display:flex;
  flex-direction:column;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
}

body[data-mode="play"] #side{
  overflow:auto;
}

#setupStageBanner{
  order:0;
  border:1px solid rgba(216,189,126,0.35);
  background:linear-gradient(180deg, rgba(216,189,126,0.12), rgba(216,189,126,0.04));
  border-radius:12px;
  padding:9px 10px;
  margin-bottom:8px;
  text-align:center;
}

.setupStageTitle{
  color:var(--accent);
  font-family:'Cinzel','Trajan Pro','Times New Roman',serif;
  text-transform:uppercase;
  letter-spacing:0.08em;
  font-weight:700;
  font-size:14px;
}

.setupStageSub{
  margin-top:3px;
  color:#d9dce5;
  font-size:12px;
  line-height:1.3;
}

.setupStageActions{
  margin-top:8px;
}

.panel{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:12px;
  padding:8px;
  margin-bottom:8px;
}

.panelTitle{
  font-size:14px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:700;
  margin-bottom:8px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.panelToggleBtn{
  appearance:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.02);
  color:var(--muted);
  border-radius:999px;
  padding:2px 8px;
  font-size:10px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  font-weight:700;
  cursor:pointer;
}

.panelToggleBtn:hover{
  background:rgba(255,255,255,0.06);
  color:var(--text);
}

.panel.panel-collapsed{
  padding-bottom:9px;
}

.panel.panel-collapsed > :not(.panelTitle){
  display:none !important;
}

.panel.panel-collapsed .panelTitle{
  margin-bottom:0;
}

.row{display:flex;gap:6px;align-items:center;margin:5px 0;flex-wrap:wrap;}
.label{width:88px;color:var(--muted);font-size:11px;letter-spacing:0.05em;text-transform:uppercase;}
#side{
  font-family:var(--ui-font);
}
#side .label{
  color:var(--text);
  font-size:14px;
  font-weight:700;
  letter-spacing:0.01em;
  text-transform:none;
}
#turnOrdersPanel .label{
  color:var(--text);
  font-size:13px;
  font-weight:700;
  letter-spacing:0.01em;
  text-transform:none;
}

.btn{
  background:var(--btn);
  color:var(--text);
  border:1px solid var(--line);
  border-radius:10px;
  padding:8px 10px;
  font-family:var(--ui-font);
  font-size:14px;
  font-weight:400;
  letter-spacing:0.01em;
  cursor:pointer;
}
.btn,.select,.input{min-height:34px;}
.btn:hover{background:var(--btn2);}
.btn.active{outline:2px solid var(--focus);}
.btn.wide{flex:1;justify-content:center;}

.btnHero{
  min-height:40px;
  font-size:14px;
  font-weight:700;
  letter-spacing:0.02em;
  border-color:rgba(216,189,126,0.45);
  background:linear-gradient(180deg, rgba(216,189,126,0.2), rgba(216,189,126,0.08));
}

.btnHero:hover{
  background:linear-gradient(180deg, rgba(216,189,126,0.3), rgba(216,189,126,0.12));
}

.btn:disabled{
  opacity:0.45;
  cursor:not-allowed;
}
.btn:disabled:hover{background:var(--btn);}

.btnGrid{display:grid;grid-template-columns:repeat(5, 1fr);gap:6px;flex:1;}
.editorOnly .btnGrid{grid-template-columns:repeat(3, 1fr);}

.select{
  flex:1;
  background:var(--btn);
  color:var(--text);
  border:1px solid var(--line);
  border-radius:10px;
  padding:8px 10px;
  font-size:14px;
  font-family:var(--ui-font);
  font-weight:400;
  letter-spacing:0.01em;
  appearance:none;
  -webkit-appearance:none;
}

.monoVal{
  flex:1;
  min-height:36px;
  display:flex;
  align-items:center;
  padding:6px 10px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#0d0f15;
  color:#c5d4f7;
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:12px;
  word-break:break-all;
}

.roomCode{
  justify-content:center;
  letter-spacing:0.22em;
  font-size:20px;
  font-weight:800;
  color:#e7f0ff;
}

.roomCode.empty{
  letter-spacing:0.08em;
  font-size:13px;
  font-weight:650;
  color:var(--muted);
}

.input{
  flex:1;
  background:var(--btn);
  color:var(--text);
  border:1px solid var(--line);
  border-radius:10px;
  padding:8px 10px;
  font-size:14px;
  font-family:var(--ui-font);
  font-weight:400;
}

.note{
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
  margin-top:8px;
}

.doctrineList{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-top:6px;
}

.ordersExplainList{
  margin-top:8px;
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,0.02);
  padding:8px;
  max-height:220px;
  overflow:auto;
}

.ordersExplainEmpty{
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
}

.ordersExplainTier{
  margin:0 0 10px;
}

.ordersExplainTier:last-child{
  margin-bottom:0;
}

.ordersExplainTierTitle{
  color:#f0ddae;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.07em;
  text-transform:uppercase;
  margin:0 0 6px;
}

.ordersExplainItem{
  border:1px solid rgba(255,255,255,0.08);
  border-radius:8px;
  background:rgba(255,255,255,0.02);
  padding:7px 8px;
  margin-bottom:6px;
}

.ordersExplainItem:last-child{
  margin-bottom:0;
}

.ordersExplainHead{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
}

.ordersExplainName{
  color:#e9edf9;
  font-size:12px;
  font-weight:700;
  line-height:1.25;
}

.ordersExplainMeta{
  color:#aeb4c5;
  font-size:11px;
  line-height:1.2;
  white-space:nowrap;
}

.ordersExplainBody{
  margin-top:4px;
  color:#d5d9e4;
  font-size:12px;
  line-height:1.35;
}

.ordersExplainLayman{
  margin-top:4px;
  color:#edf1fb;
  font-size:12px;
  line-height:1.35;
}

.doctrineChip{
  border:1px solid var(--line);
  border-radius:8px;
  padding:6px 8px;
  font-size:12px;
  line-height:1.25;
  color:#dde2ef;
  background:rgba(255,255,255,0.02);
}

.doctrineChip .monoVal{
  margin-right:8px;
}

.doctrineChip.spent{
  opacity:0.66;
  text-decoration:line-through;
}

.doctrineChip.hidden{
  color:#a3a8b5;
  background:rgba(255,255,255,0.01);
}

.doctrineCard{
  padding:0;
}

.doctrineBuilderGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
  padding:0;
  overflow:hidden;
  height:100%;
  min-height:0;
  align-content:stretch;
}

.doctrineModalBody{
  display:grid;
  grid-template-columns:minmax(430px, 0.98fr) minmax(920px, 1.5fr);
  gap:16px;
  padding:0 14px 12px;
  flex:1;
  min-height:0;
  align-items:stretch;
}

.doctrineModalAside{
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:0;
}

.doctrineCostCol{
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,0.02);
  padding:12px;
  min-height:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.doctrineCostCol.is-complete{
  border-color:rgba(88,176,108,0.92);
  box-shadow:inset 0 0 0 1px rgba(88,176,108,0.28);
}

.doctrineCostCol.is-complete h3{
  color:#9de0ae;
}

.doctrineCostCol.is-incomplete{
  border-color:var(--line);
}

#doctrineOverlay input[type="checkbox"]{
  accent-color:#59b06c;
}

.doctrineCostCol h3{
  margin:0 0 8px;
  color:#f0ddae;
  font-size:12px;
  letter-spacing:0.04em;
  text-transform:uppercase;
}

.doctrineBuilderList{
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow:auto;
  flex:1 1 auto;
  min-height:0;
  padding-right:4px;
}

.doctrineBuilderListReadOnly{
  overflow:visible;
  gap:10px;
  max-height:none;
}

.doctrineBuilderListReadOnly .doctrinePickGroup{
  margin-top:2px;
}

.doctrinePickLocked{
  cursor:default;
  min-height:68px;
}

.doctrinePickLockDot{
  color:#9ec2ff;
  font-size:12px;
  line-height:1.2;
  margin-top:3px;
  flex:0 0 auto;
}

.doctrinePick{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:8px;
  border:1px solid var(--line);
  border-radius:10px;
  padding:8px 10px;
  background:rgba(255,255,255,0.02);
}

.doctrinePickActive{
  border-color:rgba(121,167,255,0.95);
  box-shadow:0 0 0 2px rgba(121,167,255,0.44) inset, 0 0 0 1px rgba(121,167,255,0.30);
  background:rgba(121,167,255,0.16);
}

.doctrinePickActive .doctrinePickName{
  color:#ffffff;
}

.doctrinePickActive::after{
  content:"PREVIEW";
  position:absolute;
  top:8px;
  right:10px;
  font-size:10px;
  font-weight:800;
  letter-spacing:0.08em;
  color:#d8ebff;
  background:rgba(73,126,224,0.30);
  border:1px solid rgba(140,190,255,0.65);
  border-radius:999px;
  padding:2px 7px;
}

.doctrinePick input{
  margin-top:2px;
}

.doctrinePickName{
  display:block;
  color:#e9edf9;
  font-size:12px;
  font-weight:700;
  line-height:1.2;
}

.doctrinePickMeta{
  display:block;
  color:#aeb4c5;
  font-size:11.5px;
  line-height:1.2;
  margin-top:2px;
}

.doctrinePickExplain{
  display:block;
  color:#dde1eb;
  font-size:12px;
  line-height:1.4;
  margin-top:5px;
}

.doctrinePickGroup{
  margin:6px 0 4px;
  color:#f0ddae;
  font-size:11px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  font-weight:700;
}

.doctrineExplain{
  margin:8px 10px 2px;
  padding:9px 10px;
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,0.03);
  color:#d8dbe6;
  font-size:12px;
  line-height:1.36;
}

.doctrineExplainTitle{
  color:#edf1fb;
  font-size:12px;
  font-weight:700;
  margin-bottom:4px;
}

.doctrineExplainTarget{
  color:#aeb4c5;
  font-size:11px;
  margin-top:5px;
}

.commandCoachCard{
  margin:6px 0;
  padding:10px;
  border:1px solid rgba(216,189,126,0.24);
  border-radius:12px;
  background:linear-gradient(180deg, rgba(23,26,34,0.90), rgba(16,18,26,0.92));
}

.commandCoachHead{
  display:flex;
  flex-direction:column;
  gap:3px;
  margin-bottom:8px;
}

.commandCoachTitle{
  color:#f0ddae;
  font-size:12px;
  font-weight:800;
  letter-spacing:0.05em;
  text-transform:uppercase;
}

.commandCoachMeta{
  color:#b9c2d5;
  font-size:12px;
  line-height:1.35;
}

.commandCoachBody{
  color:#dde3ef;
  font-size:12.5px;
  line-height:1.45;
}

.coachPanel{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.coachPanelCompact{
  gap:8px;
}

.coachTitleRow{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
  flex-wrap:wrap;
}

.coachTitle{
  color:#edf1fb;
  font-size:13px;
  font-weight:700;
  line-height:1.25;
}

.coachPills{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.coachPill{
  display:inline-flex;
  align-items:center;
  min-height:22px;
  padding:3px 8px;
  border-radius:999px;
  border:1px solid rgba(121,167,255,0.34);
  background:rgba(121,167,255,0.10);
  color:#d9e7ff;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.02em;
}

.coachSummary{
  color:#e2e8f3;
  font-size:13px;
  line-height:1.5;
}

.coachGrid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
}

.coachGridCompact{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.coachBlock{
  border:1px solid rgba(255,255,255,0.08);
  border-radius:10px;
  padding:8px 9px;
  background:rgba(255,255,255,0.03);
}

.coachLegendBlock{
  border-color:rgba(216,189,126,0.20);
}

.coachLabel{
  color:#f0ddae;
  font-size:10.5px;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:5px;
}

.coachText{
  color:#d7deea;
  font-size:12px;
  line-height:1.45;
}

.coachList{
  margin:0;
  padding-left:18px;
  color:#d7deea;
  font-size:12px;
  line-height:1.42;
}

.coachList li{
  margin:0 0 5px;
}

.coachInlineNote{
  color:#aebbd2;
  font-size:11.5px;
  line-height:1.45;
}

.commandCoachCard .coachGrid,
.commandCoachCard .coachGridCompact{
  grid-template-columns:1fr;
}

.doctrinePreviewWrap{
  margin:0;
  padding:12px 14px 14px;
  border:1px solid var(--line);
  border-radius:12px;
  background:rgba(255,255,255,0.03);
  display:flex;
  flex-direction:column;
  flex:1 1 auto;
  min-height:0;
}

.doctrinePreviewTitle{
  margin:0 0 10px;
  color:#f0ddae;
  font-size:13px;
  letter-spacing:0.04em;
  text-transform:uppercase;
  font-weight:800;
}

#doctrinePreviewCanvas{
  width:100%;
  height:clamp(230px, 30vh, 320px);
  border:1px dashed rgba(255,255,255,0.18);
  border-radius:12px;
  background:radial-gradient(circle at 50% 35%, rgba(255,255,255,0.06), rgba(255,255,255,0.015));
  display:block;
}

.doctrinePreviewCaption{
  margin-top:10px;
  min-height:2.6em;
  color:#d8deea;
  font-size:13.5px;
  line-height:1.5;
}

#doctrineOpenTurnBtn.btnHero{
  min-height:42px;
  font-size:16px;
  letter-spacing:0.03em;
}

#statusPanel{display:none;}

.statusMeta{
  color:var(--muted);
  font-size:12px;
  line-height:1.4;
  white-space:pre-line;
  word-break:break-word;
}

.statusLast{
  margin-top:8px;
  padding-top:8px;
  border-top:1px dashed rgba(255,255,255,0.08);
  font-size:12px;
  line-height:1.35;
}

.draftStatus{
  display:none;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
  margin-top:8px;
  border-top:1px dashed rgba(255,255,255,0.08);
  padding-top:8px;
}

.details{
  border:1px solid var(--line);
  border-radius:10px;
  padding:8px;
  margin-top:8px;
  background:rgba(255,255,255,0.02);
}

.details > summary{
  cursor:pointer;
  color:var(--text);
  font-size:12px;
  font-weight:650;
}

.details[open] > summary{
  margin-bottom:8px;
}

.rulesSideOverlay{
  position:absolute;
  inset:0;
  z-index:50;
  display:none;
  padding:8px;
  background:rgba(8, 9, 12, 0.70);
  backdrop-filter:blur(1.5px);
}

.rulesSideOverlay.open{
  display:block;
}

#doctrineOverlay.rulesSideOverlay{
  position:fixed;
  inset:0;
  z-index:240;
  display:none;
  align-items:center;
  justify-content:center;
  padding:clamp(14px, 2.4vw, 34px);
  background:rgba(6,8,12,0.42);
  backdrop-filter:blur(8px) saturate(112%);
  -webkit-backdrop-filter:blur(8px) saturate(112%);
}

#doctrineOverlay.rulesSideOverlay.open{
  display:flex;
}

#doctrineOverlay .rulesSideCard.doctrineCard{
  width:min(97vw, 1940px);
  height:min(96vh, 1260px);
  max-height:calc(100dvh - 12px);
  border-radius:14px;
  box-shadow:0 24px 64px rgba(0,0,0,0.58);
}

#doctrineOverlay.play-lock .rulesSideCard.doctrineCard{
  width:min(99vw, 2100px);
  height:min(96vh, 1280px);
}

#doctrineOverlay #doctrineBuilderCounts{
  margin:8px 14px 0;
}

#doctrineOverlay .doctrineModalAside{
  min-height:0;
}

#doctrineOverlay #doctrineExplain{
  margin:0;
}

#doctrineOverlay.play-lock .doctrineModalBody{
  grid-template-columns:minmax(460px, 1fr) minmax(1040px, 1.72fr);
  gap:18px;
  padding:0 18px 14px;
}

#doctrineOverlay.play-lock .doctrineModalAside{
  min-height:0;
}

#doctrineOverlay.play-lock #doctrineBuilderCounts{
  margin:8px 14px 0;
}

#doctrineOverlay.play-lock #doctrineExplain{
  margin:0;
}

#doctrineOverlay.play-lock #doctrinePreviewWrap{
  margin:0;
  min-height:0;
  display:flex;
  flex-direction:column;
  flex:1 1 auto;
}

#doctrineOverlay.play-lock #doctrinePreviewCanvas{
  height:clamp(240px, 32vh, 340px);
}

#doctrineOverlay.play-lock .doctrineBuilderGrid{
  grid-template-columns:repeat(3, minmax(300px, 1fr));
  gap:16px;
}

#doctrineOverlay.play-lock .doctrineCostCol{
  padding:14px;
  min-height:0;
}

#doctrineOverlay.play-lock .doctrineBuilderListReadOnly{
  overflow:auto;
  min-height:0;
  flex:1 1 auto;
  padding-right:4px;
}

#doctrineOverlay.play-lock .doctrinePickLocked{
  min-height:92px;
}

#doctrineOverlay .rulesSideHead{
  padding:12px 12px 10px;
}

#doctrineOverlay .rulesSideHead h2{
  font-size:16px;
}

#doctrineOverlay .doctrineIntroNote{
  margin:8px 14px 0;
  padding:8px 10px;
  border:1px solid rgba(216,189,126,0.26);
  border-radius:10px;
  background:rgba(22, 25, 34, 0.65);
  color:#d7dbe3;
  font-size:13px;
  line-height:1.4;
}

#doctrineOverlay .doctrineBuilderGrid{
  gap:14px;
  padding:0;
}

#doctrineOverlay .doctrineCostCol{
  padding:12px;
}

html.mode-order-atlas #doctrineOverlay.rulesSideOverlay.open{
  display:flex;
}

html.mode-order-atlas #doctrineOverlay .rulesSideCard.doctrineCard{
  width:min(98vw, 1980px);
  height:min(96vh, 1280px);
}

html.mode-order-atlas #doctrineOverlay .rulesSideHead h2{
  font-size:18px;
}

html.mode-order-atlas #doctrineOverlay .doctrineIntroNote{
  font-size:14px;
  line-height:1.45;
}

html.mode-order-atlas #doctrineOverlay .doctrineBuilderGrid{
  gap:16px;
  padding:0;
}

html.mode-order-atlas #doctrineOverlay .doctrineCostCol{
  padding:14px;
}

html.mode-order-atlas #doctrinePreviewCanvas{
  height:clamp(260px, 34vh, 360px);
}

.rulesSideCard{
  height:100%;
  background:linear-gradient(180deg, rgba(15, 16, 22, 0.98), rgba(10, 11, 17, 0.98));
  border:1px solid var(--line);
  border-radius:12px;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.rulesSideHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 10px 8px;
  border-bottom:1px solid var(--line);
}

.rulesSideHead h2{
  margin:0;
  color:var(--accent);
  font-size:14px;
  letter-spacing:0.05em;
  text-transform:uppercase;
}

.rulesSideTabs{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:6px;
  padding:8px 10px;
  border-bottom:1px solid var(--line);
}

.rulesSideTabs .btn{
  min-height:34px;
  padding:6px 8px;
  font-size:12px;
}

.rulesSideTabs .btn.active{
  outline:2px solid var(--focus);
}

.rulesSideBody{
  overflow:auto;
  padding:12px 10px 12px;
}

.rulesDoc{
  display:none;
}

.rulesDoc.active{
  display:block;
}

.rulesDoc h3{
  margin:0 0 8px;
  color:#f0ddae;
  font-size:13px;
  letter-spacing:0.04em;
  text-transform:uppercase;
}

.rulesDoc p,
.rulesDoc li{
  color:#d7d9e0;
  font-size:13px;
  line-height:1.46;
}

.rulesDoc ul{
  margin:0 0 12px;
  padding-left:18px;
}

.rulesDoc p{
  margin:0 0 12px;
}

.rulesCommandTier{
  margin-bottom:14px;
  padding-bottom:10px;
  border-bottom:1px dashed rgba(255,255,255,0.1);
}

.rulesCommandTier:last-child{
  border-bottom:none;
  margin-bottom:0;
  padding-bottom:0;
}

.rulesCommandColumns{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}

.rulesCommandColumns h4{
  margin:0 0 6px;
  font-size:12px;
  color:#e7d39f;
  letter-spacing:0.04em;
  text-transform:uppercase;
}

.rulesCommandList{
  margin:0;
  padding-left:16px;
}

.rulesCommandList li{
  margin:0 0 8px;
}

.rulesCommandTag{
  color:#9fc1ff;
  font-size:11px;
  letter-spacing:0.02em;
}

.rulesCommandScopeRow{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:8px 0 6px;
}

#turnOrdersPanel{
  order:2;
  padding:8px 9px;
}
#turnOrdersPanel .panelTitle{
  margin-bottom:5px;
}
#turnOrdersPanel .row{
  margin:4px 0;
  gap:6px;
  flex-wrap:nowrap;
}
#turnOrdersPanel .label{
  width:58px;
  font-size:12px;
}
#turnOrdersPanel .btn,
#turnOrdersPanel .select{
  min-height:32px;
  padding:5px 8px;
  font-size:12px;
}
#turnOrdersPanel .btn.wide{
  min-height:33px;
}
#defensePanel{
  order:99;
  padding:8px 9px;
  display:none !important;
}
#defensePanel .combatMeta{
  font-size:11px;
  line-height:1.2;
}
#rulesPanel{order:1;}
#scenarioPanel{order:3;}
#setupPanel{order:4;}
#ordersPanel{order:5;}
#statusPanel{order:6;}
#editorPanel{order:7;}
#doctrineIntelPanel{
  order:8;
  display:none !important;
}
#dicePanel{
  display:none !important;
}

.inspectorTitle{
  flex:1;
  font-size:14px;
  font-weight:650;
}

.inspectorMeta{
  color:var(--muted);
  font-size:12px;
  line-height:1.3;
  margin-top:2px;
  margin-bottom:4px;
}

.inspectorGrid{
  display:grid;
  grid-template-columns:auto 1fr;
  column-gap:10px;
  row-gap:6px;
}

.inspectorKey{
  color:var(--muted);
  font-size:11px;
  letter-spacing:0.04em;
  text-transform:uppercase;
}

.inspectorVal{
  font-size:12px;
  font-weight:600;
  word-break:break-word;
}

.diceSummary{
  flex:1;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
  min-height:2.7em;
}

.diceTray{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(40px, 1fr));
  gap:10px;
  margin-top:6px;
}

.physicalDiceRow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  min-height:58px;
  align-items:center;
  justify-content:center;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,0.14);
  border-radius:10px;
  background:rgba(255,255,255,0.025);
}

.physicalDiceEmpty{
  color:var(--muted);
  font-size:12px;
}

.physicalDie{
  --dice-rot: 0deg;
  width:52px;
  height:52px;
  border-radius:11px;
  border:1px solid #9ca5b6;
  background:#edf1f7;
  box-shadow:
    0 2px 6px rgba(0,0,0,0.24),
    inset 0 1px 0 rgba(255,255,255,0.72);
  transform:rotate(var(--dice-rot));
  position:relative;
  overflow:hidden;
}

.physicalDie::after{
  display:none;
}

.physicalDie.hit{border-color:#2b8f52;}
.physicalDie.retreat{border-color:#b98018;}
.physicalDie.disarray{border-color:#b046d6;}
.physicalDie.miss{border-color:#555963;}

.physicalDie.rolling{
  animation:physicalDiceRoll 180ms ease-in-out infinite alternate;
}

.physicalFace{
  position:absolute;
  inset:6px;
  border-radius:8px;
  background:#f6f8fc;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.8);
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  grid-template-rows:repeat(3, 1fr);
}

.physicalPip{
  width:7px;
  height:7px;
  border-radius:50%;
  margin:auto;
  background:#1a1e26;
  opacity:0;
  box-shadow:none;
}

.physicalPip.on{opacity:1;}

.die{
  aspect-ratio:1 / 1;
  border:1px solid var(--line);
  border-radius:9px;
  background:linear-gradient(165deg, #ffffff 0%, #ededf1 62%, #dfe1e8 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.9), 0 2px 5px rgba(0,0,0,0.35);
  position:relative;
  overflow:hidden;
  transform:translateZ(0);
  transition:border-color 120ms ease, box-shadow 120ms ease;
}

.die.hit{border-color:#2b8f52;}
.die.retreat{border-color:#b98018;}
.die.disarray{border-color:#b046d6;}
.die.miss{border-color:#555963;}

.die.rolling{
  border-color:#757986;
  animation:dieRoll 210ms ease-in-out infinite alternate;
}

.dieFace{
  width:100%;
  height:100%;
  padding:5px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  grid-template-rows:repeat(3, 1fr);
  transition:opacity 100ms ease;
}

.pip{
  width:7px;
  height:7px;
  border-radius:50%;
  margin:auto;
  background:#111317;
  opacity:0;
}

.pip.on{opacity:1;}

.dieBadge{
  position:absolute;
  right:4px;
  bottom:3px;
  font-size:9px;
  font-weight:700;
  color:#1b1c22;
  text-shadow:0 1px 0 rgba(255,255,255,0.55);
  letter-spacing:0.02em;
}

@keyframes dieRoll{
  0%{transform:translateY(0) rotate(0deg);}
  50%{transform:translateY(-2px) rotate(7deg);}
  100%{transform:translateY(1px) rotate(-7deg);}
}

@keyframes physicalDiceRoll{
  0%{transform:translateY(0) rotate(calc(var(--dice-rot) - 5deg));}
  100%{transform:translateY(1px) rotate(calc(var(--dice-rot) + 5deg));}
}

#combatRail{
  min-height:0;
  height:var(--combat-h);
  max-height:var(--combat-h);
  border-top:1px solid var(--line);
  background:#0f1116;
  padding:10px 12px 11px;
  display:grid;
  grid-template-columns:
    minmax(0, 1.15fr)
    minmax(0, 0.9fr)
    minmax(0, 0.95fr)
    minmax(0, 1fr)
    minmax(0, 0.85fr)
    minmax(0, 1.05fr);
  gap:10px;
  align-items:stretch;
  overflow:hidden;
}

.combatCol{
  border:1px solid rgba(255,255,255,0.12);
  border-radius:10px;
  background:#12151d;
  padding:9px 10px;
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
  overflow:hidden;
}

.combatColBreakdown,
#selectedUnitPanel{
  overflow:auto;
}

.combatColOutcome,
.combatColOnline{
  overflow:auto;
}

.combatColTitle{
  font-size:13px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:700;
}

.combatSummary{
  font-size:14px;
  font-weight:650;
  line-height:1.35;
}

.combatMeta{
  font-size:14px;
  color:#cfd3de;
  line-height:1.35;
}

.combatHint{
  display:none;
}

.combatColDice .physicalDiceRow{
  width:100%;
  min-height:66px;
  padding:10px;
  gap:10px;
}

.combatColDice .physicalDie{
  width:46px;
  height:46px;
}

.doctrineConfirmBtn{
  min-height:42px !important;
  font-size:15px !important;
  font-weight:700 !important;
  letter-spacing:0.04em;
  border-color:rgba(216,189,126,0.56) !important;
  background:linear-gradient(180deg, rgba(216,189,126,0.20), rgba(216,189,126,0.08)) !important;
}

.combatColInspector .inspectorMeta{
  margin-bottom:4px;
}

.combatColInspector .inspectorGrid{
  row-gap:2px;
}

.combatColOnline .btn,
.combatColOnline .input,
.combatColOnline .select{
  min-height:26px;
  padding:4px 7px;
  font-size:12px;
}

.combatColOnline .btn{
  min-width:64px;
}

.combatColModifiers .combatMeta{
  font-size:13px;
  line-height:1.35;
}

.combatColOnline .roomCode{
  font-size:12px;
  letter-spacing:0.14em;
  min-height:24px;
  padding:2px 6px;
}

.combatColOnline .rowCode{
  justify-content:flex-start;
}

.onlineRow{
  display:grid;
  grid-template-columns:40px minmax(0, 1fr) auto;
  align-items:center;
  gap:6px;
}

.onlineRow .monoVal{
  min-width:0;
}

.onlineLabel{
  color:var(--muted);
  font-size:10px;
  letter-spacing:0.04em;
  text-transform:uppercase;
}

.onlineDraftBtns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4px;
}

.onlineStatusLine{
  color:var(--muted);
  font-size:12px;
  line-height:1.2;
  min-height:1.2em;
}

#onlineStatus,
.onlineStatusLine{
  display:none !important;
}

#selectedUnitPanel #inspectorMeta{
  display:none !important;
}

.combatColBreakdown{max-width:none;}

#combatRail.no-online{
  grid-template-columns:
    minmax(0, 1.2fr)
    minmax(0, 0.95fr)
    minmax(0, 1fr)
    minmax(0, 1fr)
    minmax(0, 0.9fr);
}

#combatRail.no-online .combatColOnline{
  display:none;
}

@media (max-width: 1200px){
  :root{ --side-w:306px; }
}

@media (max-width: 1600px){
  .doctrineModalBody,
  #doctrineOverlay.play-lock .doctrineModalBody{
    grid-template-columns:minmax(360px, 0.9fr) minmax(700px, 1.2fr);
  }

  .doctrineBuilderGrid,
  #doctrineOverlay.play-lock .doctrineBuilderGrid{
    grid-template-columns:repeat(3, minmax(220px, 1fr));
  }

  #doctrinePreviewCanvas,
  #doctrineOverlay.play-lock #doctrinePreviewCanvas,
  html.mode-order-atlas #doctrinePreviewCanvas{
    height:clamp(220px, 26vh, 300px);
  }
}

@media (max-width: 980px){
  :root{
    --combat-h:auto;
    --side-w:0px;
  }
  #layout{
    grid-template-columns:1fr;
    grid-template-rows:minmax(320px, 58dvh) auto;
    height:auto;
    min-height:0;
  }
  .rulesCommandColumns{
    grid-template-columns:1fr;
  }
  #canvasWrap{
    min-height:320px;
    height:min(58dvh, 620px);
  }
  #side{
    border-left:none;
    border-top:1px solid var(--line);
    max-height:min(48dvh, 420px);
  }
  .doctrineBuilderGrid{
    grid-template-columns:1fr;
  }
  .doctrineModalBody,
  #doctrineOverlay.play-lock .doctrineModalBody{
    grid-template-columns:1fr;
  }
  #doctrineOverlay .rulesSideCard.doctrineCard{
    width:min(97vw, 820px);
    height:min(93vh, 1040px);
  }
  .doctrineCostCol,
  #doctrineOverlay.play-lock .doctrineCostCol{
    min-height:260px;
  }
  .label{width:80px;}
  #combatRail{
    height:auto;
    max-height:min(38dvh, 340px);
    grid-template-columns:1fr;
    gap:10px;
  }
  body.tutorial-active #canvasWrap{
    padding-left:0;
  }
  body.tutorial-active.tutorial-show-side #layout{
    min-width:0;
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  #hud{padding:12px;}
  #hudMeta,#hudLast{font-size:12px;}
  #hudMeta{
    position:static;
    margin-top:6px;
    text-align:left;
    white-space:normal;
  }
  #layout{grid-template-rows:minmax(280px, 52dvh) auto;}
  #canvasWrap{
    min-height:280px;
    height:min(52dvh, 520px);
  }
  #side{
    padding:10px;
    max-height:none;
  }
  .row{gap:6px;}
  .label{
    width:100%;
    margin-bottom:2px;
  }
  #turnOrdersPanel .row{
    flex-wrap:wrap;
    margin:6px 0;
  }
  #turnOrdersPanel .label{
    width:100%;
  }
  .btnGrid{grid-template-columns:repeat(2, 1fr);}
  .editorOnly .btnGrid{grid-template-columns:repeat(2, 1fr);}
  .roomCode{font-size:18px;}
  .combatColDice .physicalDie{
    width:48px;
    height:48px;
  }
  .rulesSideOverlay{
    padding:6px;
  }
  .introCard{
    width:96vw;
    max-height:92dvh;
    padding:16px 14px;
  }
  .introActionTitle{
    font-size:19px;
  }
  .introActionSub{
    font-size:14px;
  }
}

@media (hover: none) and (pointer: coarse){
  :root{ --hud-h:56px; }
  #hud{
    padding:10px 14px 8px;
  }
  #hudMeta,
  #hudLast{
    display:none;
  }
  #statusPanel{
    display:block;
  }
}

@media (orientation: landscape) and (max-width: 1400px){
  #cornerDiceHud.has-roll{
    display:flex;
  }
}

@media (hover: none) and (pointer: coarse) and (orientation: portrait){
  :root{ --hud-h:48px; }
  #hud{
    padding:8px 12px 6px;
  }
  #hudTitle{
    font-size:18px;
    letter-spacing:0.1em;
  }
}

body[data-mode="play"] .editorOnly{
  display:none;
}

body[data-mode="play"] #setupPanel{
  display:none;
}

body[data-mode="play"] #scenarioPanel{
  display:none;
}

body[data-mode="play"] #setupStageBanner{
  display:none;
}

body[data-mode="edit"] .playOnlyRow{
  display:none !important;
}

body[data-mode="edit"] #commandPhaseNote{
  display:none;
}
