/* ============================================================
   AAI Networks — Ecosystem Design System
   ============================================================ */
:root{
  /* ---- dark theme (default) ---- */
  --bg:#0A0E1A;
  --bg-2:#0D1322;
  --surface:#121A2E;
  --surface-2:#16203A;
  --line:#202B47;
  --line-soft:#1A2438;
  --text:#EAF0FB;
  --text-2:#A7B2CC;
  --text-3:#6C7896;
  --brand:#2E6BFF;          /* on-dark brand (brightened from #123F9A for contrast) */
  --brand-ink:#5B8BFF;
  --brand-true:#123F9A;     /* exact logo blue */
  --cta-ink:#051022;        /* text color on accent buttons */
  --hero-glow-1:rgba(46,107,255,.16);
  --hero-glow-2:rgba(6,182,212,.10);
  --grid-line:#1A2438;
  --grid-mask:#000;
  --logo-light:none;
  --logo-dark:block;
  --shadow-card:0 20px 50px rgba(0,0,0,.45);
  --panel-shadow:0 30px 80px rgba(0,0,0,.5);
  --nav-bg:rgba(9,13,24,.66);
  --nav-bg-solid:rgba(9,13,24,.92);
  --hover-tint:rgba(255,255,255,.05);
  --soft-tint:rgba(255,255,255,.04);
  --panel-bg:linear-gradient(180deg,#0E1626,#0A1120);
  --panel-bar:rgba(255,255,255,.015);
  /* per-solution accents */
  --vigilo:#10B981;
  --emmisre:#3B82F6;
  --helix:#F59E0B;
  --wave:#06B6D4;
  --wave-2:#8B5CF6;
  --grep:#A855F7;
  --grep-2:#6366F1;
  /* active accent (set per page) */
  --accent:var(--brand);
  --accent-soft:rgba(46,107,255,.14);
  --radius:18px;
  --radius-sm:12px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-display:'Sora',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}

/* ---- light theme ---- */
html[data-theme="light"]{
  --bg:#F4F6FA;
  --bg-2:#FFFFFF;
  --surface:#FFFFFF;
  --surface-2:#F0F3F9;
  --line:#DCE3EF;
  --line-soft:#E8EDF5;
  --text:#0F1B33;
  --text-2:#46536E;
  --text-3:#7A879F;
  --brand:#123F9A;          /* exact logo blue reads well on light */
  --brand-ink:#0E347F;
  --cta-ink:#FFFFFF;
  --hero-glow-1:rgba(18,63,154,.10);
  --hero-glow-2:rgba(6,182,212,.08);
  --grid-line:#E4E9F2;
  --grid-mask:#000;
  --logo-light:block;
  --logo-dark:none;
  --shadow-card:0 18px 44px rgba(20,40,90,.10);
  --panel-shadow:0 24px 60px rgba(20,40,90,.12);
  --nav-bg:rgba(255,255,255,.72);
  --nav-bg-solid:rgba(255,255,255,.92);
  --hover-tint:rgba(18,63,154,.06);
  --soft-tint:rgba(18,63,154,.04);
  --panel-bg:linear-gradient(180deg,#FFFFFF,#F6F8FC);
  --panel-bar:rgba(18,63,154,.03);
  --accent-soft:rgba(18,63,154,.10);
  /* per-solution accents — slightly deepened for light contrast */
  --vigilo:#0E9C6E;
  --emmisre:#2563EB;
  --helix:#D97706;
  --wave:#0891B2;
  --grep:#7C3AED;
  --grep-2:#4F46E5;
}
html{transition:none}
html.theme-anim,html.theme-anim *{transition:background-color .4s ease,color .35s ease,border-color .35s ease,box-shadow .35s ease!important}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(900px 600px at 80% -5%, var(--hero-glow-1), transparent 60%),
    radial-gradient(700px 500px at 0% 10%, var(--hero-glow-2), transparent 55%),
    var(--bg);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),
                   linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 0,var(--grid-mask),transparent 70%);
          mask-image:radial-gradient(circle at 50% 0,var(--grid-mask),transparent 70%);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--accent);color:var(--cta-ink)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.mono{font-family:var(--font-mono)}
.eyebrow{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);font-weight:600;
  display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--accent);opacity:.7}

h1,h2,h3,.display{font-family:var(--font-display);font-weight:700;line-height:1.04;letter-spacing:-.02em}
.h-section{font-size:clamp(2rem,4.4vw,3.3rem);margin:.5rem 0 1rem}
.lede{color:var(--text-2);font-size:clamp(1rem,1.6vw,1.18rem);max-width:60ch}

/* ---------- Header / Nav (mega menu) ---------- */
.nav{
  position:sticky;top:0;z-index:90;
  backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);
  background:var(--nav-bg);
  border-bottom:1px solid transparent;
  transition:border-color .35s,background .35s,box-shadow .35s;
}
.nav.scrolled{border-bottom-color:var(--line);background:var(--nav-bg-solid);box-shadow:0 10px 30px rgba(0,0,0,.2)}
.nav-in{display:flex;align-items:center;gap:18px;height:96px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:-.01em;flex:none}
.brand .logo{
  width:36px;height:36px;border-radius:11px;display:grid;place-items:center;flex:none;
  background:linear-gradient(135deg,var(--brand),#1746c9);
  box-shadow:0 6px 20px rgba(46,107,255,.4);position:relative;overflow:hidden;
}
.brand .logo::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.25) 50%,transparent 60%);transform:translateX(-120%);transition:transform .6s}
.brand:hover .logo::after{transform:translateX(120%)}
.brand .logo svg{width:21px;height:21px;position:relative;z-index:1}
.brand small{display:block;font-family:var(--font-mono);font-size:.56rem;letter-spacing:.2em;color:var(--text-3);font-weight:500;margin-top:1px}

.nav-mid{display:flex;align-items:center;gap:2px;margin:0 auto}
.nav-link{
  display:inline-flex;align-items:center;gap:6px;background:none;border:none;
  font-family:var(--font-body);font-size:.92rem;color:var(--text-2);padding:9px 15px;border-radius:10px;font-weight:500;
  transition:color .2s,background .2s;position:relative;
}
.nav-link:hover{color:var(--text);background:var(--hover-tint)}
.nav-link.active{color:var(--text)}
.nav-link.active::after{content:"";position:absolute;left:15px;right:15px;bottom:3px;height:2px;border-radius:2px;background:var(--accent)}
.nav-link .chev{width:15px;height:15px;transition:transform .25s;opacity:.7}
.nav-item.has-mega:hover .chev,.nav-item.has-mega:focus-within .chev{transform:rotate(180deg)}

.nav-item{position:relative}
.mega{
  position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(8px);
  width:560px;background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line);border-radius:18px;padding:14px;
  box-shadow:0 30px 70px rgba(0,0,0,.55);opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;
}
.mega::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}
.nav-item.has-mega:hover .mega,.nav-item.has-mega:focus-within .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mega-item{display:flex;gap:13px;align-items:flex-start;padding:13px;border-radius:13px;border:1px solid transparent;transition:background .2s,border-color .2s,transform .2s}
.mega-item:hover{background:var(--soft-tint);border-color:color-mix(in srgb,var(--c) 40%,var(--line));transform:translateY(-2px)}
.mega-item.on{background:rgba(255,255,255,.03);border-color:color-mix(in srgb,var(--c) 35%,var(--line))}
.mega-ico{width:38px;height:38px;border-radius:10px;flex:none;display:grid;place-items:center;background:color-mix(in srgb,var(--c) 16%,transparent);color:var(--c);border:1px solid color-mix(in srgb,var(--c) 30%,transparent)}
.mega-ico svg{width:20px;height:20px}
.mega-tx{display:flex;flex-direction:column;gap:1px;min-width:0}
.mega-tx b{font-family:var(--font-display);font-size:.98rem;color:var(--text);font-weight:700}
.mega-tx small{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--c)}
.mega-tx em{font-style:normal;font-size:.78rem;color:var(--text-3);line-height:1.35;margin-top:3px}
.mega-foot{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:10px;padding:12px;border-radius:12px;background:rgba(46,107,255,.08);color:var(--brand-ink);font-weight:600;font-size:.86rem;border:1px solid rgba(46,107,255,.18);transition:background .2s}
.mega-foot:hover{background:rgba(46,107,255,.14)}
.mega-foot svg{width:16px;height:16px;transition:transform .2s}
.mega-foot:hover svg{transform:translateX(3px)}

.nav-end{flex:none;display:flex;align-items:center}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:var(--cta-ink);padding:10px 18px;border-radius:11px;
  font-weight:600;font-size:.9rem;border:none;transition:transform .2s,box-shadow .2s;
}
.nav-cta svg{width:16px;height:16px}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 12px 28px var(--accent-soft)}

/* hamburger */
.nav-toggle{display:none;flex:none;margin-left:auto;background:var(--hover-tint);border:1px solid var(--line);border-radius:11px;width:46px;height:46px;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:0}
.nav-toggle span{display:block;width:20px;height:2px;border-radius:2px;background:var(--text);transition:transform .3s var(--ease),opacity .2s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.drawer{position:fixed;top:0;right:0;height:100dvh;width:min(340px,82vw);z-index:95;
  background:linear-gradient(180deg,var(--bg-2),var(--bg));border-left:1px solid var(--line);
  transform:translateX(105%);transition:transform .42s var(--ease);overflow:hidden;display:none}
.drawer.open{transform:none}
.drawer-close{position:absolute;top:16px;right:16px;z-index:2;width:42px;height:42px;border-radius:11px;
  display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);color:var(--text);transition:background .2s,transform .2s}
.drawer-close:hover{background:var(--hover-tint)}
.drawer-close:active{transform:scale(.92)}
.drawer-close svg{width:22px;height:22px}
.drawer-scroll{height:100%;overflow-y:auto;padding:90px 22px 30px;-webkit-overflow-scrolling:touch}
.drawer-label{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);margin:18px 4px 12px}
.drawer-label:first-child{margin-top:0}
.drawer-sol{display:flex;flex-direction:column;gap:8px}
.dsol{display:flex;align-items:center;gap:13px;padding:13px;border-radius:13px;background:var(--surface);border:1px solid var(--line);transition:border-color .2s,transform .2s}
.dsol:active{transform:scale(.98)}
.dsol.on{border-color:color-mix(in srgb,var(--c) 45%,var(--line))}
.dsol-ico{width:38px;height:38px;border-radius:10px;flex:none;display:grid;place-items:center;background:color-mix(in srgb,var(--c) 16%,transparent);color:var(--c)}
.dsol-ico svg{width:20px;height:20px}
.dsol span:not(.dsol-ico){display:flex;flex-direction:column;min-width:0}
.dsol b{font-family:var(--font-display);font-size:1rem;color:var(--text)}
.dsol small{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}
.dsol>svg{width:18px;height:18px;color:var(--c);margin-left:auto;flex:none}
.dlink{display:block;padding:13px 14px;border-radius:11px;color:var(--text-2);font-size:1rem;font-weight:500;transition:background .2s,color .2s}
.dlink:hover,.dlink.on{background:var(--surface);color:var(--text)}
.drawer-cta{justify-content:center;width:100%;margin-top:18px}
.drawer-meta{display:flex;flex-direction:column;gap:9px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
.drawer-meta a,.drawer-meta span{color:var(--text-3);font-size:.86rem}
.drawer-meta a{transition:color .2s}.drawer-meta a:hover{color:var(--accent)}
.drawer-scrim{position:fixed;inset:0;z-index:94;background:rgba(4,7,15,.6);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;display:none}
.drawer-scrim.open{opacity:1;visibility:visible}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;
  padding:13px 24px;border-radius:12px;border:1px solid transparent;transition:transform .2s var(--ease),box-shadow .2s,background .2s;
}
.btn-primary{background:var(--accent);color:var(--cta-ink);box-shadow:0 8px 24px var(--accent-soft)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 34px var(--accent-soft)}
.btn-ghost{background:var(--soft-tint);border-color:var(--line);color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-3px)}
.btn svg{width:18px;height:18px}

/* ---------- Sections ---------- */
section{position:relative}
.section{padding:96px 0}
.section-head{max-width:680px;margin-bottom:54px}

/* ---------- Reveal ---------- */
.reveal{opacity:1;transform:none}
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js .reveal.in{opacity:1;transform:none}
/* CSS-only safety net: if JS stalls, force-show all reveals after 2.5s */
html.js .reveal{animation:revealsafe 0s linear 2.5s forwards}
@keyframes revealsafe{to{opacity:1;transform:none}}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.4s}

/* ---------- Cards ---------- */
.card{
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:26px;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
  position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--accent) 50%,var(--line));box-shadow:var(--shadow-card)}
.card-ico{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;
  background:var(--accent-soft);color:var(--accent);
}
.card-ico svg{width:24px;height:24px}
.card h3{font-size:1.18rem;margin-bottom:8px}
.card p{color:var(--text-2);font-size:.95rem}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);padding:64px 0 40px;margin-top:40px;background:var(--bg-2)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.footer h4{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);margin-bottom:16px}
.footer ul{list-style:none}
.footer li{margin-bottom:10px}
.footer a{color:var(--text-2);font-size:.92rem;transition:color .2s}
.footer a:hover{color:var(--accent)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:48px;padding-top:24px;border-top:1px solid var(--line);color:var(--text-3);font-size:.85rem}

/* ---------- Live dashboard primitives (kills the 'forms' look) ---------- */
.panel{
  background:var(--panel-bg);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--panel-shadow);
}
.panel-bar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--line);background:var(--panel-bar)}
.dot{width:11px;height:11px;border-radius:50%}
.dot.r{background:#ff5f57}.dot.y{background:#febc2e}.dot.g{background:#28c840}
.panel-title{margin-left:8px;font-family:var(--font-mono);font-size:.74rem;color:var(--text-3);letter-spacing:.04em}
.live-tag{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.66rem;color:var(--vigilo);text-transform:uppercase;letter-spacing:.12em}
.live-tag::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--vigilo);box-shadow:0 0 0 0 rgba(16,185,129,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.55)}70%{box-shadow:0 0 0 8px rgba(16,185,129,0)}100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}}

.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:16px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px}
.kpi .lab{font-size:.72rem;color:var(--text-3);letter-spacing:.02em}
.kpi .val{font-family:var(--font-display);font-weight:700;font-size:1.5rem;margin-top:4px}
.kpi .val.accent{color:var(--accent)}

/* animated bar chart */
.chart{padding:8px 18px 20px}
.chart-title{font-size:.82rem;color:var(--text-2);margin:6px 0 14px;display:flex;justify-content:space-between}
.bars{display:flex;align-items:flex-end;gap:10px;height:130px}
.bar{flex:1;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 30%,transparent));
  height:0;transition:height 1.1s var(--ease);min-width:8px;position:relative}
.bar span{position:absolute;top:-18px;left:0;right:0;text-align:center;font-family:var(--font-mono);font-size:.64rem;color:var(--text-3)}

/* donut */
.donut-wrap{display:flex;align-items:center;gap:20px;padding:18px}
.donut{width:120px;height:120px;flex:none}
.legend{display:flex;flex-direction:column;gap:7px;font-size:.78rem}
.legend i{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:8px}
.legend span{color:var(--text-2)}.legend b{color:var(--text);margin-left:auto;font-family:var(--font-mono);font-size:.74rem}
.legend>div{display:flex;align-items:center;min-width:150px}

/* status table */
.tbl{width:100%;border-collapse:collapse;font-size:.82rem}
.tbl th{text-align:left;padding:11px 16px;color:var(--text-3);font-weight:600;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.tbl td{padding:12px 16px;border-bottom:1px solid var(--line-soft);color:var(--text-2)}
.tbl tr:last-child td{border-bottom:none}
.pill{display:inline-block;padding:3px 11px;border-radius:20px;font-size:.7rem;font-weight:600}
.pill.ok{background:rgba(16,185,129,.16);color:#34d399}
.pill.warn{background:rgba(245,158,11,.16);color:#fbbf24}
.pill.info{background:rgba(59,130,246,.16);color:#60a5fa}

/* ---------- Stat counters ---------- */
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.stat-band>div{background:var(--bg-2);padding:30px 24px;text-align:center}
.stat-band .n{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,4vw,2.9rem);color:var(--accent);letter-spacing:-.02em}
.stat-band .l{color:var(--text-3);font-size:.84rem;margin-top:4px}

/* ---------- Ecosystem grid ---------- */
.eco-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.eco-card-grep{grid-column:1 / -1;background:linear-gradient(120deg,color-mix(in srgb,var(--grep) 10%,var(--surface)),var(--bg-2))}
.eco-card-grep .eco-name{display:flex;align-items:center}
.eco-card{
  display:block;border-radius:var(--radius);padding:30px;position:relative;overflow:hidden;
  background:linear-gradient(155deg,var(--surface),var(--bg-2));
  border:1px solid var(--line);transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
}
.eco-card::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(140deg,var(--c,var(--accent)),transparent 55%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s}
.eco-card:hover{transform:translateY(-8px);box-shadow:0 30px 70px rgba(0,0,0,.5)}
.eco-card:hover::after{opacity:1}
.eco-glow{position:absolute;width:280px;height:280px;border-radius:50%;filter:blur(70px);opacity:.18;top:-90px;right:-90px;background:var(--c,var(--accent));pointer-events:none;transition:opacity .4s}
.eco-card:hover .eco-glow{opacity:.34}
.eco-top{display:flex;align-items:center;gap:14px;margin-bottom:18px;position:relative}
.eco-mark{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;flex:none;
  background:color-mix(in srgb,var(--c,var(--accent)) 16%,transparent);color:var(--c,var(--accent));border:1px solid color-mix(in srgb,var(--c) 35%,transparent)}
.eco-mark svg{width:26px;height:26px}
.eco-name{font-family:var(--font-display);font-weight:700;font-size:1.35rem}
.eco-cat{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c,var(--accent))}
.eco-card p{color:var(--text-2);font-size:.95rem;margin-bottom:18px;position:relative}
.eco-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;position:relative}
.eco-meta span{font-size:.74rem;color:var(--text-3);background:var(--soft-tint);border:1px solid var(--line);padding:4px 10px;border-radius:7px}
.eco-link{display:inline-flex;align-items:center;gap:7px;color:var(--c,var(--accent));font-weight:600;font-size:.9rem;position:relative}
.eco-link svg{width:16px;height:16px;transition:transform .25s}
.eco-card:hover .eco-link svg{transform:translateX(4px)}

/* feature list */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{padding:24px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--line);transition:border-color .3s,transform .3s}
.feat:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--line));transform:translateY(-4px)}
.feat .fi{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent);margin-bottom:14px}
.feat .fi svg{width:22px;height:22px}
.feat h4{font-family:var(--font-display);font-size:1.05rem;margin-bottom:6px}
.feat p{color:var(--text-2);font-size:.9rem}

/* process / timeline */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.flow-step{padding:0 18px;position:relative}
.flow-step .num{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);font-weight:600}
.flow-step .node{width:16px;height:16px;border-radius:50%;background:var(--accent);margin:16px 0;position:relative;z-index:2;box-shadow:0 0 0 5px var(--accent-soft)}
.flow-line{position:absolute;top:calc(1.2rem + 24px);left:0;right:0;height:2px;background:var(--line)}
.flow-step h4{font-family:var(--font-display);font-size:1.1rem;margin-bottom:6px}
.flow-step p{color:var(--text-2);font-size:.88rem}

/* CTA band */
.cta-band{position:relative;border-radius:26px;overflow:hidden;padding:64px 48px;text-align:center;
  background:linear-gradient(140deg,var(--surface),var(--bg-2));border:1px solid var(--line)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 50% 0,var(--accent-soft),transparent 70%)}
.cta-band>*{position:relative}
.cta-band h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:14px}
.cta-band p{color:var(--text-2);max-width:54ch;margin:0 auto 28px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* page hero (solution) */
.shero{padding:80px 0 60px;position:relative}
.shero .badge{display:inline-flex;align-items:center;gap:9px;padding:7px 14px;border-radius:30px;
  background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);
  color:var(--accent);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.shero h1{font-size:clamp(2.4rem,6vw,4.3rem);margin:22px 0 18px}
.shero h1 em{font-style:normal;color:var(--accent)}
.shero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}

/* split feature row */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-bottom:64px}
.split:nth-child(even) .split-media{order:-1}
.split h3{font-size:1.6rem;margin-bottom:12px}
.split p{color:var(--text-2);margin-bottom:18px}
.split ul{list-style:none}
.split li{display:flex;gap:11px;align-items:flex-start;margin-bottom:11px;color:var(--text-2);font-size:.95rem}
.split li svg{width:20px;height:20px;color:var(--accent);flex:none;margin-top:1px}

/* breadcrumb of solutions */
.solnav{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:14px}
.solnav a{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  padding:7px 14px;border-radius:30px;border:1px solid var(--line);color:var(--text-3);transition:all .25s}
.solnav a:hover,.solnav a.active{border-color:var(--c);color:var(--c)}

/* marquee */
.marq{overflow:hidden;border-block:1px solid var(--line);padding:22px 0;background:var(--bg-2);-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marq-track{display:flex;gap:54px;width:max-content;animation:scrollx 32s linear infinite}
.marq:hover .marq-track{animation-play-state:paused}
.marq span{font-family:var(--font-display);font-weight:600;color:var(--text-3);font-size:1.05rem;white-space:nowrap;display:flex;align-items:center;gap:14px}
.marq span::after{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.6}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- Contact form ---------- */
.cform{padding:24px}
.cform label{display:block;font-size:.82rem;color:var(--text-2);font-weight:500;margin-bottom:16px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform input,.cform textarea{
  width:100%;margin-top:7px;background:var(--bg-2);border:1px solid var(--line);border-radius:11px;
  padding:12px 14px;color:var(--text);font-family:var(--font-body);font-size:.95rem;transition:border-color .2s,box-shadow .2s;resize:vertical;
}
.cform input::placeholder,.cform textarea::placeholder{color:var(--text-3)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:9px}
.chip{
  font-family:var(--font-body);font-size:.82rem;color:var(--text-2);background:var(--bg-2);
  border:1px solid var(--line);border-radius:30px;padding:7px 14px;transition:all .2s;font-weight:500;
}
.chip:hover{border-color:color-mix(in srgb,var(--c,var(--accent)) 45%,var(--line));color:var(--text)}
.chip.on{background:color-mix(in srgb,var(--c,var(--accent)) 16%,transparent);border-color:var(--c,var(--accent));color:var(--text)}
.fnote{font-size:.8rem;color:var(--text-3);margin-top:14px;line-height:1.5}
.fnote.err{color:#fb7185}.fnote.ok{color:#34d399}
.cchannels{display:flex;flex-direction:column;gap:10px}
.cchan{display:flex;align-items:center;gap:14px;padding:16px;border-radius:14px;background:var(--surface);border:1px solid var(--line);transition:border-color .2s,transform .2s}
a.cchan:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--line));transform:translateY(-3px)}
.cc-ico{width:42px;height:42px;border-radius:11px;flex:none;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}
.cc-ico svg{width:21px;height:21px}
.cchan b{display:block;font-family:var(--font-display);font-size:.98rem;color:var(--text)}
.cchan small{color:var(--text-3);font-size:.86rem}
.creach{margin-top:18px;padding:18px;border-radius:14px;background:var(--bg-2);border:1px solid var(--line)}
.rpill{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-2);background:var(--soft-tint);border:1px solid var(--line);padding:6px 12px;border-radius:8px}
.rpill svg{width:14px;height:14px;color:var(--accent)}

/* ---------- Logo image (theme-synced) ---------- */
.brand{display:flex;align-items:center;flex:none;gap:0}
.brand .logo-img{height:46px;width:auto;max-width:130px;display:block;object-fit:contain}
.brand .logo-img.l-light{display:var(--logo-light)}
.brand .logo-img.l-dark{display:var(--logo-dark)}

/* GREP AI nav tab — distinct font + gradient */
.ai-pill{
  font-family:var(--font-mono);font-style:normal;font-size:.58em;font-weight:700;letter-spacing:.08em;
  background:linear-gradient(120deg,var(--grep),var(--grep-2));color:#fff;
  padding:2px 6px;border-radius:6px;margin-left:6px;vertical-align:middle;line-height:1;
  display:inline-block;box-shadow:0 2px 10px rgba(168,85,247,.35);
}
.nav-grep{font-family:var(--font-display);font-weight:700;letter-spacing:.01em;
  background:linear-gradient(120deg,var(--grep),var(--grep-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.nav-grep .ai-pill{-webkit-text-fill-color:#fff}
.nav-grep:hover{background:linear-gradient(120deg,var(--grep),var(--grep-2));-webkit-background-clip:text;background-clip:text;opacity:.85}
.nav-grep.active::after{background:var(--grep)}
.mega-grep{grid-column:1 / -1;background:linear-gradient(120deg,color-mix(in srgb,var(--grep) 12%,transparent),transparent);border:1px solid color-mix(in srgb,var(--grep) 30%,var(--line))!important;margin-top:4px}
.mega-grep .mega-tx b{display:flex;align-items:center}
.dsol-grep{background:linear-gradient(120deg,color-mix(in srgb,var(--grep) 14%,transparent),var(--surface))}
.dsol-grep b{display:flex;align-items:center}

/* ---------- Theme toggle ---------- */
.theme-toggle{
  position:relative;width:58px;height:30px;border-radius:30px;flex:none;
  background:var(--surface-2);border:1px solid var(--line);padding:0;
  transition:background .3s,border-color .3s;
}
.theme-toggle .tt-thumb{
  position:absolute;top:2px;left:2px;width:24px;height:24px;border-radius:50%;
  background:var(--accent);display:grid;place-items:center;color:var(--cta-ink);
  transition:transform .35s var(--ease),background .3s;
}
html[data-theme="light"] .theme-toggle .tt-thumb{transform:translateX(28px)}
.theme-toggle svg{width:14px;height:14px}
.theme-toggle .tt-sun{display:none}
.theme-toggle .tt-moon{display:block}
html[data-theme="light"] .theme-toggle .tt-sun{display:block}
html[data-theme="light"] .theme-toggle .tt-moon{display:none}
.nav-end{gap:12px}
.drawer-theme{display:flex;align-items:center;justify-content:space-between;padding:14px;border-radius:13px;background:var(--surface);border:1px solid var(--line);margin-top:6px}
.drawer-theme span{font-size:.95rem;color:var(--text-2);font-weight:500}

/* ---------- North Star page loader ---------- */
.starloader{
  position:fixed;inset:0;z-index:2000;display:grid;place-items:center;
  background:var(--bg);opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .5s var(--ease),visibility .5s;
}
.starloader.show{opacity:1;visibility:visible;pointer-events:auto}
.starloader::before{content:"";position:absolute;inset:0;
  background:radial-gradient(600px 400px at 50% 45%,var(--accent-soft),transparent 60%)}
.sl-core{position:relative;width:200px;height:200px;display:grid;place-items:center}
.sl-star{position:relative;z-index:3;width:64px;height:64px;color:var(--accent);animation:slspin 3.4s linear infinite}
.sl-star svg{width:100%;height:100%;filter:drop-shadow(0 0 14px var(--accent-soft))}
@keyframes slspin{to{transform:rotate(360deg)}}
.sl-ring{position:absolute;border-radius:50%;border:1px solid var(--line);}
.sl-ring.r1{width:120px;height:120px;animation:slpulse 2s ease-in-out infinite}
.sl-ring.r2{width:170px;height:170px;animation:slpulse 2s ease-in-out infinite .4s}
.sl-ring.r3{width:200px;height:200px;animation:slpulse 2s ease-in-out infinite .8s}
@keyframes slpulse{0%,100%{opacity:.2;transform:scale(.96)}50%{opacity:.6;transform:scale(1.02)}}
.sl-orbit{position:absolute;width:170px;height:170px;animation:slspin 6s linear infinite reverse}
.sl-orbit i{position:absolute;top:-3px;left:50%;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);margin-left:-3px}
.sl-label{position:absolute;bottom:-46px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--text-3);white-space:nowrap}
.sl-label::after{content:"";animation:sldots 1.4s steps(4,end) infinite}
@keyframes sldots{0%{content:""}25%{content:"·"}50%{content:"··"}75%{content:"···"}}

/* page entrance */
.page-enter{animation:pagein .6s var(--ease)}
@keyframes pagein{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* footer social */
.foot-brand-sub{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3)}
.foot-social{display:flex;gap:10px;margin-top:18px}
.foot-social a{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;
  background:var(--brand);border:1px solid var(--brand);color:#fff;transition:all .2s var(--ease)}
.foot-social a:hover{transform:translateY(-3px);opacity:.85;box-shadow:0 8px 20px var(--accent-soft)}
.foot-social svg{width:20px;height:20px}

/* hero solution list */
.sol-header{display:flex;align-items:center;gap:16px;padding-bottom:8px}
.sol-mark{width:60px;height:60px;border-radius:15px;flex:none;display:grid;place-items:center;
  background:color-mix(in srgb,var(--c) 15%,transparent);color:var(--c);
  border:1px solid color-mix(in srgb,var(--c) 38%,transparent)}
.sol-mark svg{width:32px;height:32px}
.sol-logo{padding:0!important;background:none!important;border:none!important;width:60px;height:60px}
.sol-logo svg{width:60px;height:60px}
.sol-name{font-family:var(--font-display);font-weight:800;font-size:clamp(1.7rem,4vw,2.3rem);letter-spacing:-.02em;line-height:1;color:var(--text)}
.sol-cat{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--c);margin-top:6px}
.hero-sol-list{list-style:none;display:flex;flex-direction:column;gap:11px}
.hero-sol-list li{display:flex;align-items:center;gap:11px;color:var(--text-2);font-size:1.02rem}
.hero-sol-list li b{color:var(--text);font-weight:600;font-family:var(--font-display)}
.hs-dot{width:9px;height:9px;border-radius:50%;flex:none}

/* ecosystem hub visual */
.eco-hub{position:relative;width:100%;max-width:460px;aspect-ratio:1;margin:0 auto}
.eco-hub-lines{position:absolute;inset:0;width:100%;height:100%}
.eco-hub-lines line{stroke:var(--line);stroke-width:2;stroke-dasharray:5 6;animation:dash 22s linear infinite}
@keyframes dash{to{stroke-dashoffset:-200}}
.hub-core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:128px;height:128px;border-radius:50%;display:grid;place-items:center;align-content:center;z-index:3;
  background:radial-gradient(circle at 30% 30%,color-mix(in srgb,var(--grep) 40%,transparent),color-mix(in srgb,var(--grep-2) 35%,transparent));
  border:1px solid color-mix(in srgb,var(--grep) 55%,transparent);
  box-shadow:0 0 50px color-mix(in srgb,var(--grep) 40%,transparent),inset 0 0 30px color-mix(in srgb,var(--grep) 20%,transparent);
  animation:corepulse 3s ease-in-out infinite}
@keyframes corepulse{0%,100%{box-shadow:0 0 40px color-mix(in srgb,var(--grep) 35%,transparent),inset 0 0 30px color-mix(in srgb,var(--grep) 18%,transparent)}50%{box-shadow:0 0 64px color-mix(in srgb,var(--grep) 55%,transparent),inset 0 0 36px color-mix(in srgb,var(--grep) 26%,transparent)}}
.hub-core span{font-family:var(--font-display);font-weight:800;font-size:1.45rem;color:#fff;letter-spacing:.01em;line-height:1}
.hub-core small{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.2em;color:rgba(255,255,255,.85);margin-top:4px}
/* all four nodes identical fixed size, content centered, text on one line */
.hub-node{position:absolute;width:120px;height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;z-index:2;
  background:var(--surface);border:1px solid color-mix(in srgb,var(--c) 40%,var(--line));border-radius:18px;padding:12px;
  box-shadow:0 12px 30px rgba(0,0,0,.3);transition:transform .3s var(--ease),box-shadow .3s}
.hub-node svg{width:26px;height:26px;color:var(--c)}
.hub-logo{display:block;width:42px;height:42px}
.hub-logo svg{width:42px;height:42px}
.eco-logo{padding:0!important;background:none!important;border:none!important;width:48px;height:48px}
.eco-logo svg{width:48px;height:48px}
.hub-node span{font-family:var(--font-display);font-weight:600;font-size:.86rem;color:var(--text);text-align:center;white-space:nowrap;line-height:1.1}
.hub-node.n-top{top:0;left:50%;transform:translateX(-50%)}
.hub-node.n-top:hover{transform:translateX(-50%) scale(1.06)}
.hub-node.n-bottom{bottom:0;left:50%;transform:translateX(-50%)}
.hub-node.n-bottom:hover{transform:translateX(-50%) scale(1.06)}
.hub-node.n-left{left:0;top:50%;transform:translateY(-50%)}
.hub-node.n-left:hover{transform:translateY(-50%) scale(1.06)}
.hub-node.n-right{right:0;top:50%;transform:translateY(-50%)}
.hub-node.n-right:hover{transform:translateY(-50%) scale(1.06)}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .foot-grid{grid-template-columns:1fr 1fr}
  .eco-grid,.feat-grid,.shero-grid,.split,.kpi-row,#hero-grid,.contact-layout{grid-template-columns:1fr!important}
  .frow{grid-template-columns:1fr}
  .split:nth-child(even) .split-media{order:0}
  .stat-band{grid-template-columns:1fr 1fr}
  .flow{grid-template-columns:1fr 1fr;gap:32px 0}
  .flow-line{display:none}
  .kpi-row{grid-template-columns:1fr 1fr}
}
@media(max-width:980px){
  .nav-mid,.nav-end{display:none}
  .nav-toggle{display:flex}
  .drawer,.drawer-scrim{display:block}
  .nav-in{height:76px}
  .brand .logo-img{height:46px;max-width:200px}
}
@media(max-width:760px){
  .section{padding:64px 0}
  .donut-wrap{flex-direction:column}
  .cta-band{padding:44px 24px}
  .legend>div{min-width:0;width:100%}
}
@media(max-width:520px){
  .stat-band,.flow{grid-template-columns:1fr}
  .kpi-row{grid-template-columns:1fr 1fr}
  .wrap{padding:0 18px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
/* ================= GREP AI PAGE ================= */
.grep-hero{padding:60px 0 50px;position:relative;overflow:hidden}
.grep-hero::before{content:"";position:absolute;top:-20%;left:50%;transform:translateX(-50%);width:900px;height:600px;
  background:radial-gradient(circle,color-mix(in srgb,var(--grep) 18%,transparent),transparent 65%);z-index:-1;pointer-events:none}
.grep-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--grep);background:color-mix(in srgb,var(--grep) 12%,transparent);border:1px solid color-mix(in srgb,var(--grep) 35%,transparent);
  padding:8px 16px;border-radius:30px;margin-bottom:22px}
.grep-badge svg{width:15px;height:15px}
.grep-title{font-family:var(--font-display);font-weight:800;font-size:clamp(3.4rem,9vw,6rem);letter-spacing:-.03em;line-height:1;margin:0;
  background:linear-gradient(120deg,var(--grep),var(--grep-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.grep-sub{font-family:var(--font-mono);font-size:.9rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);margin-top:14px}
.grep-chat{max-width:680px;margin:44px auto 0}
.chat-body{padding:20px;display:flex;flex-direction:column;gap:14px}
.msg{max-width:85%;padding:13px 16px;border-radius:14px;font-size:.95rem;line-height:1.5}
.msg.user{align-self:flex-end;background:var(--accent,var(--brand));color:var(--cta-ink);border-bottom-right-radius:4px}
.msg.ai{align-self:flex-start;background:var(--surface-2);border:1px solid var(--line);color:var(--text);display:flex;gap:10px;border-bottom-left-radius:4px}
.msg.ai b{color:var(--grep)}
.msg-ai-mark{flex:none;width:24px;height:24px;border-radius:7px;display:grid;place-items:center;
  background:linear-gradient(120deg,var(--grep),var(--grep-2));color:#fff}
.msg-ai-mark svg{width:15px;height:15px}
.chat-input{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 20px 20px;padding:13px 16px;
  border:1px solid var(--line);border-radius:12px;background:var(--bg-2);color:var(--text-3);font-size:.92rem}
.chat-input svg{width:18px;height:18px;color:var(--grep)}
.grep-band{position:relative;border:1px solid color-mix(in srgb,var(--grep) 28%,var(--line));border-radius:var(--radius);
  background:linear-gradient(160deg,color-mix(in srgb,var(--grep) 10%,var(--surface)),var(--bg-2));padding:48px 32px;overflow:hidden}
.grep-band-glow{position:absolute;top:-40%;right:-10%;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--grep) 16%,transparent),transparent 65%);pointer-events:none}
.grep-mods{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.grep-mods span{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:11px;font-weight:600;font-family:var(--font-display);
  background:var(--surface);border:1px solid color-mix(in srgb,var(--c) 40%,var(--line));color:var(--text)}
.grep-mods span svg{width:18px;height:18px;color:var(--c)}

/* ================= DEMO DASHBOARDS ================= */
.demo-banner{background:linear-gradient(120deg,color-mix(in srgb,var(--grep) 16%,var(--surface)),var(--surface));
  border-bottom:1px solid var(--line);padding:11px 0;font-size:.88rem;color:var(--text-2)}
.demo-banner .wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;text-align:center}
.demo-banner svg{width:16px;height:16px;color:var(--grep);flex:none}
.demo-banner b{color:var(--text)}
.demo-banner a{color:var(--grep);font-weight:600;display:inline-flex;align-items:center;gap:5px}
.demo-banner a svg{width:14px;height:14px;color:var(--grep)}
.dashboard{display:grid;grid-template-columns:248px 1fr;min-height:80vh;max-width:1320px;margin:0 auto}
.ds-side{border-right:1px solid var(--line);padding:22px 16px;display:flex;flex-direction:column;gap:6px;background:var(--bg-2)}
.ds-side-head{display:flex;align-items:center;gap:11px;padding:8px 10px 18px;border-bottom:1px solid var(--line);margin-bottom:10px}
.ds-logo{width:42px;height:42px;border-radius:11px;flex:none;display:grid;place-items:center;background:color-mix(in srgb,var(--c) 15%,transparent);color:var(--c);border:1px solid color-mix(in srgb,var(--c) 35%,transparent)}
.ds-logo svg{width:22px;height:22px}
.ds-logo-bold{padding:0!important;background:none!important;border:none!important;width:42px;height:42px}
.ds-logo-bold svg{width:42px;height:42px}
.ds-side-head b{font-family:var(--font-display);font-size:1.05rem;display:block;color:var(--text)}
.ds-side-head small{color:var(--text-3);font-size:.74rem}
.ds-nav-list{display:flex;flex-direction:column;gap:3px;flex:1}
.ds-nav{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:10px;color:var(--text-2);font-size:.92rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s}
.ds-nav svg{width:19px;height:19px;flex:none}
.ds-nav:hover{background:var(--hover-tint);color:var(--text)}
.ds-nav.on{background:color-mix(in srgb,var(--c) 14%,transparent);color:var(--c)}
.ds-back{margin-top:14px;padding:11px 13px;color:var(--text-3);font-size:.85rem;border-top:1px solid var(--line)}
.ds-back:hover{color:var(--text)}
.ds-main{padding:26px 30px;min-width:0}
.ds-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.ds-top h1{font-family:var(--font-display);font-size:1.7rem;font-weight:700;color:var(--text)}
.ds-top p{color:var(--text-3);font-size:.9rem;margin-top:3px}
.ds-top-actions{display:flex;align-items:center;gap:10px}
.ds-search{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border:1px solid var(--line);border-radius:10px;color:var(--text-3);font-size:.85rem;background:var(--surface)}
.ds-search svg{width:15px;height:15px}
.ds-bell{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;color:var(--text-2);background:var(--surface)}
.ds-bell svg{width:17px;height:17px}
.ds-user{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-weight:700;color:var(--cta-ink);background:var(--c)}
.ds-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.ds-kpi{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px}
.ds-kpi-l{color:var(--text-3);font-size:.82rem;margin-bottom:8px}
.ds-kpi-v{font-family:var(--font-display);font-weight:700;font-size:1.9rem;color:var(--text)}
.ds-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.ds-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px}
.ds-card-h{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:var(--text);margin-bottom:16px;font-size:.95rem}
.ds-card-h span{font-family:var(--font-mono);font-size:.72rem;color:var(--text-3);font-weight:400}
.ds-bars{display:flex;align-items:flex-end;gap:9px;height:150px}
.ds-bar{flex:1;background:linear-gradient(180deg,var(--c),color-mix(in srgb,var(--c) 35%,transparent));border-radius:7px 7px 0 0;height:var(--bh,40%);min-height:8px;transition:height 1s var(--ease)}
.ds-bar-labels{display:flex;gap:9px;margin-top:8px}
.ds-bar-labels span{flex:1;text-align:center;font-size:.68rem;color:var(--text-3);font-family:var(--font-mono)}
.ds-legend{display:flex;flex-direction:column;gap:11px}
.ds-legend>div{display:flex;align-items:center;gap:9px;font-size:.88rem;color:var(--text-2)}
.ds-legend i{width:11px;height:11px;border-radius:3px;flex:none}
.ds-legend b{margin-left:auto;color:var(--text);font-family:var(--font-mono)}
.ds-donut-wrap{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.ds-donut{width:130px;height:130px;flex:none;transform:rotate(-90deg)}
.ds-meter{height:9px;border-radius:6px;background:var(--surface-2);overflow:hidden}
.ds-meter span{display:block;height:100%;border-radius:6px;transition:width 1s var(--ease)}
.ds-table{width:100%;border-collapse:collapse;font-size:.88rem}
.ds-table thead td{color:var(--text-3);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono);padding-bottom:10px;border-bottom:1px solid var(--line)}
.ds-table td{padding:13px 10px;border-bottom:1px solid var(--line-soft);color:var(--text-2)}
.ds-table tr:last-child td{border-bottom:none}
.ds-table td:first-child{color:var(--text);font-weight:500}

@media(max-width:900px){
  .dashboard{grid-template-columns:1fr}
  .ds-side{flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--line);gap:8px;align-items:center}
  .ds-side-head{border-bottom:none;padding:6px 8px;margin:0;flex:none}
  .ds-nav-list{flex-direction:row;flex:none}
  .ds-nav span{display:none}
  .ds-back{border-top:none;white-space:nowrap;flex:none}
  .ds-kpis{grid-template-columns:repeat(2,1fr)}
  .ds-grid-2{grid-template-columns:1fr}
}
