/* ───────────────────────────────────────────────────────────────────────────
   ELOISE · THE LEDGER — editorial cost telemetry
   Aesthetic: financial broadsheet / private ledger. Bone paper, espresso ink,
   oxblood "in the red" accent. Fraunces (display + figures) · IBM Plex Mono (data).
   No framework, no chart lib. Hand-set hairlines, tabular figures, spring motion.
   ─────────────────────────────────────────────────────────────────────────── */

:root{
  /* surfaces — warm bone paper */
  --paper:    #f1ece1;
  --paper-2:  #f7f3ea;   /* raised leaf */
  --paper-3:  #fbf8f1;   /* highest */
  --ink:      #211e18;   /* espresso near-black, warm */
  --ink-2:    #423d33;
  --muted:    #7c7464;
  --faint:    #a89e8b;
  --rule:     rgba(33,30,24,.12);
  --rule-2:   rgba(33,30,24,.22);
  --rule-3:   rgba(33,30,24,.40);

  /* semantics */
  --signal:   #9c382b;   /* oxblood — expenditure, "in the red" */
  --signal-2: #b5462f;   /* brighter oxblood for highlights */
  --sage:     #586b49;   /* within budget / reconciled */
  --amber:    #a96a22;   /* drift / caution */

  /* categorical "natural dye" palette — desaturated, distinct on bone */
  --s1:#9c382b; --s2:#3c5366; --s3:#a9823a; --s4:#67784f;
  --s5:#79566a; --s6:#436b64; --s7:#b05a3a; --s8:#84714f;

  --display:'Fraunces', Georgia, serif;
  --mono:'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --ease:cubic-bezier(.32,.72,0,1);
  --ease-spring:cubic-bezier(.34,1.4,.5,1);
  --maxw:1320px;
}

*{box-sizing:border-box}
[hidden]{display:none !important} /* honour the hidden attr even when a class sets display */
html{-webkit-text-size-adjust:100%}
body{
  margin:0; min-height:100dvh; color:var(--ink);
  background:var(--paper);
  font-family:var(--mono);
  font-feature-settings:"tnum" 1, "cv05" 1;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  letter-spacing:.01em;
  overflow-x:hidden; /* page never scrolls sideways; only the matrix does, internally */
}
/* faint ledger ruling + warm corner light */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 90% at 100% -10%, rgba(156,56,43,.05), transparent 55%),
    radial-gradient(90% 80% at -10% 0%, rgba(88,107,73,.045), transparent 50%),
    repeating-linear-gradient(180deg, transparent 0 31px, rgba(33,30,24,.022) 31px 32px);
}
/* paper grain */
.grain{position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;}
.vignette{position:fixed; inset:0; z-index:1; pointer-events:none;
  box-shadow:inset 0 0 240px rgba(33,30,24,.10);}

a{color:inherit}
::selection{background:rgba(156,56,43,.16)}

/* ── numerals helper ── */
.num{font-feature-settings:"tnum" 1; font-variant-numeric:tabular-nums}

/* ═══════════════════════════ MASTHEAD ═══════════════════════════ */
.masthead{
  position:sticky; top:0; z-index:20;
  background:linear-gradient(180deg, var(--paper) 70%, rgba(241,236,225,.86));
  border-bottom:1px solid var(--rule-3);
  box-shadow:0 1px 0 var(--rule); /* the second rule of a masthead */
}
.masthead .mast-inner{
  max-width:var(--maxw); margin:0 auto; padding:18px 32px 14px;
  display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
.mast-left{display:flex; align-items:center; gap:16px}
.seal{flex:0 0 auto; width:46px; height:46px; color:var(--signal)}
.wordmark h1{
  font-family:var(--display); font-optical-sizing:auto;
  font-weight:600; font-size:30px; line-height:.9; letter-spacing:-.02em;
  margin:0; color:var(--ink);
}
.wordmark h1 .thin{font-weight:300; font-style:italic; letter-spacing:0}
.folio{
  margin:7px 0 0; font-size:10.5px; letter-spacing:.13em; text-transform:uppercase;
  color:var(--muted); display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}
.folio .sep{color:var(--faint)}
.live{display:inline-flex; align-items:center; gap:7px; color:var(--signal)}
.live .dot{width:6px; height:6px; border-radius:50%; background:var(--signal);
  box-shadow:0 0 0 0 rgba(156,56,43,.5); animation:pulse 2.6s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(156,56,43,.45)}70%{box-shadow:0 0 0 7px rgba(156,56,43,0)}100%{box-shadow:0 0 0 0 rgba(156,56,43,0)}}

.mast-right{display:flex; flex-direction:column; align-items:flex-end; gap:9px}
.ranges{display:flex; gap:2px; align-items:center}
.ranges button{
  appearance:none; background:none; border:0; cursor:pointer;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; font-weight:500;
  color:var(--muted); padding:6px 10px 8px; position:relative;
  transition:color .25s var(--ease);
}
.ranges button::after{content:""; position:absolute; left:10px; right:10px; bottom:2px; height:2px;
  background:var(--signal); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease)}
.ranges button:hover{color:var(--ink)}
.ranges button.active{color:var(--ink)}
.ranges button.active::after{transform:scaleX(1)}
.ranges .custom-btn{color:var(--faint)}

.custom-range{display:flex; align-items:center; gap:7px; margin-top:2px}
.custom-range input{font-family:var(--mono); font-size:10.5px; color:var(--ink);
  background:var(--paper-3); border:1px solid var(--rule-2); border-radius:7px; padding:5px 7px}
.custom-range input:focus{outline:0; border-color:var(--signal)}
.custom-range span{color:var(--faint)}
.custom-range button{font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase;
  background:var(--ink); color:var(--paper-3); border:0; border-radius:7px; padding:6px 11px; cursor:pointer}

.updated{font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted)}
.updated::before{content:"posted  "; color:var(--faint)}

/* ═══════════════════════════ LAYOUT ═══════════════════════════ */
main{position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; padding:30px 32px 60px}

/* shared section heading — small-caps editorial */
.kicker{
  display:flex; align-items:baseline; gap:10px 12px; flex-wrap:wrap; margin:0 0 14px;
  padding-bottom:9px; border-bottom:1px solid var(--rule-2);
}
.kicker h2{
  font-family:var(--mono); font-weight:600; font-size:11px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ink); margin:0;
}
.kicker .hint{font-family:var(--display); font-style:italic; font-size:13px; color:var(--muted); letter-spacing:0}
.kicker .grow{flex:1}

/* entry/leaf animation */
.leaf{opacity:0; transform:translateY(18px); filter:blur(6px);
  animation:rise .85s var(--ease) forwards; animation-delay:calc(var(--i,0) * 70ms + 80ms)}
@keyframes rise{to{opacity:1; transform:none; filter:blur(0)}}

/* ── headline / statement row : asymmetric bento ── */
.statement{display:grid; gap:14px; margin-bottom:30px;
  grid-template-columns:1.55fr 1fr 1fr; grid-template-rows:auto auto;}
.entry{
  position:relative; background:var(--paper-2);
  border:1px solid var(--rule); border-radius:14px; padding:20px 22px 18px;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 14px 30px -26px rgba(33,30,24,.5);
}
.entry .e-label{font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted)}
.entry .e-label .muted{color:var(--faint)}
.entry .e-value{font-family:var(--display); font-optical-sizing:auto; font-weight:500;
  letter-spacing:-.02em; line-height:1; color:var(--ink); margin:12px 0 6px;
  font-variant-numeric:tabular-nums; font-size:38px;}
.entry .e-sub{font-size:11px; color:var(--muted); letter-spacing:.02em}

/* the lead statement — spans, oxblood figure */
.entry.lead{grid-row:span 2; display:flex; flex-direction:column;
  background:
    radial-gradient(130% 120% at 100% 0%, rgba(156,56,43,.07), transparent 52%),
    var(--paper-2);}
.entry.lead .e-value{font-size:clamp(46px,6vw,72px); color:var(--signal); font-weight:600}
.entry.lead .e-label{font-size:11px}
.spark{width:100%; height:60px; margin-top:auto; display:block; overflow:visible}

/* projected — band scale */
.band{position:relative; height:7px; margin:14px 0 7px; border-radius:4px;
  background:linear-gradient(90deg,var(--rule),var(--rule-2)); overflow:visible}
.band .band-fill{position:absolute; inset:0 auto 0 0; width:calc(var(--p,0)*100%);
  background:linear-gradient(90deg,var(--sage),var(--signal)); border-radius:4px;
  transition:width .9s var(--ease)}
.band .band-mark{position:absolute; top:-4px; left:var(--m,50%); width:2px; height:15px;
  background:var(--ink); transform:translateX(-1px); transition:left .9s var(--ease)}
.band-cap{font-size:9.5px; letter-spacing:.06em; color:var(--faint); line-height:1.5}

/* cache ring */
.ring{position:absolute; top:18px; right:20px; width:40px; height:40px; border-radius:50%;
  background:conic-gradient(var(--sage) calc(var(--v,0)*1%), var(--rule) 0);
  mask:radial-gradient(farthest-side, transparent 64%, #000 65%);
  -webkit-mask:radial-gradient(farthest-side, transparent 64%, #000 65%);}

/* ── chart of record ── */
.panel{background:var(--paper-2); border:1px solid var(--rule); border-radius:16px;
  padding:20px 22px 18px; margin-bottom:24px;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 18px 40px -32px rgba(33,30,24,.55);}
.controls{display:flex; gap:8px; flex-wrap:wrap; margin-left:auto}
.seg{display:inline-flex; background:var(--paper); border:1px solid var(--rule-2);
  border-radius:9px; padding:2px; gap:1px}
.seg button{appearance:none; background:none; border:0; cursor:pointer;
  font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--muted);
  padding:5px 11px; border-radius:7px; transition:.25s var(--ease)}
.seg button:hover{color:var(--ink)}
.seg button.active{color:var(--paper-3); background:var(--ink)}

.chart-wrap{position:relative; height:300px; margin:6px 0 4px}
.area{width:100%; height:100%; display:block; overflow:visible}
.gridline{stroke:var(--rule); stroke-width:1}
.axis-label{fill:var(--faint); font-family:var(--mono); font-size:9.5px; letter-spacing:.04em}
.series-path{stroke-width:1.5; fill-opacity:.22; stroke-linejoin:round;
  stroke-dasharray:var(--len,2000); stroke-dashoffset:var(--len,2000);
  animation:draw 1.3s var(--ease) forwards; }
@keyframes draw{to{stroke-dashoffset:0}}
.cross{stroke:var(--rule-3); stroke-width:1; stroke-dasharray:3 3; pointer-events:none}

.chart-tip{position:absolute; transform:translate(-50%,calc(-100% - 12px)); pointer-events:none;
  background:var(--ink); color:var(--paper-3); border-radius:10px; padding:9px 11px; min-width:130px;
  font-size:10.5px; box-shadow:0 18px 40px -16px rgba(33,30,24,.6); z-index:5}
.chart-tip .tt-b{font-family:var(--display); font-style:italic; font-size:12px; color:var(--paper);
  margin-bottom:6px; padding-bottom:5px; border-bottom:1px solid rgba(255,255,255,.14)}
.tt-row{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:1.5px 0}
.tt-row .tt-k{display:flex; align-items:center; gap:6px; color:rgba(251,248,241,.78)}
.tt-row b{font-variant-numeric:tabular-nums}
.tt-total{display:flex; justify-content:space-between; gap:16px; margin-top:6px; padding-top:5px;
  border-top:1px solid rgba(255,255,255,.14); color:var(--paper)}
.swatch{width:8px; height:8px; border-radius:2px; display:inline-block; flex:0 0 auto}

.legend{display:flex; flex-wrap:wrap; gap:8px 18px; margin-top:12px; padding-top:12px; border-top:1px solid var(--rule)}
.legend .li{display:inline-flex; align-items:center; gap:7px; font-size:10.5px; color:var(--muted); letter-spacing:.03em}
.legend .li b{color:var(--ink); font-variant-numeric:tabular-nums; font-weight:500}

/* ── two-column rows ── */
.row{display:grid; grid-template-columns:1fr 1.5fr; gap:24px; margin-bottom:24px}
.row .panel{margin-bottom:0}

/* provider allocation bar */
.alloc-bar{display:flex; height:16px; border-radius:6px; overflow:hidden;
  border:1px solid var(--rule-2); margin:4px 0 18px; background:var(--paper)}
.alloc-seg{height:100%; transition:flex-grow .7s var(--ease), filter .2s var(--ease)}
.alloc-seg:hover{filter:brightness(1.08) saturate(1.1)}
.alloc-legend{display:flex; flex-direction:column; gap:2px}
.dl{display:grid; grid-template-columns:14px 1fr auto auto; align-items:center; gap:10px;
  padding:8px 2px; border-bottom:1px solid var(--rule)}
.dl:last-child{border-bottom:0}
.dl .dl-k{color:var(--ink); font-size:11.5px; letter-spacing:.02em}
.dl .dl-v{color:var(--ink); font-size:12px; font-variant-numeric:tabular-nums}
.dl .dl-p{color:var(--muted); font-size:10.5px; font-variant-numeric:tabular-nums; min-width:34px; text-align:right}

/* source bars — debit ledger */
.bars{display:flex; flex-direction:column; gap:3px}
.bar-row{display:grid; grid-template-columns:minmax(120px,1.1fr) 2.2fr auto; align-items:center; gap:14px;
  padding:7px 0; border-bottom:1px solid var(--rule)}
.bar-row:last-child{border-bottom:0}
.bar-row .bn{font-size:11.5px; color:var(--ink); letter-spacing:.02em; text-transform:capitalize}
.bar-row .bn small{color:var(--faint); font-size:9.5px; margin-left:5px}
.bar-track{height:9px; border-radius:5px; background:var(--paper); border:1px solid var(--rule); overflow:hidden}
.bar-fill{height:100%; width:0; transform-origin:left; border-radius:5px;
  animation:grow 1s var(--ease) forwards; --p:0}
@keyframes grow{to{width:calc(var(--p)*100%)}}
.bar-row .bv{font-size:12px; color:var(--ink); font-variant-numeric:tabular-nums; text-align:right; white-space:nowrap}
.bar-row .bv small{margin-left:6px}

/* ── matrix : ruled ledger table ── */
.matrix-wrap{overflow-x:auto; margin:2px -4px -4px; padding:0 4px 4px}
.matrix{display:grid; gap:1px; min-width:max-content; font-variant-numeric:tabular-nums}
.matrix .mhead{font-size:9.5px; letter-spacing:.06em; color:var(--muted); text-transform:uppercase;
  padding:8px 10px; text-align:right; white-space:nowrap; border-bottom:1px solid var(--rule-2)}
.matrix .mhead:first-child{text-align:left}
.matrix .mrow-h{font-size:11px; color:var(--ink); padding:9px 10px; white-space:nowrap;
  letter-spacing:.02em; border-bottom:1px solid var(--rule)}
.matrix .mcell{position:relative; padding:9px 10px; text-align:right; font-size:11px; color:var(--ink);
  border-bottom:1px solid var(--rule); background:var(--cellbg,transparent); transition:transform .2s var(--ease)}
.matrix .mcell:hover{transform:scale(1.04); z-index:2; box-shadow:0 6px 18px -10px rgba(33,30,24,.5); border-radius:4px}
.matrix .mcell .mc-n{display:block; font-size:8.5px; color:var(--muted); margin-top:1px}
.matrix .mcell.empty{color:var(--faint); text-align:center}

/* ── audit + journal ── */
.status-pill{font-family:var(--mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase;
  padding:3px 9px; border-radius:20px; border:1px solid var(--rule-2); color:var(--muted)}
.status-pill.ok{color:var(--sage); border-color:rgba(88,107,73,.4); background:rgba(88,107,73,.08)}
.status-pill.warn{color:var(--amber); border-color:rgba(169,106,34,.35); background:rgba(169,106,34,.08)}
.status-pill.drift{color:var(--signal); border-color:rgba(156,56,43,.4); background:rgba(156,56,43,.08)}

.recon-note{font-size:11px; line-height:1.6; color:var(--muted); margin-bottom:14px;
  padding:12px 14px; background:var(--paper); border:1px solid var(--rule); border-left:2px solid var(--amber); border-radius:8px}
.recon-note b{color:var(--ink); font-weight:600}
.recon-note code{font-size:10.5px; color:var(--signal); background:rgba(156,56,43,.07); padding:1px 5px; border-radius:4px}
.recon-row{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:10px; align-items:center;
  padding:8px 2px; border-bottom:1px solid var(--rule); font-size:11px}
.recon-row:last-child{border-bottom:0}
.rr-p{color:var(--ink); letter-spacing:.02em}
.rr-d{color:var(--faint); font-size:9.5px}
.rr-v{color:var(--ink); font-variant-numeric:tabular-nums; text-align:right}
.rr-delta{font-variant-numeric:tabular-nums; text-align:right; font-size:10.5px}
.rr-delta.ok{color:var(--sage)} .rr-delta.drift{color:var(--signal)}

/* journal — recent calls */
.ticker{display:flex; flex-direction:column; max-height:380px; overflow-y:auto; margin:-2px -6px -4px; padding:0 6px}
.ticker::-webkit-scrollbar{width:8px}
.ticker::-webkit-scrollbar-thumb{background:var(--rule-2); border-radius:4px}
.tk{display:grid; grid-template-columns:48px 1.7fr 1.3fr auto; gap:12px; align-items:center;
  padding:8px 4px; border-bottom:1px solid var(--rule); font-size:11px;
  transition:background .2s var(--ease)}
.tk:hover{background:var(--paper-3)}
.tk-t{color:var(--faint); font-size:10px; font-variant-numeric:tabular-nums}
.tk-s{display:flex; align-items:center; gap:8px; color:var(--ink); min-width:0}
.tk-s .tag{font-size:8.5px; letter-spacing:.08em; text-transform:uppercase; padding:2px 6px;
  border-radius:5px; border:1px solid var(--rule-2); white-space:nowrap}
.tk-s > :last-child{overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--muted)}
.tk-m{color:var(--muted); font-size:10px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-variant-numeric:tabular-nums}
.tk-c{color:var(--ink); font-variant-numeric:tabular-nums; text-align:right; white-space:nowrap; font-weight:500}

.skel{color:var(--faint); font-size:11px; font-style:italic; font-family:var(--display); padding:14px 2px; display:block}

/* ── colophon footer ── */
.foot{position:relative; display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap;
  margin-top:34px; padding-top:18px; border-top:1px solid var(--rule-3); font-size:10px;
  letter-spacing:.04em; color:var(--muted)}
.foot::before{content:"❦"; position:absolute; top:-9px; left:50%; transform:translateX(-50%);
  background:var(--paper); padding:0 10px; color:var(--faint); font-size:13px}
.foot .foot-mark{color:var(--faint); font-style:italic; font-family:var(--display); letter-spacing:0; font-size:11px}
.foot code{font-family:var(--mono); font-style:normal; color:var(--ink-2); font-size:9.5px}
#footMeta{font-variant-numeric:tabular-nums}

/* ═══════════════════════════ RESPONSIVE ═══════════════════════════ */
@media (max-width:1000px){
  .statement{grid-template-columns:1fr 1fr; grid-template-rows:auto auto auto}
  .entry.lead{grid-row:span 1; grid-column:span 2}
  .row{grid-template-columns:1fr}
}
@media (max-width:640px){
  .masthead .mast-inner{padding:14px 22px 12px}
  main{padding:24px 22px 52px}
  .statement{grid-template-columns:1fr; gap:12px; margin-bottom:24px}
  .entry.lead{grid-column:span 1}
  .wordmark h1{font-size:25px}
  .mast-right{align-items:flex-start; width:100%}
  .ranges{flex-wrap:wrap}
  .ranges button{padding:6px 9px 8px}
  /* tab groups get their own full-width line, never spilling against the edge */
  .kicker .grow{display:none}
  .controls{width:100%; margin-left:0; gap:8px}
  .seg{flex:0 1 auto}
  .panel,.entry{padding:18px 18px 16px}
  .row{gap:16px}
  /* keep the bleed-out children inside the tighter panel padding */
  .matrix-wrap{margin:2px -2px -2px; padding:0 2px 2px}
  .ticker{margin:-2px -4px -4px; padding:0 4px}
}
@media (max-width:380px){
  .masthead .mast-inner{padding:12px 18px 10px}
  main{padding:20px 18px 44px}
  .panel,.entry{padding:16px 16px 14px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important; animation-delay:0 !important; transition-duration:.001ms !important}
  .leaf{opacity:1; transform:none; filter:none}
}
