:root{
  --ink:        #0a0a0a;
  --ink-soft:   #1a1a1a;
  --steel:      #4a5562;
  --steel-2:    #6b7480;
  --steel-3:    #c9cdd3;
  --steel-4:    #e6e7ea;
  --royal:      #1d3fb5;
  --royal-deep: #15308a;
  --paper:      #f7f5ef;
  --paper-2:    #efece4;
  --good:       #1f7a4a;
  --bad:        #a8341f;

  --serif: "Newsreader", "Times New Roman", Times, serif;
  --sans:  "Geist", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --mono:  "Geist Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }

.shell{ max-width:1320px; margin:0 auto; padding:0 56px; }
@media (max-width:820px){ .shell{ padding:0 22px; } }

.rule{ border:0; border-top:1px solid var(--steel-3); margin:0; }
.rule-ink{ border:0; border-top:1px solid var(--ink); margin:0; }
.rule-soft{ border:0; border-top:1px solid var(--steel-4); margin:0; }

/* ---------- top bar ---------- */
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 0; gap:24px; flex-wrap:wrap;
}
.brand{
  display:flex; align-items:baseline; gap:14px;
}
.wordmark{
  font-family:var(--serif);
  font-weight:400;
  font-size:30px;
  line-height:1;
  letter-spacing:-0.02em;
  color:var(--ink);
}
.wordmark .dot{ color:var(--royal); }
.wordmark .it{ font-style:italic; }
.brand .sub{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--steel-2);
}
.topbar-right{ display:flex; align-items:center; gap:18px; }
.status-chip{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--steel);
  border:1px solid var(--steel-3);
  padding:7px 12px;
}
.status-chip .led{ width:7px; height:7px; border-radius:50%; background:var(--steel-2); }
.status-chip.is-live .led{ background:var(--good); }
.status-chip.is-demo .led{ background:var(--royal); }
.iconbtn{
  appearance:none; border:1px solid var(--steel-3); background:transparent;
  cursor:pointer; padding:8px 14px;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink); transition: all .18s ease;
}
.iconbtn:hover{ border-color:var(--royal); color:var(--royal); }
.iconbtn.solid{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.iconbtn.solid:hover{ background:var(--royal); border-color:var(--royal); color:var(--paper); }

/* ---------- masthead row ---------- */
.head{
  display:flex; align-items:flex-end; justify-content:space-between;
  padding:30px 0 20px; gap:24px; flex-wrap:wrap;
}
.head .title{
  font-family:var(--serif);
  font-weight:400;
  font-size:52px;
  line-height:1;
  letter-spacing:-0.02em;
  margin:0;
}
.head .title em{ font-style:italic; color:var(--royal); }
.head .meta{
  text-align:right;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.06em;
  color:var(--steel-2);
  text-transform:uppercase;
  line-height:1.7;
}
.head .meta .greet{ color:var(--ink); }

/* ---------- KPI strip ---------- */
.kpis{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
  margin:0 0 40px;
}
.kpi{ padding:20px 24px; border-left:1px solid var(--steel-4); }
.kpi:first-child{ border-left:0; padding-left:0; }
.kpi .n{
  font-family:var(--serif);
  font-size:40px; line-height:1;
  letter-spacing:-0.01em; color:var(--ink);
}
.kpi .n em{ font-style:italic; color:var(--royal); }
.kpi .n .u{ font-family:var(--mono); font-size:15px; color:var(--steel-2); margin-left:4px; }
.kpi .l{
  margin-top:9px;
  font-family:var(--mono);
  font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-2);
}
.kpi .d{ font-size:11px; margin-top:3px; color:var(--steel); font-family:var(--sans); letter-spacing:0; text-transform:none; }
.kpi .d.up{ color:var(--good); }
.kpi .d.dn{ color:var(--bad); }
@media (max-width:820px){
  .kpis{ grid-template-columns: repeat(2,1fr); }
  .kpi{ padding:16px 14px; }
  .kpi:nth-child(3){ border-left:0; padding-left:0; }
}

/* ---------- main grid ---------- */
.dash{
  display:grid;
  grid-template-columns: 1.55fr 1fr;
  gap:56px;
  padding-bottom:80px;
}
@media (max-width:980px){ .dash{ grid-template-columns:1fr; gap:44px; } }

.section-hd{
  display:flex; align-items:baseline; justify-content:space-between;
  margin-bottom:18px; gap:18px;
}
.section-hd .t{
  font-family:var(--serif);
  font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink);
}
.section-hd .t::before{ content:"§ "; color:var(--royal); font-style:italic; }
.section-hd .a{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-2);
}

/* ---------- task list ---------- */
.group{ margin-bottom:30px; border-top:2px solid var(--ink); }
.group-hd{
  display:flex; align-items:baseline; justify-content:space-between;
  padding:12px 0 10px; gap:14px;
}
.group-hd .gname{
  font-family:var(--serif); font-size:22px; letter-spacing:-0.01em; color:var(--ink);
}
.group-hd .gmeta{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--steel-2);
  display:flex; align-items:center; gap:12px;
}
.gbar{ width:90px; height:4px; background:var(--steel-4); position:relative; }
.gbar > i{ position:absolute; inset:0 auto 0 0; background:var(--royal); }

.task{
  display:grid;
  grid-template-columns: 20px 1fr auto;
  gap:14px; align-items:start;
  padding:12px 0;
  border-bottom:1px solid var(--steel-4);
}
.task .mark{
  width:16px; height:16px; border:1px solid var(--steel); border-radius:50%;
  margin-top:3px; display:inline-flex; align-items:center; justify-content:center; flex:0 0 16px;
}
.task.done .mark{ background:var(--royal); border-color:var(--royal); }
.task.done .mark::after{
  content:""; width:7px; height:4px;
  border-left:1.5px solid var(--paper); border-bottom:1.5px solid var(--paper);
  transform: translateY(-1px) rotate(-45deg);
}
.task.overdue .mark{ border-color:var(--bad); }
.task .body .tt{
  font-family:var(--serif); font-size:18px; line-height:1.3; color:var(--ink);
}
.task.done .body .tt{ color:var(--steel-2); text-decoration:line-through; text-decoration-color:var(--steel-3); }
.task .body .nn{
  font-size:13px; color:var(--steel); margin-top:3px; line-height:1.4;
}
.task .side{
  text-align:right; display:flex; flex-direction:column; gap:5px; align-items:flex-end;
}
.tag{
  font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--steel-2);
  white-space:nowrap;
}
.tag.due{ color:var(--steel); }
.tag.due.over{ color:var(--bad); }
.tag.est{ color:var(--royal); }
.empty{
  font-family:var(--serif); font-style:italic; color:var(--steel-2); padding:18px 0; font-size:16px;
}

/* ---------- metrics panel ---------- */
.panel{ position:sticky; top:18px; align-self:start; }
.card{ border-top:1px solid var(--ink); padding:20px 0 24px; }
.card:first-child{ border-top:2px solid var(--ink); }
.card .ch{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--steel-2);
  margin-bottom:14px; display:flex; align-items:baseline; justify-content:space-between; gap:12px;
}
.card .ch .seg{ display:inline-flex; gap:2px; }
.seg button{
  appearance:none; border:1px solid var(--steel-3); background:transparent; cursor:pointer;
  font-family:var(--mono); font-size:10px; letter-spacing:.06em; padding:4px 9px; color:var(--steel);
}
.seg button.on{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* rings */
.rings{ display:flex; gap:28px; align-items:center; }
.ring{ display:flex; flex-direction:column; align-items:center; gap:8px; }
.ring svg{ display:block; }
.ring .rl{
  font-family:var(--mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-2);
}
.ring .rv{ font-family:var(--serif); font-size:13px; color:var(--ink); }

/* split bar (overdue vs ontime) */
.split{ margin-top:4px; }
.split .bar{ display:flex; height:34px; border:1px solid var(--ink); overflow:hidden; }
.split .bar .seg-on{ background:var(--paper-2); }
.split .bar .seg-over{ background:var(--bad); }
.split .legend{ display:flex; justify-content:space-between; margin-top:10px; }
.split .legend div{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--steel-2); }
.split .legend .v{ font-family:var(--serif); font-size:20px; color:var(--ink); display:block; margin-top:2px; }
.split .legend .v.bad{ color:var(--bad); }

/* streak */
.streak{ display:flex; align-items:center; gap:18px; }
.streak .big{ font-family:var(--serif); font-size:56px; line-height:.9; color:var(--royal); font-style:italic; }
.streak .big .u{ font-style:normal; font-family:var(--mono); font-size:16px; color:var(--steel-2); margin-left:4px; }
.streak .dots{ display:flex; gap:5px; flex-wrap:wrap; max-width:200px; }
.streak .dots i{ width:13px; height:13px; border:1px solid var(--steel-3); background:var(--paper); }
.streak .dots i.on{ background:var(--royal); border-color:var(--royal); }
.streak .cap{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--steel-2); margin-top:8px; }

/* trend chart */
.trend svg{ width:100%; height:auto; display:block; }
.trend .axis{ display:flex; justify-content:space-between; margin-top:8px; }
.trend .axis span{ font-family:var(--mono); font-size:9px; letter-spacing:.04em; color:var(--steel-2); }

/* time est vs done */
.timebars{ display:flex; flex-direction:column; gap:14px; }
.timebar .tl{ display:flex; justify-content:space-between; font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--steel-2); margin-bottom:6px; }
.timebar .tl b{ font-family:var(--serif); font-size:16px; color:var(--ink); font-weight:400; letter-spacing:0; text-transform:none; }
.timebar .track{ height:14px; background:var(--steel-4); position:relative; }
.timebar .track > i{ position:absolute; inset:0 auto 0 0; }
.timebar .track > i.done{ background:var(--royal); }
.timebar .track > i.est{ background:var(--ink); }
.note{ font-size:11.5px; color:var(--steel); line-height:1.5; margin-top:14px; font-family:var(--sans); }
.note code{ font-family:var(--mono); font-size:11px; background:var(--paper-2); padding:1px 5px; color:var(--royal); }

/* per-list bars */
.listbars{ display:flex; flex-direction:column; gap:14px; }
.listbar .ll{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; }
.listbar .ll .nm{ font-family:var(--serif); font-size:17px; color:var(--ink); }
.listbar .ll .pc{ font-family:var(--mono); font-size:11px; color:var(--steel); }
.listbar .track{ height:8px; background:var(--steel-4); position:relative; }
.listbar .track > i{ position:absolute; inset:0 auto 0 0; background:var(--royal); }
.listbar .sub{ font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--steel-2); margin-top:5px; }

/* ---------- footer ---------- */
.foot{
  border-top:1px solid var(--ink); padding:26px 0 60px;
  display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap;
  font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-2);
}

/* ---------- connect overlay ---------- */
.overlay{
  position:fixed; inset:0; background:rgba(10,10,10,.5);
  display:none; align-items:center; justify-content:center; padding:24px; z-index:100;
}
.overlay.open{ display:flex; }
.modal{
  background:var(--paper); max-width:560px; width:100%; padding:40px;
  border:1px solid var(--ink); box-shadow:0 30px 80px rgba(10,10,10,.25);
  max-height:90vh; overflow:auto;
}
.modal h3{
  font-family:var(--serif); font-weight:400; font-size:30px; letter-spacing:-0.01em; margin:0 0 6px;
}
.modal h3 em{ font-style:italic; color:var(--royal); }
.modal .lead{ font-family:var(--serif); font-size:16px; color:var(--steel); margin:0 0 22px; line-height:1.5; }
.modal ol{ margin:0 0 22px; padding-left:20px; color:var(--ink); font-size:13.5px; line-height:1.6; }
.modal ol code{ font-family:var(--mono); font-size:12px; background:var(--paper-2); padding:1px 5px; color:var(--royal); word-break:break-all; }
.modal .field{ display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.modal label{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--steel-2); }
.modal input{
  appearance:none; border:0; border-bottom:1px solid var(--steel-3); background:transparent;
  padding:8px 0 9px; font-family:var(--mono); font-size:13px; color:var(--ink); outline:none; border-radius:0;
  transition:border-color .2s ease;
}
.modal input:focus{ border-color:var(--royal); }
.modal .actions{ display:flex; gap:12px; align-items:center; margin-top:24px; flex-wrap:wrap; }
.modal .err{ color:var(--bad); font-size:12.5px; margin-top:12px; font-family:var(--sans); min-height:1em; }
.modal .x{
  position:absolute; top:18px; right:20px; cursor:pointer; font-family:var(--mono); font-size:14px; color:var(--steel-2);
  background:none; border:0;
}
.modal-wrap{ position:relative; }
.muted{ color:var(--steel-2); font-size:11.5px; font-family:var(--sans); }

/* env block banner inside modal */
.env-banner{
  border:1px solid var(--bad);
  border-left-width:3px;
  background:#fbf0ed;
  padding:14px 16px;
  margin:0 0 22px;
  font-size:13px;
  line-height:1.5;
  color:var(--ink);
}
.env-banner strong{ display:block; font-family:var(--serif); font-size:16px; margin-bottom:4px; color:var(--bad); }
.env-banner code{ font-family:var(--mono); font-size:11.5px; background:#fff; padding:1px 5px; color:var(--royal); }
.env-banner .env-actions{ margin:12px 0 6px; display:flex; gap:10px; flex-wrap:wrap; }
.env-banner .env-steps{ display:block; margin-top:8px; font-size:11.5px; color:var(--steel); }
.env-banner .env-steps em{ font-style:normal; font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--steel-2); }

/* settings controls */
.set-row{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:18px 0;
}
.set-label .set-t{ font-family:var(--serif); font-size:18px; color:var(--ink); }
.set-label .set-d{ font-size:12.5px; color:var(--steel); line-height:1.4; margin-top:3px; max-width:42ch; }

.seg-toggle{ display:inline-flex; border:1px solid var(--steel-3); flex:0 0 auto; }
.seg-toggle button{
  appearance:none; background:transparent; border:0; cursor:pointer;
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--steel); padding:9px 16px; transition: all .15s ease; white-space:nowrap;
}
.seg-toggle button + button{ border-left:1px solid var(--steel-3); }
.seg-toggle button.on{ background:var(--ink); color:var(--paper); }

.switch{
  appearance:none; border:1px solid var(--steel-3); background:var(--paper-2);
  width:52px; height:28px; border-radius:0; position:relative; cursor:pointer; flex:0 0 auto;
  transition: background .18s ease, border-color .18s ease; padding:0;
}
.switch .knob{
  position:absolute; top:2px; left:2px; width:22px; height:22px; background:var(--steel-2);
  transition: transform .18s ease, background .18s ease;
}
.switch.on{ background:var(--royal); border-color:var(--royal); }
.switch.on .knob{ transform: translateX(24px); background:var(--paper); }

.set-input{
  appearance:none; border:0; border-bottom:1px solid var(--steel-3); background:transparent;
  padding:8px 0 9px; font-family:var(--sans); font-size:15px; color:var(--ink); outline:none;
  border-radius:0; min-width:180px; text-align:right; transition:border-color .2s ease;
}
.set-input:focus{ border-color:var(--royal); }

/* group header — date mode */
.gname.is-over{ color:var(--bad); }
.gbar-est{ font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; color:var(--royal); text-transform:uppercase; }

.loading{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--steel-2); padding:40px 0; text-align:center; }
