:root{
  --paper:#F4F1EA; --surface:#FFFFFF; --surface-2:#FBFAF6;
  --ink:#13241F; --ink-soft:#2A3A34; --muted:#62716A; --faint:#8A9690; --line:#E6E1D6; --line-soft:#EFEBE2;
  --accent:#0F6B5C; --accent-bright:#15937E; --amber:#C2772A; --danger:#B4452F;
  --success:#2E7D5B; --info:#2C6E8F;
  --sidebar:#0E1B17; --sidebar-2:#0B1612; --sb-text:#BCCBC3; --sb-active:#17332B; --sb-line:#1E332B;
  --radius:14px; --radius-sm:10px; --shadow:0 1px 2px rgba(19,36,31,.05),0 10px 30px -18px rgba(19,36,31,.35);
  --shadow-lg:0 24px 60px -28px rgba(19,36,31,.45);
  --display:"Bricolage Grotesque",Georgia,serif; --body:"Hanken Grotesk",-apple-system,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--body); color:var(--ink); background:var(--paper);
  background-image:radial-gradient(900px 500px at 100% -10%,rgba(21,147,126,.07),transparent 60%),
                   radial-gradient(700px 500px at -10% 110%,rgba(194,119,42,.06),transparent 55%);
  -webkit-font-smoothing:antialiased; line-height:1.5; font-size:15px;
}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-.02em;color:var(--ink);line-height:1.12}
.num{font-family:var(--display);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.muted{color:var(--muted)}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}

/* ---------- Auth shell ---------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:28px}
.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--line);
  border-radius:20px;box-shadow:var(--shadow-lg);padding:38px 34px;animation:rise .5s ease both}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.auth-brand h1{font-size:22px}
.auth-brand p{font-size:13px;color:var(--muted);margin-top:2px}
.mark{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;flex:none;
  background:linear-gradient(150deg,var(--accent),var(--ink));color:#EAF6F1;font-family:var(--display);
  font-weight:800;font-size:22px;box-shadow:0 8px 20px -10px rgba(15,107,92,.7)}
.auth-foot{margin-top:24px;padding-top:18px;border-top:1px solid var(--line-soft);
  display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted)}
.auth-foot a{color:var(--accent);font-weight:600}

/* ---------- App layout ---------- */
.shell{display:grid;grid-template-columns:250px 1fr;min-height:100vh}
.sidebar{background:var(--sidebar);color:var(--sb-text);position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;padding:22px 16px;border-right:1px solid var(--sb-line)}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 20px}
.sidebar .brand strong{display:block;font-family:var(--display);font-size:17px;color:#F1F8F4;letter-spacing:-.01em}
.sidebar .brand small{display:block;font-size:11px;color:#7E938A;letter-spacing:.04em}
.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav .sect{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#5F756B;margin:16px 10px 6px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:var(--sb-text);
  font-weight:500;font-size:14px;transition:.16s}
.nav a svg{width:18px;height:18px;opacity:.85}
.nav a:hover{background:#142821;color:#EAF6F1}
.nav a.active{background:var(--sb-active);color:#FFF;box-shadow:inset 0 0 0 1px #224a3e}
.nav a.active svg{opacity:1;color:var(--accent-bright)}
.sidebar .sb-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--sb-line)}
.sidebar .sb-foot a{color:#A9BBB2}
.sidebar .sb-foot a:hover{color:#fff;background:#142821}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 32px;border-bottom:1px solid var(--line);background:rgba(251,250,246,.7);
  backdrop-filter:blur(8px);position:sticky;top:0;z-index:20}
.topbar h1{font-size:23px}
.topbar .eyebrow{margin-bottom:3px}
.userchip{display:flex;align-items:center;gap:10px}
.userchip .avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--accent-bright),var(--accent));color:#fff;font-weight:700;
  font-family:var(--display);font-size:16px}
.userchip .who{text-align:right;line-height:1.2}
.userchip .who b{font-size:14px}
.userchip .who span{font-size:11.5px;color:var(--muted)}
.menu-btn{display:none;background:none;border:1px solid var(--line);border-radius:10px;
  width:40px;height:40px;align-items:center;justify-content:center;cursor:pointer}
.content{padding:26px 32px 64px;max-width:1180px;width:100%}

/* ---------- Cards / panels ---------- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden}
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
  padding:18px 22px;border-bottom:1px solid var(--line-soft)}
.panel-head h2{font-size:17px}
.panel-head p{font-size:13px;color:var(--muted);margin-top:2px}
.panel-body{padding:22px}
.grid{display:grid;gap:18px}
.mt{margin-top:20px}.mt-s{margin-top:12px}

/* ---------- KPI ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 16px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;inset:0 0 auto auto;width:70px;height:70px;
  background:radial-gradient(circle at 80% 20%,rgba(21,147,126,.12),transparent 70%)}
.kpi .k-label{display:flex;align-items:center;justify-content:space-between;
  font-size:12px;color:var(--muted);font-weight:600}
.kpi .k-label svg{width:17px;height:17px;color:var(--accent)}
.kpi .k-val{font-family:var(--display);font-size:27px;font-weight:700;margin-top:10px;
  font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.kpi .k-sub{font-size:12px;color:var(--muted);margin-top:3px}
.kpi.warm{border-color:#EAD6B6;background:linear-gradient(180deg,#FDF6EC,#fff)}
.kpi.warm .k-label svg,.kpi.warm .k-val{color:var(--amber)}
.kpi.good{border-color:#C9E4D6;background:linear-gradient(180deg,#F0F8F3,#fff)}
.kpi.good .k-label svg{color:var(--success)}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:14px}
table.tbl th{text-align:left;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);font-weight:700;padding:12px 16px;border-bottom:1px solid var(--line)}
table.tbl td{padding:13px 16px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
table.tbl tbody tr:last-child td{border-bottom:none}
table.tbl tbody tr:hover{background:var(--surface-2)}
table.tbl td b{font-weight:600}
table.tbl td small{display:block;color:var(--muted);font-size:11.5px;margin-top:1px}
.tnum{font-variant-numeric:tabular-nums}
.row-actions{display:flex;gap:8px;justify-content:flex-end}

/* ---------- Pills / badges ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;
  padding:4px 10px;border-radius:999px;letter-spacing:.02em;text-transform:capitalize}
.pill.active,.pill.credit,.pill.success{background:#E4F2EA;color:#236B4C}
.pill.inactive,.pill.debit,.pill.danger{background:#F6E2DC;color:#9A3A26}
.pill.info{background:#E1EEF4;color:#235870}.pill.warning{background:#F8ECD6;color:#8A5414}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot.on{background:var(--success);box-shadow:0 0 0 3px rgba(46,125,91,.18)}
.dot.off{background:var(--amber);box-shadow:0 0 0 3px rgba(194,119,42,.18)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--body);font-weight:600;
  font-size:14px;border-radius:10px;padding:10px 16px;border:1px solid transparent;cursor:pointer;
  transition:.16s;background:#EDEAE1;color:var(--ink)}
.btn svg{width:17px;height:17px}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(160deg,var(--accent-bright),var(--accent));color:#fff;
  box-shadow:0 10px 22px -12px rgba(15,107,92,.8)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink-soft)}
.btn-ghost:hover{background:var(--surface-2)}
.btn-danger{background:#F6E2DC;color:#9A3A26}
.btn-sm{padding:7px 12px;font-size:13px}
.btn[disabled]{opacity:.6;cursor:not-allowed;transform:none}
.link-danger{background:none;border:none;color:var(--danger);font-weight:600;cursor:pointer;font-size:13.5px;font-family:var(--body)}
.link-danger:hover{text-decoration:underline}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field.col-2{grid-column:span 2}
label{font-size:12.5px;font-weight:600;color:var(--ink-soft)}
input,select,textarea{font-family:var(--body);font-size:14px;color:var(--ink);background:var(--surface-2);
  border:1px solid var(--line);border-radius:10px;padding:11px 13px;width:100%;transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-bright);
  background:#fff;box-shadow:0 0 0 3px rgba(21,147,126,.13)}
textarea{resize:vertical;min-height:74px}
.hint{font-size:12px;color:var(--muted)}
.filter-bar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px}
.filter-bar .field{min-width:150px}
.custom-range{display:none}
.custom-range.show{display:flex}

/* ---------- Alerts ---------- */
.alert{border-radius:12px;padding:13px 16px;font-size:14px;font-weight:500;margin-bottom:16px;
  border:1px solid;display:flex;gap:10px;align-items:flex-start}
.alert svg{width:18px;height:18px;flex:none;margin-top:1px}
.alert.info{background:#EAF3F8;border-color:#CADEE9;color:#235870}
.alert.success{background:#E9F5EE;border-color:#C7E5D4;color:#236B4C}
.alert.warning{background:#FBF1DD;border-color:#EBD9B4;color:#8A5414}
.alert.danger{background:#F9E7E1;border-color:#EECDC3;color:#9A3A26}

/* ---------- Spend bars / misc ---------- */
.spend-row{display:grid;grid-template-columns:130px 1fr auto;align-items:center;gap:14px;padding:9px 0}
.spend-row + .spend-row{border-top:1px solid var(--line-soft)}
.spend-row .lbl{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink-soft)}
.spend-row .lbl svg{width:16px;height:16px;color:var(--muted)}
.track{height:9px;border-radius:999px;background:var(--line-soft);overflow:hidden}
.track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-bright))}
.spend-row b{font-family:var(--display);font-variant-numeric:tabular-nums}
.orb{margin:6px auto 14px;width:120px;height:120px;border-radius:50%;display:grid;place-content:center;text-align:center;
  background:radial-gradient(circle at 50% 35%,#fff,var(--surface-2));border:1px solid var(--line);
  box-shadow:inset 0 0 0 6px rgba(21,147,126,.08)}
.orb.warn{box-shadow:inset 0 0 0 6px rgba(194,119,42,.12)}
.orb b{font-family:var(--display);font-size:30px;line-height:1}
.orb span{font-size:11.5px;color:var(--muted);margin-top:3px}
.balance-line{display:flex;justify-content:space-between;padding:9px 0;border-top:1px solid var(--line-soft);font-size:14px}
.balance-line b{font-family:var(--display);font-variant-numeric:tabular-nums}
.empty{text-align:center;color:var(--muted);padding:30px 16px}
.empty b{display:block;color:var(--ink);font-family:var(--display);margin-bottom:4px}
.notice{display:flex;gap:11px;align-items:flex-start;padding:13px 16px;border-radius:12px;margin-bottom:12px;border:1px solid}
.notice.info{background:#EAF3F8;border-color:#CADEE9}.notice.success{background:#E9F5EE;border-color:#C7E5D4}
.notice.warning{background:#FBF1DD;border-color:#EBD9B4}.notice.danger{background:#F9E7E1;border-color:#EECDC3}
.notice b{font-family:var(--display)}
.dl{display:grid;grid-template-columns:160px 1fr;gap:0}
.dl dt{padding:12px 0;font-size:13px;color:var(--muted);border-bottom:1px solid var(--line-soft);font-weight:600}
.dl dd{padding:12px 0;border-bottom:1px solid var(--line-soft);font-weight:500}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.search{display:flex;gap:8px;align-items:center}
.search input{min-width:230px}

@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.content > *{animation:rise .4s ease both}
.content > *:nth-child(2){animation-delay:.04s}
.content > *:nth-child(3){animation-delay:.08s}

/* ---------- Responsive ---------- */
@media(max-width:980px){.kpis{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}.field.col-2{grid-column:auto}}
@media(max-width:820px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;z-index:60;width:250px;left:-260px;transition:left .25s;box-shadow:var(--shadow-lg)}
  .sidebar.open{left:0}
  .menu-btn{display:inline-flex}
  .content{padding:20px 18px 56px}.topbar{padding:16px 18px}
  .scrim{position:fixed;inset:0;background:rgba(8,18,14,.45);z-index:55;display:none}
  .scrim.show{display:block}
}
@media(max-width:560px){.kpis{grid-template-columns:1fr}.userchip .who{display:none}.dl{grid-template-columns:1fr}.dl dt{border-bottom:none;padding-bottom:0}}
