/* aboo brand layer over tina4css — admin PWA shell, mobile-first.
   tina4css provides btn/card/badge/grid/forms; this adds the app frame + brand tokens. */
/* Brand tokens mapped from the canonical aboo palette (brand/aboo-colors.css).
   --aboo-accent / --aboo-bg / --aboo-fg flip with [data-theme]; we layer surfaces on top. */
:root{
  --brand: var(--aboo-accent);   /* teal #19C4C4 light / #2AE0E0 dark */
  --brand-ink: var(--aboo-ink);  /* #0E2E33 deep teal — drawer, code chips */
  --bg: var(--aboo-bg);          /* #EAF3F2 mist (light) / #0E2E33 (dark) */
  --ink: var(--aboo-fg);         /* text */
  --surface:#ffffff; --muted:#2E575E; --line:#d3e6e4;
  --ok:#15803d; --bad:#b91c1c; --warn:#b45309; --info:#0e7490;
  --drawer-w:248px; --bar-h:58px; --radius:14px;
}
/* aboo-colors.css lists `:root` in the LIGHT selector after the dark block (equal specificity →
   :root wins), so --aboo-bg/fg/accent never flip. Re-assert the dark values at higher specificity. */
:root[data-theme="dark"]{
  /* depth: drawer (darkest) < content bg < elevated surfaces (cards/app-bar) */
  --bg:#0c2429; --ink:#EAF3F2; --surface:#15414A; --muted:#8fb1b0; --line:#2E575E;
  --brand: var(--aboo-teal-bright);   /* #2AE0E0 bright teal in dark */
}
:root[data-theme="dark"] .drawer{ background:#081e22; }
:root[data-theme="dark"] .form-control{ background:#0c2429; color:var(--ink); border-color:var(--line); }
:root[data-theme="dark"] .form-control::placeholder{ color:#6f9694; }
:root[data-theme="dark"] .cat-code,
:root[data-theme="dark"] .iso-badge{ background:#081e22; color:var(--aboo-teal-bright); }
:root[data-theme="dark"] .row-card:hover,
:root[data-theme="dark"] .kpi{ box-shadow:0 1px 2px rgba(0,0,0,.3); }
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--ink);
  font:15px/1.45 "Sora",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;-webkit-font-smoothing:antialiased}
#app{height:100%}
a{color:var(--brand);text-decoration:none}

/* ---------- brand lockup ---------- */
.brand-lockup{display:flex;align-items:center;gap:8px;font-weight:800;letter-spacing:-.01em}
.brand-dot{width:14px;height:14px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px rgba(25,196,196,.25)}
.brand-name{font-size:20px}
.brand-sub{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.6;margin-left:2px}

/* ---------- layout ---------- */
.layout{min-height:100%}
.drawer{position:fixed;top:0;left:0;width:var(--drawer-w);height:100%;background:var(--brand-ink);
  color:#cfe9e8;display:flex;flex-direction:column;z-index:40;transition:transform .22s ease;overflow-y:auto}
.drawer-brand{padding:16px 18px;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
.nav-list{padding:10px 10px 24px}
.nav-section{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:#7fb1ad;
  padding:14px 12px 6px;font-weight:700}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:#cfe9e8;
  cursor:pointer;font-weight:500;user-select:none}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:var(--brand);color:var(--aboo-ink);font-weight:600}
.nav-item.soon{opacity:.45;cursor:default}
.nav-item.soon:hover{background:none;color:#cfe9e8}
.nav-ico{width:20px;text-align:center;font-size:15px;opacity:.9}
.nav-lbl{flex:1}
.soon-badge{font-size:9px;opacity:.8}

.main{margin-left:var(--drawer-w);min-height:100%;display:flex;flex-direction:column}
.app-bar{position:sticky;top:0;height:var(--bar-h);background:var(--surface);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:12px;padding:0 16px;z-index:30}
.app-title{font-weight:700;font-size:16px;flex:1}
.app-user{display:flex;align-items:center;gap:10px}
.user-name{font-size:13px;color:var(--muted);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hamb{display:none;font-size:18px;line-height:1;padding:4px 10px}
.content{padding:18px 16px 64px;flex:1}
.scrim{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:35}

/* mobile */
@media (max-width:767px){
  .drawer{transform:translateX(-100%)}
  .layout.nav-open .drawer{transform:translateX(0)}
  .layout.nav-open .scrim{display:block}
  .main{margin-left:0}
  .hamb{display:inline-flex;align-items:center}
}

/* ---------- page ---------- */
.page{max-width:920px;margin:0 auto}
.page-head{margin:2px 0 16px}
.page-head.with-action{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.page-title{font-size:22px;margin:0 0 2px}
.page-sub{color:var(--muted);font-size:13px;display:flex;align-items:center;gap:8px}
.muted-block{color:var(--muted);text-align:center;padding:42px 0}
.count-line{font-size:12px;color:var(--muted);margin:0 2px 10px}
.toolbar{display:flex;gap:8px;margin:6px 0 12px;flex-wrap:wrap}
.toolbar .form-control{flex:1 1 200px}
.per-select{flex:0 0 130px;max-width:140px}

/* ---------- KPI dashboard ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.kpi{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);
  border-left:4px solid var(--line);box-shadow:0 1px 2px rgba(15,23,42,.04)}
.kpi .card-body{padding:14px 16px}
.kpi-label{font-size:12.5px;color:var(--muted);font-weight:600}
.kpi-val{font-size:30px;font-weight:800;line-height:1.1;margin:6px 0 4px;letter-spacing:-.02em}
.kpi-sub{font-size:11.5px;color:var(--muted)}
.kpi-sub.pending{color:var(--warn)}
.kpi.accent-primary{border-left-color:var(--brand)}
.kpi.accent-success{border-left-color:var(--ok)}
.kpi.accent-danger{border-left-color:var(--bad)}
.kpi.accent-info{border-left-color:var(--info)}
.kpi.accent-dark{border-left-color:var(--brand-ink)}

/* ---------- ledger categories ---------- */
.cat-root{margin:0 0 16px}
.cat-root-head{display:flex;align-items:baseline;gap:8px;padding:0 2px 7px}
.cat-root-head h2{font-size:14px;margin:0;text-transform:uppercase;letter-spacing:.05em}
.cat-stmt{font-size:11px;color:var(--muted)}
.cat-cards{display:flex;flex-direction:column;gap:8px}
.cat-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:11px 14px}
.cat-code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:700;font-size:12.5px;
  background:var(--brand-ink);color:#fff;padding:3px 8px;border-radius:8px;min-width:48px;text-align:center}
.cat-name{flex:1;font-weight:600}
.cat-edit{padding:2px 9px;line-height:1.4}

/* ---------- list rows (clickable) ---------- */
.row-list{display:flex;flex-direction:column;gap:8px}
.row-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:12px 14px;cursor:pointer;transition:border-color .12s,box-shadow .12s}
.row-card:hover{border-color:var(--brand);box-shadow:0 2px 10px rgba(79,70,229,.12)}
.iso-badge{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:700;font-size:12px;
  background:var(--brand-ink);color:#fff;padding:4px 9px;border-radius:8px;min-width:42px;text-align:center}
.row-main{flex:1;display:flex;flex-direction:column;min-width:0}
.row-main b{font-weight:600}
.row-sub{font-size:12px;color:var(--muted)}
.row-chevron{color:var(--muted);font-size:22px;line-height:1}

/* ---------- detail: back link, tabs, fields ---------- */
.back-link{display:inline-block;color:var(--muted);font-size:13px;cursor:pointer;margin:0 0 6px}
.back-link:hover{color:var(--brand)}
.tabbar{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:4px 0 16px;overflow-x:auto}
.tab{appearance:none;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);
  font-size:14px;font-weight:600;padding:9px 12px;cursor:pointer;white-space:nowrap}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--brand);border-bottom-color:var(--brand)}
.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.field{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px}
.field-label{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.field-val{font-size:15px;font-weight:600;margin-top:3px}
.hint{margin-top:14px;font-size:12.5px;color:var(--muted);background:#e3f2f1;border-radius:10px;padding:10px 12px}

/* tina4css button/badge primaries → aboo teal (dark text for contrast on the bright teal) */
.btn-primary{background:var(--brand);border-color:var(--brand);color:var(--aboo-ink)}
.btn-primary:hover{background:var(--brand);border-color:var(--brand);filter:brightness(.94)}
.badge-primary{background:var(--brand);color:var(--aboo-ink)}
.brand-dot{background:var(--brand)}
/* outline / secondary button — theme-aware (tina4css default has dark text invisible on dark) */
.btn-outline{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn-outline:hover{background:rgba(127,160,160,.14);border-color:var(--muted);color:var(--ink)}
/* comfortable, consistent modal actions */
.form-actions .btn{padding:9px 18px;border-radius:10px;font-weight:600;min-width:96px}
.muted-sub{font-size:12.5px;color:var(--muted)}

/* ---------- pricing tiers ---------- */
.tier-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.tier{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
.tier-name{font-weight:700;font-size:15px}
.tier-price{font-size:20px;font-weight:800;margin:4px 0;color:var(--brand)}
.tier-caps{font-size:12px;color:var(--muted)}

/* ---------- account add/edit form + modal ---------- */
.tab-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 12px}
.ledger-search{margin:0 0 12px}
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:flex;align-items:flex-start;
  justify-content:center;z-index:50;padding:24px 16px;overflow-y:auto}
.modal-card{background:var(--surface);color:var(--ink);border-radius:16px;width:100%;max-width:440px;
  padding:20px 22px;box-shadow:0 24px 60px rgba(0,0,0,.4)}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.modal-head h3{margin:0;font-size:18px}
.modal-x{appearance:none;border:none;background:none;font-size:18px;color:var(--muted);cursor:pointer;line-height:1}
.form-check{display:flex;align-items:center;gap:8px;font-size:14px;margin:8px 0;cursor:pointer}
.form-note{font-size:11.5px;color:var(--muted);margin:-2px 0 10px}
.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}
.cat-card.inactive{opacity:.55}
.tag-off{font-size:10px;background:#fee2e2;color:var(--bad);padding:1px 6px;border-radius:999px;margin-left:8px;font-weight:600}

/* ---------- theme toggle ---------- */
.theme-toggle{appearance:none;border:1px solid var(--line);background:var(--surface);color:var(--ink);
  border-radius:9px;padding:5px 9px;cursor:pointer;font-size:15px;line-height:1}

/* ---------- dark mode (brand) — token mapping handles bg/ink/surface; these are tweaks ---------- */
:root[data-theme="dark"] .hint{background:#123339}
:root[data-theme="dark"] .tag-off{background:#3b1414}
:root[data-theme="dark"] .row-card:hover{box-shadow:0 2px 10px rgba(0,0,0,.4)}

/* ---------- login ---------- */
.login-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(1200px 600px at 50% -10%,#1a4d54 0%,#0E2E33 55%,#07191c 100%)}
/* The login card is a fixed white card on the teal gradient — theme-independent (don't inherit
   dark-mode text colours, or it goes invisible on white). */
/* theme toggle floating on the gradient (light styling so it shows on the dark backdrop) */
.login-toggle{position:fixed;top:16px;right:16px;z-index:2;background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.25);color:#EAF3F2}
/* login card adapts to the theme (white card / dark text in light; dark card / light text in dark) */
.login-card{width:100%;max-width:380px;border:1px solid var(--line);border-radius:18px;
  box-shadow:0 24px 60px rgba(0,0,0,.45);background:var(--surface);color:var(--ink)}
.login-card .card-body{padding:28px 26px 30px}
.login-card .brand-name{color:var(--ink)}
.login-title{font-size:22px;margin:6px 0 0;color:var(--ink)}
.login-hint{font-size:13px;color:var(--muted)}
.login-remember{margin:2px 0 14px;color:var(--muted)}
.login-card .btn-primary{background:var(--brand);border-color:var(--brand);color:var(--aboo-ink)}
.form-label{display:block;font-size:12.5px;font-weight:600;color:var(--muted);margin:0 0 5px}
