:root{
  --bg:#0F1A14; --surface:#16241C; --raised:#1C2E24; --line:#27402F;
  --ink:#E7F0EA; --muted:#8CA595; --faint:#5E7568;
  --green:#48B583; --amber:#E5AC3F; --red:#E25B4C; --blue:#5FA8D3;
  --disp:'Barlow Condensed',Impact,'Arial Narrow',sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box;margin:0}
html,body{height:100%}
body{background:var(--bg);color:var(--ink);font:14px/1.5 var(--body)}
a{color:var(--green)}
button{font-family:var(--body)}

/* layout */
.shell{display:grid;grid-template-columns:196px 1fr;min-height:100vh}
nav{background:var(--surface);border-right:1px solid var(--line);padding:20px 0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
.brand{font-family:var(--disp);font-size:26px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:0 20px 4px}
.brand b{color:var(--green)}
.brand-sub{padding:0 20px 18px;color:var(--faint);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
nav a.tab{display:flex;justify-content:space-between;align-items:center;padding:9px 20px;color:var(--muted);text-decoration:none;font-family:var(--disp);font-size:17px;letter-spacing:.08em;text-transform:uppercase;border-left:3px solid transparent}
nav a.tab:hover{color:var(--ink)}
nav a.tab.on{color:var(--ink);border-left-color:var(--green);background:linear-gradient(90deg,rgba(72,181,131,.10),transparent)}
nav a.tab .pill{font:600 11px var(--mono);color:var(--bg);background:var(--red);border-radius:9px;padding:0 7px}
nav .spacer{flex:1}
nav .logout{margin:0 20px;background:none;border:1px solid var(--line);color:var(--muted);padding:6px;border-radius:4px;cursor:pointer;font-size:12px}
main{padding:26px 32px 80px;max-width:1180px}
h1{font-family:var(--disp);font-size:32px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:4px}
.sub{color:var(--muted);margin-bottom:22px}
h2{font-family:var(--disp);font-size:20px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:26px 0 10px}

/* cards & grid */
.grid{display:grid;gap:14px}
.g3{grid-template-columns:repeat(3,1fr)} .g2{grid-template-columns:repeat(2,1fr)} .g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:16px}
.stat .lbl{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.stat .val{font:600 26px var(--mono);margin-top:4px}
.stat .val.pos{color:var(--green)} .stat .val.neg{color:var(--red)}
.money{font-family:var(--mono)}

/* due rail — signature */
.rail-wrap{background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:16px 16px 8px;margin-bottom:18px}
.rail-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.rail-head .t{font-family:var(--disp);font-size:18px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.rail{position:relative;height:8px;background:var(--raised);border-radius:4px;margin:26px 8px 6px}
.rail .tick{position:absolute;top:-4px;width:1px;height:16px;background:var(--line)}
.rail .tick span{position:absolute;top:18px;left:-12px;width:26px;text-align:center;font:10px var(--mono);color:var(--faint)}
.rail .dot{position:absolute;top:-3px;width:14px;height:14px;border-radius:50%;border:2px solid var(--bg);cursor:pointer;transform:translateX(-7px)}
.dot.overdue{background:var(--red)} .dot.due_soon{background:var(--amber)} .dot.upcoming{background:var(--green)}
.ob-list{margin-top:22px}
.ob{display:flex;align-items:center;gap:12px;padding:8px 4px;border-top:1px solid var(--line)}
.ob .d{font:600 12px var(--mono);width:64px;color:var(--muted)}
.ob .badge{width:78px}
.ob .who{flex:1}
.ob .who small{display:block;color:var(--faint)}
.ob .amt{font:600 14px var(--mono);width:100px;text-align:right}
.ob button{margin-left:8px}
.badge{display:inline-block;font:600 10px var(--body);letter-spacing:.08em;text-transform:uppercase;padding:2px 8px;border-radius:3px;text-align:center}
.badge.overdue{background:rgba(226,91,76,.18);color:var(--red)}
.badge.due_soon{background:rgba(229,172,63,.18);color:var(--amber)}
.badge.upcoming{background:rgba(72,181,131,.14);color:var(--green)}
.badge.open{background:rgba(226,91,76,.18);color:var(--red)}
.badge.in_progress{background:rgba(229,172,63,.18);color:var(--amber)}
.badge.done,.badge.active,.badge.paid{background:rgba(72,181,131,.14);color:var(--green)}
.badge.neutral{background:var(--raised);color:var(--muted)}

/* tables */
table{width:100%;border-collapse:collapse}
th{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top}
tr:hover td{background:rgba(255,255,255,.015)}
td.r,th.r{text-align:right}

/* forms & buttons */
.btn{background:var(--green);color:#08130D;border:0;border-radius:4px;padding:8px 14px;font-weight:600;cursor:pointer;font-size:13px}
.btn:hover{filter:brightness(1.1)}
.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
.btn.ghost:hover{color:var(--ink);border-color:var(--muted)}
.btn.sm{padding:4px 10px;font-size:12px}
.btn.danger{background:transparent;border:1px solid var(--red);color:var(--red)}
input,select,textarea{background:var(--raised);border:1px solid var(--line);color:var(--ink);border-radius:4px;padding:8px 10px;font:13px var(--body);width:100%}
input:focus,select:focus,textarea:focus,button:focus-visible{outline:2px solid var(--green);outline-offset:1px}
label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin:10px 0 4px}
.frow{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}
.bar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.bar .grow{flex:1}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(5,10,8,.7);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto;z-index:50}
.modal{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:22px;width:min(640px,100%)}
.modal h3{font-family:var(--disp);font-size:22px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}

/* deals board */
.stages{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.stages .st{font:600 11px var(--body);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--raised);padding:4px 10px;border-radius:12px}
.stages .st b{color:var(--ink);font-family:var(--mono)}
.strategy-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:12px}
.strat{background:var(--raised);border:1px solid var(--line);border-radius:6px;padding:12px}
.strat.rec{border-color:var(--green);box-shadow:0 0 0 1px var(--green)}
.strat h4{font-family:var(--disp);font-size:16px;letter-spacing:.08em;text-transform:uppercase}
.strat .kv{display:flex;justify-content:space-between;font-size:12px;margin-top:6px}
.strat .kv b{font-family:var(--mono)}
.strat .note{font-size:11px;color:var(--faint);margin-top:8px}
.progress{height:6px;background:var(--raised);border-radius:3px;overflow:hidden}
.progress i{display:block;height:100%;background:var(--green)}
.progress i.over{background:var(--red)}

/* sparkline months */
.months{display:flex;gap:6px;align-items:flex-end;height:90px;padding-top:8px}
.months .m{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:2px;text-align:center}
.months .bi{background:var(--green);border-radius:2px 2px 0 0;min-height:2px}
.months .be{background:var(--red);opacity:.75;border-radius:0 0 2px 2px;min-height:2px}
.months .ml{font:10px var(--mono);color:var(--faint);margin-top:4px}

.empty{color:var(--faint);padding:24px;text-align:center;border:1px dashed var(--line);border-radius:6px}
.note-amber{color:var(--amber);font-size:12px}
.copy-token{cursor:pointer;text-decoration:underline dotted;color:var(--blue);font-size:12px}

/* login */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login .card{width:320px}

@media(max-width:860px){
  .shell{grid-template-columns:1fr}
  nav{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;gap:2px;padding:10px}
  nav a.tab{padding:7px 12px;border-left:0;border-bottom:2px solid transparent}
  nav a.tab.on{border-bottom-color:var(--green);background:none}
  .brand{font-size:20px;padding:0 12px} .brand-sub,.logout{display:none}
  main{padding:16px}
  .g3,.g4,.g2{grid-template-columns:1fr 1fr}
}
@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}
