/* A4 / Vacei FS Review — dashboard design system (v2).
   Dark sidebar (#0b0b0d + cobalt glow) · warm #faf9f7 canvas · white cards w/ warm hairline ·
   cobalt-violet #494fdf accent · JetBrains-Mono "technical" labels · pill controls.
   FONT NOTE: the v2 spec names HelveticaNowDisplay (proprietary). Per the brand decision we
   substitute the free, reliably-hosted "Inter" (Google Fonts) for display + body, with tight
   tracking on headings to echo HelveticaNow. JetBrains Mono powers the eyebrow/technical labels. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  --primary:#494fdf;             /* cobalt-violet — the brand stamp */
  --primary-deep:#3a40c4;        /* pressed/active */
  --primary-light:#8388ea;       /* gradient partner / icon accent */
  --primary-soft:rgba(73,79,223,.08);
  --primary-soft-line:rgba(73,79,223,.25);

  --ink:#14161a; --slate:#14161a; --body:#3a3d40; --mute:#5c5951; --stone:#8a857c; --faint:#a8a49c;
  --bg:#faf9f7; --card:#ffffff; --line:#e7e5e0; --line-soft:#efece6; --soft:#f6f5f2;
  --ok:#2aa06a; --okText:#1f7a51; --warn:#e08a2c; --warnText:#b06a1a; --warnBg:#fbf1e3;
  --danger:#d1493a; --dangerText:#b53225;

  --font-display:"Inter",system-ui,-apple-system,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --r-sm:10px; --r-md:12px; --r-lg:16px; --r-xl:18px; --r-full:9999px;
  --shadow-card:0 1px 2px rgba(20,22,26,.04);
  --shadow-lift:0 10px 24px -12px rgba(20,22,26,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:var(--font-body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.02em}
a{text-decoration:none;color:inherit}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes ping{75%,100%{transform:scale(1.8);opacity:0}}
@keyframes pulse{50%{opacity:.5}}
.sbhide{scrollbar-width:none}.sbhide::-webkit-scrollbar{display:none}
::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#d5d1c9;border-radius:9999px}
.hidden{display:none!important}
.spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}

/* technical / mono helpers (the v2 "terminal" flavour) */
.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone)}
.mono{font-family:var(--font-mono)}

/* ---- shell ---- */
.app{display:flex;height:100vh;width:100%;background:var(--bg);position:relative;overflow:hidden}
.sidebar{width:270px;flex-shrink:0;background:#0b0b0d;border-right:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;padding:28px 0 22px;position:relative;overflow:hidden;transition:width .35s cubic-bezier(.4,0,.2,1)}
.sidebar .glow{position:absolute;top:-10%;left:-10%;width:44%;height:36%;background:var(--primary);filter:blur(100px);border-radius:9999px;opacity:.35;pointer-events:none}
.sb-logo{padding:0 20px;margin-bottom:36px;display:flex;align-items:center;gap:11px;flex-shrink:0;position:relative}
.sb-logo img{width:28px;height:32px;object-fit:contain;display:block;flex-shrink:0}
.sb-logo .wm{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:-.01em;color:#fff;white-space:nowrap}
.sb-logo .wm b{color:var(--primary-light);font-weight:600}
.sb-nav{flex:1;padding:0 14px;display:flex;flex-direction:column;gap:6px;overflow-y:auto;position:relative}
.sb-sep{margin:14px 16px 8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.32)}
.sb-link{position:relative;display:flex;align-items:center;padding:13px 15px;border-radius:12px;color:rgba(255,255,255,.58);font-weight:500;font-size:14px;transition:.15s}
.sb-link svg{width:19px;height:19px;margin-right:14px;flex-shrink:0}
.sb-link:hover{background:rgba(255,255,255,.05);color:#fff}
.sb-link.on{background:rgba(255,255,255,.08);color:#fff}
.sb-link.on .bar{position:absolute;left:-14px;width:3px;height:22px;background:var(--primary);border-radius:0 9999px 9999px 0}
.sb-link.on svg{stroke:var(--primary-light)}
.sb-foot{padding:0 14px;margin-top:auto}
.sb-user{border-radius:18px;padding:8px;background:rgba(255,255,255,.06)}
.sb-user .row{display:flex;align-items:center;padding:10px 12px}
.sb-user .av{width:38px;height:38px;border-radius:9999px;background:linear-gradient(45deg,var(--primary),var(--primary-light));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;font-size:15px}
.sb-user .nm{font-size:13px;font-weight:500;color:#fff;white-space:nowrap;margin-left:11px}
.sb-user .em{font-family:var(--font-mono);font-size:10px;color:rgba(255,255,255,.45);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-left:11px}
.sb-logout{width:100%;margin-top:4px;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:#e07a6a;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;transition:background-color .2s;background:none;border:none;cursor:pointer}
.sb-logout:hover{background:rgba(255,255,255,.06)}
.sb-logout svg{width:14px;height:14px}
.sidebar.mini{width:86px}
.sidebar.mini .collapsible{display:none}

.col{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:74px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;
  background:rgba(250,249,247,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--line);flex-shrink:0;z-index:40}
.topbar h1{font-size:21px;font-weight:600;color:var(--ink);letter-spacing:-.02em;display:flex;align-items:center;gap:6px}
.topbar h1 span{color:var(--primary-light)}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:9999px;background:#fff;border:1px solid var(--line);color:var(--mute);cursor:pointer}
.credit-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:9999px;background:#fff;border:1px solid var(--line);font-family:var(--font-mono);font-size:12px;color:var(--ink)}
.credit-pill .dot{width:6px;height:6px;border-radius:9999px;background:var(--ok)}
.userchip{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:9999px;padding:5px 16px 5px 5px;cursor:default}
.userchip .av{width:34px;height:34px;border-radius:9999px;background:linear-gradient(45deg,var(--primary),var(--primary-light));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}
.userchip .nm{font-size:13px;color:var(--ink);line-height:1.2;white-space:nowrap}
.userchip .em{font-family:var(--font-mono);font-size:10px;color:var(--faint);line-height:1.2;white-space:nowrap}
.scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:28px 28px 40px}
.wrap{max-width:1240px;margin:0 auto;width:100%;display:flex;flex-direction:column}
.page-head{margin-bottom:22px}
.page-head .eyebrow{margin-bottom:8px;display:block}
.page-head h2{font-size:28px;font-weight:600;color:var(--ink);letter-spacing:-.02em}
.page-head p{font-size:14px;color:var(--mute);margin-top:6px}

/* ---- cards + controls ---- */
.card{background:var(--card);border-radius:var(--r-xl);border:1px solid var(--line);box-shadow:var(--shadow-card);padding:24px}
.card h3{font-size:18px;font-weight:600;color:var(--ink);margin-bottom:16px;letter-spacing:-.01em}
.stat-card{background:#fff;border-radius:14px;border:1px solid var(--line);padding:18px 20px}
.stat-card .k{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--stone);margin-bottom:10px}
.stat-card .v{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--ink);letter-spacing:-.02em}
.lbl{display:block;font-size:13px;font-weight:600;color:var(--mute);margin-bottom:6px}
.inp{width:100%;padding:11px 14px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--soft);font-family:inherit;font-size:14px;color:var(--ink);outline:none}
.inp:focus{border-color:var(--primary);background:#fff}
.btn{font-family:var(--font-body);font-weight:600;font-size:14px;border:none;border-radius:9999px;padding:11px 22px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-deep)}
.btn-primary:disabled{background:#d8d4cc;color:#fff;cursor:default}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{opacity:.85}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--soft)}
.btn-soft{background:var(--primary-soft);color:var(--primary);border:1px solid var(--primary-soft-line)}
.btn-soft:hover{background:rgba(73,79,223,.14)}

/* status pills */
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:9999px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;border:1px solid transparent}
.pill-primary{background:var(--primary-soft);color:var(--primary);border-color:var(--primary-soft-line)}
.pill-ok{background:rgba(42,160,106,.1);color:var(--ok);border-color:rgba(42,160,106,.3)}
.pill-warn{background:var(--warnBg);color:var(--warnText);border-color:rgba(224,138,44,.3)}
.pill-danger{background:rgba(209,73,58,.1);color:var(--dangerText);border-color:rgba(209,73,58,.3)}
.pill-muted{background:var(--line-soft);color:var(--stone);border-color:var(--line)}

/* data table (v2 spaced-row style) */
.dt{width:100%;font-size:14px;text-align:left;border-collapse:separate;border-spacing:0 10px}
.dt thead tr{color:var(--faint);font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em}
.dt thead th{padding:0 16px 10px;font-weight:500}
.dt tbody td{padding:14px 16px;background:var(--soft);color:var(--mute)}
.dt tbody td:first-child{border-radius:12px 0 0 12px;color:var(--ink)}
.dt tbody td:last-child{border-radius:0 12px 12px 0}

.toggle{width:42px;height:24px;border-radius:9999px;position:relative;flex-shrink:0;cursor:pointer;background:var(--faint);transition:.18s}
.toggle .knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.18s}
.toggle.on{background:var(--primary)}.toggle.on .knob{left:21px}
.swatch{width:34px;height:34px;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer;padding:0}
.swatch.on{box-shadow:0 0 0 2px currentColor}
@media(max-width:900px){.sidebar{position:absolute;z-index:50;height:100%}.grid2{grid-template-columns:1fr!important}}
