/* ──────────────────────────────────────────────────────────────
   Hammerstein — wargamer demo surface
   Port of the Claude Design pass at hammerstein-model/web/frontend/
   src/wargame/wargame.css. shadcn-flavored HSL token system.
   Palette: navy ink, cream paper, rust accent, gold secondary.
   ────────────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
[hidden] { display: none !important; }

.wargame-page {
  --background:       45 35% 95%;        /* warm cream paper */
  --foreground:       222 40% 12%;       /* navy ink */
  --card:             45 50% 99%;
  --card-foreground:  222 40% 12%;
  --popover:          45 50% 99%;
  --popover-foreground: 222 40% 12%;
  --primary:          14 70% 44%;        /* rust */
  --primary-foreground: 45 35% 98%;
  --secondary:        222 30% 22%;       /* navy block */
  --secondary-foreground: 45 35% 96%;
  --accent:           38 78% 48%;        /* gold */
  --accent-foreground: 222 40% 12%;
  --muted:            45 18% 88%;
  --muted-foreground: 222 15% 38%;
  --border:           222 15% 80%;
  --border-strong:    222 18% 68%;
  --input:            222 15% 80%;
  --ring:             14 70% 44%;
  --destructive:      0 70% 48%;
  --destructive-foreground: 45 35% 98%;

  --paper-grain:      45 30% 92%;
  --rule:             222 18% 75%;

  --wg-radius: 6px;

  --dens-pad-card: 16px;
  --dens-pad-row: 10px;
  --dens-gap: 12px;
  --dens-fs: 13px;
  --dens-h: 13.5px;

  background: hsl(var(--background));
  color: hsl(var(--foreground));
  font: var(--dens-fs)/1.5 ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
}

.wargame-page.dark {
  --background:       222 30% 9%;
  --foreground:       45 30% 90%;
  --card:             222 28% 12%;
  --card-foreground:  45 30% 90%;
  --popover:          222 28% 12%;
  --popover-foreground: 45 30% 90%;
  --primary:          14 70% 56%;
  --primary-foreground: 222 40% 8%;
  --secondary:        45 30% 88%;
  --secondary-foreground: 222 30% 9%;
  --accent:           38 78% 58%;
  --accent-foreground: 222 30% 9%;
  --muted:            222 22% 16%;
  --muted-foreground: 45 12% 62%;
  --border:           222 18% 22%;
  --border-strong:    222 18% 32%;
  --input:            222 18% 22%;
  --ring:             14 70% 56%;
  --destructive:      0 70% 56%;
  --destructive-foreground: 45 30% 96%;

  --paper-grain:      222 25% 11%;
  --rule:             222 18% 26%;
}

.wargame-page .wg-mono {
  font-family: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
}

.wargame-page a { color: hsl(var(--primary)); text-decoration: none; }
.wargame-page a:hover { text-decoration: underline; }

.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

/* ── primitives ───────────────────────────────────────── */

.wargame-page .wg-card {
  background: hsl(var(--card));
  color: hsl(var(--card-foreground));
  border: 1px solid hsl(var(--border));
  border-radius: var(--wg-radius);
}
.wargame-page .wg-card-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px var(--dens-pad-card) 9px;
  border-bottom: 1px solid hsl(var(--border));
  font-size: 11px; letter-spacing: .04em; text-transform: uppercase;
  color: hsl(var(--muted-foreground)); font-weight: 600;
}
.wargame-page .wg-card-hd .hd-r { display: flex; align-items: center; gap: 6px; text-transform: none; letter-spacing: 0; }
.wargame-page .wg-card-bd { padding: var(--dens-pad-card); }

.wargame-page .wg-btn {
  appearance: none; border: 1px solid hsl(var(--border-strong));
  background: hsl(var(--card)); color: hsl(var(--foreground));
  font: inherit; font-size: var(--dens-h); font-weight: 500;
  padding: 7px 11px; border-radius: var(--wg-radius); cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  transition: background .12s, border-color .12s;
}
.wargame-page .wg-btn:hover:not(:disabled) { background: hsl(var(--muted)); }
.wargame-page .wg-btn:disabled { opacity: .5; cursor: not-allowed; }
.wargame-page .wg-btn-primary {
  background: hsl(var(--primary)); color: hsl(var(--primary-foreground));
  border-color: hsl(var(--primary));
}
.wargame-page .wg-btn-primary:hover:not(:disabled) { background: hsl(var(--primary) / .9); }
.wargame-page .wg-btn-ghost { border-color: transparent; background: transparent; }
.wargame-page .wg-btn-ghost:hover { background: hsl(var(--muted)); }
.wargame-page .wg-btn-sm { padding: 4px 8px; font-size: 12px; }

.wargame-page .wg-input,
.wargame-page .wg-textarea {
  width: 100%; appearance: none; border: 1px solid hsl(var(--input));
  background: hsl(var(--card)); color: hsl(var(--foreground));
  font: inherit; padding: 7px 10px; border-radius: var(--wg-radius);
  outline: none;
}
.wargame-page .wg-input:focus,
.wargame-page .wg-textarea:focus { border-color: hsl(var(--ring)); box-shadow: 0 0 0 3px hsl(var(--ring) / .15); }
.wargame-page .wg-textarea { resize: vertical; min-height: 110px; line-height: 1.55; font-family: inherit; }
.wargame-page .wg-input::placeholder,
.wargame-page .wg-textarea::placeholder { color: hsl(var(--muted-foreground) / .65); }

.wargame-page .wg-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 7px; font-size: 11px; font-weight: 500;
  border: 1px solid hsl(var(--border-strong)); border-radius: 999px;
  color: hsl(var(--muted-foreground)); background: transparent;
  font-variant-numeric: tabular-nums;
}
.wargame-page .wg-badge.b-primary { color: hsl(var(--primary)); border-color: hsl(var(--primary) / .45); background: hsl(var(--primary) / .08); }
.wargame-page .wg-badge.b-accent  { color: hsl(var(--accent));  border-color: hsl(var(--accent) / .55);  background: hsl(var(--accent) / .12); }
.wargame-page .wg-badge.b-mono    { font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-size: 10.5px; padding: 1px 6px; }

.wargame-page .wg-icon {
  width: 16px; height: 16px; flex-shrink: 0; stroke: currentColor;
  fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round;
  display: inline-block; vertical-align: middle;
}
.wargame-page .wg-icon-sm { width: 14px; height: 14px; }
.wargame-page .wg-icon-lg { width: 22px; height: 22px; }

/* ── topbar ───────────────────────────────────────────── */
.wargame-page .wg-app { display: flex; flex-direction: column; }
.wargame-page .wg-topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 24px;
  border-bottom: 1px solid hsl(var(--border));
  background: hsl(var(--card));
  position: sticky; top: 0; z-index: 10;
}
.wargame-page .wg-topbar-l, .wargame-page .wg-topbar-r { display: flex; align-items: center; gap: 12px; }

.wargame-page .wg-brand {
  display: inline-flex; align-items: center; gap: 9px;
  font-weight: 600; letter-spacing: -.005em;
  color: hsl(var(--foreground));
  text-decoration: none;
}
.wargame-page .wg-brand:hover { text-decoration: none; }
.wargame-page .wg-brand-mark {
  width: 26px; height: 26px; border-radius: 4px;
  background: hsl(var(--secondary));
  color: hsl(var(--secondary-foreground));
  display: inline-flex; align-items: center; justify-content: center;
  font-family: ui-monospace, Menlo, monospace; font-weight: 700; font-size: 11px;
  letter-spacing: .03em;
  border: 1px solid hsl(var(--secondary) / .8);
  position: relative;
}
.wargame-page .wg-brand-mark::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(135deg, transparent 48%, hsl(var(--accent) / .55) 49%, hsl(var(--accent) / .55) 51%, transparent 52%);
  border-radius: 3px;
}
.wargame-page .wg-brand-name { font-size: 14px; }
.wargame-page .wg-brand-sub { color: hsl(var(--muted-foreground)); font-weight: 400; font-size: 13px; margin-left: 2px; }

.wargame-page .wg-nav-tabs { display: flex; align-items: center; gap: 2px; margin-left: 18px; }
.wargame-page .wg-nav-tab {
  padding: 6px 10px; font-size: 12.5px; font-weight: 500;
  color: hsl(var(--muted-foreground)); border-radius: 4px; cursor: pointer;
  border: 0; background: transparent;
  text-decoration: none;
}
.wargame-page .wg-nav-tab.active { color: hsl(var(--foreground)); background: hsl(var(--muted)); }
.wargame-page .wg-nav-tab:hover:not(.active) { color: hsl(var(--foreground)); text-decoration: none; }

.wargame-page .wg-cost-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 4px 4px 4px 10px;
  border: 1px solid hsl(var(--border));
  border-radius: 999px; font-size: 12px;
  color: hsl(var(--muted-foreground)); font-variant-numeric: tabular-nums;
}
.wargame-page .wg-cost-pill .cp-amt { color: hsl(var(--foreground)); font-weight: 600; }
.wargame-page .wg-cost-pill .cp-spark { display: inline-flex; align-items: end; gap: 1.5px; height: 14px; padding: 0 4px; border-left: 1px solid hsl(var(--border)); }
.wargame-page .wg-cost-pill .cp-spark i { display: block; width: 3px; background: hsl(var(--primary) / .55); border-radius: 1px; }

.wargame-page .wg-icon-btn {
  appearance: none; border: 1px solid transparent; background: transparent;
  width: 30px; height: 30px; display: inline-flex; align-items: center; justify-content: center;
  border-radius: 6px; cursor: pointer; color: hsl(var(--muted-foreground));
}
.wargame-page .wg-icon-btn:hover { background: hsl(var(--muted)); color: hsl(var(--foreground)); }

/* ── workspace ────────────────────────────────────────── */
.wargame-page .wg-workspace {
  max-width: 1080px;
  width: 100%;
  margin: 0 auto;
  padding: 18px 24px 32px;
  display: flex; flex-direction: column; gap: var(--dens-gap);
}

.wargame-page .wg-campaign-bar { display: flex; align-items: stretch; gap: 8px; }
.wargame-page .wg-campaign-picker {
  flex: 1; display: flex; align-items: center;
  border: 1px solid hsl(var(--border)); border-radius: var(--wg-radius);
  background: hsl(var(--card)); padding: 0 4px 0 12px; gap: 10px;
  min-height: 38px;
  position: relative;
}
.wargame-page .wg-campaign-picker .cp-label {
  font-size: 11px; letter-spacing: .04em; text-transform: uppercase;
  color: hsl(var(--muted-foreground)); font-weight: 600;
  border-right: 1px solid hsl(var(--border));
  padding: 8px 12px 8px 0; margin-right: 2px;
  flex-shrink: 0;
}
.wargame-page .wg-campaign-picker .cp-name {
  flex: 1; font-weight: 600; padding: 8px 0;
  background: transparent; border: 0; outline: none;
  color: hsl(var(--foreground)); font: inherit; font-weight: 600;
  min-width: 0;
}
.wargame-page .wg-campaign-picker .cp-name::placeholder { color: hsl(var(--muted-foreground)); font-weight: 400; }
.wargame-page .wg-campaign-picker .cp-meta {
  margin-left: auto; display: flex; align-items: center; gap: 10px;
  color: hsl(var(--muted-foreground)); font-size: 12px;
  padding-right: 10px;
  flex-shrink: 0;
}
.wargame-page .wg-campaign-picker .cp-meta b { color: hsl(var(--foreground)); font-weight: 600; }
.wargame-page .wg-campaign-picker .cp-meta code {
  font-family: ui-monospace, Menlo, monospace; font-size: 11px;
}

/* ── sources panel (static showcase) ──────────────────── */
.wargame-page .wg-sources { margin-bottom: 0; }
.wargame-page .wg-sources .wg-card-hd .hd-sub {
  color: hsl(var(--muted-foreground)); font-weight: 400;
  font-size: 11.5px; text-transform: none; letter-spacing: 0;
  margin-left: 2px;
}
.wargame-page .wg-sheet-preview {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 11px; border: 1px solid hsl(var(--border));
  border-radius: 4px; background: hsl(var(--muted) / .4);
  font-size: 12px;
  margin-bottom: 6px;
}
.wargame-page .wg-sheet-preview:last-of-type { margin-bottom: 0; }
.wargame-page .wg-sheet-preview .sp-icon {
  width: 28px; height: 36px; border-radius: 2px;
  background: hsl(var(--accent) / .15);
  color: hsl(var(--accent));
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid hsl(var(--accent) / .35);
  flex-shrink: 0;
  overflow: hidden;
  position: relative;
}
.wargame-page .wg-sheet-preview .sp-icon-img {
  background-image: linear-gradient(135deg,
    hsl(204 80% 55%) 0%, hsl(204 80% 55%) 50%,
    hsl(48 95% 55%) 50%, hsl(48 95% 55%) 100%);
}
.wargame-page .wg-sheet-preview .sp-body { flex: 1; min-width: 0; }
.wargame-page .wg-sheet-preview .sp-name { font-weight: 600; color: hsl(var(--foreground)); }
.wargame-page .wg-sheet-preview .sp-cols {
  color: hsl(var(--muted-foreground));
  font-family: ui-monospace, Menlo, monospace; font-size: 11px;
  word-break: break-word;
}

.wargame-page .wg-dropzone {
  border: 1.5px dashed hsl(var(--border-strong));
  border-radius: var(--wg-radius);
  padding: 11px 14px;
  display: flex; align-items: center; gap: 14px;
  background:
    repeating-linear-gradient(135deg,
      hsl(var(--paper-grain)) 0 6px,
      hsl(var(--card)) 6px 12px);
}
.wargame-page .wg-dropzone.disabled { opacity: .75; cursor: not-allowed; }
.wargame-page .wg-dz-icon {
  width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center;
  border-radius: 6px; background: hsl(var(--muted)); color: hsl(var(--foreground));
  flex-shrink: 0;
}
.wargame-page .wg-dz-prompt {
  display: flex; flex-direction: column; gap: 2px;
  color: hsl(var(--muted-foreground)); min-width: 0; flex: 1;
}
.wargame-page .wg-dz-prompt b { color: hsl(var(--foreground)); font-weight: 600; }
.wargame-page .wg-dz-prompt .dz-sub { font-size: 11.5px; }

/* ── form card ────────────────────────────────────────── */
.wargame-page .wg-form-grid {
  display: flex; flex-direction: column; gap: var(--dens-gap);
}
.wargame-page .wg-form-label {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 11.5px; color: hsl(var(--muted-foreground));
  margin-bottom: 6px;
  letter-spacing: .01em;
}
.wargame-page .wg-form-label b { color: hsl(var(--foreground)); font-weight: 600; }

.wargame-page .wg-issue-row {
  display: flex; align-items: center; gap: 12px;
  margin-top: 4px; padding-top: 12px;
  border-top: 1px solid hsl(var(--border));
  flex-wrap: wrap;
}
.wargame-page .wg-issue-cost {
  display: flex; flex-direction: column;
  font-size: 11px; color: hsl(var(--muted-foreground));
}
.wargame-page .wg-issue-cost .ic-amt { font-size: 14px; color: hsl(var(--foreground)); font-weight: 600; font-variant-numeric: tabular-nums; }
.wargame-page .wg-issue-cost .ic-bd { display: flex; align-items: baseline; gap: 6px; font-variant-numeric: tabular-nums; }
.wargame-page .wg-issue-cost .ic-bd code { font-size: 11px; color: hsl(var(--muted-foreground)); font-family: ui-monospace, Menlo, monospace; }

.wargame-page .wg-issue-btn {
  margin-left: auto;
  padding: 9px 16px; font-size: 13.5px; font-weight: 600;
  min-width: 160px; justify-content: center;
}
.wargame-page .wg-issue-btn .wg-icon { width: 15px; height: 15px; stroke-width: 1.8; }

/* error + flag banners */
.wargame-page .wg-banner {
  border-radius: var(--wg-radius);
  padding: 10px 12px;
  font-size: 12.5px;
  line-height: 1.5;
  margin-bottom: var(--dens-gap);
  display: flex; align-items: flex-start; gap: 8px;
}
.wargame-page .wg-banner.error {
  background: hsl(var(--destructive) / .08);
  border: 1px solid hsl(var(--destructive) / .35);
  color: hsl(var(--destructive));
}
.wargame-page .wg-banner.flag {
  background: hsl(var(--accent) / .1);
  border: 1px solid hsl(var(--accent) / .45);
  color: hsl(38 80% 28%);
}
.wargame-page.dark .wg-banner.flag { color: hsl(38 80% 70%); }
.wargame-page .wg-banner.gate {
  background: hsl(var(--secondary) / .04);
  border: 1px solid hsl(var(--secondary) / .35);
  color: hsl(var(--foreground));
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
}
.wargame-page .wg-banner.gate .gate-title {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: 13.5px;
  color: hsl(var(--foreground));
}
.wargame-page .wg-banner.gate .gate-body {
  font-size: 12.5px; color: hsl(var(--muted-foreground));
  line-height: 1.55;
}
.wargame-page .wg-banner.gate .gate-actions {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.wargame-page .wg-banner.gate .gate-meta {
  font-family: ui-monospace, Menlo, monospace; font-size: 11px;
  color: hsl(var(--muted-foreground));
  margin-left: auto; align-self: center;
}

.wargame-page .wg-spinner {
  width: 11px; height: 11px; border-radius: 50%;
  border: 2px solid hsl(var(--accent) / .25);
  border-top-color: hsl(var(--accent));
  animation: wg-spin 1s linear infinite;
  display: inline-block;
}
@keyframes wg-spin { to { transform: rotate(360deg); } }
.wargame-page .wg-streaming-meta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: ui-monospace, Menlo, monospace;
  font-size: 11.5px;
  color: hsl(var(--accent));
}

/* ── orders panel ─────────────────────────────────────── */
.wargame-page .wg-orders {
  border: 1px solid hsl(var(--border));
  border-radius: var(--wg-radius);
  background: hsl(var(--card));
  overflow: hidden;
  scroll-margin-top: 64px;
}
.wargame-page .wg-orders-hd {
  padding: 12px 18px;
  display: flex; align-items: center; justify-content: space-between;
  background: hsl(var(--secondary));
  color: hsl(var(--secondary-foreground));
  border-bottom: 3px solid hsl(var(--accent));
  position: relative;
  flex-wrap: wrap;
  gap: 10px;
}
.wargame-page .wg-orders-hd::before {
  content: ""; position: absolute; left: 0; right: 0; bottom: -3px; height: 3px;
  background: repeating-linear-gradient(90deg,
    hsl(var(--accent)) 0 14px, hsl(var(--secondary)) 14px 16px);
}
.wargame-page .wg-orders-hd-l { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.wargame-page .wg-orders-hd-l .stamp {
  font-family: ui-monospace, Menlo, monospace;
  font-weight: 700; letter-spacing: .14em;
  font-size: 10.5px;
  border: 1px solid hsl(var(--accent) / .65);
  color: hsl(var(--accent));
  padding: 3px 7px; border-radius: 2px;
  text-transform: uppercase;
}
.wargame-page .wg-orders-hd-l .ohd-title { font-weight: 700; font-size: 14.5px; letter-spacing: -.005em; }
.wargame-page .wg-orders-hd-l .ohd-sub { color: hsl(var(--secondary-foreground) / .7); font-size: 12px; }
.wargame-page .wg-orders-hd-r { display: flex; align-items: center; gap: 10px; font-size: 11.5px; color: hsl(var(--secondary-foreground) / .8); }

.wargame-page .wg-see-board {
  margin: 14px 18px 0;
  background: hsl(var(--accent) / .12);
  border: 1px solid hsl(var(--accent) / .45);
  border-left: 3px solid hsl(var(--accent));
  border-radius: 4px;
  padding: 10px 12px;
  font-size: 12.5px; line-height: 1.55;
}
.wargame-page .wg-see-board .sb-label {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  color: hsl(38 80% 32%);
  margin-bottom: 4px;
}
.wargame-page.dark .wg-see-board .sb-label { color: hsl(38 80% 65%); }
.wargame-page .wg-see-board .sb-body { color: hsl(var(--foreground)); }
.wargame-page .wg-see-board ul { margin: 0; padding-left: 18px; line-height: 1.55; }
.wargame-page .wg-see-board ul li { margin-bottom: 3px; }
.wargame-page .wg-see-board p { margin: 0 0 6px; }
.wargame-page .wg-see-board p:last-child { margin-bottom: 0; }
.wargame-page .wg-see-board .sb-confirm {
  display: flex; align-items: center; gap: 12px;
  margin-top: 8px; padding-top: 8px;
  border-top: 1px dashed hsl(var(--accent) / .4);
  font-size: 11.5px;
  flex-wrap: wrap;
}
.wargame-page .wg-see-board .sb-confirm .sb-unread { color: hsl(var(--muted-foreground)); }
.wargame-page .wg-see-board .sb-confirm .sb-unread strong { color: hsl(38 90% 36%); }
.wargame-page.dark .wg-see-board .sb-confirm .sb-unread strong { color: hsl(38 90% 65%); }
.wargame-page .wg-see-board .sb-actions { margin-left: auto; display: inline-flex; gap: 6px; }
.wargame-page .wg-see-board.confirmed {
  background: hsl(140 50% 92% / .8); border-color: hsl(140 60% 45% / .55);
  border-left-color: hsl(140 60% 38%);
}
.wargame-page.dark .wg-see-board.confirmed { background: hsl(140 30% 18% / .5); }
.wargame-page .wg-see-board.confirmed .sb-label { color: hsl(140 55% 28%); }
.wargame-page.dark .wg-see-board.confirmed .sb-label { color: hsl(140 55% 70%); }

.wargame-page .wg-orders-bd { padding: 6px 18px 18px; }

.wargame-page .wg-section {
  padding: 12px 0;
  border-top: 1px solid hsl(var(--rule));
}
.wargame-page .wg-section:first-of-type { border-top: 0; padding-top: 8px; }
.wargame-page .wg-section-hd {
  display: flex; align-items: baseline; gap: 12px;
  margin-bottom: 6px;
}
.wargame-page .wg-section-num {
  font-family: ui-monospace, Menlo, monospace;
  font-size: 10.5px; font-weight: 700; letter-spacing: .12em;
  color: hsl(var(--muted-foreground));
}
.wargame-page .wg-section-title {
  font-size: 13px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  color: hsl(var(--foreground));
}
.wargame-page .wg-section-body { color: hsl(var(--foreground)); font-size: 13px; line-height: 1.6; }
.wargame-page .wg-section-body p { margin: 0 0 8px; }
.wargame-page .wg-section-body p:last-child { margin-bottom: 0; }
.wargame-page .wg-section-body ul { margin: 0 0 8px; padding-left: 20px; line-height: 1.6; }
.wargame-page .wg-section-body ul li { margin-bottom: 3px; }
.wargame-page .wg-section-body em { font-style: italic; color: hsl(var(--muted-foreground)); }
.wargame-page .wg-section-body strong { font-weight: 700; }
.wargame-page .wg-section-body code {
  font-family: ui-monospace, Menlo, monospace;
  font-size: .92em;
  background: hsl(var(--muted));
  border-radius: 3px; padding: 1px 4px;
  color: hsl(var(--foreground));
}

.wargame-page .wg-orders-ack {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid hsl(var(--rule));
  font-family: ui-monospace, Menlo, monospace;
  font-size: 12px;
  color: hsl(var(--muted-foreground));
}

.wargame-page .wg-orders-actions {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 18px;
  background: hsl(var(--muted) / .5);
  border-top: 1px solid hsl(var(--border));
  flex-wrap: wrap;
}
.wargame-page .wg-orders-actions .meta { margin-left: auto; font-size: 11px; color: hsl(var(--muted-foreground)); display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.wargame-page .wg-orders-actions .meta code { font-family: ui-monospace, Menlo, monospace; font-size: 11px; color: hsl(var(--foreground)); }

.wargame-page .copy-feedback {
  font-size: 11.5px; color: hsl(var(--muted-foreground)); margin: 0;
}

/* ── session log ──────────────────────────────────────── */
.wargame-page .wg-session-log {
  border: 1px solid hsl(var(--border));
  border-radius: var(--wg-radius);
  background: hsl(var(--card));
  overflow: hidden;
}
.wargame-page .wg-session-log .wg-card-hd {
  background: hsl(var(--muted) / .4);
}
.wargame-page .wg-session-log .wg-card-hd .hd-sub {
  color: hsl(var(--muted-foreground)); font-weight: 400;
  font-size: 11.5px; text-transform: none; letter-spacing: 0;
  margin-left: 2px;
}
.wargame-page .wg-session-log .wg-card-bd {
  padding: 12px var(--dens-pad-card);
  display: flex; flex-direction: column; gap: 8px;
}
.wargame-page .wg-turncard {
  border: 1px solid hsl(var(--border));
  border-radius: 5px;
  background: hsl(var(--card));
  font-size: 12.5px;
  overflow: hidden;
}
.wargame-page .wg-turncard.current {
  border-color: hsl(var(--primary) / .6);
  box-shadow: 0 0 0 3px hsl(var(--primary) / .08);
}
.wargame-page .wg-tc-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 10px;
  background: hsl(var(--muted) / .55);
  border-bottom: 1px solid hsl(var(--border));
  cursor: pointer;
  user-select: none;
}
.wargame-page .wg-tc-hd-l { display: flex; align-items: center; gap: 8px; }
.wargame-page .wg-tc-num {
  font-family: ui-monospace, Menlo, monospace;
  font-size: 11px; font-weight: 700;
  background: hsl(var(--secondary)); color: hsl(var(--secondary-foreground));
  border-radius: 3px; padding: 2px 5px;
  letter-spacing: .04em;
}
.wargame-page .wg-tc-num.current-num {
  background: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
}
.wargame-page .wg-tc-campaign { color: hsl(var(--muted-foreground)); font-size: 11px; }
.wargame-page .wg-tc-time {
  color: hsl(var(--muted-foreground)); font-size: 11px;
  font-variant-numeric: tabular-nums;
}
.wargame-page .wg-tc-bd { padding: 8px 10px; }
.wargame-page .wg-tc-status {
  font-size: 12px; color: hsl(var(--foreground));
  margin-bottom: 6px; line-height: 1.5;
}
.wargame-page .wg-tc-status::before { content: "› "; color: hsl(var(--muted-foreground)); }
.wargame-page .wg-tc-intent {
  display: flex; gap: 6px; align-items: baseline;
  font-size: 12px; color: hsl(var(--muted-foreground)); line-height: 1.5;
}
.wargame-page .wg-tc-intent .tag {
  font-size: 9.5px; font-weight: 700; letter-spacing: .07em;
  color: hsl(var(--accent));
  border: 1px solid hsl(var(--accent) / .55);
  background: hsl(var(--accent) / .08);
  padding: 1px 4px; border-radius: 2px;
  flex-shrink: 0;
}
.wargame-page .wg-tc-model {
  font-family: ui-monospace, Menlo, monospace;
  font-size: 10.5px; color: hsl(var(--muted-foreground));
  margin-top: 6px; padding-top: 6px;
  border-top: 1px dashed hsl(var(--border));
  display: flex; align-items: center; gap: 6px;
}

/* ── footer note ──────────────────────────────────────── */
.wargame-page .wg-footer-note {
  margin-top: 8px;
  padding: 14px 18px;
  border: 1px dashed hsl(var(--border-strong));
  border-radius: var(--wg-radius);
  background: hsl(var(--muted) / .4);
  font-size: 12.5px;
  line-height: 1.55;
  color: hsl(var(--muted-foreground));
}
.wargame-page .wg-footer-note b { color: hsl(var(--foreground)); }
.wargame-page .wg-footer-note .fn-title {
  display: inline-flex; align-items: center; gap: 6px;
  font-weight: 600; color: hsl(var(--foreground));
  letter-spacing: .03em; font-size: 11px; text-transform: uppercase;
  margin-bottom: 4px;
}

/* ── mobile ───────────────────────────────────────────── */
@media (max-width: 720px) {
  .wargame-page .wg-topbar { padding: 8px 12px; gap: 8px; }
  .wargame-page .wg-topbar-l { gap: 6px; min-width: 0; flex: 1; }
  .wargame-page .wg-topbar-r { gap: 4px; flex-shrink: 0; }
  .wargame-page .wg-nav-tabs { margin-left: 6px; gap: 0; }
  .wargame-page .wg-nav-tab { padding: 5px 7px; font-size: 12px; }
  .wargame-page .wg-cost-pill { display: none; }
  .wargame-page .wg-brand-sub { display: none; }
  .wargame-page .wg-workspace { padding: 12px 14px 24px; }
  .wargame-page .wg-campaign-picker { flex-wrap: wrap; padding: 4px 4px 4px 10px; }
  .wargame-page .wg-campaign-picker .cp-meta {
    padding: 6px 0 4px; width: 100%;
    border-top: 1px dashed hsl(var(--border)); margin-top: 4px;
  }
  .wargame-page .wg-orders-hd { padding: 10px 14px; flex-direction: column; align-items: flex-start; gap: 6px; }
  .wargame-page .wg-orders-bd { padding: 6px 14px 14px; }
  .wargame-page .wg-see-board { margin: 12px 14px 0; }
  .wargame-page .wg-orders-actions { padding: 10px 14px; }
  .wargame-page .wg-orders-actions .meta { width: 100%; margin-left: 0; }
  /* iOS Safari auto-zooms inputs <16px on focus; bump to defeat it. */
  .wargame-page .wg-input,
  .wargame-page .wg-textarea,
  .wargame-page .wg-campaign-picker .cp-name { font-size: 16px; }
}

@media (max-width: 380px) {
  .wargame-page .wg-brand-name { display: none; }
}
