/* ============ THEME TOKENS ============ */
:root{
  --bg:#e9eef2; --bg-grad:#dfe6ec;
  --panel:#ffffff; --panel-2:#f5f8fa; --panel-3:#eef2f6;
  --text:#0f1b2d; --muted:#5b6b80; --faint:#8b99ad;
  --border:#dde4ec; --border-2:#e8edf2;
  --brand:#059669; --brand-d:#047857; --brand-l:#d9f3e8; --brand-ll:#ecfaf4;
  --shadow:0 1px 2px rgba(15,27,45,.05),0 8px 24px -12px rgba(15,27,45,.18);
  --shadow-sm:0 1px 2px rgba(15,27,45,.06);
  --track:#e6ebf1;
  --ring-track:#e3e9ef;
}
html[data-theme="dark"]{
  --bg:#0a1019; --bg-grad:#0e1622;
  --panel:#141d2b; --panel-2:#1a2536; --panel-3:#1f2c40;
  --text:#e7edf5; --muted:#9aabc0; --faint:#6c7d93;
  --border:#28344a; --border-2:#222d40;
  --brand:#10b981; --brand-d:#34d399; --brand-l:#0c3a2c; --brand-ll:#10271f;
  --shadow:0 1px 2px rgba(0,0,0,.4),0 12px 30px -14px rgba(0,0,0,.7);
  --shadow-sm:0 1px 2px rgba(0,0,0,.35);
  --track:#283449;
  --ring-track:#283449;
}
.ph-define   {--pc:#0284c7;--pcl:#e0f2fe}
.ph-measure  {--pc:#4f46e5;--pcl:#e6e7fc}
.ph-analyze  {--pc:#d97706;--pcl:#fdedd3}
.ph-improve  {--pc:#059669;--pcl:#d9f3e8}
.ph-control  {--pc:#7c3aed;--pcl:#eee4fd}
.ph-replicate{--pc:#db2777;--pcl:#fbe0ee}
html[data-theme="dark"] .ph-define   {--pcl:#0b2c3d}
html[data-theme="dark"] .ph-measure  {--pcl:#1d1d4a}
html[data-theme="dark"] .ph-analyze  {--pcl:#3a2708}
html[data-theme="dark"] .ph-improve  {--pcl:#0c3a2c}
html[data-theme="dark"] .ph-control  {--pcl:#291245}
html[data-theme="dark"] .ph-replicate{--pcl:#3d0f29}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:linear-gradient(180deg,var(--bg),var(--bg-grad));
  color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5;min-height:100%;
}
a{color:inherit}
::selection{background:var(--brand);color:#fff}

header.top{
  position:sticky;top:0;z-index:50;
  background:var(--panel);border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.top-inner{
  max-width:1240px;margin:0 auto;padding:12px 22px;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.logo{
  width:44px;height:44px;border-radius:13px;flex-shrink:0;
  background:linear-gradient(150deg,var(--brand),var(--brand-d));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:24px;font-weight:700;
  box-shadow:0 6px 16px -6px var(--brand);
}
.brand h1{font-size:18px;font-weight:800;letter-spacing:-.3px;line-height:1.15}
.brand .sub{font-size:11.5px;color:var(--muted);font-weight:600;letter-spacing:.3px;text-transform:uppercase}
.save-status{font-size:11px;color:var(--faint);font-weight:600;margin-top:2px}
.top-actions{display:flex;gap:8px;flex-wrap:wrap}
.btn{
  border:1px solid var(--border);background:var(--panel-2);color:var(--text);
  font-size:12.5px;font-weight:650;padding:8px 13px;border-radius:9px;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;transition:.15s;white-space:nowrap;
}
.btn:hover{background:var(--panel-3);border-color:var(--faint)}
.btn.brand{background:var(--brand);border-color:var(--brand);color:#fff}
.btn.brand:hover{background:var(--brand-d)}
.btn.btn-danger{background:#e11d48;border-color:#e11d48;color:#fff}
.btn.btn-danger:hover{background:#be123c;border-color:#be123c}
.btn.icon{padding:8px 10px}

.wrap{max-width:1240px;margin:0 auto;padding:22px}
.ventures{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.venture{
  border:1.5px solid var(--border);background:var(--panel);color:var(--muted);
  padding:9px 15px;border-radius:11px;cursor:pointer;font-size:13px;font-weight:700;
  transition:.15s;display:flex;flex-direction:column;gap:1px;line-height:1.25;
}
.venture small{font-size:10px;font-weight:600;color:var(--faint);text-transform:none}
.venture:hover{border-color:var(--vc, var(--brand));color:var(--text)}
.venture.active{
  border-color:var(--vc, var(--brand));background:var(--vc, var(--brand));color:#fff;
  box-shadow:0 8px 18px -8px var(--vc, var(--brand));
}
.venture.active small{color:rgba(255,255,255,.85)}

/* Per-startup colors (venture buttons + task code chips) */
.venture[data-pid="svlms"], #board[data-project="svlms"]     { --vc:#2563eb; --vcd:#1e40af; --vcl:#dbeafe; }
.venture[data-pid="banks4all"], #board[data-project="banks4all"] { --vc:#0891b2; --vcd:#0e7490; --vcl:#cffafe; }
.venture[data-pid="easycasa"], #board[data-project="easycasa"]  { --vc:#ea580c; --vcd:#c2410c; --vcl:#ffedd5; }
.venture[data-pid="mundida"], #board[data-project="mundida"]   { --vc:#db2777; --vcd:#be185d; --vcl:#fce7f3; }
.venture[data-pid="chaskies"], #board[data-project="chaskies"]   { --vc:#059669; --vcd:#047857; --vcl:#d1fae5; }
.venture[data-pid="tamia"], #board[data-project="tamia"]         { --vc:#7c3aed; --vcd:#6d28d9; --vcl:#ede9fe; }
html[data-theme="dark"] .venture[data-pid="svlms"], html[data-theme="dark"] #board[data-project="svlms"]         { --vcd:#93c5fd; --vcl:#1e3a5f; }
html[data-theme="dark"] .venture[data-pid="banks4all"], html[data-theme="dark"] #board[data-project="banks4all"] { --vcd:#67e8f9; --vcl:#164e63; }
html[data-theme="dark"] .venture[data-pid="easycasa"], html[data-theme="dark"] #board[data-project="easycasa"]  { --vcd:#fdba74; --vcl:#431407; }
html[data-theme="dark"] .venture[data-pid="mundida"], html[data-theme="dark"] #board[data-project="mundida"]    { --vcd:#f9a8d4; --vcl:#500724; }
html[data-theme="dark"] .venture[data-pid="chaskies"], html[data-theme="dark"] #board[data-project="chaskies"]  { --vcd:#6ee7b7; --vcl:#064e3b; }
html[data-theme="dark"] .venture[data-pid="tamia"], html[data-theme="dark"] #board[data-project="tamia"]        { --vcd:#c4b5fd; --vcl:#2e1065; }

.dash{display:grid;grid-template-columns:248px 1fr 360px;gap:16px;margin-bottom:18px}
.card{
  background:var(--panel);border:1px solid var(--border);border-radius:16px;
  box-shadow:var(--shadow);padding:18px;
}
.card-h{font-size:11px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:var(--faint);margin-bottom:12px}
.overall{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.donut{position:relative;width:150px;height:150px}
.donut svg{transform:rotate(-90deg)}
.donut .mid{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
}
.donut .pct{font-size:34px;font-weight:850;letter-spacing:-1px}
.donut .lbl{font-size:10px;font-weight:700;color:var(--faint);text-transform:uppercase;letter-spacing:.5px}
.overall .vname{margin-top:12px;font-size:14.5px;font-weight:800}
.overall .vtag{font-size:11.5px;color:var(--muted)}
.stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;align-content:start}
.stat{
  background:var(--panel-2);border:1px solid var(--border-2);border-radius:12px;
  padding:12px 13px;cursor:pointer;transition:.15s;
}
.stat:hover{border-color:var(--faint)}
.stat.on{border-color:var(--brand);background:var(--brand-ll)}
.stat .n{font-size:24px;font-weight:850;letter-spacing:-.5px}
.stat .t{font-size:11px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:5px}
.sdot{width:9px;height:9px;border-radius:50%;display:inline-block}
.s-done .sdot{background:var(--brand)}
.s-prog .sdot{background:#d97706}
.s-todo .sdot{background:var(--faint)}
.s-appr .sdot{background:#059669}
.s-urg .sdot{background:#e11d48}
.s-top .sdot{background:#7c3aed}
.s-done .n{color:var(--brand)}
.s-appr .n{color:#059669}
.s-urg .n{color:#e11d48}
.s-top .n{color:#7c3aed}
.ring-card{display:flex;flex-direction:column}
.kring{position:relative;width:320px;height:320px;margin:2px auto 0}
.kring .orbit{
  position:absolute;left:50%;top:50%;width:236px;height:236px;
  transform:translate(-50%,-50%);border:2px dashed var(--border);border-radius:50%;
}
.kring .core{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:118px;height:118px;border-radius:50%;
  background:var(--panel-2);border:1px solid var(--border);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
}
.kring .core .ko{font-size:30px;font-weight:850;letter-spacing:-1px;color:var(--brand)}
.kring .core .kl{font-size:8.5px;font-weight:800;letter-spacing:.9px;color:var(--faint);text-transform:uppercase}
.knode{position:absolute;width:92px;height:92px;cursor:pointer}
.knode .disc{
  width:62px;height:62px;border-radius:50%;margin:0 auto;
  display:flex;align-items:center;justify-content:center;
  position:relative;transition:.15s;
}
.knode .disc::after{
  content:"";position:absolute;inset:6px;border-radius:50%;
  background:var(--panel);
}
.knode .gl{position:relative;z-index:1;font-size:19px;font-weight:850;color:var(--pc)}
.knode .kt{text-align:center;font-size:9.5px;font-weight:800;margin-top:3px;letter-spacing:.2px}
.knode .kp{text-align:center;font-size:10px;font-weight:800;color:var(--pc)}
.knode:hover .disc{transform:scale(1.07)}

.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.seg{display:flex;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:3px}
.seg button{
  border:0;background:transparent;color:var(--muted);font-size:12.5px;font-weight:700;
  padding:7px 14px;border-radius:7px;cursor:pointer;transition:.15s;
}
.seg button.on{background:var(--brand);color:#fff;box-shadow:var(--shadow-sm)}
.field{
  display:flex;align-items:center;gap:7px;background:var(--panel);
  border:1px solid var(--border);border-radius:10px;padding:0 11px;
}
.field input,.field select{
  border:0;background:transparent;color:var(--text);font-size:13px;
  padding:9px 0;outline:none;font-family:inherit;
}
.field input{width:190px}
.field select{cursor:pointer;font-weight:650;padding-right:4px}
.field .ic{color:var(--faint);font-size:13px}
.grow{margin-left:auto;font-size:12px;color:var(--muted);font-weight:600}

.group-h{
  font-size:12px;font-weight:850;letter-spacing:.6px;text-transform:uppercase;
  color:var(--faint);margin:6px 2px 11px;display:flex;align-items:center;gap:8px;
}
.group-h::after{content:"";flex:1;height:1px;background:var(--border)}
.sect{
  background:var(--panel);border:1px solid var(--border);border-radius:14px;
  margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow-sm);
}
.sect-h{
  display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;
  user-select:none;transition:.12s;
}
.sect-h:hover{background:var(--panel-2)}
.sect-ic{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:var(--panel-2);border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;font-size:18px;
}
.sect.phase .sect-ic{background:var(--pcl);border-color:transparent;color:var(--pc);font-weight:850;font-size:17px}
.sect-tt{flex:1;min-width:0}
.sect-tt .nm{font-size:14.5px;font-weight:800;letter-spacing:-.2px}
.sect-tt .ds{font-size:11.5px;color:var(--muted);margin-top:1px}
.sect-meta{display:flex;align-items:center;gap:14px;flex-shrink:0}
.mini-bar{width:120px;height:8px;background:var(--track);border-radius:99px;overflow:hidden}
.mini-bar i{display:block;height:100%;border-radius:99px;background:var(--brand);transition:width .35s}
.sect.phase .mini-bar i{background:var(--pc)}
.sect-pct{font-size:14px;font-weight:850;min-width:42px;text-align:right}
.sect-cnt{
  font-size:11px;font-weight:750;color:var(--muted);background:var(--panel-2);
  border:1px solid var(--border-2);padding:3px 8px;border-radius:99px;
}
.chev{color:var(--faint);font-size:13px;transition:.2s;width:14px;text-align:center}
.sect.collapsed .chev{transform:rotate(-90deg)}
.sect-body{border-top:1px solid var(--border)}
.sect.collapsed .sect-body{display:none}

.task{padding:13px 16px;border-bottom:1px solid var(--border-2)}
.task:last-child{border-bottom:0}
.task-top{display:flex;align-items:flex-start;gap:11px}
.t-complete{
  width:22px;height:22px;border-radius:7px;flex-shrink:0;margin-top:2px;
  border:2px solid var(--faint);background:var(--panel);cursor:pointer;padding:0;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;color:#fff;line-height:1;
}
.t-complete.on{background:var(--brand);border-color:var(--brand)}
.t-complete.on::after{content:"✓"}
.task.is-completed .t-title{text-decoration:line-through;opacity:.82}
.task.is-checked{box-shadow:inset 3px 0 0 #0284c7}
.dot{
  width:11px;height:11px;border-radius:50%;flex-shrink:0;margin-top:4px;
  border:2px solid var(--panel);box-shadow:0 0 0 1.5px var(--track);
}
.st-done .dot{background:var(--brand);box-shadow:0 0 0 1.5px var(--brand)}
.st-in-progress .dot{background:#d97706;box-shadow:0 0 0 1.5px #d97706}
.st-not-started .dot{background:var(--panel);box-shadow:0 0 0 1.5px var(--faint)}
.st-approved .dot{background:#059669;box-shadow:0 0 0 1.5px #059669}
.st-urgent .dot{background:#e11d48;box-shadow:0 0 0 1.5px #e11d48}
.st-top-priority .dot{background:#7c3aed;box-shadow:0 0 0 1.5px #7c3aed}
.t-info{flex:1;min-width:0}
.t-title{font-size:13.5px;font-weight:700;letter-spacing:-.1px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.t-title .num{color:var(--faint);font-weight:800;margin-right:5px}
.t-code{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:800;letter-spacing:.5px;
  padding:2px 6px;border-radius:6px;
  background:var(--vcl, var(--brand-l));color:var(--vcd, var(--brand-d));border:1px solid var(--vc, var(--brand));
}
.v-name{display:inline-flex;align-items:center;gap:6px}
.v-code{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:9.5px;font-weight:800;letter-spacing:.5px;
  padding:1px 5px;border-radius:5px;
  background:var(--vcl, var(--brand-l));color:var(--vcd, var(--brand-d));border:1px solid var(--vc, var(--brand));
}
.venture.active .v-code{background:rgba(255,255,255,.22);color:#fff;border-color:rgba(255,255,255,.5)}
.t-link{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:6px;
  background:var(--brand-ll);color:var(--brand-d);text-decoration:none;
  font-size:12px;font-weight:800;border:1px solid var(--brand-l);
}
.t-link:hover{background:var(--brand);color:#fff}
.t-link-edit{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:6px;border:1px solid var(--border);
  background:var(--panel-2);color:var(--muted);font-size:11px;cursor:pointer;
}
.t-link-edit:hover{border-color:var(--brand);color:var(--brand-d)}
.t-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:5px}
.badge{
  font-size:10px;font-weight:800;padding:3px 8px;border-radius:99px;
  letter-spacing:.2px;display:inline-flex;align-items:center;gap:4px;
}
.badge.phase{background:var(--pcl);color:var(--pc)}
.badge.sys{background:var(--panel-2);color:var(--muted);border:1px solid var(--border-2)}
.badge.own{background:transparent;color:var(--faint);font-weight:700}
.t-pct{font-size:15px;font-weight:850;min-width:46px;text-align:right;letter-spacing:-.5px}
.t-bar{height:7px;background:var(--track);border-radius:99px;overflow:hidden;margin:10px 0 0}
.t-bar i{display:block;height:100%;border-radius:99px;transition:width .25s}
.st-done .t-bar i{background:var(--brand)}
.st-in-progress .t-bar i{background:#d97706}
.st-approved .t-bar i{background:#059669}
.st-urgent .t-bar i{background:#e11d48}
.st-top-priority .t-bar i{background:#7c3aed}
.st-not-started .t-bar i{background:var(--faint)}
.t-ctrl{display:flex;align-items:center;gap:12px;margin-top:10px;flex-wrap:wrap}
input[type=range]{
  -webkit-appearance:none;appearance:none;height:6px;border-radius:99px;
  background:var(--track);flex:1;min-width:160px;cursor:pointer;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--brand);border:3px solid var(--panel);
  box-shadow:0 1px 4px rgba(0,0,0,.3);cursor:pointer;
}
input[type=range]::-moz-range-thumb{
  width:15px;height:15px;border-radius:50%;background:var(--brand);
  border:3px solid var(--panel);cursor:pointer;
}
.tbtn{
  border:1px solid var(--border);background:var(--panel-2);color:var(--muted);
  font-size:11px;font-weight:750;padding:6px 11px;border-radius:8px;cursor:pointer;transition:.13s;
}
.tbtn:hover{border-color:var(--faint);color:var(--text)}
.tbtn.on-appr{background:#d9f3e8;border-color:#059669;color:#047857}
.tbtn.on-urg{background:#fde7ec;border-color:#f3a9b9;color:#c2123c}
html[data-theme="dark"] .tbtn.on-urg{background:#3a0f1c;border-color:#7a2238;color:#ff8aa3}
.tbtn.on-top{background:#ede9fe;border-color:#c4b5fd;color:#6d28d9}
html[data-theme="dark"] .tbtn.on-top{background:#2e1065;border-color:#5b21b6;color:#c4b5fd}
.tbtn.on-note{background:var(--brand-ll);border-color:var(--brand);color:var(--brand-d)}
.tbtn.on-link{background:var(--brand-ll);border-color:var(--brand);color:var(--brand-d)}
.tbtn.on-check{background:#e0f2fe;border-color:#0284c7;color:#0369a1}
.tbtn.on-tocheck{background:#fff7ed;border-color:#fdba74;color:#c2410c}
html[data-theme="dark"] .tbtn.on-check{background:#0c4a6e;border-color:#0284c7;color:#7dd3fc}
html[data-theme="dark"] .tbtn.on-tocheck{background:#431407;border-color:#c2410c;color:#fdba74}
.tbtn.on-done{background:var(--brand-l);border-color:var(--brand);color:var(--brand-d)}
.badge.check{background:#e0f2fe;color:#0369a1}
.badge.to-check{background:#fff7ed;color:#c2410c}
.badge.done{background:var(--brand-l);color:var(--brand-d)}
html[data-theme="dark"] .badge.check{background:#0c4a6e;color:#7dd3fc}
html[data-theme="dark"] .badge.to-check{background:#431407;color:#fdba74}
.tbtn.tbtn-del{margin-left:auto;color:#be123c;border-color:#fecdd3;background:#fff1f2}
html[data-theme="dark"] .tbtn.tbtn-del{background:#3f0d19;border-color:#7f1d35;color:#fda4af}
.tbtn.tbtn-del:hover{border-color:#f43f5e;color:#be123c}
.modal select.inp{width:100%;cursor:pointer}
.controls .btn.brand{flex-shrink:0}

.t-extra{display:none;margin-top:11px;gap:10px;flex-direction:column}
.task.open .t-extra{display:flex}
.t-extra-panel{display:none;flex-direction:column;gap:10px}
.task.show-link .t-extra-link{display:flex}
.task.show-notes .t-extra-notes{display:flex}
.t-extra-actions{display:flex;gap:8px;flex-wrap:wrap}
.t-file-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.t-file-name{font-size:12px;color:var(--muted);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.t-file-name.has-file{color:var(--brand-d);font-weight:600}
.t-link-status{
  font-size:12px;font-weight:600;padding:8px 10px;border-radius:8px;
  background:var(--panel-2);border:1px solid var(--border);color:var(--muted);
}
.t-link-status.saved{background:var(--brand-ll);border-color:var(--brand);color:var(--brand-d)}
.t-link-status.unsaved{background:#fef3c7;border-color:#f59e0b;color:#92400e}
[data-theme="dark"] .t-link-status.unsaved{background:#422006;border-color:#b45309;color:#fcd34d}
.tbtn:disabled{opacity:.45;cursor:not-allowed}
.t-extra .row{display:flex;gap:10px;flex-wrap:wrap}
.inp{
  border:1px solid var(--border);background:var(--panel-2);color:var(--text);
  border-radius:9px;padding:8px 11px;font-size:12.5px;font-family:inherit;outline:none;
}
.inp:focus{border-color:var(--brand)}
.inp.owner{width:170px}
.inp.link{flex:1;min-width:220px}
textarea.inp{width:100%;resize:vertical;min-height:62px;line-height:1.5}
.lab{font-size:10.5px;font-weight:800;color:var(--faint);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;display:block}

.empty{
  text-align:center;padding:54px 20px;color:var(--muted);
  background:var(--panel);border:1px dashed var(--border);border-radius:14px;
}
.empty .big{font-size:30px;margin-bottom:8px}
footer{
  max-width:1240px;margin:8px auto 0;padding:20px 22px 40px;
  color:var(--faint);font-size:11.5px;text-align:center;line-height:1.7;
}
footer b{color:var(--muted)}
footer .heart{color:#e11d48}
.legend{display:flex;gap:13px;flex-wrap:wrap;justify-content:center;margin-top:12px}
.legend span{font-size:10.5px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:5px}
.legend i{width:9px;height:9px;border-radius:3px;display:inline-block}
.toast{
  position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--text);color:var(--bg);font-size:12.5px;font-weight:700;
  padding:11px 20px;border-radius:10px;box-shadow:var(--shadow);
  opacity:0;transition:.25s;pointer-events:none;z-index:99;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.modal-backdrop{
  position:fixed;inset:0;background:rgba(15,27,45,.45);z-index:80;
  display:none;align-items:center;justify-content:center;padding:20px;
}
.modal-backdrop.open{display:flex}
body.modal-open{overflow:hidden}
.modal{
  background:var(--panel);border:1px solid var(--border);border-radius:16px;
  box-shadow:var(--shadow);width:100%;max-width:480px;padding:22px;
}
.modal h2{font-size:17px;font-weight:800;margin-bottom:8px}
.modal p{font-size:13px;color:var(--muted);margin-bottom:14px;line-height:1.55}
.modal .row{margin-bottom:12px}
.modal .actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}

@media(max-width:1080px){
  .dash{grid-template-columns:1fr 1fr}
  .ring-card{grid-column:1/-1}
  .kring{margin-top:8px}
}
.task.open{box-shadow:inset 0 0 0 1px var(--brand-l)}
.task[data-uid^="custom__"] .t-title{font-style:normal}

@media(max-width:680px){
  .wrap{padding:16px}
  .top-inner{padding:11px 16px}
  .dash{grid-template-columns:1fr}
  .brand h1{font-size:16px}
  .field input{width:130px}
  .ventures{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    margin-bottom:16px;
  }
  .venture{
    width:100%;
    min-height:58px;
    padding:10px 12px;
    align-items:center;
    justify-content:center;
    text-align:center;
  }
  .venture small{
    display:block;
    line-height:1.25;
    margin-top:2px;
  }
  .controls{gap:8px}
  .controls .btn.brand{width:100%;justify-content:center;order:10}
  .sect-tt .ds{display:none}
  .mini-bar{width:74px}
  .donut{width:128px;height:128px}
  .stats{
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
  }
  .stat{padding:10px 8px}
  .stat .n{font-size:20px}
  .stat .t{font-size:10px;line-height:1.25}
  .t-ctrl{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
    align-items:stretch;
  }
  .t-ctrl input[type=range]{
    grid-column:1 / -1;
    min-width:0;
    width:100%;
    margin-bottom:2px;
  }
  .tbtn{
    width:100%;
    min-height:34px;
    padding:7px 6px;
    font-size:10px;
    line-height:1.2;
    text-align:center;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  .tbtn.tbtn-del{margin-left:0}
  .modal{max-height:90vh;overflow:auto}
}

/* ============ TIME & BUDGET TRACKER ============ */
.tracker{
  display:grid;grid-template-columns:minmax(280px,1fr) 2fr;gap:16px;margin-bottom:18px;
}
.trk-timer{
  background:linear-gradient(160deg,var(--brand),var(--brand-d));color:#fff;
  border-radius:16px;padding:18px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;
}
.trk-timer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px}
.trk-head-left{display:flex;flex-direction:column;gap:4px;min-width:0}
.trk-storage{font-size:11px;font-weight:700;line-height:1.35;opacity:.92}
.trk-storage.ok{color:#bbf7d0}
.trk-storage.warn{color:#fde68a}
.trk-storage.err{color:#fecaca}
.trk-kicker{font-size:11px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;opacity:.9}
.trk-timer-head .btn{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.25);color:#fff}
.trk-timer-head .btn:hover{background:rgba(255,255,255,.26)}
.trk-clock{font-size:38px;font-weight:800;letter-spacing:.5px;font-variant-numeric:tabular-nums;line-height:1.1;margin-top:4px}
.trk-runcost{font-size:12px;font-weight:700;opacity:.92;min-height:16px}
.trk-runmeta{font-size:11.5px;opacity:.85;margin:6px 0 12px;font-weight:600}
.tracker.running .trk-clock{color:#fff}
.trk-controls{display:flex;flex-direction:column;gap:8px;margin-top:auto}
.trk-controls .inp{
  background:rgba(255,255,255,.92);border-color:transparent;color:#0f1b2d;width:100%;
}
.trk-controls .inp:focus{border-color:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.4)}
.trk-controls select.inp{cursor:pointer}
.trk-start,.trk-stop{width:100%;justify-content:center;font-size:13.5px;padding:10px}
.btn[hidden]{display:none!important}
.trk-start{background:#fff;color:var(--brand-d);border-color:#fff}
.trk-start:hover{background:#f0fdf8}

.trk-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.trk-stat{
  background:var(--panel);border:1px solid var(--border);border-radius:16px;
  box-shadow:var(--shadow);padding:16px;display:flex;flex-direction:column;gap:8px;
}
#trkBudgetCard,#trkHoursCard{cursor:pointer;transition:.15s}
#trkBudgetCard:hover,#trkHoursCard:hover{border-color:var(--brand)}
.trk-stat-h{font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--faint)}
.trk-stat-big{font-size:24px;font-weight:800;letter-spacing:-.4px;font-variant-numeric:tabular-nums}
.trk-stat-big.over{color:#e11d48}
.trk-meter{height:8px;border-radius:6px;background:var(--track);overflow:hidden}
.trk-meter i{display:block;height:100%;width:0;border-radius:6px;background:linear-gradient(90deg,var(--brand),var(--brand-d));transition:width .35s}
.trk-meter i.danger{background:linear-gradient(90deg,#f59e0b,#e11d48)}
.trk-stat-sub{font-size:11.5px;color:var(--muted);font-weight:600}

/* ledger modal */
.modal.modal-wide{max-width:680px}
.led-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.led-head h2{margin:0}
.led-tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--border)}
.led-tabs button{
  border:none;background:none;color:var(--muted);font-size:12.5px;font-weight:700;
  padding:9px 12px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;
}
.led-tabs button:hover{color:var(--text)}
.led-tabs button.on{color:var(--brand-d);border-bottom-color:var(--brand)}
.led-form{
  background:var(--panel-2);border:1px solid var(--border);border-radius:12px;
  padding:14px;display:flex;flex-direction:column;gap:10px;margin-bottom:14px;
}
.led-form-row{display:flex;gap:10px;flex-wrap:wrap}
.led-form-row label{flex:1;min-width:120px}
.led-form label{display:flex;flex-direction:column;gap:5px;font-size:10.5px;font-weight:800;color:var(--faint);text-transform:uppercase;letter-spacing:.5px}
.led-form label .inp{text-transform:none;font-weight:500;letter-spacing:0;color:var(--text)}
.led-form .btn.brand{align-self:flex-start}
.led-hint{font-size:12px;color:var(--muted);line-height:1.5;margin:0}
.led-summary{font-size:12.5px;color:var(--muted);margin-bottom:10px;line-height:1.6}
.led-summary b{color:var(--text)}
.led-summary b.over{color:#e11d48}
.led-list{display:flex;flex-direction:column;gap:8px;max-height:42vh;overflow:auto}
.led-row{
  display:flex;align-items:center;gap:10px;
  background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;
}
.led-main{flex:1;min-width:0}
.led-title{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.led-sub{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.led-amt{font-size:13px;font-weight:800;text-align:right;display:flex;flex-direction:column;line-height:1.2;white-space:nowrap}
.led-amt small{font-size:10.5px;font-weight:600;color:var(--muted)}
.led-del{
  border:1px solid var(--border);background:var(--panel);color:var(--muted);
  width:26px;height:26px;border-radius:8px;cursor:pointer;flex-shrink:0;font-size:12px;
}
.led-del:hover{background:#e11d48;border-color:#e11d48;color:#fff}
.led-empty{font-size:12.5px;color:var(--muted);text-align:center;padding:24px;border:1px dashed var(--border);border-radius:10px}

@media(max-width:1080px){
  .tracker{grid-template-columns:1fr}
}
@media(max-width:680px){
  .trk-stats{grid-template-columns:1fr}
  .trk-clock{font-size:34px}
  .modal.modal-wide{max-height:92vh;overflow:auto}
}
