/* dash-revenue-workbench.css - Revenue Unit Economics Workbench.
 *
 * Aesthetic flavor: PRICING BLUEPRINT / ARCHITECT DESK.
 *
 * Dark blueprint paper, brass quote stamps, cyan construction lines, and
 * invoice-like white cards. Distinct from financial-terminal cost burn:
 * this is forward pricing and bid math, not spend monitoring.
 */

.rw-page {
  --rw-bg: #102f4a;
  --rw-bg-2: #0a2136;
  --rw-card: #f8f4e8;
  --rw-ink: #101820;
  --rw-soft: #5b6570;
  --rw-line: #2e6f92;
  --rw-line-soft: rgba(46,111,146,0.28);
  --rw-cyan: #63d7ff;
  --rw-brass: #d3a13b;
  --rw-green: #2f9b62;
  --rw-red: #c94d41;
  --rw-amber: #c17a18;
  color: var(--rw-card);
  background: var(--rw-bg);
}

body.mc.rw-page {
  background:
    linear-gradient(rgba(99,215,255,0.08) 1px, transparent 1px) 0 0 / 32px 32px,
    linear-gradient(90deg, rgba(99,215,255,0.08) 1px, transparent 1px) 0 0 / 32px 32px,
    radial-gradient(circle at 70% 0%, rgba(99,215,255,0.15), transparent 42%),
    var(--rw-bg-2);
  background-image: var(--bg, none) !important;
}

.rw-hud {
  background: #06182a;
  color: var(--rw-card);
  border-bottom: 1px solid var(--rw-cyan);
  font-family: "IBM Plex Mono", monospace;
}
.rw-page .callsign,
.rw-page .hud-mode {
  color: var(--rw-cyan);
  font-family: "Archivo Black", sans-serif;
  letter-spacing: 0.06em;
}
.rw-page .hud-sub { color: #a8cce0; }
.rw-page .hud-pill {
  background: rgba(99,215,255,0.08);
  color: var(--rw-cyan);
  border: 1px solid rgba(99,215,255,0.45);
  border-radius: 2px;
}
.rw-page .hud-pill[data-band="good"] { color: #a5ffc9; border-color: var(--rw-green); }
.rw-page .hud-pill[data-band="thin"] { color: #ffd89a; border-color: var(--rw-amber); }
.rw-page .hud-pill[data-band="bad"] { color: #ffb4ad; border-color: var(--rw-red); }
.rw-page .hud-link { text-decoration: none; }

.rw-stage {
  max-width: 1420px;
  padding: 26px 28px 80px;
  font-family: "Public Sans", sans-serif;
}
.rw-hero {
  max-width: 1080px;
  margin-bottom: 22px;
  padding: 24px;
  border: 1px solid rgba(99,215,255,0.5);
  background: rgba(6,24,42,0.72);
  box-shadow: 0 24px 80px rgba(0,0,0,0.28);
}
.rw-kicker {
  margin: 0 0 8px;
  font: 800 12px "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rw-brass);
}
.rw-hero h1 {
  margin: 0;
  max-width: 1000px;
  font: 800 clamp(38px, 7vw, 82px) / 0.94 "Archivo Black", sans-serif;
  letter-spacing: -0.055em;
  text-transform: uppercase;
}
.rw-hero p:last-child {
  max-width: 780px;
  line-height: 1.55;
  color: #c7d9e4;
}

.rw-grid {
  display: grid;
  grid-template-columns: minmax(360px, 0.95fr) minmax(440px, 1.05fr);
  gap: 18px;
  margin-bottom: 18px;
}
.rw-panel {
  background: var(--rw-card);
  color: var(--rw-ink);
  border: 1px solid rgba(99,215,255,0.35);
  box-shadow: 8px 8px 0 rgba(6,24,42,0.85);
  margin-bottom: 18px;
}
.rw-panel-head {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #fff9e8;
  border-bottom: 1px solid #d9cda9;
  padding: 12px 16px;
}
.rw-panel-head span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  background: var(--rw-brass);
  color: #111;
  font: 800 12px "IBM Plex Mono", monospace;
}
.rw-panel-head h2 {
  margin: 0;
  font: 800 21px "Archivo Black", sans-serif;
  letter-spacing: -0.03em;
  text-transform: uppercase;
}

.rw-field {
  display: grid;
  gap: 6px;
  padding: 16px 16px 0;
  font: 800 12px "IBM Plex Mono", monospace;
  text-transform: uppercase;
  color: var(--rw-soft);
}
.rw-field select {
  width: 100%;
  border: 1px solid #b9a979;
  background: #fffdf5;
  color: var(--rw-ink);
  padding: 10px;
  font: 700 14px "Public Sans", sans-serif;
}
.rw-package-card {
  margin: 16px;
  padding: 14px;
  border: 1px solid #d9cda9;
  background: #fffdf5;
}
.rw-package-card h3 {
  margin: 0 0 8px;
  font: 800 22px "Archivo Black", sans-serif;
  text-transform: uppercase;
  letter-spacing: -0.03em;
}
.rw-package-card p { color: var(--rw-soft); line-height: 1.45; }
dl {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 8px;
  margin: 0;
}
dl div {
  border-top: 2px solid var(--rw-line-soft);
  padding-top: 6px;
}
dt {
  color: var(--rw-soft);
  font: 800 10px "IBM Plex Mono", monospace;
  text-transform: uppercase;
}
dd {
  margin: 2px 0 0;
  font: 800 16px "IBM Plex Mono", monospace;
}

.rw-controls {
  display: grid;
  gap: 12px;
  padding: 0 16px 18px;
}
.rw-slider {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px 12px;
  align-items: center;
  font: 800 12px "IBM Plex Mono", monospace;
  color: var(--rw-soft);
  text-transform: uppercase;
}
.rw-slider strong { color: var(--rw-ink); }
.rw-slider input {
  grid-column: 1 / -1;
  width: 100%;
  accent-color: var(--rw-line);
}

.rw-result {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding: 16px;
}
.rw-kpi {
  border: 1px solid #d9cda9;
  background: #fffdf5;
  padding: 14px;
}
.rw-kpi span {
  display: block;
  color: var(--rw-soft);
  font: 800 11px "IBM Plex Mono", monospace;
  text-transform: uppercase;
}
.rw-kpi strong {
  display: block;
  margin-top: 7px;
  font: 800 24px "IBM Plex Mono", monospace;
}
.rw-result[data-band="good"] .rw-kpi:last-child strong { color: var(--rw-green); }
.rw-result[data-band="thin"] .rw-kpi:last-child strong { color: var(--rw-amber); }
.rw-result[data-band="bad"] .rw-kpi:last-child strong { color: var(--rw-red); }

.rw-waterfall { padding: 0 16px 18px; }
.rw-bar-row {
  display: grid;
  grid-template-columns: 130px 1fr 95px;
  gap: 10px;
  align-items: center;
  margin: 8px 0;
  font: 800 12px "IBM Plex Mono", monospace;
  text-transform: uppercase;
}
.rw-bar-track {
  height: 15px;
  background: #dfe8e8;
  border: 1px solid #b7caca;
}
.rw-bar-track b {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--rw-line), var(--rw-cyan));
}
.rw-bar-row:last-child .rw-bar-track b { background: linear-gradient(90deg, var(--rw-green), #9ff0bf); }

.rw-evidence {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
  padding: 16px;
}
.rw-evidence-card {
  border: 1px solid #d9cda9;
  background: #fffdf5;
  padding: 14px;
}
.rw-evidence-card h3 {
  margin: 0 0 12px;
  font: 800 16px "Archivo Black", sans-serif;
  text-transform: uppercase;
}
.rw-export {
  margin: 16px;
  padding: 16px;
  background: #06182a;
  color: #d9f7ff;
  overflow-x: auto;
  font: 600 12px/1.5 "IBM Plex Mono", monospace;
  border-left: 6px solid var(--rw-brass);
}
.rw-error { color: var(--rw-red); padding: 16px; }
.rw-foot {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: #c7d9e4;
  font-size: 12px;
  line-height: 1.45;
}
.rw-foot p { margin: 0; }
code {
  font-family: "IBM Plex Mono", monospace;
  background: rgba(99,215,255,0.14);
  padding: 1px 4px;
}

@media (max-width: 980px) {
  .rw-stage { padding: 18px 14px 60px; }
  .rw-grid { grid-template-columns: 1fr; }
  .rw-result { grid-template-columns: 1fr; }
  .rw-bar-row { grid-template-columns: 1fr; }
  .rw-foot { flex-direction: column; }
}
