/* Ebb dashboard — editorial-light, "soft modern / luminous".
   Essence kept (warm paper, serif display, ink, restraint) but made tactile and
   dimensional: a luminous page wash, layered soft shadows, rounded surfaces, a
   refined indigo accent with a tasteful gradient, and a calm indigo↔teal duotone
   for data. Refined system fonts only (offline-safe). Variable NAMES preserved —
   app.js + inline SVGs read --blue/--green at runtime. */
:root{
  --bg:#f4f1ea; --bg2:#efeae0; --panel:#ffffff; --panel2:#faf8f3;
  --line:#ece6da; --line-strong:#ddd5c5; --text:#1a1712; --muted:#9a917f; --soft:#524a3d;
  --blue:#2b3fb3; --blue2:#4f63e6;                 /* indigo accent + bright end */
  --teal:#1f8a78;                                  /* duotone partner */
  --green:#1f8a6d; --yellow:#9a7b1e; --orange:#b3473c; --pink:#b3473c; --purple:#6a57c2;
  --blue-tint:#eef0fc; --green-tint:#e8f5ef; --yellow-tint:#f8f1df; --orange-tint:#faeeec;
  --accent-grad:linear-gradient(135deg,#3247c4 0%,#5468e8 100%);
  --duo-grad:linear-gradient(180deg,#4f63e6 0%,#1f8a78 100%);
  --sh-1:0 1px 2px rgba(26,23,18,.05);
  --sh-2:0 1px 1px rgba(26,23,18,.03), 0 6px 16px -8px rgba(26,23,18,.13), 0 20px 44px -26px rgba(26,23,18,.18);
  --sh-pop:0 2px 4px rgba(26,23,18,.04), 0 16px 32px -10px rgba(26,23,18,.20);
  --hi:inset 0 1px 0 rgba(255,255,255,.9);          /* tactile top highlight */
  --radius:16px; --radius2:11px; --max:1200px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  --mono:"SF Mono",ui-monospace,"Cascadia Code",Menlo,Consolas,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  background:var(--bg);
  -webkit-font-smoothing:antialiased; line-height:1.55; text-rendering:optimizeLegibility;
}
::selection{background:rgba(43,63,179,.15)}
:focus-visible{outline:2px solid var(--blue); outline-offset:2px; border-radius:4px}
/* luminous warm page wash + a whisper of cool light, top */
.bg{position:fixed; inset:0; z-index:-1;
  background:
    radial-gradient(1100px 600px at 50% -14%, #fffefb, rgba(255,254,251,0) 60%),
    radial-gradient(820px 460px at 92% -6%, rgba(79,99,230,.07), transparent 55%),
    radial-gradient(820px 520px at 4% 6%, rgba(31,138,120,.05), transparent 52%),
    linear-gradient(180deg,#f6f3ec,#f0ebe2 70%)}
.wrap{max-width:var(--max); margin:0 auto; padding:0 24px}
h2{font-family:var(--serif); font-size:1.3rem; margin:0; letter-spacing:-.018em; font-weight:600}
h3{font-family:var(--serif); margin:0 0 6px; font-size:1.25rem; letter-spacing:-.018em; font-weight:600}
.muted{color:var(--muted)}
.small{font-size:.82rem}
.tabular{font-variant-numeric:tabular-nums}

/* ---------------- topbar ---------------- */
.topbar{position:sticky; top:0; z-index:20; background:rgba(246,243,236,.72);
  backdrop-filter:saturate(1.3) blur(14px); -webkit-backdrop-filter:saturate(1.3) blur(14px);
  border-bottom:1px solid var(--line)}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; gap:18px; padding:16px 24px}
.brand{display:flex; align-items:center; gap:14px; text-decoration:none; color:inherit}
.logo{display:flex; filter:drop-shadow(0 6px 14px rgba(43,63,179,.26))}
.logo svg{border-radius:12px}
.brand-text{display:flex; flex-direction:column; line-height:1.22}
.wordmark{font-family:var(--serif); font-size:1.6rem; font-weight:600; letter-spacing:.005em; color:var(--text)}
.tagline{font-size:.78rem; color:var(--muted); max-width:540px}
.topbar-right{display:flex; align-items:center; gap:10px}

.pill{display:inline-flex; align-items:center; gap:8px; padding:7px 14px; border-radius:999px;
  border:1px solid var(--line); background:var(--panel); font-size:.8rem; font-weight:600; white-space:nowrap; box-shadow:var(--sh-1)}
.pill .dot{width:8px; height:8px; border-radius:999px; background:var(--muted)}
.pill-ok{color:var(--green); border-color:#c7e6da; background:var(--green-tint)}
.pill-ok .dot{background:var(--green); box-shadow:0 0 0 3px rgba(31,138,109,.16)}
.pill-err{color:var(--orange); border-color:#eccdc7; background:var(--orange-tint)}
.pill-err .dot{background:var(--orange)}
.pill-wait .dot{animation:pulse 1.3s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.35}50%{opacity:1}}

/* ---------------- tab bar ---------------- */
.tabbar{display:flex; gap:4px; padding-top:26px; padding-bottom:0; border-bottom:1px solid var(--line)}
.tab{padding:10px 20px; border:none; background:none; color:var(--muted); font-family:var(--serif);
  font-weight:600; font-size:1.05rem; cursor:pointer; position:relative; transition:color .18s var(--ease)}
.tab:hover{color:var(--soft)}
.tab.active{color:var(--text)}
.tab::after{content:""; position:absolute; left:14px; right:14px; bottom:-1px; height:2.5px; border-radius:3px;
  background:var(--accent-grad); transform:scaleX(0); transform-origin:center; transition:transform .24s var(--ease)}
.tab.active::after{transform:scaleX(1)}
.tabpane{animation:rise .36s var(--ease) both}

/* ---------------- layout ---------------- */
main.wrap{padding-top:26px; padding-bottom:54px}
.panel{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--sh-2), var(--hi); padding:28px; margin-bottom:22px}
.panel-head{margin-bottom:18px}
.panel-head.row{display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap}
.panel-head h2 + .small{display:block; margin-top:6px; color:var(--muted)}
.cols{display:grid; grid-template-columns:minmax(340px,420px) 1fr; gap:24px; align-items:start}
.results{min-width:0}
@media(max-width:880px){ .cols{grid-template-columns:1fr} }

/* ---------------- ledger ---------------- */
.ledger{margin-bottom:24px}
.ledger-head{display:flex; align-items:baseline; gap:14px; margin-bottom:16px; flex-wrap:wrap}
.ledger-grid{display:grid; grid-template-columns:repeat(5,1fr); gap:14px}
@media(max-width:880px){ .ledger-grid{grid-template-columns:repeat(2,1fr)} }
.ledger-empty{padding:8px 2px}
.lstat{padding:18px; border:1px solid var(--line); border-radius:var(--radius2); background:var(--panel); box-shadow:var(--sh-1), var(--hi);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease)}
.lstat:hover{transform:translateY(-3px); box-shadow:var(--sh-pop), var(--hi)}
.lstat .v{font-family:var(--serif); font-size:2rem; font-weight:600; letter-spacing:-.025em; line-height:1.02; font-variant-numeric:tabular-nums}
.lstat .k{font-family:var(--mono); font-size:.68rem; color:var(--muted); margin-top:7px; text-transform:uppercase; letter-spacing:.08em}
.lstat.good .v{color:var(--green)}
.lstat.blue .v{color:var(--blue)}

/* ---------------- form ---------------- */
.field{display:flex; flex-direction:column; gap:7px; margin-bottom:15px}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
@media(max-width:430px){ .field-row{grid-template-columns:1fr} }
label{font-size:.83rem; font-weight:600; color:var(--soft); letter-spacing:.005em}
.field-row .field > label{white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.hint-inline{font-weight:400; color:var(--muted); font-size:.72rem; margin-left:4px}
.hint{font-size:.72rem; color:var(--muted)}
input,select{
  width:100%; padding:11px 13px; border-radius:var(--radius2); border:1px solid var(--line-strong);
  background:var(--panel); color:var(--text); font:inherit; font-size:.9rem; outline:none;
  transition:border-color .15s var(--ease), box-shadow .15s var(--ease)}
input:hover,select:hover{border-color:#c8bda6}
input:focus,select:focus{border-color:var(--blue); box-shadow:0 0 0 3px rgba(43,63,179,.14)}
input::placeholder{color:#b8b09e}
select{appearance:none; cursor:pointer; padding-right:36px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 4.75 6 8.25l3.5-3.5' fill='none' stroke='%239a917f' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 13px center}
input[type=datetime-local]{color-scheme:light}

.actions{display:flex; gap:12px; margin-top:6px}
.btn{flex:1; padding:13px 16px; border-radius:var(--radius2); border:1px solid var(--line-strong); font:inherit;
  font-weight:650; font-size:.92rem; cursor:pointer; color:var(--text); background:var(--panel); box-shadow:var(--sh-1);
  transition:background .15s var(--ease), border-color .15s var(--ease), transform .12s var(--ease), box-shadow .2s var(--ease)}
.btn:hover{background:var(--panel2); transform:translateY(-1px); box-shadow:var(--sh-2)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.55; cursor:wait; transform:none}
.btn-primary,.btn-primary:hover,.btn-primary:active{background:var(--accent-grad); color:#fff; border:none}
.btn-primary{box-shadow:0 10px 24px -10px rgba(43,63,179,.6), var(--hi)}
.btn-primary:hover{filter:brightness(1.05); transform:translateY(-1px); box-shadow:0 14px 30px -10px rgba(43,63,179,.6)}
.btn-ghost{background:var(--panel)}
.form-error{margin-top:13px; padding:11px 14px; border-radius:var(--radius2); font-size:.85rem;
  color:var(--orange); background:var(--orange-tint); border:1px solid #eccdc7}

/* ---------------- submit: grouped sections + levers ---------------- */
.fs{padding:22px 0; border-top:1px solid var(--line)}
.fs:first-of-type{border-top:none; padding-top:2px}
.fs-label{display:flex; align-items:baseline; gap:8px; font-family:var(--mono); font-size:.68rem; text-transform:uppercase;
  letter-spacing:.12em; color:var(--text); font-weight:700; margin-bottom:16px}
.fs-note{font-family:var(--sans); text-transform:none; letter-spacing:0; font-weight:400; font-size:.78rem; color:var(--muted)}
.fs .field:last-child,.fs .field-row:last-child{margin-bottom:0}
.hint.slack{color:var(--green); font-weight:600}

.levers-grid{display:grid; gap:10px}
.lever-toggle{display:grid; grid-template-columns:38px 1fr; align-items:center; gap:14px; padding:13px 15px;
  border:1px solid var(--line); border-radius:var(--radius2); background:var(--panel2); cursor:pointer;
  transition:border-color .15s var(--ease), background .15s var(--ease), box-shadow .15s var(--ease)}
.lever-toggle:hover{border-color:var(--line-strong); box-shadow:var(--sh-1)}
.lever-toggle:has(input:checked){border-color:#cdd2f3; background:var(--blue-tint)}
.lever-toggle input{appearance:none; width:38px; height:22px; border-radius:999px; background:var(--line-strong);
  position:relative; cursor:pointer; transition:background .2s var(--ease); border:none; margin:0}
.lever-toggle input::after{content:""; position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%;
  background:#fff; box-shadow:0 1px 3px rgba(0,0,0,.28); transition:transform .2s var(--ease)}
.lever-toggle input:checked{background:var(--accent-grad)}
.lever-toggle input:checked::after{transform:translateX(16px)}
.lt-text{display:flex; flex-direction:column; gap:2px; line-height:1.25; min-width:0}
.lt-name{font-weight:650; font-size:.88rem; color:var(--text)}
.lt-desc{font-size:.76rem; color:var(--muted)}
.submit .actions{margin-top:24px; padding-top:20px; border-top:1px solid var(--line)}

/* shared compact switch (exec controls, tamper) */
.switch{display:flex; align-items:center; gap:10px; font-size:.84rem; font-weight:500; color:var(--soft); cursor:pointer; padding:6px 0}
.switch.compact{font-size:.8rem}
.switch input{appearance:none; width:38px; height:22px; border-radius:999px; background:var(--line-strong);
  position:relative; cursor:pointer; flex:0 0 auto; transition:background .2s var(--ease); border:none; padding:0; margin:0}
.switch input::after{content:""; position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%;
  background:#fff; box-shadow:0 1px 3px rgba(0,0,0,.28); transition:transform .2s var(--ease)}
.switch input:checked{background:var(--accent-grad)}
.switch input:checked::after{transform:translateX(16px)}

/* ---------------- empty states ---------------- */
.empty{text-align:center; padding:54px 22px}
.empty-icon{display:flex; justify-content:center; margin-bottom:16px; opacity:.7}
.empty h3{color:var(--soft)}
.empty p{max-width:440px; margin:0 auto; font-size:.92rem; color:var(--muted); line-height:1.6}

/* ---------------- plan hero ---------------- */
.decision-bar{display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:8px}
.decision{font-family:var(--serif); font-size:2rem; font-weight:600; letter-spacing:-.03em; color:var(--text); line-height:1.08}
.badge{display:inline-flex; align-items:center; gap:6px; padding:4px 11px; border-radius:999px; font-size:.7rem; font-weight:700;
  border:1px solid var(--line-strong); background:var(--panel2); text-transform:uppercase; letter-spacing:.06em; font-family:var(--mono)}
.badge.spot{color:var(--yellow); border-color:#e3d6b3; background:var(--yellow-tint)}
.badge.ondemand{color:var(--blue); border-color:#cdd2f3; background:var(--blue-tint)}
.route{font-size:1rem; color:var(--soft); margin-bottom:5px}
.route strong{color:var(--text)}
.route .chip{display:inline-block; padding:2px 9px; border-radius:7px; background:var(--panel2); border:1px solid var(--line); font-size:.84rem; margin:0 1px}
.timing{font-size:.86rem; color:var(--muted); margin-bottom:20px}
.timing b{color:var(--green); font-weight:600}

.tiles{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:20px}
@media(max-width:560px){ .tiles{grid-template-columns:1fr} }
.tile{padding:18px; border-radius:var(--radius2); border:1px solid var(--line); background:var(--panel2); box-shadow:var(--hi)}
.tile .label{font-family:var(--mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted)}
.tile .big{font-family:var(--serif); font-size:2.25rem; font-weight:600; letter-spacing:-.035em; line-height:1.02; font-variant-numeric:tabular-nums; margin:8px 0 3px}
.tile .sub{font-size:.84rem; color:var(--soft); font-variant-numeric:tabular-nums}
.tile.cost{background:linear-gradient(155deg,#ecf7f2,#e4f3ec); border-color:#d2e9df}
.tile.cost .big{color:var(--green)}
.tile.carbon{background:linear-gradient(155deg,#ecf7f2,#e4f3ec); border-color:#d2e9df}
.tile.carbon .big{color:var(--green)}
.tile.conf{background:linear-gradient(155deg,#eef0fc,#e6e9fb); border-color:#d6dcf5}
.tile.conf .big{color:var(--blue)}

.split2{display:grid; grid-template-columns:1fr 1fr; gap:22px}
@media(max-width:560px){ .split2{grid-template-columns:1fr} }
.subhead{font-family:var(--mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); margin-bottom:10px}
.breakdown{list-style:none; margin:0; padding:0; font-size:.9rem}
.breakdown li{display:flex; justify-content:space-between; padding:7px 0; border-bottom:1px dashed var(--line)}
.breakdown li:last-child{border-bottom:none}
.breakdown .total{font-weight:700; border-top:1px solid var(--line-strong); margin-top:2px; padding-top:9px}
.breakdown .v{font-variant-numeric:tabular-nums}
.compare{display:flex; flex-direction:column; gap:12px; font-size:.88rem}
.compare .row2{display:flex; justify-content:space-between; align-items:center}
.bar{height:9px; border-radius:999px; background:var(--panel2); border:1px solid var(--line); overflow:hidden; margin-top:5px}
.bar > span{display:block; height:100%; border-radius:999px; transition:width .6s var(--ease)}
.bar.base > span{background:linear-gradient(90deg,#c98a82,var(--orange))}
.bar.chosen > span{background:var(--duo-grad)}

.reasons{list-style:none; margin:16px 0 0; padding:0; display:grid; gap:9px}
.reasons li{display:flex; gap:11px; align-items:flex-start; font-size:.9rem; color:var(--soft)}
.reasons .tick{flex:0 0 auto; width:20px; height:20px; border-radius:50%;
  background:var(--green-tint); color:var(--green); display:grid; place-items:center; font-size:.7rem; font-weight:900; margin-top:1px; box-shadow:var(--hi)}

/* ---------------- forecast chart ---------------- */
.region-toggle{display:flex; gap:6px; flex-wrap:wrap}
.region-toggle button{padding:6px 13px; border-radius:999px; border:1px solid var(--line-strong); background:var(--panel);
  color:var(--soft); font:inherit; font-size:.78rem; font-weight:600; cursor:pointer; transition:all .15s var(--ease)}
.region-toggle button:hover{border-color:var(--blue); color:var(--text)}
.region-toggle button.active{background:var(--blue-tint); color:var(--blue); border-color:#cdd2f3}
.chart-wrap{width:100%; overflow:hidden}
.chart-wrap svg{width:100%; height:auto; display:block}
.chart-legend{display:flex; gap:18px; flex-wrap:wrap; margin-top:14px; font-size:.8rem; color:var(--muted)}
.chart-legend .li{display:flex; align-items:center; gap:7px}
.chart-legend .sw{width:16px; height:3px; border-radius:2px}
.chart-legend .sw.win{height:12px; width:14px; border-radius:3px}

/* ---------------- tables ---------------- */
.table-scroll{overflow-x:auto; margin:0 -6px}
.data-table{width:100%; border-collapse:collapse; font-size:.85rem; min-width:560px}
.data-table th{text-align:left; font-family:var(--mono); font-weight:600; color:var(--muted); font-size:.66rem; text-transform:uppercase;
  letter-spacing:.06em; padding:9px 12px; border-bottom:1px solid var(--line-strong); white-space:nowrap}
.data-table td{padding:11px 12px; border-bottom:1px solid var(--line); white-space:nowrap; font-variant-numeric:tabular-nums}
.data-table tbody tr{transition:background .14s var(--ease)}
.data-table tbody tr:hover td{background:var(--panel2)}
.data-table tr.chosen td{background:var(--blue-tint)}
.data-table tr.chosen:hover td{background:#e6e9fb}
.data-table tr.chosen td:first-child{box-shadow:inset 3px 0 0 var(--blue)}
.tag{display:inline-block; padding:2px 8px; border-radius:6px; font-size:.7rem; font-weight:600; border:1px solid var(--line-strong); font-family:var(--mono)}
.tag.spot{color:var(--yellow); background:var(--yellow-tint); border-color:#e3d6b3}
.tag.od{color:var(--blue); background:var(--blue-tint); border-color:#cdd2f3}
.tag.win{color:var(--green); background:var(--green-tint); border-color:#c7e6da; font-size:.64rem; margin-left:6px}

/* ---------------- fallback ---------------- */
.fallback-list{list-style:none; counter-reset:fb; margin:0; padding:0; display:grid; gap:11px}
.fallback-list li{counter-increment:fb; display:flex; gap:14px; align-items:flex-start; padding:14px 16px;
  border:1px solid var(--line); border-radius:var(--radius2); background:var(--panel2); transition:border-color .15s var(--ease), box-shadow .15s var(--ease)}
.fallback-list li:hover{border-color:var(--line-strong); box-shadow:var(--sh-1)}
.fallback-list li::before{content:counter(fb); flex:0 0 auto; width:26px; height:26px; border-radius:8px;
  background:var(--accent-grad); color:#fff; font-weight:700; font-size:.8rem; display:grid; place-items:center; font-family:var(--mono); box-shadow:var(--hi)}
.fb-body{min-width:0}
.fb-route{font-weight:600; font-size:.92rem}
.fb-route .tag{margin-left:6px}
.fb-meta{font-size:.82rem; color:var(--muted); font-variant-numeric:tabular-nums; margin-top:3px}
.fb-trigger{font-size:.78rem; color:var(--soft); margin-top:6px}

/* ---------------- receipt / execute ---------------- */
.exec-controls{display:flex; align-items:center; gap:14px; flex-wrap:wrap}
.exec-controls .btn{flex:0 0 auto; padding:11px 18px}
.receipt-empty{padding:6px 2px}
.outcome-bar{display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:18px}
.outcome{font-family:var(--serif); font-size:1.45rem; font-weight:600; letter-spacing:-.02em}
.badge.met{color:var(--green); border-color:#c7e6da; background:var(--green-tint)}
.badge.missed{color:var(--orange); border-color:#eccdc7; background:var(--orange-tint)}
.receipt-tiles{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:18px}
@media(max-width:560px){ .receipt-tiles{grid-template-columns:1fr} }

.timeline{list-style:none; margin:8px 0 0; padding:0; position:relative}
.timeline::before{content:""; position:absolute; left:9px; top:6px; bottom:6px; width:2px; background:var(--line-strong)}
.timeline li{position:relative; padding:0 0 18px 32px}
.timeline li:last-child{padding-bottom:0}
.timeline .node{position:absolute; left:2px; top:2px; width:16px; height:16px; border-radius:50%;
  background:var(--panel); border:2px solid var(--blue); box-shadow:0 0 0 3px var(--panel)}
.timeline li.completed .node{border-color:var(--green); background:var(--green)}
.timeline li.preempted .node,.timeline li.failed .node{border-color:var(--orange); background:var(--orange)}
.timeline li.rerouted .node{border-color:var(--purple); background:var(--purple)}
.timeline li.checkpoint .node{border-color:var(--yellow)}
.tl-kind{font-weight:700; font-size:.9rem; text-transform:capitalize}
.tl-detail{font-size:.84rem; color:var(--muted)}
.tl-time{font-size:.74rem; color:var(--muted); font-variant-numeric:tabular-nums}

.foot{padding:28px 24px 40px; text-align:center; border-top:1px solid var(--line); margin-top:10px}

/* ---------------- provenance badges ---------------- */
.prov{display:flex; gap:8px; flex-wrap:wrap; margin:0 0 16px}
.prov-badge{display:inline-flex; align-items:center; gap:7px; padding:5px 12px; border-radius:999px;
  font-size:.74rem; font-weight:600; border:1px solid var(--line-strong); background:var(--panel2); white-space:nowrap}
.prov-badge .pdot{width:8px; height:8px; border-radius:999px; background:var(--muted); flex:0 0 auto}
.prov-badge .pk{color:var(--muted); text-transform:uppercase; letter-spacing:.06em; font-size:.64rem; font-weight:700; font-family:var(--mono)}
.prov-badge.live{color:var(--green); border-color:#c7e6da; background:var(--green-tint)}
.prov-badge.live .pdot{background:var(--green)}
.prov-badge.modeled{color:var(--muted)}

/* ---------------- flexibility value ---------------- */
.flex-rec{font-size:.9rem; color:var(--soft); margin:0 0 16px; padding:12px 14px; border-radius:var(--radius2);
  background:var(--blue-tint); border:1px solid #cdd2f3}
.lever-list{list-style:none; margin:0; padding:0; display:grid; gap:11px}
.lever{display:flex; align-items:center; gap:14px; padding:14px 16px; border:1px solid var(--line);
  border-radius:var(--radius2); background:var(--panel2); transition:border-color .15s var(--ease), box-shadow .15s var(--ease)}
.lever:hover{border-color:var(--line-strong); box-shadow:var(--sh-1)}
.lever.required{border-color:#eccdc7; background:var(--orange-tint)}
.lever.valuable{border-color:#c7e6da; background:var(--green-tint)}
.lever-state{flex:0 0 auto; width:48px; text-align:center; font-size:.62rem; font-weight:800; letter-spacing:.06em;
  text-transform:uppercase; padding:5px 0; border-radius:7px; border:1px solid var(--line-strong); font-family:var(--mono)}
.lever-state.on{color:var(--green); border-color:#c7e6da; background:var(--green-tint)}
.lever-state.off{color:var(--muted)}
.lever-state.na{color:var(--muted); opacity:.7}
.lever-body{min-width:0; flex:1}
.lever-name{font-weight:700; font-size:.92rem}
.lever-desc{font-size:.8rem; color:var(--muted); margin-top:2px}
.lever-val{flex:0 0 auto; font-family:var(--serif); font-weight:600; font-size:1.2rem; font-variant-numeric:tabular-nums; text-align:right; white-space:nowrap}
.lever-val.req{color:var(--orange)}
.lever-val.gain{color:var(--green)}
.lever-val.none{color:var(--muted); font-weight:600; font-size:.85rem; font-family:inherit}
.lever-rec{font-size:.78rem; color:var(--soft); margin-top:4px}

/* ---------------- calibration ---------------- */
.btn-mini{margin-left:auto; padding:8px 14px; border-radius:var(--radius2); border:1px solid var(--line-strong);
  background:var(--panel); color:var(--soft); font:inherit; font-weight:650; font-size:.78rem; cursor:pointer; box-shadow:var(--sh-1);
  transition:background .15s var(--ease), border-color .15s var(--ease), transform .12s var(--ease)}
.btn-mini:hover{background:var(--panel2); border-color:var(--blue); transform:translateY(-1px)}
.btn-mini:disabled{opacity:.55; cursor:wait; transform:none}
.calib-box{margin-top:16px; padding:16px 18px; border:1px solid var(--line); border-radius:var(--radius2); background:var(--panel2)}
.calib-head{display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; margin-bottom:11px}
.calib-cf{font-weight:800; color:var(--blue)}
.calib-note{font-size:.8rem; color:var(--muted); margin-top:11px}

/* ---------------- certificate ---------------- */
.cert-actions{display:flex; gap:11px; align-items:center; flex-wrap:wrap; margin-top:20px;
  padding-top:18px; border-top:1px solid var(--line)}
.cert-actions .btn{flex:0 0 auto; padding:11px 18px}
.cert-card{margin-top:16px; padding:20px; border:1px solid #d6dcf5; border-radius:var(--radius2);
  background:linear-gradient(155deg,#eef0fc,#e9f6f1); box-shadow:var(--sh-1), var(--hi); animation:rise .3s var(--ease) both}
.cert-card .cert-top{display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:13px}
.cert-title{font-family:var(--serif); font-weight:600; font-size:1.2rem; letter-spacing:-.01em}
.cert-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:13px; margin-bottom:13px}
.cert-cell .ck{font-family:var(--mono); font-size:.64rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted)}
.cert-cell .cv{font-size:1.05rem; font-weight:700; font-variant-numeric:tabular-nums; margin-top:3px}
.cert-sig{font-family:var(--mono); font-size:.78rem; color:var(--soft);
  word-break:break-all; background:rgba(255,255,255,.7); padding:10px 12px; border-radius:var(--radius2); border:1px solid var(--line)}
.cert-sig .sk{color:var(--muted); display:block; font-size:.64rem; text-transform:uppercase; letter-spacing:.06em; margin-bottom:3px}
.verdict{margin-top:13px; padding:13px 15px; border-radius:var(--radius2); font-weight:700; font-size:.95rem; animation:rise .3s var(--ease) both}
.verdict.ok{color:var(--green); background:var(--green-tint); border:1px solid #c7e6da}
.verdict.bad{color:var(--orange); background:var(--orange-tint); border:1px solid #eccdc7}
.verdict .vr{display:block; font-weight:500; font-size:.82rem; opacity:.9; margin-top:3px}
.badge.grid-on{color:var(--green); border-color:#c7e6da; background:var(--green-tint)}
.badge.grid-off{color:var(--muted)}

/* ---------------- fleet ---------------- */
.fleet-bars rect{transition:opacity .15s}
.grid-event-card{display:flex; gap:18px; flex-wrap:wrap; align-items:stretch}
.ge-headline{flex:1 1 220px; padding:20px; border-radius:var(--radius2); border:1px solid #e3d6b3; background:linear-gradient(155deg,#f9f3e3,#f5ecd6); box-shadow:var(--hi)}
.ge-headline .big{font-family:var(--serif); font-size:2.25rem; font-weight:600; letter-spacing:-.035em; line-height:1.02;
  font-variant-numeric:tabular-nums; color:var(--yellow)}
.ge-headline .label{font-family:var(--mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted)}
.ge-headline .sub{font-size:.84rem; color:var(--soft); margin-top:7px}
.ge-stats{flex:2 1 280px; display:grid; grid-template-columns:repeat(auto-fit,minmax(130px,1fr)); gap:13px; align-content:start}
.ge-stat{padding:15px 16px; border-radius:var(--radius2); border:1px solid var(--line); background:var(--panel2); box-shadow:var(--hi)}
.ge-stat .v{font-family:var(--serif); font-size:1.5rem; font-weight:600; font-variant-numeric:tabular-nums}
.ge-stat .k{font-family:var(--mono); font-size:.66rem; color:var(--muted); margin-top:4px; text-transform:uppercase; letter-spacing:.06em}

/* motion */
.fade{animation:rise .4s var(--ease) both}
@keyframes rise{from{opacity:0; transform:translateY(10px)}to{opacity:1; transform:none}}
@media(prefers-reduced-motion:reduce){*{animation:none!important; transition:none!important}}
