/* ============================================================
   CashLens — Shared Stylesheet
   Target: Desktop/laptop. Safari (Mac), Chrome/Edge (PC).
   No framework. No chart styles (charts deferred).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,600;0,700;1,400&display=swap');

/* ── Brand tokens ─────────────────────────────────────────── */

:root {
  --cream:       #f5f2e8;
  --parchment:   #ede9db;
  --ink:         #1c1c2e;
  --navy:        #1e3a5f;
  --slate:       #5c7a9e;
  --forest:      #355e3b;
  --amber:       #b87333;
  --amber-hover: #9a6128;
  --red:         #c0392b;
}

/* ── Reset & base ─────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Lora', Georgia, serif;
  font-size: 18px;
  line-height: 1.78;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

h1 { font-size: 1.78rem; font-weight: 700; color: var(--navy); }
h2 { font-size: 1.22rem; font-weight: 700; color: var(--navy); margin-bottom: 12px; }
h3 { font-size: 1rem;    font-weight: 700; color: var(--navy); margin-bottom: 8px; }

a { color: var(--forest); text-decoration: none; }
a:hover { color: var(--navy); text-decoration: underline; }

/* ── Utility ──────────────────────────────────────────────── */

.hidden            { display: none !important; }
.visually-hidden   { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); clip-path: inset(50%); white-space: nowrap; }
.error             { color: var(--red); font-size: 0.833rem; margin-top: 6px; }

/* Per-section validation banners */
.validation-banner {
  margin: 0 0 18px;
  padding: 11px 14px;
  border-radius: 6px;
  font-size: 0.875rem;
  line-height: 1.5;
}
.validation-banner.is-success {
  background: #eafaf1;
  border: 1px solid #27ae60;
  color: #1a7a3c;
}
.validation-banner.is-error {
  background: #fdecea;
  border: 1px solid var(--red);
  color: var(--red);
}
.validation-banner ul { margin: 6px 0 0; padding-left: 20px; }
.validation-banner li { margin-bottom: 2px; }
.run-diagnostic-hint { font-size: 0.833rem; color: var(--red); margin-top: 8px; }
.no-issues,
.no-sessions       { color: var(--slate); font-style: italic; }

/* ── Layout ───────────────────────────────────────────────── */

.site-header {
  background: var(--navy);
  border-bottom: 2px solid rgba(255,255,255,0.1);
  padding: 12px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.site-logo    { color: var(--cream); font-size: 1.4rem; }
.site-tagline { color: rgba(245,242,232,0.65); font-size: 0.875rem; }

.main-container {
  max-width: 960px;
  margin: 0 auto;
  padding: 24px 24px 48px;
}

/* ── Cards ────────────────────────────────────────────────── */

.card {
  background: var(--parchment);
  border: 1px solid rgba(30,58,95,0.12);
  border-radius: 6px;
  padding: 24px;
  margin-bottom: 16px;
}

/* ── Session start mode ───────────────────────────────────── */

.start-mode-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 16px 0 0;
}
.start-mode-option {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.start-mode-option:has(input:checked) {
  border-color: var(--forest);
  background: rgba(53,94,59,0.05);
}
.start-mode-option input[type="radio"] { margin-top: 3px; flex-shrink: 0; }
.start-mode-label { display: flex; flex-direction: column; gap: 3px; }
.start-mode-label strong { font-size: 0.9rem; color: var(--navy); }
.start-mode-desc { font-size: 0.8rem; color: var(--slate); line-height: 1.45; }

/* ── Buttons ──────────────────────────────────────────────── */

button, .btn-primary, .btn-secondary, .btn-ghost, .btn-danger {
  cursor: pointer;
  font-size: 0.875rem;
  font-family: 'Lora', Georgia, serif;
  border-radius: 4px;
  padding: 7px 16px;
  border: 1px solid transparent;
  transition: background 0.2s, border-color 0.2s;
  white-space: nowrap;
  appearance: none;
  -webkit-appearance: none;
}

.btn-primary {
  background: var(--amber);
  color: var(--cream);
  border-color: var(--amber);
  font-weight: 600;
}
.btn-primary:hover    { background: var(--amber-hover); border-color: var(--amber-hover); }
.btn-primary:disabled { background: rgba(184,115,51,0.4); border-color: rgba(184,115,51,0.4); cursor: default; }

.btn-secondary {
  background: var(--cream);
  color: var(--forest);
  border-color: var(--forest);
}
.btn-secondary:hover { background: rgba(53,94,59,0.08); }

.btn-ghost {
  background: transparent;
  color: var(--slate);
  border-color: rgba(92,122,158,0.4);
}
.btn-ghost:hover { background: var(--parchment); }

.btn-danger {
  background: var(--cream);
  color: var(--red);
  border-color: var(--red);
}
.btn-danger:hover { background: #fdf0ef; }

.btn-run {
  font-size: 0.944rem;
  padding: 14px 28px;
}

/* ── Form elements ────────────────────────────────────────── */

.field-group {
  margin-bottom: 14px;
}

.field-group label {
  display: block;
  font-weight: 600;
  margin-bottom: 4px;
  font-size: 0.875rem;
}

input[type="text"],
input[type="number"],
input[type="date"],
input[type="email"],
select,
textarea {
  display: block;
  width: 100%;
  max-width: 400px;
  padding: 6px 10px;
  border: 1px solid rgba(30,58,95,0.2);
  border-radius: 4px;
  font-size: 0.875rem;
  font-family: 'Lora', Georgia, serif;
  background: var(--cream);
  color: var(--ink);
}

input[readonly] {
  background: var(--parchment);
  color: var(--slate);
  cursor: default;
}

input:focus, select:focus, textarea:focus {
  outline: 2px solid var(--forest);
  outline-offset: 1px;
}

.helper-text {
  font-size: 0.8rem;
  color: var(--slate);
  margin-top: 3px;
}

.field-set {
  border: 1px solid rgba(30,58,95,0.15);
  border-radius: 4px;
  padding: 14px 16px;
  margin-bottom: 16px;
}

.field-set legend {
  font-weight: 600;
  font-size: 0.875rem;
  padding: 0 6px;
  color: var(--navy);
}

.radio-group {
  display: flex;
  gap: 20px;
  margin-bottom: 12px;
  font-size: 0.875rem;
}

.radio-group label {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
}

/* Monthly / weekly grids */
.monthly-grid,
.weekly-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px 12px;
}

.monthly-grid .field-group,
.weekly-grid .field-group {
  margin-bottom: 0;
}

.monthly-grid input,
.weekly-grid input {
  max-width: 100%;
}

/* Repeating rows (Section F) */
.repeating-row {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.repeating-row input {
  display: inline-block;
  max-width: none;
  flex: 1 1 120px;
}

.repeating-row .row-description { flex: 2 1 180px; }

.btn-remove-row {
  background: transparent;
  color: var(--red);
  border: 1px solid var(--red);
  border-radius: 4px;
  padding: 4px 10px;
  font-size: 0.8rem;
  cursor: pointer;
}
.btn-remove-row:hover { background: #fdf0ef; }

.btn-add-row { margin-top: 8px; }

/* ── Form notes ───────────────────────────────────────────── */

.persistent-note {
  font-size: 0.875rem;
  color: var(--forest);
  font-weight: 500;
}

.limitation-note {
  font-size: 0.8rem;
  color: var(--slate);
}

.section-note {
  font-size: 0.875rem;
  color: var(--slate);
  font-style: italic;
  margin-bottom: 16px;
}

.saved-indicator {
  font-size: 0.8rem;
  color: #27ae60;
  margin-left: auto;
}

/* ── Tab bar (input.html) ─────────────────────────────────── */

.tab-bar {
  background: var(--cream);
  border-bottom: 1px solid rgba(30,58,95,0.12);
  display: flex;
  gap: 0;
  overflow-x: auto;
  padding: 0 24px;
  position: sticky;
  top: 0;
  z-index: 100;
}

.tab-btn {
  background: var(--cream);
  border: none;
  border-bottom: 3px solid transparent;
  border-radius: 0;
  padding: 10px 16px;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--slate);
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.2s, border-color 0.2s;
  appearance: none;
  -webkit-appearance: none;
  display: inline-block;
  line-height: normal;
}

.tab-btn:hover         { color: var(--forest); }
.tab-btn.tab-active    { color: var(--forest); border-bottom-color: var(--forest); }

/* Completion indicators */
.tab-btn.tab-complete  { color: #27ae60; }
.tab-btn.tab-incomplete {
  color: var(--red);
  background: var(--cream);
}

/* ── Tab panel ────────────────────────────────────────────── */

.tab-panel {
  background: var(--parchment);
  border: 1px solid rgba(30,58,95,0.12);
  border-radius: 0 0 6px 6px;
  padding: 24px;
  margin-bottom: 8px;
}

/* ── Form navigation & actions ────────────────────────────── */

.form-nav {
  display: flex;
  gap: 12px;
  margin-top: 8px;
  padding: 0 2px;
}

.form-actions {
  display: flex;
  gap: 12px;
  margin-top: 12px;
}

.run-diagnostic-row {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid rgba(30,58,95,0.1);
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.loading-text {
  font-size: 0.875rem;
  color: var(--slate);
  font-style: italic;
}

/* ── Purchase link row ────────────────────────────────────── */

.purchase-link-row {
  margin-top: 12px;
  font-size: 0.875rem;
  color: var(--slate);
}

/* ── Session list ─────────────────────────────────────────── */

.session-controls {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.session-controls input[type="text"] {
  flex: 1;
  max-width: 300px;
}

.upload-row {
  margin-bottom: 16px;
}

.upload-label {
  display: inline-block;
  cursor: pointer;
}

.session-card {
  background: var(--parchment);
  border: 1px solid rgba(30,58,95,0.12);
  border-radius: 6px;
  padding: 14px 16px;
  margin-bottom: 10px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  flex-wrap: wrap;
}

.session-info { flex: 1; min-width: 200px; }

.session-client {
  font-weight: 600;
  font-size: 0.95rem;
  margin-bottom: 2px;
}

.session-dates {
  font-size: 0.8rem;
  color: var(--slate);
}

.session-expiry-warning {
  font-size: 0.8rem;
  color: var(--red);
  margin-top: 4px;
  font-weight: 500;
}

.session-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: flex-start;
}

.session-op-error {
  flex-basis: 100%;
  margin-top: 6px;
}

/* ── Banner ───────────────────────────────────────────────── */

.banner-red {
  background: #fdf0ef;
  border: 1px solid var(--red);
  border-radius: 4px;
  color: var(--red);
  padding: 10px 14px;
  margin-bottom: 16px;
  font-size: 0.875rem;
  font-weight: 500;
}

/* ── Results tab bar ──────────────────────────────────────── */

.results-tab-bar {
  background: var(--cream);
  border-bottom: 1px solid rgba(30,58,95,0.12);
}

.results-tab-btn {
  background: var(--cream);
  border: none;
  border-bottom: 3px solid transparent;
  border-radius: 0;
  padding: 10px 18px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--slate);
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.2s, border-color 0.2s;
  appearance: none;
  -webkit-appearance: none;
  display: inline-block;
  line-height: normal;
}

.results-tab-btn:hover        { color: var(--forest); }
.results-tab-btn.tab-active   { color: var(--forest); border-bottom-color: var(--forest); }

.results-tab-btn[disabled] {
  color: rgba(92,122,158,0.4);
  cursor: default;
}

.results-tab-btn[disabled]:hover { color: rgba(92,122,158,0.4); }

.phase2-badge {
  display: inline-block;
  background: var(--parchment);
  color: var(--slate);
  font-size: 0.7rem;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 10px;
  vertical-align: middle;
  margin-left: 4px;
  letter-spacing: 0.02em;
}

.results-tab-panel { padding: 0; }

/* ── Results section wrappers ─────────────────────────────── */

.results-section {
  background: var(--parchment);
  border: 1px solid rgba(30,58,95,0.12);
  border-radius: 6px;
  padding: 20px 24px;
  margin-bottom: 16px;
  margin-top: 16px;
}

.phase2-placeholder {
  color: var(--slate);
  font-style: italic;
  text-align: center;
  padding: 40px;
}

/* ── Metric cards (CCC Scorecard) ─────────────────────────── */

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

.metric-card {
  border-radius: 6px;
  padding: 16px;
  border: 2px solid rgba(30,58,95,0.15);
  background: var(--parchment);
  min-width: 0;
}

.metric-step {
  font-size: 0.75rem;
  color: var(--slate);
  font-weight: 600;
  margin-bottom: 4px;
}

.metric-label {
  font-size: 0.8rem;
  color: var(--slate);
  margin-bottom: 6px;
  line-height: 1.3;
}

.metric-value {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 4px;
}

/* Severity variants — driven by Worker output */
.metric-card.severity-high   { border-color: var(--red); }
.metric-card.severity-medium { border-color: #f39c12; }
.metric-card.severity-low    { border-color: #27ae60; }

/* ── Severity badges ──────────────────────────────────────── */

.severity-badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 10px;
  letter-spacing: 0.03em;
}

.severity-badge-high   { background: #fdecea; color: var(--red); }
.severity-badge-medium { background: #fef9ec; color: #b7770d; }
.severity-badge-low    { background: #eafaf1; color: #1e8449; }

/* ── Cash trapped table ───────────────────────────────────── */

.cash-trapped-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.cash-trapped-table th,
.cash-trapped-table td {
  padding: 8px 12px;
  border-bottom: 1px solid rgba(30,58,95,0.08);
  text-align: left;
}

.cash-trapped-table th { font-weight: 500; color: var(--slate); }
.cash-trapped-total th,
.cash-trapped-total td { font-weight: 700; border-top: 2px solid rgba(30,58,95,0.15); }

.cash-amount { text-align: right; font-variant-numeric: tabular-nums; }
.cash-total  { font-size: 1.1rem; }

/* ── Analysis table ───────────────────────────────────────── */

.analysis-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.analysis-table th,
.analysis-table td {
  padding: 8px 12px;
  border-bottom: 1px solid rgba(30,58,95,0.08);
  text-align: left;
}

.analysis-table th { font-weight: 500; color: var(--slate); width: 55%; }
.analysis-table td { font-variant-numeric: tabular-nums; }

/* ── Margin compression ───────────────────────────────────── */

.compression-down { color: var(--red); font-weight: 600; }
.compression-up   { color: #27ae60; font-weight: 600; }

/* ── Issue cards ──────────────────────────────────────────── */

.section-actions {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
  justify-content: flex-end;
}

.issue-card {
  border-radius: 6px;
  border: 1px solid rgba(30,58,95,0.12);
  padding: 14px 16px;
  margin-bottom: 10px;
  background: var(--parchment);
}

.issue-card.severity-border-high   { border-left: 4px solid var(--red); }
.issue-card.severity-border-medium { border-left: 4px solid #f39c12; }
.issue-card.severity-border-low    { border-left: 4px solid #27ae60; }

.issue-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}

.issue-title   { font-weight: 600; font-size: 0.95rem; }
.issue-impact  { font-size: 0.875rem; font-weight: 600; color: var(--ink); margin-bottom: 4px; }
.issue-explanation { font-size: 0.875rem; color: var(--ink); margin-bottom: 4px; }
.issue-threshold   { font-size: 0.8rem; color: var(--slate); font-style: italic; }

/* ── Forecast table ───────────────────────────────────────── */

.forecast-label {
  font-size: 0.875rem;
  color: var(--slate);
  font-style: italic;
  margin-bottom: 8px;
}

.forecast-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.forecast-table th,
.forecast-table td {
  padding: 7px 10px;
  border-bottom: 1px solid rgba(30,58,95,0.08);
  text-align: right;
}

.forecast-table th:first-child,
.forecast-table td:first-child { text-align: left; }

.forecast-table thead th {
  background: var(--parchment);
  font-weight: 600;
  font-size: 0.8rem;
  color: var(--slate);
}

.low-cash { background: #fff4f4; }
.cash-negative { color: var(--red); font-weight: 600; }

/* ── Executive Summary (Tab 5 / results.html) ─────────────── */

.summary-issue {
  margin-bottom: 6px;
  font-size: 0.9rem;
}

.summary-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

/* ── summary.html layout ──────────────────────────────────── */

.summary-page body,
.summary-page {
  background: var(--cream);
}

.summary-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 20px 32px 12px;
  border-bottom: 2px solid var(--navy);
}

.summary-logo     { color: var(--navy); font-size: 1.3rem; }
.summary-subtitle { font-size: 0.85rem; color: var(--slate); }
.summary-client   { font-weight: 600; font-size: 0.95rem; text-align: right; }
.summary-date     { font-size: 0.85rem; color: var(--slate); text-align: right; }

.summary-main {
  max-width: 840px;
  margin: 0 auto;
  padding: 20px 32px;
}

.summary-section {
  margin-bottom: 20px;
  page-break-inside: avoid;
}

.summary-section h2 {
  font-size: 0.833rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--slate);
  border-bottom: 1px solid rgba(30,58,95,0.12);
  padding-bottom: 4px;
  margin-bottom: 10px;
}

.summary-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.summary-table th,
.summary-table td {
  padding: 6px 10px;
  border-bottom: 1px solid rgba(30,58,95,0.08);
  text-align: left;
}

.summary-table th { font-weight: 500; color: var(--slate); width: 55%; }

.summary-cash-total { font-size: 0.95rem; }
.summary-cash-total strong { font-size: 1.05rem; color: var(--forest); }

.summary-issue-row { margin-bottom: 5px; font-size: 0.875rem; }

.summary-actions {
  padding: 16px 32px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.summary-footer {
  border-top: 1px solid rgba(30,58,95,0.12);
  padding: 12px 32px;
  font-size: 0.8rem;
  color: var(--slate);
  text-align: center;
}

/* ══════════════════════════════════════════════════════════════
   CashLens Results Page — extended output elements
   Brand palette (Lora serif, cream/parchment/navy/amber/forest)
   ══════════════════════════════════════════════════════════════ */

/* Header meta (company · date · sector · band) */
.results-header-meta {
  margin-left: auto;
  color: rgba(245,242,232,0.75);
  font-size: 0.8rem;
}

/* ── Alert banner ─────────────────────────────────────────── */
.results-alert {
  background: #fdf0ef;
  border-bottom: 2px solid var(--red);
  padding: 12px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.results-alert-headline {
  color: var(--red);
  font-weight: 700;
  font-size: 0.95rem;
}
.results-alert-sub {
  color: var(--ink);
  font-size: 0.8rem;
  margin-top: 2px;
}
.results-alert-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.sev-pill {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 12px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--cream);
}
.sev-pill-high   { background: var(--red); }
.sev-pill-medium { background: #b7770d; }
.sev-pill-alert  { background: var(--amber); }
.sev-pill-low    { background: var(--slate); }

/* ── Within-page anchor nav ────────────────────────────────── */
.results-anchor-nav {
  background: var(--parchment);
  border-bottom: 1px solid rgba(30,58,95,0.12);
  padding: 6px 24px;
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.results-anchor-nav .anchor-link {
  padding: 4px 12px;
  font-size: 0.8rem;
  color: var(--navy);
  border-radius: 4px;
  text-decoration: none;
}
.results-anchor-nav .anchor-link:hover {
  background: var(--cream);
  color: var(--forest);
  text-decoration: none;
}

/* ── Cash trapped — rich 3-card layout ────────────────────── */
.cash-trapped-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 14px;
}
.ct-card {
  background: var(--cream);
  border: 1px solid rgba(30,58,95,0.12);
  border-top: 4px solid var(--red);
  border-radius: 6px;
  padding: 18px;
  min-width: 0;
}
.ct-card.ct-card-ap { border-top-color: var(--amber); }
.ct-card-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--slate);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 6px;
}
.ct-card-amount {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.1;
  color: var(--red);
  margin-bottom: 8px;
  font-variant-numeric: tabular-nums;
}
.ct-card-amount.ct-amount-ap { color: var(--amber); }
.ct-card-explain {
  font-size: 0.82rem;
  color: var(--ink);
  line-height: 1.5;
  margin-bottom: 6px;
}
.ct-card-formula {
  font-size: 0.72rem;
  color: var(--slate);
  font-style: italic;
}

/* ── Cash trapped — navy total banner ─────────────────────── */
.cash-trapped-total-banner {
  background: var(--navy);
  border-radius: 6px;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  color: var(--cream);
}
.cash-trapped-total-label {
  color: var(--cream);
  font-size: 0.9rem;
  font-weight: 700;
}
.cash-trapped-total-sub {
  color: rgba(245,242,232,0.7);
  font-size: 0.78rem;
  margin-top: 2px;
}
.cash-trapped-total-amount {
  color: var(--cream);
  font-size: 2rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

/* ── CCC two-column (scorecard + benchmarks) ─────────────── */
.ccc-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 780px) {
  .ccc-two-col { grid-template-columns: 1fr; }
  .cash-trapped-cards { grid-template-columns: 1fr; }
}
.ccc-panel {
  background: var(--cream);
  border: 1px solid rgba(30,58,95,0.12);
  border-radius: 6px;
  padding: 16px 18px;
  min-width: 0;
}
.ccc-panel-header {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(30,58,95,0.1);
}
.ccc-panel-sub {
  font-size: 0.72rem;
  color: var(--slate);
  font-weight: 400;
  margin-left: 6px;
}
.ccc-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid rgba(30,58,95,0.06);
  font-size: 0.85rem;
}
.ccc-row:last-child { border-bottom: none; }
.ccc-metric { color: var(--slate); }
.ccc-metric-strong { color: var(--navy); font-weight: 700; }
.ccc-value {
  color: var(--ink);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.ccc-value-large { font-size: 1.1rem; color: var(--red); }
.ccc-row-divider {
  border-top: 2px solid rgba(30,58,95,0.15);
  margin-top: 6px;
  padding-top: 12px;
}
.ccc-row-coverage {
  border-top: 2px solid rgba(192,57,43,0.3);
  margin-top: 6px;
  padding-top: 12px;
  background: rgba(192,57,43,0.04);
  border-radius: 4px;
  padding-left: 8px;
  padding-right: 8px;
}

/* ── Benchmark table ─────────────────────────────────────── */
.bench-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  font-variant-numeric: tabular-nums;
}
.bench-table th,
.bench-table td {
  padding: 7px 10px;
  border-bottom: 1px solid rgba(30,58,95,0.08);
  text-align: right;
}
.bench-table th {
  background: var(--parchment);
  font-weight: 600;
  font-size: 0.72rem;
  color: var(--slate);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.bench-table th:first-child,
.bench-table td:first-child,
.bench-table .bench-label { text-align: left; font-weight: 600; color: var(--navy); }
.bench-you { font-weight: 700; }
.bench-sev-high    { color: var(--red); }
.bench-sev-medium  { color: #b7770d; }
.bench-sev-alert   { color: var(--amber); }
.bench-sev-low     { color: var(--forest); }
.bench-best { color: var(--forest); font-weight: 600; }
.bench-row-strong td { font-weight: 700; border-top: 2px solid rgba(30,58,95,0.15); }
.bench-source-note {
  margin-top: 10px;
  font-size: 0.72rem;
  color: var(--slate);
  line-height: 1.5;
}
.bench-unavailable {
  padding: 16px;
  background: var(--parchment);
  border: 1px dashed rgba(30,58,95,0.25);
  border-radius: 4px;
  color: var(--slate);
  font-style: italic;
  text-align: center;
  font-size: 0.85rem;
}

/* ── Margin — 4-up cards ─────────────────────────────────── */
.margin-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
@media (max-width: 780px) {
  .margin-cards { grid-template-columns: repeat(2, 1fr); }
}
.margin-card {
  background: var(--cream);
  border: 1px solid rgba(30,58,95,0.12);
  border-radius: 6px;
  padding: 14px 16px;
  text-align: center;
  min-width: 0;
}
.margin-card-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--slate);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}
.margin-card-value {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--navy);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.margin-card-sub {
  font-size: 0.7rem;
  color: var(--slate);
  margin-top: 4px;
}
.margin-card-compress {
  font-size: 0.78rem;
  color: var(--red);
  font-weight: 700;
  margin-top: 6px;
}
.margin-card-compress.compress-up { color: var(--forest); }

/* ── Break-even 3-column grid ─────────────────────────────── */
.breakeven-panel {
  background: var(--cream);
  border: 1px solid rgba(30,58,95,0.12);
  border-radius: 6px;
  padding: 16px 18px;
}
.breakeven-panel-header {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(30,58,95,0.1);
}
.breakeven-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.breakeven-item { min-width: 0; }
@media (max-width: 780px) {
  .breakeven-grid { grid-template-columns: 1fr; }
}
.breakeven-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--slate);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}
.breakeven-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.breakeven-value.cushion-positive { color: var(--forest); }
.breakeven-value.cushion-negative { color: var(--red); }
.breakeven-note {
  font-size: 0.72rem;
  color: var(--slate);
  margin-top: 4px;
}
.breakeven-note.cushion-positive { color: var(--forest); font-weight: 600; }
.breakeven-note.cushion-negative { color: var(--red); font-weight: 600; }

/* ── Severity badge — Alert variant (adds to existing high/medium/low) ── */
.severity-badge-alert { background: #fdf0e5; color: var(--amber); }
.issue-card.severity-border-alert { border-left: 4px solid var(--amber); }

/* ── Forecast extended table (row coloring + status column) ── */
.forecast-note {
  background: var(--parchment);
  border: 1px solid rgba(30,58,95,0.15);
  border-radius: 4px;
  padding: 10px 14px;
  font-size: 0.82rem;
  color: var(--ink);
  margin-bottom: 12px;
  line-height: 1.55;
}
.forecast-note strong { color: var(--navy); }
.forecast-footnote {
  font-size: 0.72rem;
  color: var(--slate);
  font-style: italic;
  margin-top: 8px;
}
.forecast-table-ext { font-size: 0.82rem; }
.forecast-table-ext .forecast-row-ok       { /* default */ }
.forecast-table-ext .forecast-row-warn     { background: #fdf5e7; }
.forecast-table-ext .forecast-row-critical { background: #fdf0ef; }
.forecast-table-ext .fc-neg { color: var(--red); font-weight: 600; }
.forecast-table-ext .fc-pos { color: var(--forest); }
.forecast-table-ext .status-ok       { color: var(--forest); font-weight: 600; }
.forecast-table-ext .status-warn     { color: var(--amber); font-weight: 600; }
.forecast-table-ext .status-critical { color: var(--red);   font-weight: 700; }

/* ── Results bottom action bar ────────────────────────────── */
.results-action-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--parchment);
  border: 1px solid rgba(30,58,95,0.12);
  border-radius: 6px;
  padding: 14px 18px;
  margin-top: 20px;
  gap: 12px;
  flex-wrap: wrap;
}

/* ══════════════════════════════════════════════════════════════
   CashLens Summary Page — document envelope + sections
   ══════════════════════════════════════════════════════════════ */

/* Sticky top chrome (screen) */
.summary-sticky-top {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--navy);
  box-shadow: 0 3px 8px rgba(0,0,0,0.15);
}
.summary-screen-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 24px;
  flex-wrap: wrap;
  gap: 12px;
}
.summary-screen-header .site-logo { color: var(--cream); font-size: 1.3rem; }
.summary-chrome-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.summary-back-link {
  color: var(--cream);
  font-size: 0.85rem;
  opacity: 0.85;
}
.summary-back-link:hover { opacity: 1; color: var(--cream); text-decoration: underline; }

.summary-print-note {
  background: var(--parchment);
  border-bottom: 1px solid rgba(30,58,95,0.15);
  padding: 10px 24px;
  font-size: 0.82rem;
  color: var(--navy);
}

/* Document envelope */
.summary-doc-wrap {
  max-width: 880px;
  margin: 20px auto;
  padding: 0 24px;
}
.summary-doc {
  background: var(--cream);
  border: 1px solid rgba(30,58,95,0.15);
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  overflow: hidden;
}

/* Doc header */
.summary-doc-header {
  background: var(--navy);
  color: var(--cream);
  padding: 24px 32px;
  border-bottom: 0;
  display: block;
}
.summary-doc-header-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 14px;
  gap: 16px;
  flex-wrap: wrap;
}
.summary-doc-logo { color: var(--cream); font-size: 1.2rem; font-weight: 700; margin: 0; }
.summary-doc-confidential {
  font-size: 0.72rem;
  color: rgba(245,242,232,0.75);
  text-align: right;
  line-height: 1.5;
}
.summary-doc-company {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--cream);
  margin-bottom: 4px;
}
.summary-doc-meta {
  font-size: 0.82rem;
  color: rgba(245,242,232,0.8);
}
.summary-doc-tagline {
  font-size: 0.82rem;
  color: rgba(96,165,250,0.95);
  font-style: italic;
  margin-top: 8px;
}

/* Doc body */
.summary-doc-body { padding: 24px 32px; }

/* Summary alert row (red-on-cream, brand-aligned) */
.summary-alert-row {
  background: #fdf0ef;
  border: 1px solid rgba(192,57,43,0.3);
  border-radius: 6px;
  padding: 12px 16px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.summary-alert-headline {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--red);
}
.summary-alert-sub {
  font-size: 0.78rem;
  color: var(--ink);
  margin-top: 3px;
}
.summary-alert-pills {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* CCC 4-up snapshot */
.summary-ccc-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}
@media (max-width: 720px) {
  .summary-ccc-grid { grid-template-columns: repeat(2, 1fr); }
}
.summary-ccc-box {
  border: 1px solid rgba(30,58,95,0.15);
  border-radius: 6px;
  padding: 12px 14px;
  text-align: center;
  background: var(--cream);
  min-width: 0;
}
.summary-ccc-box-ccc {
  border-color: rgba(192,57,43,0.35);
  background: #fdf5f4;
}
.summary-ccc-lbl {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--slate);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}
.summary-ccc-val {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.summary-ccc-sev-high    { color: var(--red); }
.summary-ccc-sev-medium  { color: #b7770d; }
.summary-ccc-sev-alert   { color: var(--amber); }
.summary-ccc-sev-low     { color: var(--forest); }
.summary-ccc-bench {
  font-size: 0.7rem;
  color: var(--slate);
  margin-top: 3px;
}

/* Cash Trapped navy row */
.summary-trapped-row {
  background: var(--navy);
  border-radius: 6px;
  padding: 16px 20px;
  margin-bottom: 20px;
  color: var(--cream);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}
.summary-trapped-lbl {
  font-size: 0.82rem;
  color: rgba(245,242,232,0.75);
  font-weight: 600;
  margin-bottom: 4px;
}
.summary-trapped-total {
  font-size: 2rem;
  font-weight: 700;
  color: var(--cream);
  font-variant-numeric: tabular-nums;
}
.summary-trapped-components {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.summary-tc { text-align: center; min-width: 110px; }
.summary-tc-lbl {
  font-size: 0.7rem;
  color: rgba(245,242,232,0.7);
  margin-bottom: 3px;
}
.summary-tc-val {
  font-size: 1rem;
  font-weight: 700;
  color: #fca5a5;
  font-variant-numeric: tabular-nums;
}
.summary-tc.summary-tc-ap .summary-tc-val { color: #fed7aa; }

/* Issues title */
.summary-issues-title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--slate);
  margin-bottom: 10px;
}

/* Issue cards inside summary */
.summary-issue-card {
  border: 1px solid rgba(30,58,95,0.12);
  border-left: 4px solid var(--red);
  border-radius: 6px;
  padding: 12px 16px;
  margin-bottom: 10px;
  background: var(--cream);
}
.summary-issue-border-high   { border-left-color: var(--red); }
.summary-issue-border-medium { border-left-color: #b7770d; }
.summary-issue-border-alert  { border-left-color: var(--amber); }
.summary-issue-border-low    { border-left-color: var(--forest); }
.summary-issue-top {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.summary-issue-name {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--navy);
}
.summary-issue-dollar {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--red);
  margin-bottom: 4px;
  font-variant-numeric: tabular-nums;
}
.summary-issue-text {
  font-size: 0.8rem;
  color: var(--ink);
  line-height: 1.5;
  margin-bottom: 4px;
}
.summary-issue-trigger {
  font-size: 0.72rem;
  color: var(--slate);
  font-style: italic;
}

/* Bottom row: Margin Summary + 13-Week Outlook */
.summary-bottom-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 20px;
}
@media (max-width: 720px) {
  .summary-bottom-row { grid-template-columns: 1fr; }
}
.summary-mini-card {
  border: 1px solid rgba(30,58,95,0.15);
  border-radius: 6px;
  padding: 14px 18px;
  background: var(--cream);
  min-width: 0;
}
.summary-mini-title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--slate);
  margin-bottom: 10px;
}
.summary-mini-row {
  display: flex;
  justify-content: space-between;
  padding: 5px 0;
  border-bottom: 1px solid rgba(30,58,95,0.06);
  font-size: 0.82rem;
  color: var(--slate);
}
.summary-mini-row:last-child { border-bottom: none; }
.summary-mini-row span:last-child { color: var(--ink); font-weight: 600; font-variant-numeric: tabular-nums; }
.summary-mini-compress {
  color: var(--red);
  font-size: 0.78rem;
  font-weight: 700;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid rgba(192,57,43,0.2);
}
.summary-outlook-stat {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--red);
  margin-bottom: 6px;
}
.summary-outlook-stat.summary-outlook-positive { color: var(--forest); }
.summary-outlook-stat.summary-outlook-warning  { color: var(--red); }
.summary-outlook-text {
  font-size: 0.82rem;
  color: var(--ink);
  line-height: 1.5;
}
.summary-outlook-ok {
  font-size: 0.82rem;
  color: var(--forest);
  font-weight: 600;
  margin-top: 8px;
}

/* Doc footer */
.summary-doc-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 14px 32px;
  border-top: 1px solid rgba(30,58,95,0.12);
  font-size: 0.72rem;
  color: var(--slate);
  flex-wrap: wrap;
}
.summary-doc-disclaimer {
  max-width: 300px;
  text-align: right;
}

/* ── Print styles (summary.html via @media print) ─────────── */

@media print {
  /* Remove all screen chrome and action buttons */
  .no-print,
  .summary-sticky-top,
  .summary-print-note,
  .summary-actions,
  .summary-footer,
  nav,
  .tab-bar,
  .form-nav,
  .form-actions,
  .site-header { display: none !important; }

  body {
    background: #fff;
    font-size: 10.5pt;
    color: #000;
    font-family: 'Lora', Georgia, serif;
  }

  /* Doc envelope — collapse shadow and margins for print */
  .summary-doc-wrap { margin: 0; padding: 0; max-width: 100%; }
  .summary-doc {
    border: none;
    border-radius: 0;
    box-shadow: none;
    background: #fff;
  }

  /* Doc header — convert to monochrome for print */
  .summary-doc-header {
    background: #fff;
    color: #000;
    border-bottom: 1.5pt solid #000;
    padding: 0 0 8pt;
    margin-bottom: 10pt;
  }
  .summary-doc-logo,
  .summary-doc-company { color: #000; }
  .summary-doc-confidential,
  .summary-doc-meta,
  .summary-doc-tagline { color: #000; font-style: italic; }

  .summary-doc-body { padding: 0; }

  /* Alert row — keep border, strip red background */
  .summary-alert-row {
    background: none;
    border: 1pt solid #000;
    page-break-inside: avoid;
  }
  .summary-alert-headline { color: #000; }

  /* Severity pills — outline only */
  .sev-pill {
    background: none !important;
    color: #000 !important;
    border: 0.5pt solid #000;
    padding: 0 4pt;
    font-size: 7.5pt;
  }

  /* CCC grid */
  .summary-ccc-grid { page-break-inside: avoid; }
  .summary-ccc-box {
    border: 0.5pt solid #000;
    background: none;
  }
  .summary-ccc-box-ccc {
    background: none;
    border: 1pt solid #000;
  }
  .summary-ccc-val,
  .summary-ccc-sev-high,
  .summary-ccc-sev-medium,
  .summary-ccc-sev-alert,
  .summary-ccc-sev-low { color: #000; }

  /* Cash trapped navy row — invert for print (outline + black text) */
  .summary-trapped-row {
    background: none;
    border: 1pt solid #000;
    color: #000;
    page-break-inside: avoid;
  }
  .summary-trapped-lbl,
  .summary-trapped-total,
  .summary-tc-lbl,
  .summary-tc-val { color: #000; }

  /* Issue cards */
  .summary-issue-card {
    border: 0.5pt solid #000;
    border-left: 2pt solid #000;
    background: none;
    page-break-inside: avoid;
  }
  .summary-issue-name,
  .summary-issue-dollar,
  .summary-issue-text,
  .summary-issue-trigger { color: #000; }

  /* Bottom row */
  .summary-bottom-row { page-break-inside: avoid; }
  .summary-mini-card {
    border: 0.5pt solid #000;
    background: none;
  }
  .summary-mini-compress,
  .summary-outlook-stat,
  .summary-outlook-stat.summary-outlook-positive,
  .summary-outlook-stat.summary-outlook-warning { color: #000; border-color: #000; }

  /* Doc footer */
  .summary-doc-footer {
    border-top: 0.5pt solid #000;
    color: #000;
    font-size: 8pt;
    padding: 6pt 0 0;
  }

  /* Severity badges — outline only */
  .severity-badge {
    background: none !important;
    color: #000 !important;
    border: 0.5pt solid #000;
    padding: 0 4pt;
    font-size: 7.5pt;
  }

  .cash-negative { color: #000 !important; font-weight: bold; }
  .low-cash { background: #eee !important; }

  /* Single-page layout — no mid-section breaks */
  h1, h2, h3 { page-break-after: avoid; }
}

/* ── Working Capital / CCC / Accounting-vs-Cash panels ──────────────────────
   Ported verbatim from src/pages/original-input.html (lines 75–133).
   Note: .ccc-panel is deliberately omitted — a different .ccc-panel rule is
   already defined above for the .ccc-two-col layout. The new panels rely on
   inline styles for their primary visuals, so the collision is harmless. */
.wcc-chain { display: flex; flex-direction: column; gap: 0; }
.wcc-step {
  display: flex; align-items: center; padding: 12px 16px;
  border-bottom: 1px solid #f1f5f9; gap: 16px;
}
.wcc-step:last-child { border-bottom: none; }
.step-num { width: 28px; height: 28px; border-radius: 50%; background: #1e3a5f; color: white; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex-shrink: 0; }
.step-num.calc { background: #2563eb; }
.step-label { flex: 1; font-size: 13px; font-weight: 500; }
.step-value { font-size: 14px; font-weight: 700; min-width: 100px; text-align: right; }
.step-value.blue { color: #2563eb; }
.step-value.green { color: #16a34a; }
.step-value.red { color: #dc2626; }
.step-value.orange { color: #ea580c; }

.inline-note { font-size: 11px; color: #6b7280; font-style: italic; margin-left: 6px; font-weight: 400; }

.ccc-panels { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.ccc-panel-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px; }
.ccc-panel.accounting .ccc-panel-title { color: #16a34a; }
.ccc-panel.reality .ccc-panel-title { color: #2563eb; }
.ccc-equation { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.ccc-eq-item { text-align: center; }
.ccc-eq-val { font-size: 22px; font-weight: 800; }
.ccc-eq-lbl { font-size: 11px; color: #64748b; margin-top: 2px; }
.ccc-eq-op { font-size: 22px; color: #94a3b8; font-weight: 300; }
.ccc-eq-result { border-top: 1.5px solid #e5e7eb; padding-top: 12px; display: flex; justify-content: space-between; align-items: center; }
.ccc-eq-result .lbl { font-size: 13px; font-weight: 600; color: #374151; }
.ccc-eq-result .val { font-size: 24px; font-weight: 900; }
.ccc-panel.accounting .ccc-eq-result .val { color: #16a34a; }
.ccc-panel.reality .ccc-eq-result .val { color: #2563eb; }
.ccc-gap-bar { background: #fff7ed; border: 1.5px solid #fed7aa; border-radius: 10px; padding: 18px 24px; }
.ccc-gap-title { font-size: 12px; font-weight: 700; color: #92400e; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 10px; }
.ccc-gap-grid { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 12px; }
.ccc-gap-item { text-align: center; }
.ccc-gap-item .g-lbl { font-size: 11px; color: #64748b; margin-bottom: 4px; }
.ccc-gap-item .g-val { font-size: 16px; font-weight: 800; }
.ccc-gap-item .g-val.green { color: #16a34a; }
.ccc-gap-item .g-val.blue { color: #2563eb; }
.ccc-gap-item .g-val.red { color: #dc2626; }
.ccc-gap-item .g-val.orange { color: #ea580c; }
.ccc-gap-explain { margin-top: 12px; font-size: 13px; color: #475569; line-height: 1.6; border-top: 1px solid #fed7aa; padding-top: 12px; }
