/* ============================================================
   Komo — Fleet Telemetry tab
   Visually continuous with the Komo Management Console.
   Brand: obsidian #0B0F14 · jade #10D9A0 · grey #F4F6FA
   Type:  Sora (display/body) · JetBrains Mono (labels/data)
   ============================================================ */
:root{
  --obsidian:#0B0F14;
  --ink:#0B0F14;
  --muted:#5A6478;
  --faint:#8A93A6;
  --jade:#10D9A0;
  --jade-deep:#0BB387;
  --jade-soft:rgba(16,217,160,.12);
  --bg:#FFFFFF;
  --bg-alt:#F4F6FA;
  --line:#E7EAF0;
  --line-strong:#D7DCE6;
  --danger:#E5484D;
  --danger-soft:rgba(229,72,77,.10);
  --amber:#E8930C;
  --amber-soft:rgba(232,147,12,.12);
  --green:#16A06B;
  --green-soft:rgba(22,160,107,.12);
  --violet:#8B5CF6;
  --slate:#64748B;

  --topbar-h:64px;
  --content-w:1280px;
  --radius:16px;
  --radius-sm:12px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-display:'Sora',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --shadow-card:0 1px 2px rgba(11,15,20,.04);
  --shadow-pop:0 30px 70px -28px rgba(11,15,20,.45);
  --shadow-float:0 12px 36px -16px rgba(11,15,20,.22);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  font-family:var(--font-display);color:var(--ink);background:var(--bg-alt);
  line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;
}
[v-cloak]{display:none;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,select{font-family:inherit;}
img{max-width:100%;display:block;}
::selection{background:var(--jade);color:var(--obsidian);}
.mono{font-family:var(--font-mono);}
.tnum{font-variant-numeric:tabular-nums;}

/* =====================  BUTTONS  ===================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:14px;letter-spacing:-.01em;
  padding:10px 18px;border-radius:10px;white-space:nowrap;
  transition:transform .15s var(--ease),background .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease);
}
.btn:active{transform:translateY(1px);}
.btn--primary{background:var(--jade);color:var(--obsidian);}
.btn--primary:hover{background:var(--jade-deep);box-shadow:0 6px 22px -8px rgba(16,217,160,.7);}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-strong);}
.btn--ghost:hover{border-color:var(--ink);}
.btn--subtle{background:var(--bg-alt);color:var(--ink);}
.btn--subtle:hover{background:var(--line);}
.btn--sm{padding:7px 13px;font-size:13px;border-radius:8px;}
.btn--lg{padding:13px 24px;font-size:15px;border-radius:12px;}
.btn .arrow{transition:transform .2s var(--ease);}
.btn:hover .arrow{transform:translateX(3px);}
.btn:disabled{opacity:.5;cursor:not-allowed;}

.iconbtn{width:34px;height:34px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);transition:background .15s var(--ease),color .15s var(--ease);}
.iconbtn:hover{background:var(--bg-alt);color:var(--ink);}
.iconbtn svg{width:17px;height:17px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;}

/* =====================  TOP BAR  ===================== */
.topbar{position:sticky;top:0;z-index:80;height:var(--topbar-h);background:rgba(255,255,255,.86);backdrop-filter:saturate(150%) blur(14px);-webkit-backdrop-filter:saturate(150%) blur(14px);border-bottom:1px solid var(--line);display:flex;align-items:center;}
.topbar__inner{width:100%;max-width:var(--content-w);margin:0 auto;padding-inline:clamp(20px,4vw,44px);display:flex;align-items:center;justify-content:space-between;gap:20px;}
.topbar__brand{display:inline-flex;align-items:center;gap:14px;}
.topbar__brand img{height:22px;width:auto;}
.topbar__divider{width:1px;height:22px;background:var(--line-strong);}
.topbar__context{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);}
.topbar__right{display:flex;align-items:center;gap:14px;}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--obsidian);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:box-shadow .15s var(--ease);}
.avatar:hover{box-shadow:0 0 0 4px var(--bg-alt);}
.avatar.active{box-shadow:0 0 0 4px var(--jade-soft);}

/* user menu dropdown */
.usermenu{position:relative;}
.usermenu__pop{position:absolute;right:0;top:calc(100% + 12px);min-width:208px;z-index:90;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-pop);padding:6px;animation:popIn .18s var(--ease);}
.usermenu__id{padding:11px 12px 12px;border-bottom:1px solid var(--line);margin-bottom:6px;}
.usermenu__id .nm{font-size:14px;font-weight:600;letter-spacing:-.01em;color:var(--ink);}
.usermenu__id .sub{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-top:3px;}
.usermenu__item{display:flex;align-items:center;gap:11px;width:100%;padding:10px 12px;border-radius:9px;font-size:14px;font-weight:500;color:var(--ink);text-align:left;transition:background .12s var(--ease);}
.usermenu__item:hover{background:var(--bg-alt);}
.usermenu__item svg{width:17px;height:17px;stroke:var(--muted);stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;}

/* primary nav tabs in topbar */
.navtabs{display:flex;align-items:center;gap:2px;}
.navtabs a{position:relative;padding:8px 14px;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--muted);transition:color .15s var(--ease),background .15s var(--ease);}
.navtabs a:hover{color:var(--ink);background:var(--bg-alt);}
.navtabs a.active{color:var(--ink);}
.navtabs a.active::after{content:"";position:absolute;left:14px;right:14px;bottom:-13px;height:2px;background:var(--jade);}

/* =====================  PAGE SHELL  ===================== */
.page{max-width:var(--content-w);margin:0 auto;padding:clamp(22px,3.4vw,34px) clamp(20px,4vw,44px) 140px;}
.breadcrumb{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);margin-bottom:16px;}
.breadcrumb button{font-size:13px;color:var(--muted);font-weight:500;transition:color .15s var(--ease);display:inline-flex;align-items:center;gap:6px;}
.breadcrumb button:hover{color:var(--ink);}
.breadcrumb button svg{width:15px;height:15px;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.breadcrumb .sep{color:var(--line-strong);}
.breadcrumb .current{color:var(--ink);font-weight:600;}

.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);font-weight:500;display:flex;align-items:center;gap:10px;}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--line-strong);}

.page__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:8px;}
.page__title{margin-top:12px;font-size:clamp(26px,3.4vw,36px);font-weight:600;letter-spacing:-.03em;line-height:1.05;}
.page__sub{margin-top:8px;font-size:14.5px;color:var(--muted);max-width:60ch;}

/* section anchor headers */
.sectionhead{display:flex;align-items:baseline;gap:14px;margin:46px 0 18px;padding-bottom:14px;border-bottom:1px solid var(--line);scroll-margin-top:130px;}
.sectionhead h2{font-size:21px;font-weight:600;letter-spacing:-.02em;}
.sectionhead .nóte,.sectionhead .note{font-size:13px;color:var(--faint);}
.sectionhead .spacer{flex:1;}

/* anchored sub-nav (sticky) */
.subnav{position:sticky;top:var(--topbar-h);z-index:60;background:rgba(244,246,250,.86);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line);margin-bottom:8px;}
.subnav__inner{max-width:var(--content-w);margin:0 auto;padding:0 clamp(20px,4vw,44px);display:flex;align-items:center;gap:6px;height:48px;}
.subnav a{font-size:13px;font-weight:600;color:var(--muted);padding:7px 12px;border-radius:8px;transition:color .15s,background .15s;}
.subnav a:hover{color:var(--ink);background:#fff;}
.subnav a.active{color:var(--ink);background:#fff;box-shadow:var(--shadow-card);}
.subnav .spacer{flex:1;}
.subnav__meta{font-family:var(--font-mono);font-size:11px;color:var(--faint);letter-spacing:.04em;}

/* =====================  CONTROLS BAR  ===================== */
.controls{position:sticky;top:calc(var(--topbar-h) + 48px);z-index:55;display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 0 16px;background:linear-gradient(var(--bg-alt) 72%,rgba(244,246,250,0));}
.ctl{display:flex;align-items:center;gap:8px;}
.ctl__lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);}
.seg{display:inline-flex;background:#fff;border:1px solid var(--line);padding:3px;border-radius:10px;gap:2px;box-shadow:var(--shadow-card);}
.seg button{font-size:12.5px;font-weight:600;color:var(--muted);padding:6px 11px;border-radius:7px;transition:all .15s var(--ease);white-space:nowrap;}
.seg button:hover{color:var(--ink);}
.seg button.active{background:var(--obsidian);color:#fff;}
.seg.seg--soft button.active{background:var(--jade-soft);color:var(--jade-deep);}
.spacer{flex:1;}
.gzoomrow{display:flex;justify-content:flex-end;gap:4px;margin:2px 0 6px;}
.gzoomrow button{width:24px;height:22px;border-radius:6px;border:1px solid var(--line);background:#fff;color:var(--muted);font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .12s var(--ease);}
.gzoomrow button:hover{border-color:var(--line-strong);color:var(--ink);background:var(--bg-alt);}
.gzoomrow button:disabled{opacity:.35;cursor:not-allowed;}
.controls--detail{position:sticky;top:var(--topbar-h);z-index:55;background:var(--bg-alt);border-bottom:1px solid var(--line);margin:0 0 10px;padding:12px 0;}
.dtin{font-family:var(--font-mono);font-size:11.5px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px 8px;box-shadow:var(--shadow-card);}
.dtin:focus{outline:none;border-color:var(--jade);box-shadow:0 0 0 3px var(--jade-soft);}

/* machine selector dropdown */
.mselect{position:relative;}
.mselect__btn{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 13px;font-size:13px;font-weight:600;color:var(--ink);box-shadow:var(--shadow-card);transition:border-color .15s;}
.mselect__btn:hover{border-color:var(--line-strong);}
.mselect__btn .cnt{font-family:var(--font-mono);font-size:11px;color:var(--jade-deep);background:var(--jade-soft);padding:2px 7px;border-radius:6px;}
.mselect__btn svg{width:15px;height:15px;stroke:var(--muted);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.mselect__pop{position:absolute;left:0;top:calc(100% + 8px);width:336px;max-height:60vh;overflow-y:auto;z-index:120;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-pop);padding:8px;animation:popIn .16s var(--ease);}
.mselect__head{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 10px;border-bottom:1px solid var(--line);margin-bottom:6px;}
.mselect__head .lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);}
.mselect__head button{font-size:12px;font-weight:600;color:var(--jade-deep);}
.mrow{display:flex;align-items:center;gap:11px;padding:9px 8px;border-radius:9px;cursor:pointer;transition:background .12s;}
.mrow:hover{background:var(--bg-alt);}
.mrow .cb{width:18px;height:18px;border-radius:5px;border:1.6px solid var(--line-strong);flex:none;display:flex;align-items:center;justify-content:center;transition:all .12s;}
.mrow.on .cb{background:var(--jade);border-color:var(--jade);}
.mrow .cb svg{width:12px;height:12px;stroke:var(--obsidian);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:0;}
.mrow.on .cb svg{opacity:1;}
.mrow .nm{flex:1;min-width:0;font-size:13.5px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mrow .tag{font-family:var(--font-mono);font-size:10px;color:var(--faint);}
.mrow .gpudot{width:6px;height:6px;border-radius:50%;background:var(--jade);flex:none;}

/* =====================  CARD / GRID  ===================== */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);}
.card__head{display:flex;align-items:center;gap:12px;padding:16px 20px 12px;}
.card__head h3{font-size:14.5px;font-weight:600;letter-spacing:-.01em;}
.card__head .sub{font-size:12px;color:var(--faint);}
.card__head .spacer{flex:1;}
.card__body{padding:6px 20px 18px;}

.grid{display:grid;gap:16px;}
.grid--stats{grid-template-columns:repeat(4,1fr);}
.grid--2{grid-template-columns:1fr 1fr;}
.grid--charts{grid-template-columns:1fr 1fr;}
@media (max-width:1080px){.grid--stats{grid-template-columns:repeat(2,1fr);}.grid--charts,.grid--2{grid-template-columns:1fr;}}

/* =====================  STAT CARD  ===================== */
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:18px 20px 17px;display:flex;flex-direction:column;gap:3px;position:relative;overflow:visible;transition:box-shadow .2s var(--ease),transform .15s var(--ease);}
.stat--link{cursor:pointer;}
.stat--link:hover{box-shadow:var(--shadow-float);}
.stat__label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:flex;align-items:center;gap:7px;}
.stat__label .help{width:14px;height:14px;border-radius:50%;border:1px solid var(--line-strong);color:var(--faint);font-size:9px;display:inline-flex;align-items:center;justify-content:center;cursor:help;font-family:var(--font-display);position:relative;}
.stat__label .help:hover{border-color:var(--ink);color:var(--ink);}
.help .tip{position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%);width:218px;background:var(--obsidian);color:#fff;font-family:var(--font-display);font-size:11.5px;font-weight:500;line-height:1.5;letter-spacing:0;text-transform:none;text-align:left;padding:10px 12px;border-radius:10px;box-shadow:var(--shadow-float);opacity:0;visibility:hidden;transition:opacity .14s var(--ease);z-index:60;pointer-events:none;}
.help .tip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--obsidian);}
.help:hover .tip{opacity:1;visibility:visible;}
.stat__value{font-size:33px;font-weight:600;letter-spacing:-.03em;line-height:1.05;margin-top:6px;font-variant-numeric:tabular-nums;}
.stat__value .unit{font-size:17px;color:var(--faint);font-weight:500;margin-left:2px;}
.stat__sub{font-size:12.5px;color:var(--muted);margin-top:5px;line-height:1.45;}
.stat__sub b{color:var(--ink);font-weight:600;}
.stat__second{margin-top:11px;font-size:12.5px;color:var(--muted);display:flex;align-items:baseline;gap:6px;}
.stat__second .n{font-size:19px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.02em;}
.stat__foot{margin-top:11px;}
.stat__pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10.5px;font-weight:500;padding:3px 8px;border-radius:6px;letter-spacing:.02em;white-space:nowrap;}
.stat__pill .d{width:6px;height:6px;border-radius:50%;}
.pill--green{background:var(--green-soft);color:var(--green);} .pill--green .d{background:var(--green);}
.pill--amber{background:var(--amber-soft);color:var(--amber);} .pill--amber .d{background:var(--amber);}
.pill--red{background:var(--danger-soft);color:var(--danger);} .pill--red .d{background:var(--danger);}
.pill--jade{background:var(--jade-soft);color:var(--jade-deep);} .pill--jade .d{background:var(--jade);}

/* big hero stat (thesis number) */
.stat--hero .stat__value{font-size:46px;}
.stat--hero{background:linear-gradient(180deg,#fff,#fbfdfc);}
.stat__accentbar{position:absolute;left:0;top:16px;bottom:16px;width:3px;border-radius:0 3px 3px 0;}
.bar--jade{background:var(--jade);} .bar--green{background:var(--green);} .bar--amber{background:var(--amber);} .bar--red{background:var(--danger);}

/* stacked mini bar inside a card */
.ministack{display:flex;height:10px;border-radius:6px;overflow:hidden;margin-top:12px;background:var(--bg-alt);}
.ministack > span{height:100%;transition:width .4s var(--ease);}
.minilegend{display:flex;gap:14px;margin-top:11px;flex-wrap:wrap;}
.minilegend span{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--muted);}
.minilegend .d{width:8px;height:8px;border-radius:3px;}

/* horizontal capacity bar (stranded storage) */
.capbar{margin-top:14px;}
.capbar__track{height:12px;border-radius:7px;background:var(--bg-alt);overflow:hidden;position:relative;}
.capbar__used{height:100%;background:var(--obsidian);border-radius:7px;}
.capbar__labels{display:flex;justify-content:space-between;margin-top:8px;font-size:11.5px;color:var(--muted);}

/* =====================  CHART CARD  ===================== */
.chartcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:16px 18px 14px;display:flex;flex-direction:column;}
.chartcard__head{display:flex;align-items:flex-start;gap:12px;margin-bottom:6px;}
.chartcard__title{font-size:13.5px;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:8px;}
.chartcard__title .dot{width:9px;height:9px;border-radius:3px;background:var(--jade);}
.chartcard__sub{font-family:var(--font-mono);font-size:10.5px;color:var(--faint);letter-spacing:.04em;margin-top:3px;}
.chartcard__val{margin-left:auto;text-align:right;}
.chartcard__val .big{font-size:18px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em;}
.chartcard__val .lbl{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);}
.chartwrap{position:relative;width:100%;}
.chartwrap svg{display:block;width:100%;overflow:visible;}

/* svg chart primitives */
.axis-line{stroke:var(--line);stroke-width:1;}
.grid-line{stroke:var(--line);stroke-width:1;stroke-dasharray:2 4;}
.axis-text{font-family:var(--font-mono);font-size:9px;fill:var(--faint);}
.series-line{fill:none;stroke:var(--jade);stroke-width:1.6;stroke-linejoin:round;stroke-linecap:round;}
.series-band{fill:var(--jade-soft);stroke:none;}
.series-area{fill:url(#jadefill);stroke:none;}
.crosshair{stroke:var(--line-strong);stroke-width:1;stroke-dasharray:3 3;}
.hover-dot{fill:#fff;stroke:var(--jade);stroke-width:2;}

/* chart tooltip */
.charttip{position:absolute;pointer-events:none;z-index:30;background:var(--obsidian);color:#fff;border-radius:9px;padding:8px 11px;font-size:12px;box-shadow:var(--shadow-float);transform:translate(-50%,-115%);white-space:nowrap;transition:opacity .1s;}
.charttip .t{font-family:var(--font-mono);font-size:10px;color:#aab4c4;letter-spacing:.03em;margin-bottom:4px;}
.charttip .v{font-weight:600;font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:7px;}
.charttip .v .d{width:7px;height:7px;border-radius:2px;background:var(--jade);}
.charttip .vmax{color:#aab4c4;font-weight:500;font-size:11px;margin-top:2px;}

/* legend chips */
.legend{display:flex;gap:14px;align-items:center;flex-wrap:wrap;}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);font-family:var(--font-mono);letter-spacing:.02em;}
.legend .ln{width:14px;height:2px;border-radius:2px;background:var(--jade);}
.legend .bnd{width:12px;height:9px;border-radius:2px;background:var(--jade-soft);}

/* =====================  HEATMAP  ===================== */
.heat{display:grid;gap:3px;}
.heat__cell{border-radius:3px;aspect-ratio:1;transition:transform .1s;cursor:default;}
.heat__cell:hover{transform:scale(1.18);box-shadow:0 0 0 2px #fff,0 0 0 3px var(--ink);}
.heat__row{display:contents;}
.heatlbl{font-family:var(--font-mono);font-size:9px;fill:var(--faint);color:var(--faint);}
.heatscale{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:10px;color:var(--faint);}
.heatscale__bar{height:9px;width:80px;border-radius:3px;background:linear-gradient(90deg,#EEF1F6,var(--jade-deep));}

/* =====================  HISTOGRAM  ===================== */
.histo{display:flex;align-items:flex-end;gap:12px;height:200px;padding-top:10px;}
.histo__col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end;}
.histo__bar{width:100%;border-radius:6px 6px 0 0;background:var(--jade);position:relative;transition:height .5s var(--ease);min-height:2px;}
.histo__bar .pct{position:absolute;top:-21px;left:0;right:0;text-align:center;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--ink);}
.histo__lbl{font-family:var(--font-mono);font-size:10px;color:var(--muted);text-align:center;}
.histo__lbl .band{display:block;color:var(--faint);font-size:9px;margin-top:2px;}

/* =====================  COMPARISON STRIP / TABLES  ===================== */
.tbl{width:100%;border-collapse:collapse;}
.tbl thead th{text-align:left;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:500;padding:12px 16px;border-bottom:1px solid var(--line);white-space:nowrap;cursor:pointer;user-select:none;}
.tbl thead th.num{text-align:right;}
.tbl thead th .sortcaret{display:none;margin-left:5px;}
.tbl thead th.sorted .sortcaret{display:inline;color:var(--jade-deep);}
.tbl thead th.sorted{color:var(--ink);}
.tbl tbody td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle;font-size:13.5px;}
.tbl tbody tr:last-child td{border-bottom:none;}
.tbl tbody tr{transition:background .12s var(--ease);}
.tbl--rows tbody tr{cursor:pointer;}
.tbl--rows tbody tr:hover{background:var(--bg-alt);}
.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--font-mono);font-size:12.5px;}
.tbl .mname{display:flex;align-items:center;gap:10px;font-weight:600;font-family:var(--font-display);font-size:13.5px;}
.tbl .mname .badge{width:24px;height:24px;border-radius:7px;flex:none;display:flex;align-items:center;justify-content:center;font-size:11px;}
.badge--mac{background:var(--bg-alt);color:var(--slate);}
.badge--win{background:rgba(37,99,235,.1);color:#2563EB;}
.badge--gpu{background:var(--jade-soft);color:var(--jade-deep);}

/* inline mini bar in table cells */
.cellbar{display:flex;align-items:center;gap:9px;justify-content:flex-end;}
.cellbar__track{width:64px;height:6px;border-radius:4px;background:var(--bg-alt);overflow:hidden;flex:none;}
.cellbar__fill{height:100%;background:var(--jade);border-radius:4px;}
.pctcell{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:600;font-size:12.5px;padding:3px 8px;border-radius:6px;}
.pct--red{background:var(--danger-soft);color:var(--danger);}
.pct--green{background:var(--green-soft);color:var(--green);}

/* =====================  MONEY CHART (3-bar)  ===================== */
.moneybars{display:flex;align-items:stretch;gap:clamp(18px,5vw,64px);height:300px;padding:36px 8px 0;}
.mbar{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;position:relative;max-width:160px;}
.mbar__plot{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;min-height:0;}
.mbar__col{width:100%;border-radius:0;position:relative;transition:height .6s var(--ease);min-height:6px;display:flex;align-items:flex-start;justify-content:center;}
.mbar__amt{position:absolute;top:-30px;font-size:17px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em;white-space:nowrap;}
.mbar__lbl{height:52px;margin-top:12px;text-align:center;}
.mbar__lbl .nm{font-size:13px;font-weight:600;}
.mbar__lbl .ds{font-size:11px;color:var(--faint);margin-top:3px;line-height:1.4;}
.col--owned{background:var(--slate);}
.col--static{background:var(--danger);}
.col--elastic{background:var(--jade);}
.mbar__col--stack{display:flex;flex-direction:column;background:none;}
.mbar__seg{width:100%;min-height:0;transition:height .6s var(--ease);}
.reslegend{display:flex;flex-wrap:wrap;gap:14px 20px;justify-content:center;margin-top:8px;}
.reslegend span{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);}
.reslegend .sw{width:11px;height:11px;border-radius:3px;flex:none;}
.savings-bracket{position:absolute;right:-8px;top:0;bottom:0;display:flex;align-items:center;}

/* =====================  SESSION STRIP  ===================== */
.sessions{display:flex;flex-direction:column;gap:5px;}
.sessrow{display:flex;align-items:center;gap:12px;}
.sessrow__day{font-family:var(--font-mono);font-size:10.5px;color:var(--faint);width:84px;flex:none;text-align:right;}
.sessrow__track{flex:1;height:18px;border-radius:5px;background:repeating-linear-gradient(90deg,#fff,#fff 1px,var(--bg-alt) 1px,var(--bg-alt));position:relative;overflow:hidden;border:1px solid var(--line);}
.sessrow__on{position:absolute;top:0;bottom:0;background:var(--jade);opacity:.85;border-radius:2px;}
.sessrow__hours{font-family:var(--font-mono);font-size:10.5px;color:var(--muted);width:58px;flex:none;text-align:right;}

/* =====================  PER-CORE GRID  ===================== */
.cores{display:grid;gap:3px;}
.corerow{display:flex;align-items:center;gap:10px;}
.corerow__lbl{font-family:var(--font-mono);font-size:10px;color:var(--faint);width:42px;flex:none;}
.corerow__cells{display:flex;gap:2px;flex:1;}
.corecell{flex:1;height:13px;border-radius:2px;min-width:1px;}

/* =====================  SPEC CARD  ===================== */
.spec{display:grid;grid-template-columns:1fr 1fr;gap:0 38px;}
.specrow{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line);}
.specrow .k{font-size:12.5px;color:var(--muted);font-weight:500;}
.specrow .v{font-size:13.5px;font-weight:600;text-align:right;font-family:var(--font-mono);font-variant-numeric:tabular-nums;}
.specrow input{font-family:var(--font-mono);font-size:13px;text-align:right;width:160px;border:1.5px solid var(--line-strong);border-radius:8px;padding:6px 9px;color:var(--ink);}
.specrow input:focus{outline:none;border-color:var(--jade);box-shadow:0 0 0 3px var(--jade-soft);}
@media (max-width:760px){.spec{grid-template-columns:1fr;}}

/* editable name */
.editname{display:inline-flex;align-items:center;gap:10px;}
.editname input{font-family:var(--font-display);font-size:clamp(26px,3.4vw,36px);font-weight:600;letter-spacing:-.03em;border:none;border-bottom:2px solid var(--jade);background:transparent;color:var(--ink);padding:0 0 2px;}
.editname input:focus{outline:none;}
.editname .pencil{opacity:0;transition:opacity .15s;}
.editname:hover .pencil{opacity:1;}

/* =====================  APP LIST  ===================== */
.applist{display:flex;flex-direction:column;gap:11px;}
.approw{display:flex;align-items:center;gap:12px;}
.approw__ico{width:30px;height:30px;border-radius:8px;flex:none;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:12px;font-weight:600;background:var(--bg-alt);color:var(--slate);}
.approw__body{flex:1;min-width:0;}
.approw__top{display:flex;justify-content:space-between;gap:10px;font-size:13px;}
.approw__nm{font-weight:600;}
.approw__time{font-family:var(--font-mono);color:var(--muted);font-size:12px;}
.approw__track{height:6px;border-radius:4px;background:var(--bg-alt);margin-top:6px;overflow:hidden;}
.approw__fill{height:100%;background:var(--jade);border-radius:4px;}

/* =====================  OVERLAY / MODAL  ===================== */
.overlay{position:fixed;inset:0;z-index:200;background:rgba(11,15,20,.42);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:flex;animation:fade .2s var(--ease);}
.overlay.center{align-items:center;justify-content:center;padding:24px;}
@keyframes fade{from{opacity:0;}to{opacity:1;}}
.panel{background:#fff;display:flex;flex-direction:column;box-shadow:var(--shadow-pop);}
.panel--modal{width:min(620px,100%);max-height:min(86vh,760px);border-radius:20px;overflow:hidden;animation:popIn .26s var(--ease);}
@keyframes popIn{from{opacity:0;transform:translateY(14px) scale(.98);}to{opacity:1;transform:none;}}
.panel__head{display:flex;align-items:flex-start;gap:16px;padding:24px 26px 18px;border-bottom:1px solid var(--line);}
.panel__titlewrap{flex:1;min-width:0;}
.panel__ey{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:7px;}
.panel__title{font-size:22px;font-weight:600;letter-spacing:-.025em;line-height:1.15;}
.panel__close{width:34px;height:34px;border-radius:9px;flex:none;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:20px;transition:background .15s,color .15s;}
.panel__close:hover{background:var(--bg-alt);color:var(--ink);}
.panel__body{padding:22px 26px;overflow-y:auto;flex:1;}
.panel__note{background:var(--amber-soft);color:#9a6206;border-radius:10px;padding:11px 14px;font-size:12.5px;line-height:1.5;margin-bottom:20px;display:flex;gap:10px;}
.panel__note svg{width:16px;height:16px;flex:none;stroke:var(--amber);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;margin-top:1px;}
.form{display:flex;flex-direction:column;gap:16px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{display:flex;flex-direction:column;gap:7px;}
.field label{font-size:12.5px;font-weight:600;color:var(--ink);}
.field input,.field select{font-size:14px;color:var(--ink);background:#fff;border:1.5px solid var(--line-strong);border-radius:10px;padding:10px 13px;transition:border-color .2s,box-shadow .2s;width:100%;}
.field input:focus,.field select:focus{outline:none;border-color:var(--jade);box-shadow:0 0 0 4px var(--jade-soft);}
.field__hint{font-size:11.5px;color:var(--faint);}
.field--disabled{opacity:.55;}
.form__foot{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:18px 26px;border-top:1px solid var(--line);background:var(--bg-alt);}

/* assumptions modal extras */
.fsec{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:24px 0 13px;display:flex;align-items:center;gap:9px;}
.fsec:first-child{margin-top:0;}
.fsec::after{content:"";flex:1;height:1px;background:var(--line);}
.meth{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px;}
.meth__card{border:1px solid var(--line);border-radius:12px;padding:14px 15px;background:var(--bg-alt);}
.meth__tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 9px;border-radius:999px;margin-bottom:9px;}
.meth__tag--static{background:#FDECEC;color:var(--danger);}
.meth__tag--elastic{background:var(--jade-soft);color:var(--jade-deep);}
.meth__card p{font-size:12px;line-height:1.55;color:var(--muted);margin:0;}
.meth__card b{color:var(--ink);font-weight:600;}
.fpreview{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px;}
.fpreview__cell{border:1px solid var(--line);border-radius:12px;padding:13px 14px;text-align:center;}
.fpreview__k{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);font-weight:600;}
.fpreview__v{font-size:21px;font-weight:700;margin-top:6px;font-family:var(--font-mono);letter-spacing:-.02em;}

/* =====================  EMPTY / LOADING  ===================== */
.empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:80px 30px;}
.empty__mark{width:74px;height:74px;border-radius:18px;background:var(--bg-alt);display:flex;align-items:center;justify-content:center;margin-bottom:22px;}
.empty__mark img{width:42px;height:42px;}
.empty__title{font-size:19px;font-weight:600;letter-spacing:-.02em;}
.empty__sub{margin-top:8px;font-size:14px;color:var(--muted);max-width:42ch;line-height:1.6;}
.empty__cta{margin-top:22px;}

.skel{background:linear-gradient(90deg,var(--bg-alt) 25%,#eef1f6 37%,var(--bg-alt) 63%);background-size:400% 100%;animation:shimmer 1.3s infinite;border-radius:8px;}
@keyframes shimmer{0%{background-position:100% 0;}100%{background-position:-100% 0;}}
.loadnote{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12px;color:var(--muted);}
.spinner{width:15px;height:15px;border:2px solid var(--line-strong);border-top-color:var(--jade);border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* =====================  TOASTS  ===================== */
.toasts{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);z-index:400;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none;}
.toast{display:flex;align-items:center;gap:11px;background:var(--obsidian);color:#fff;padding:12px 18px 12px 14px;border-radius:12px;font-size:14px;font-weight:500;box-shadow:var(--shadow-pop);animation:toastIn .3s var(--ease);}
.toast .tic{width:22px;height:22px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;background:var(--jade-soft);}
.toast .tic svg{width:13px;height:13px;stroke:var(--jade);stroke-width:2.6;fill:none;stroke-linecap:round;stroke-linejoin:round;}
@keyframes toastIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

/* =====================  RESPONSIVE  ===================== */
@media (max-width:760px){
  .controls{position:static;}
  .moneybars{gap:14px;}
  .navtabs{display:none;}
  .spec{grid-template-columns:1fr;}
}
