/* ----------------------------------------------------------------------------
   Local fonts — air-gap safe. Argus ships these .woff2 under /static/fonts/.
   If absent, the stacks fall back to system fonts with no layout break.
   ---------------------------------------------------------------------------- */
@font-face{font-family:'Inter Tight';font-style:normal;font-weight:400;font-display:swap;src:local('Inter Tight'),url('/static/fonts/inter-tight-400.woff2') format('woff2');}
@font-face{font-family:'Inter Tight';font-style:normal;font-weight:500;font-display:swap;src:local('Inter Tight Medium'),url('/static/fonts/inter-tight-500.woff2') format('woff2');}
@font-face{font-family:'Inter Tight';font-style:normal;font-weight:600;font-display:swap;src:local('Inter Tight SemiBold'),url('/static/fonts/inter-tight-600.woff2') format('woff2');}
@font-face{font-family:'Inter Tight';font-style:normal;font-weight:700;font-display:swap;src:local('Inter Tight Bold'),url('/static/fonts/inter-tight-700.woff2') format('woff2');}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:400;font-display:swap;src:local('Source Serif 4'),url('/static/fonts/source-serif-4-400.woff2') format('woff2');}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:500;font-display:swap;src:local('Source Serif 4 Medium'),url('/static/fonts/source-serif-4-500.woff2') format('woff2');}
@font-face{font-family:'Source Serif 4';font-style:italic;font-weight:400;font-display:swap;src:local('Source Serif 4 Italic'),url('/static/fonts/source-serif-4-400-italic.woff2') format('woff2');}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:local('JetBrains Mono'),url('/static/fonts/jetbrains-mono-400.woff2') format('woff2');}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:600;font-display:swap;src:local('JetBrains Mono SemiBold'),url('/static/fonts/jetbrains-mono-600.woff2') format('woff2');}

/* ============================================================================
   ARGUS REPORTS — print-ready stylesheet (Elytra editorial)
   Onyx ink on warm paper · Source Serif 4 display · Inter Tight body ·
   JetBrains Mono for IDs/scores. Designed to print cleanly to A4/Letter PDF
   from any browser, and to be templatized with Go html/template bindings.
   ============================================================================ */
:root{
  --ink:#15191F; --ink-2:#454C59; --ink-3:#7A8290; --line:#DED7C8; --line-2:#C7BFAE;
  --paper:#FFFFFF; --paper-2:#F7F4EC; --paper-3:#EFEADE;
  --copper:#BC6F36; --copper-deep:#8E5224; --copper-bright:#C97B3F;
  --onyx:#0E1116; --trust:#3C6E80;
  --risk-crit:#C7493A; --risk-high:#C2410C; --risk-med:#B98318; --risk-low:#5C7A45; --ok:#3F8A4E;
  --serif:'Source Serif 4',Georgia,serif; --sans:'Inter Tight','Inter',-apple-system,sans-serif; --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{background:#3A3F47;color:var(--ink);font-family:var(--sans);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;}

/* On-screen: center the page on a grey desk. */
.report{ width:210mm; min-height:297mm; margin:24px auto; background:var(--paper); padding:0; box-shadow:0 8px 40px rgba(0,0,0,.4); position:relative; }
.rp-pad{ padding:22mm 20mm; }

/* Running cover */
.rp-cover{ background:var(--onyx); color:var(--paper-2); padding:34mm 20mm 24mm; position:relative; overflow:hidden; }
.rp-cover::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:6px;
  background:linear-gradient(90deg,var(--copper) 0%,var(--copper-bright) 40%,transparent 78%); }
.rp-mark{ display:flex; align-items:center; gap:12px; margin-bottom:40mm; }
.rp-mark svg{ display:block; }
.rp-mark .nm{ font-weight:700; font-size:18px; letter-spacing:.04em; }
.rp-mark .vr{ font-family:var(--mono); font-size:11px; color:#9AA3B2; }
.rp-eyebrow{ font-size:11px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--copper-bright); margin-bottom:14px; }
.rp-title{ font-family:var(--serif); font-weight:500; font-size:40px; line-height:1.06; letter-spacing:-.015em; margin:0 0 14px; }
.rp-title em{ font-style:italic; color:var(--copper-bright); }
.rp-lede{ font-family:var(--serif); font-style:italic; font-size:17px; line-height:1.5; color:#C9CFDA; max-width:60ch; margin:0 0 34mm; }
.rp-meta{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px 16px; border-top:1px solid rgba(255,255,255,.16); padding-top:16px; }
.rp-meta .k{ font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:#8C95A4; margin-bottom:5px; }
.rp-meta .v{ font-family:var(--mono); font-size:11.5px; color:var(--paper-2); word-break:break-word; line-height:1.35; }

/* Section structure */
.rp-h2{ font-family:var(--serif); font-weight:500; font-size:21px; letter-spacing:-.01em; margin:0 0 4px; color:var(--ink); }
.rp-eyebrow-dark{ font-size:10px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--copper-deep); }
.rp-rule{ height:2px; width:54px; background:var(--copper); border:none; margin:7px 0 16px; }
.rp-section{ margin-bottom:26px; }
.rp-section--break{ break-before:page; }
.rp-prose{ font-size:13px; line-height:1.62; color:var(--ink-2); max-width:74ch; }
.rp-prose p{ margin:0 0 10px; }
.rp-prose strong{ color:var(--ink); }

/* Stat callouts */
.rp-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.rp-stat{ background:var(--paper); padding:13px 15px; }
.rp-stat__l{ font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); font-weight:700; margin-bottom:8px; }
.rp-stat__v{ font-family:var(--serif); font-size:30px; line-height:1; color:var(--ink); font-variant-numeric:tabular-nums; }
.rp-stat__v.crit{ color:var(--risk-crit); } .rp-stat__v.high{ color:var(--risk-high); }
.rp-stat__v.ok{ color:var(--ok); } .rp-stat__s{ font-size:10px; color:var(--ink-3); margin-top:6px; font-family:var(--mono); }

/* Tables */
.rp-table{ width:100%; border-collapse:collapse; font-size:11.5px; }
.rp-table thead th{ text-align:left; font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); font-weight:700; padding:8px 10px; border-bottom:1.5px solid var(--ink); white-space:nowrap; }
.rp-table td{ padding:7px 10px; border-bottom:1px solid var(--line); vertical-align:top; }
.rp-table tr{ break-inside:avoid; }
.rp-table .num{ font-family:var(--mono); font-variant-numeric:tabular-nums; }
.rp-table tr.kev td{ background:#FBEDE6; }

.rp-pill{ display:inline-block; padding:1px 8px; border-radius:100px; font-size:9.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
.p-crit{ background:#F4D9D3; color:#7A2417; } .p-high{ background:#F8E2D0; color:#8A3D17; }
.p-med{ background:#F4EBCF; color:#6F5212; } .p-low{ background:#E4EAD8; color:#3F5530; }
.p-ok{ background:#DCEBDD; color:#2E5B36; } .p-kev{ background:#F4D9D3; color:#7A2417; border:1px solid #C7493A; }
.p-info{ background:#E0EAEE; color:#2C5563; }

/* Two-col */
.rp-2col{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.rp-callout{ background:var(--paper-2); border-left:3px solid var(--copper); padding:13px 16px; font-size:12px; line-height:1.55; color:var(--ink-2); }
.rp-callout strong{ color:var(--ink); }
.rp-validation{ background:var(--paper-2); border:1px solid var(--line-2); border-top:3px solid var(--ok); padding:15px 18px; }
.rp-validation .t{ font-family:var(--serif); font-size:15px; margin:0 0 6px; color:var(--ink); }

/* RRS gauge (conic donut) */
.rp-gauge{ --v:0; --c:var(--ok); width:128px; height:128px; border-radius:50%; flex-shrink:0; position:relative; display:flex; align-items:center; justify-content:center;
  background:conic-gradient(var(--c) calc(var(--v)*3.6deg), var(--paper-3) 0); -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.rp-gauge::after{ content:""; position:absolute; inset:11px; border-radius:50%; background:var(--paper); }
.rp-gauge__in{ position:relative; text-align:center; }
.rp-gauge__n{ font-family:var(--serif); font-size:38px; line-height:1; color:var(--ink); }
.rp-gauge__b{ font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--copper-deep); margin-top:3px; }
.rp-bar{ height:7px; background:var(--paper-3); border-radius:100px; overflow:hidden; }
.rp-bar>span{ display:block; height:100%; border-radius:100px; background:var(--copper); -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.rp-barline{ display:grid; grid-template-columns:120px 1fr 64px; gap:10px; align-items:center; margin-bottom:7px; font-size:11px; }
.rp-barline .v{ font-family:var(--mono); text-align:right; color:var(--ink-2); }

/* Trend sparkbars */
.rp-trend{ display:flex; align-items:flex-end; gap:6px; height:120px; padding:8px 0; border-bottom:1px solid var(--line); }
.rp-trend .col{ flex:1; display:flex; flex-direction:column; justify-content:flex-end; align-items:center; gap:5px; }
.rp-trend .bar{ width:62%; background:var(--copper); border-radius:2px 2px 0 0; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.rp-trend .bar.last{ background:var(--ok); }
.rp-trend .lab{ font-family:var(--mono); font-size:8.5px; color:var(--ink-3); }

.rp-foot{ display:flex; justify-content:space-between; align-items:baseline; gap:6px 20px; flex-wrap:wrap; border-top:1px solid var(--line); padding-top:10px; margin-top:6px;
  font-size:9px; color:var(--ink-3); font-family:var(--mono); letter-spacing:.02em; }
.rp-foot>span:first-child{ flex:1 1 auto; min-width:0; }
.rp-foot>span:last-child{ flex:0 0 auto; text-align:right; white-space:nowrap; }

/* Donut legend + two-line trend overlay (SLA throughput) */
.rp-trend--dual{ position:relative; }
.rp-trend .bar.dim{ background:var(--line-2); }
.rp-legend{ display:flex; gap:18px; margin-top:10px; font-size:10.5px; color:var(--ink-2); }
.rp-legend .sw{ display:inline-block; width:11px; height:11px; border-radius:2px; margin-right:5px; vertical-align:-1px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.rp-kpi{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.rp-kpi .rp-stat__v{ font-size:26px; }
.rp-sla-row .bnum{ font-family:var(--mono); }
.rp-meter-cell{ min-width:120px; }
.rp-meter{ height:8px; background:var(--paper-3); border-radius:100px; overflow:hidden; }
.rp-meter>span{ display:block; height:100%; border-radius:100px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.rp-meter>span.met{ background:var(--ok); } .rp-meter>span.miss{ background:var(--risk-high); }
.rp-donut{ --v:0; --c:var(--ok); width:96px; height:96px; border-radius:50%; flex-shrink:0; position:relative; display:flex; align-items:center; justify-content:center;
  background:conic-gradient(var(--c) calc(var(--v)*3.6deg), var(--paper-3) 0); -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.rp-donut::after{ content:""; position:absolute; inset:9px; border-radius:50%; background:var(--paper); }
.rp-donut__n{ position:relative; font-family:var(--serif); font-size:26px; color:var(--ink); }

.rp-print-hint{ position:fixed; bottom:18px; right:18px; background:var(--onyx); color:var(--paper-2); font-family:var(--sans);
  font-size:12px; font-weight:600; padding:9px 15px; border-radius:100px; box-shadow:0 6px 24px rgba(0,0,0,.4); cursor:pointer; z-index:50; border:none; }

/* ============================================================================
   PRINT
   ============================================================================ */
@page{ size:A4; margin:14mm 0; }
@media print{
  body{ background:#fff; }
  .report{ width:auto; min-height:0; margin:0; box-shadow:none; }
  .rp-pad{ padding:0 16mm; }
  .rp-cover{ padding:24mm 16mm 18mm; break-after:page; }
  .rp-print-hint{ display:none; }
  .rp-section{ break-inside:avoid-page; }
  a{ color:inherit; text-decoration:none; }
}
