/* Ops Desk additions — extends styles-editorial.css */

/* Section nav: wider (10 items) */
.chapter-nav.ops { padding: 0 36px; flex-wrap: nowrap; overflow-x: auto; }
.chapter-nav.ops .chap { padding: 11px 14px; font-size: 11px; letter-spacing: 0.14em; }
.chapter-nav.ops .chap .num { font-size: 9.5px; margin-right: 6px; }

/* Status badges — editorial */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--sans);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 2px 7px;
  border: 0.5px solid var(--rule);
  background: transparent;
  color: var(--ink);
  white-space: nowrap;
  line-height: 1.4;
}
.badge .dot { width: 6px; height: 6px; flex: none; }
.badge-live    { color: var(--signal); border-color: var(--signal); }
.badge-live .dot { background: var(--signal); border-radius: 50%; }
.badge-warn    { color: var(--ink); border-color: var(--ink-3); }
.badge-warn .dot { background: var(--ink-3); }
.badge-crit    { color: var(--signal); border-color: var(--signal); border-style: solid; }
.badge-crit .dot { background: var(--signal); }
.badge-info    { color: var(--ink-2); border-color: var(--ink-3); border-style: dashed; }
.badge-neutral { color: var(--ink-3); border-color: var(--rule-soft); }
.badge-neutral .dot { background: var(--ink-3); }
.badge-paused  { color: var(--ink-4); border-color: var(--ink-4); border-style: dashed; }
.badge-paused .dot { background: var(--ink-4); }
.badge-onboard { color: var(--signal); border-color: var(--signal); border-style: dashed; }
.badge-onboard .dot { background: var(--signal); }
.badge-draft   { color: var(--ink-3); border-style: dashed; border-color: var(--ink-3); }

/* Alert banners — newspaper-style rule with kicker */
.alert {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 14px;
  padding: 12px 16px;
  border: 1px solid var(--rule);
  border-left: 4px solid var(--signal);
  background: var(--paper);
  margin-bottom: 14px;
}
.alert.warn  { border-left-color: var(--ink-3); }
.alert.info  { border-left-color: var(--ink); }
.alert .kicker { margin: 0; font-size: 10px; letter-spacing: 0.2em; }
.alert .body  { font-family: var(--sans); font-size: 14.5px; letter-spacing: 0; color: var(--ink); }
.alert .body em { font-style: normal; color: var(--signal); font-weight: 600; }
.alert .body strong { font-weight: 600; color: var(--ink); }
.alert .link { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink); border-bottom: 1px solid var(--rule); padding-bottom: 1px; cursor: pointer; }

/* "Today so far" hero */
.today-hero {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 28px;
  padding: 22px 26px;
  background: var(--ink);
  color: var(--paper);
  margin: 22px 0;
}
.today-hero .lbl { font-size: 10.5px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(244,237,224,0.6); font-weight: 600; margin-bottom: 12px; }
.today-hero .big {
  font-family: var(--display); font-weight: 700;
  font-size: 40px; letter-spacing: -0.022em; line-height: 1.05;
  font-variant-numeric: tabular-nums;
}
.today-hero .big em { font-style: normal; color: var(--signal); font-weight: 500; }
.today-hero .sub { font-family: var(--mono); font-size: 12px; color: rgba(244,237,224,0.65); margin-top: 10px; }
.today-hero .deltas {
  display: flex; flex-direction: column; gap: 6px; text-align: right;
  font-family: var(--mono); font-size: 12px;
}
.today-hero .delta-lbl { color: rgba(244,237,224,0.5); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 4px; }
.today-hero .delta-row { display: flex; gap: 14px; justify-content: flex-end; align-items: baseline; }
.today-hero .delta-row .v { color: var(--paper); }
.today-hero .delta-row .d { color: var(--signal); }
.today-hero .delta-row .d.dn { color: rgba(244,237,224,0.5); }

/* Filter bar */
.filterbar {
  display: flex; gap: 0; align-items: stretch;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  margin: 18px 0 0;
}
.filterbar .field {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px 10px 0;
  border-right: 1px solid var(--hairline);
  font-size: 11px; letter-spacing: 0.04em;
}
.filterbar .field:first-child { padding-left: 0; }
.filterbar .field .l { color: var(--ink-3); letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; }
.filterbar select, .filterbar input {
  appearance: none; -webkit-appearance: none;
  background: transparent; border: 0;
  font-family: var(--mono); font-size: 12px; color: var(--ink);
  padding: 0; cursor: default; outline: none;
  letter-spacing: 0;
}
.filterbar select { padding-right: 16px; background-image: linear-gradient(45deg, transparent 50%, var(--ink-3) 50%), linear-gradient(135deg, var(--ink-3) 50%, transparent 50%); background-position: calc(100% - 8px) center, calc(100% - 4px) center; background-size: 4px 4px, 4px 4px; background-repeat: no-repeat; }
.filterbar input::placeholder { color: var(--ink-4); }
.filterbar .spacer { flex: 1; border-right: 0; padding: 0; }
.filterbar .actions { padding: 8px 0; display: flex; gap: 8px; align-items: center; }

/* Warmup mini-bar */
.warmup {
  display: inline-grid;
  grid-template-columns: 60px 32px;
  align-items: center;
  gap: 10px;
}
.warmup .track { position: relative; height: 6px; background: var(--paper-3); }
.warmup .fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--ink);
}
.warmup .fill.low  { background: var(--signal); }
.warmup .fill.mid  { background: var(--ink-3); }
.warmup .fill.good { background: var(--ink); }
.warmup .v { font-family: var(--mono); font-size: 11.5px; color: var(--ink); font-variant-numeric: tabular-nums; }

/* Sparkbar grid (client volume sparkline) */
.sparkbar-grid {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 1fr;
  align-items: end;
  gap: 1px;
  height: 64px;
}
.sparkbar-grid .b {
  background: var(--ink);
  min-height: 1px;
}
.sparkbar-grid .b.wknd { background: var(--ink-4); }

/* Stat card — bordered plate variant */
.stat-card {
  border: 1px solid var(--rule);
  padding: 16px 18px;
  display: flex; flex-direction: column; gap: 6px;
}
.stat-card .l { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-3); font-weight: 600; }
.stat-card .v { font-family: var(--display); font-weight: 600; font-size: 28px; letter-spacing: -0.02em; line-height: 1.1; color: var(--ink); margin: 4px 0 2px; }
.stat-card .v.signal { color: var(--signal); }
.stat-card .sub { font-family: var(--mono); font-size: 11px; color: var(--ink-3); }

/* Clickable summary tiles (Accounts page) */
.summary-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
}
.summary-grid .cell {
  padding: 18px 22px;
  border-right: 1px solid var(--hairline);
  cursor: pointer;
  display: flex; flex-direction: column; gap: 8px;
}
.summary-grid .cell:last-child { border-right: 0; }
.summary-grid .cell:hover { background: var(--paper-2); }
.summary-grid .cell.signal .v { color: var(--signal); }
.summary-grid .cell.active { background: var(--paper-2); box-shadow: inset 0 -2px 0 0 var(--signal); }
.summary-grid .cell .l { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-3); font-weight: 600; }
.summary-grid .cell .v { font-family: var(--display); font-weight: 700; font-size: 30px; letter-spacing: -0.022em; line-height: 1.05; }
.summary-grid .cell .sub { font-family: var(--mono); font-size: 11px; color: var(--ink-3); }

/* Inline edit select — looks editorial */
.inline-edit {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--mono); font-size: 12px; color: var(--ink);
  padding: 3px 6px;
  border: 0.5px dashed var(--ink-4);
  background: transparent;
}
.inline-edit:hover { border-color: var(--ink); background: var(--paper-2); }
.inline-edit select {
  appearance: none; -webkit-appearance: none;
  border: 0; background: transparent; color: inherit;
  font: inherit; padding: 0 12px 0 0; outline: none; cursor: default;
}
.inline-edit::after {
  content: '▾'; font-size: 9px; color: var(--ink-3); margin-left: -8px;
}

/* Two-column definition list */
.deflist {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.deflist .row {
  display: grid; grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid var(--hairline);
  border-right: 1px solid var(--hairline);
}
.deflist .row:nth-child(2n) { border-right: 0; }
.deflist .row .k { padding: 10px 14px 10px 0; font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); font-weight: 600; }
.deflist .row:nth-child(2n) .k { padding-left: 14px; }
.deflist .row .v { padding: 10px 14px 10px 0; font-family: var(--mono); font-size: 12.5px; color: var(--ink); }
.deflist .row .v.signal { color: var(--signal); }
.deflist .row .v.warn { color: var(--ink-3); }

/* Health score huge badge */
.health-huge {
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  border: 2px solid var(--ink);
  padding: 10px 22px;
  min-width: 96px;
}
.health-huge .v { font-family: var(--display); font-weight: 700; font-size: 38px; letter-spacing: -0.022em; line-height: 1; color: var(--ink); }
.health-huge .l { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3); font-weight: 600; margin-top: 4px; }
.health-huge.crit { border-color: var(--signal); }
.health-huge.crit .v { color: var(--signal); }

/* Sync result block (Settings) */
.sync-result {
  border: 1px solid var(--rule);
  padding: 16px 18px;
  margin-top: 12px;
}
.sync-result h4 { font-family: var(--display); font-size: 15px; margin: 0 0 10px; letter-spacing: -0.005em; font-weight: 600; }

/* Breadcrumb back */
.crumb {
  font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 600;
  display: inline-flex; align-items: center; gap: 6px;
  margin-bottom: 14px;
  cursor: pointer;
}
.crumb:hover { color: var(--ink); }

/* Small list (account flags, mapped tags) */
.li-row {
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: baseline; gap: 14px;
  padding: 10px 0;
  border-bottom: 1px solid var(--hairline);
  font-size: 13px;
}
.li-row .num { font-family: var(--mono); font-size: 10.5px; color: var(--ink-4); }
.li-row .main { color: var(--ink); }
.li-row .main em { font-style: italic; color: var(--ink-2); }
.li-row .meta { font-family: var(--mono); font-size: 11px; color: var(--ink-3); }

/* Section heads spacing for ops pages */
.page.ops { padding-top: 24px; }
.page.ops .page-h { padding-bottom: 14px; margin-bottom: 18px; }
.page.ops .headline { font-size: 30px; max-width: 28ch; }
.page.ops .dek { font-size: 15px; }

/* Empty state */
.empty {
  border: 1px dashed var(--ink-4);
  padding: 28px;
  text-align: center;
  font-family: var(--sans);
  font-size: 14.5px;
  color: var(--ink-3);
  letter-spacing: 0;
}
.empty em { color: var(--signal); font-style: normal; font-weight: 600; }

/* PDF preview placeholder */
.pdf-thumb {
  border: 1px solid var(--rule);
  padding: 16px;
  font-family: var(--mono); font-size: 11px;
  color: var(--ink-3);
  background: var(--paper-2);
}

/* Tabular helper for tighter density */
.tbl.dense thead th { padding: 8px 12px 8px 0; }
.tbl.dense tbody td { padding: 9px 12px 9px 0; }
.tbl.dense .co { font-size: 14px; }

/* small inline action link */
.linklike {
  border-bottom: 1px solid var(--rule);
  cursor: pointer;
}
.linklike:hover { color: var(--signal); border-bottom-color: var(--signal); }

/* ── Top-level product tabs (black bar above the main top-nav) ── */
.product-nav {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 8px 24px;
  background: var(--ink);
  color: #fff;
  border-bottom: 1px solid var(--rule);
}
.product-nav-brand {
  font-family: var(--display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: -0.005em;
  color: #fff;
  padding-right: 18px;
  border-right: 1px solid rgba(255,255,255,0.2);
}
.product-nav-tabs { display: flex; gap: 0; align-items: stretch; flex: 1; }
.product-tab {
  padding: 6px 18px;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  border: 0;
  background: transparent;
  cursor: default;
  text-decoration: none;
  transition: color 0.12s;
}
.product-tab:hover { color: #fff; }
.product-tab.active { color: #fff; position: relative; }
.product-tab.active::after {
  content: '';
  position: absolute;
  left: 18px; right: 18px; bottom: -9px;
  height: 2px;
  background: var(--signal);
}

body.print-mode .product-nav { display: none; }

/* ── Top nav band (logo · chapters · utility tray) ────────── */
.top-nav {
  display: flex;
  align-items: stretch;
  border-bottom: 2px solid var(--rule);
  background: var(--paper);
}
.top-nav-mark {
  padding: 14px 24px;
  border-right: 1px solid var(--hairline);
  display: flex;
  align-items: center;
}
.top-nav-mark img { height: 22px; width: auto; display: block; }
.top-nav-chapters { display: flex; align-items: stretch; }
.top-nav-chap {
  padding: 0 22px;
  display: flex;
  align-items: center;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  border-right: 1px solid var(--hairline);
  text-decoration: none;
  transition: color 0.12s;
}
.top-nav-chap:hover { color: var(--ink); }
.top-nav-chap.on {
  color: var(--ink);
  box-shadow: inset 0 -3px 0 var(--signal);
}
.top-nav-tray {
  margin-left: auto;
  display: flex;
  align-items: center;
  padding: 0 22px;
  gap: 18px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-3);
}
.top-nav-meta { font-variant-numeric: tabular-nums; }
.top-nav-settings {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  text-decoration: none;
  padding: 6px 12px;
  border: 1px solid var(--hairline);
}
.top-nav-settings:hover { color: var(--ink); border-color: var(--ink); }
.top-nav-settings.on {
  color: var(--ink);
  background: var(--paper-3);
  border-color: var(--ink-3);
}

body.print-mode .top-nav { display: none; }

/* ── Print mode (PDF export) ─────────────────────────────── */
body.print-mode { background: #fff; }
body.print-mode .page { padding: 18mm 16mm 24mm; max-width: none; }
body.print-mode .pdf-btn,
body.print-mode .crumb,
body.print-mode form button,
body.print-mode .filterbar .actions,
body.print-mode .summary-grid .cell { cursor: default !important; }
body.print-mode .pdf-export-button,
body.print-mode .no-print { display: none !important; }
body.print-mode .page-h { padding-bottom: 14px; margin-bottom: 18px; }
body.print-mode .page.ops .headline { font-size: 26px; max-width: 32ch; }
body.print-mode .lede-val { font-size: 26px; }
body.print-mode .stat-card .v { font-size: 22px; }
body.print-mode .summary-grid .cell .v { font-size: 24px; }
body.print-mode .today-hero .big { font-size: 30px; }
body.print-mode .today-hero { padding: 16px 18px; margin: 16px 0; }
body.print-mode .tbl thead th { font-size: 9.5px; padding: 8px 10px 8px 0; }
body.print-mode .tbl tbody td { padding: 7px 10px 7px 0; }
body.print-mode .sect-h h2 { font-size: 15px; }
body.print-mode table { page-break-inside: auto; }
body.print-mode tr { page-break-inside: avoid; page-break-after: auto; }
body.print-mode .alert { page-break-inside: avoid; }
body.print-mode .pdf-foot {
  display: block;
  margin-top: 36px;
  padding-top: 12px;
  border-top: 1px solid var(--hairline);
  font-family: var(--mono);
  font-size: 9.5px;
  color: var(--ink-4);
  letter-spacing: 0.04em;
}
.pdf-foot { display: none; }

@page { size: A4; margin: 12mm 10mm; }

/* Editorial form inputs / labels (templates) */
.ed-label {
  display: block;
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 600;
  margin-bottom: 4px;
}
.ed-input,
.ed-select,
.ed-textarea {
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--rule);
  background: transparent;
  padding: 8px 0;
  font-family: var(--mono);
  font-size: 13px;
  color: var(--ink);
  outline: none;
  appearance: none; -webkit-appearance: none;
}
.ed-input:focus,
.ed-select:focus,
.ed-textarea:focus { border-bottom-color: var(--signal); }
.ed-textarea { min-height: 88px; resize: vertical; font-family: var(--sans); }
.ed-select {
  padding-right: 16px;
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-3) 50%), linear-gradient(135deg, var(--ink-3) 50%, transparent 50%);
  background-position: calc(100% - 8px) center, calc(100% - 4px) center;
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
}
