/* ═════════════════════════════════════════════════
   Autonowmy · shared design system
   Warm-dark Actively-style. One accent. Editorial.
   ═════════════════════════════════════════════════ */
:root{
  /* ── Surfaces (warm dark) ── */
  --bg:#0B0A09;
  --bg-2:#15130F;
  --bg-3:#1E1B16;
  --bg-4:#2A2620;
  --rule:#2A2620;
  --rule-2:#3A352D;

  /* ── Ink (cream) ── */
  --ink:#F2EFE8;
  --ink-2:#D9D5CB;
  --mute:#8B8780;
  --mute-2:#5F5C55;

  /* ── Accents
     We keep multi-token names so existing pages don't break, but
     the palette is intentionally restrained: one true accent (trace blue)
     plus three muted siblings used sparingly for severity / status. ── */
  --blue:#5B8DEF;          /* primary accent — used sparingly */
  --violet:#7A6FE0;        /* tuned warmer + muted */
  --green:#7FBD8A;
  --cyan:#6FB8C8;
  --warn:#D4AF55;
  --bad:#E0805B;

  /* Legacy compatibility */
  --trace:var(--blue);
  --good:var(--green);

  /* ── Type ── */
  --h:'Space Grotesk', system-ui, sans-serif;
  --b:'DM Sans', system-ui, sans-serif;
  --m:'JetBrains Mono', ui-monospace, monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--b);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-size:15px;line-height:1.55}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
@media (max-width:780px){ .wrap{padding:0 20px} }

/* ── No aurora. No animated gradients. Just a single soft hero glow. ── */
body::before{ display:none }

/* ── Type ───────────────────────────────────────── */
.eyebrow{font-family:var(--m);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--mute);display:inline-flex;align-items:center;gap:10px;white-space:nowrap}
.eyebrow::before{content:"";width:5px;height:5px;background:var(--mute);border-radius:50%}
.eyebrow.blue::before  {background:var(--blue)}
.eyebrow.violet::before{background:var(--violet)}
.eyebrow.green::before {background:var(--green)}
.eyebrow.cyan::before  {background:var(--cyan)}

h1.hero{font-family:var(--h);font-weight:500;font-size:clamp(46px,7vw,108px);line-height:.97;letter-spacing:-.035em;margin:0;text-wrap:balance}
h2.sec{font-family:var(--h);font-weight:500;font-size:clamp(34px,5vw,72px);line-height:1.02;letter-spacing:-.03em;margin:0;text-wrap:balance}
h3.sub{font-family:var(--h);font-weight:500;font-size:clamp(24px,2.4vw,34px);line-height:1.15;letter-spacing:-.02em;margin:0}
.lead{font-family:var(--b);font-size:clamp(16px,1.4vw,19px);line-height:1.55;color:var(--ink-2);max-width:58ch}
em.dim{font-style:italic;color:var(--mute);font-weight:400}

/* ── Animated neon gradient text — matches autonowmy.com (cool tones, no amber) ── */
.neon{
  background:linear-gradient(
    90deg,
    #60A5FA 0%,
    #A78BFA 30%,
    #4ADE80 60%,
    #22D3EE 85%,
    #60A5FA 100%
  );
  background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;
  color:transparent;-webkit-text-fill-color:transparent;
  animation:neonShift 7s linear infinite;
  filter:drop-shadow(0 0 22px rgba(96,165,250,.18));
}
.neon.italic{font-style:italic;font-weight:400}
.neon.bold{font-weight:500}
@keyframes neonShift{
  0%{background-position:0% 50%}
  100%{background-position:300% 50%}
}

/* ── Subtle hairline divider (was the neon ribbon) ── */
.neon-ribbon{
  appearance:none;border:0;height:1px;width:100%;margin:0;
  background:linear-gradient(90deg,
    transparent 0%,
    var(--rule) 18%,
    var(--rule-2) 50%,
    var(--rule) 82%,
    transparent 100%);
}

/* ── Brand mark — replaces traffic-light dots in product UI chrome ── */
.uiph .chrome .brand-mark{
  width:11px;height:11px;border-radius:50%;flex:0 0 11px;
  background:radial-gradient(circle at 35% 35%, #fafafa 0%, #6f6a60 60%, #2a2620 100%);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}

/* ── Trademark glyph (used after "Per-Operation Agents") ── */
.tm{font-family:var(--m);font-size:.5em;vertical-align:super;color:var(--mute);font-weight:400;margin-left:1px;letter-spacing:0}

/* ── Buttons ────────────────────────────────────── */
.btn{
  font-family:var(--b);font-weight:500;font-size:13.5px;
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:999px;line-height:1;cursor:pointer;white-space:nowrap;
  transition:transform .15s ease, background .15s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease;
  border:0;
}
.btn.primary,.btn.cream{background:var(--ink);color:#0B0A09}
.btn.primary:hover,.btn.cream:hover{transform:translateY(-1px);background:#fff}
.btn.ghost{color:var(--ink-2);border:1px solid var(--rule)}
.btn.ghost:hover{color:var(--ink);border-color:var(--rule-2)}
.btn.bare{color:var(--ink-2)}
.btn.bare:hover{color:var(--ink)}
.btn .arr{font-family:var(--m);font-size:14px;line-height:1}

/* ── Top banner — inline header strip above the nav; shows once per load, then collapses ── */
.banner{
  position:relative;
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:10px 22px;
  background:var(--bg-2);
  font-family:var(--b);font-size:12.5px;color:var(--ink-2);letter-spacing:-.002em;
  overflow:hidden;
  max-height:60px;
  opacity:1;
  transition:max-height .55s cubic-bezier(.4,0,.2,1),
             opacity .35s ease,
             padding .55s cubic-bezier(.4,0,.2,1);
}
.banner.hidden{
  max-height:0;opacity:0;padding-top:0;padding-bottom:0;pointer-events:none;
}
.banner .dot{width:6px;height:6px;border-radius:50%;background:var(--blue);box-shadow:0 0 10px rgba(91,141,239,.55);flex:0 0 6px}
.banner .msg{display:inline-block;transition:opacity .25s ease, transform .25s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100vw - 80px)}
.banner .msg.fade{opacity:0;transform:translateY(-3px)}
.banner a{color:var(--ink);font-weight:500;border-bottom:1px solid var(--rule-2);padding-bottom:1px;white-space:nowrap}
.banner a:hover{border-color:var(--ink)}
@media (max-width:640px){ .banner{font-size:11.5px;padding:9px 16px} }

/* ── Nav — slim, no separator line, right-aligned menu ── */
nav.top{
  position:sticky;top:0;z-index:50;
  background:rgba(11,10,9,.78);backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
}
nav.top .inner{display:flex;align-items:center;justify-content:space-between;height:52px}
nav.top .logo{display:inline-flex;align-items:center;height:30px}
nav.top .logo img{height:22px;width:auto;display:block}
nav.top .right{display:flex;align-items:center;gap:22px;margin-left:auto}
nav.top ul{display:flex;align-items:center;gap:24px;list-style:none;margin:0;padding:0}
nav.top ul li{font-size:13.5px;color:var(--ink-2);cursor:pointer;display:inline-flex;align-items:center;gap:6px}
nav.top ul li a{color:inherit}
nav.top ul li:hover{color:var(--ink)}
nav.top ul li.active{color:var(--ink)}
nav.top ul li.active::after{content:"";width:4px;height:4px;background:var(--blue);border-radius:50%;margin-left:4px;box-shadow:0 0 8px rgba(96,165,250,.6)}

/* Notification bell — single icon button with a soft pulse dot */
nav.top .nav-bell{
  width:34px;height:34px;border-radius:50%;
  background:transparent;border:0;color:var(--ink-2);
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;position:relative;
  transition:color .15s ease, background .15s ease;
}
nav.top .nav-bell:hover{color:var(--ink);background:rgba(255,255,255,.04)}
nav.top .nav-bell svg{width:17px;height:17px}
nav.top .nav-bell::after{
  content:"";position:absolute;top:7px;right:9px;
  width:7px;height:7px;border-radius:50%;background:#60A5FA;
  box-shadow:0 0 0 2px rgba(11,10,9,1), 0 0 8px rgba(96,165,250,.7);
  animation:bell-pulse 2.2s ease-in-out infinite;
}
@keyframes bell-pulse{
  0%,100%{opacity:1}
  50%{opacity:.55}
}

/* ── Mobile nav: hamburger toggle + slide-down drawer ────────── */
nav.top .nav-toggle{
  display:none;width:34px;height:34px;border-radius:7px;
  align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--rule);
  color:var(--ink-2);cursor:pointer;
  transition:background .15s ease, border-color .15s ease, color .15s ease;
}
nav.top .nav-toggle:hover{background:var(--bg-3);border-color:var(--rule-2);color:var(--ink)}
nav.top .nav-toggle svg{width:18px;height:18px}
nav.top .nav-toggle .x{display:none}
nav.top.nav-open .nav-toggle .h{display:none}
nav.top.nav-open .nav-toggle .x{display:block}

@media (max-width:880px){
  nav.top .nav-toggle{display:inline-flex}
  /* Drawer anchored to the nav bar's bottom — works whether banner is showing or not */
  nav.top ul{
    position:absolute;top:100%;left:0;right:0;
    display:flex;flex-direction:column;align-items:stretch;
    background:var(--bg);border-bottom:1px solid var(--rule);
    padding:6px 24px 18px;gap:0;margin:0;
    visibility:hidden;opacity:0;
    transform:translateY(-8px);
    pointer-events:none;
    transition:transform .3s cubic-bezier(.22,.61,.36,1), opacity .22s ease, visibility .22s;
    z-index:60;
    box-shadow:0 24px 40px -20px rgba(0,0,0,.7);
  }
  nav.top.nav-open ul{
    visibility:visible;opacity:1;
    transform:translateY(0);
    pointer-events:auto;
  }
  nav.top ul li{
    font-size:15.5px;color:var(--ink-2);
    padding:14px 4px;border-top:1px solid var(--rule);
    display:flex;align-items:center;gap:10px;
  }
  nav.top ul li:first-child{border-top:0}
  nav.top ul li a{display:block;width:100%}
  nav.top ul li.active{color:var(--ink)}
  nav.top ul li.active::after{display:none}
  nav.top ul li.active a::before{
    content:"";width:5px;height:5px;border-radius:50%;
    background:var(--blue);display:inline-block;
    margin-right:8px;vertical-align:middle;
    box-shadow:0 0 8px rgba(96,165,250,.6);
  }
  nav.top .car{display:none}
}

/* ── Industry marquee (shared component) ────────── */
.marquee{overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%, #000 8%, #000 92%, transparent 100%)}
.marquee .track{display:flex;gap:18px;width:max-content;animation:marquee 60s linear infinite}
.ind-chip{
  display:inline-flex;align-items:center;gap:14px;height:54px;padding:0 22px;
  border:1px solid var(--rule);border-radius:10px;background:var(--bg-2);
  white-space:nowrap;flex:0 0 auto;
}
.ind-chip .ico{width:26px;height:26px;border-radius:6px;background:var(--bg);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;flex:0 0 26px}
.ind-chip .ico svg{width:14px;height:14px;color:var(--ink-2)}
.ind-chip .name{font-family:var(--h);font-weight:600;font-size:14px;letter-spacing:.02em;color:var(--ink);text-transform:uppercase}
.ind-chip .meta{font-family:var(--m);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);border-left:1px solid var(--rule);padding-left:14px;font-weight:500}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── Page hero (compact, used by interior pages) ── */
.pagehero{padding:72px 0 56px;position:relative;overflow:hidden}
.pagehero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 50% -10%, rgba(91,141,239,.07), transparent 60%);
}
.pagehero .wrap{position:relative}
.pagehero .crumbs{font-family:var(--m);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);display:flex;align-items:center;gap:8px;margin-bottom:32px}
.pagehero .crumbs a{color:var(--mute)}
.pagehero .crumbs a:hover{color:var(--ink)}
.pagehero .crumbs .sep{opacity:.4}
.pagehero .crumbs .cur{color:var(--ink-2)}
.pagehero h1{font-family:var(--h);font-weight:500;font-size:clamp(40px,5.4vw,72px);line-height:1.02;letter-spacing:-.03em;margin:0;text-wrap:balance;max-width:24ch}
.pagehero p.lead{margin-top:20px;max-width:56ch}
.pagehero .acts{margin-top:28px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}

/* ── Big CTA (small variant for internal pages) ── */
section.bigcta{padding:120px 0;text-align:center;position:relative;overflow:hidden;background:var(--bg-2)}
section.bigcta .wrap{position:relative}
section.bigcta h2{margin:0 auto;max-width:22ch;font-size:clamp(36px,5vw,64px);line-height:1.02;letter-spacing:-.03em}
section.bigcta .ctas{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:36px;flex-wrap:wrap}
section.bigcta .terms{display:block;font-family:var(--m);font-size:11.5px;color:var(--mute);letter-spacing:.04em;margin-top:18px}

/* ── Section atmospheres — shared color washes (replaces section dividers) ── */
.atmo{position:relative;overflow:hidden}
.atmo > *{position:relative;z-index:1}
.atmo::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0}

.atmo-warm::before{
  background:
    radial-gradient(ellipse 70% 80% at 95% -10%, rgba(212,175,85,.07), transparent 55%),
    radial-gradient(ellipse 40% 50% at 0% 100%, rgba(91,141,239,.03), transparent 60%);
}
.atmo-violet::before{
  background:
    radial-gradient(ellipse 65% 75% at 5% -10%, rgba(122,111,224,.06), transparent 55%),
    radial-gradient(ellipse 40% 60% at 100% 90%, rgba(91,141,239,.04), transparent 60%);
}
.atmo-cyan::before{
  background:
    radial-gradient(ellipse 60% 70% at 100% 110%, rgba(111,184,200,.06), transparent 55%),
    radial-gradient(ellipse 50% 50% at 0% 0%, rgba(127,189,138,.03), transparent 60%);
}
.atmo-green::before{
  background:
    radial-gradient(ellipse 65% 70% at 5% -10%, rgba(127,189,138,.06), transparent 55%),
    radial-gradient(ellipse 40% 50% at 100% 100%, rgba(212,175,85,.03), transparent 60%);
}
.atmo-blue::before{
  background:
    radial-gradient(ellipse 60% 80% at 95% -10%, rgba(91,141,239,.06), transparent 55%),
    radial-gradient(ellipse 40% 50% at 5% 100%, rgba(111,184,200,.03), transparent 60%);
}
.atmo-soft::before{
  background:
    radial-gradient(ellipse 55% 70% at 5% -10%, rgba(122,111,224,.04), transparent 55%);
}
.atmo-cta::before{
  background:
    radial-gradient(ellipse 60% 80% at 15% 50%, rgba(212,175,85,.09), transparent 60%),
    radial-gradient(ellipse 60% 80% at 85% 50%, rgba(212,175,85,.07), transparent 60%),
    radial-gradient(ellipse 100% 40% at 50% 100%, rgba(127,189,138,.05), transparent 70%);
}

/* Tone modifier — sets bg-2 background */
.tone-2{background:var(--bg-2)}

/* Auto-apply CTA atmosphere site-wide (every page has a bigcta) */
section.bigcta{position:relative;overflow:hidden}
section.bigcta > *{position:relative;z-index:1}
section.bigcta::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 60% 80% at 15% 50%, rgba(212,175,85,.09), transparent 60%),
    radial-gradient(ellipse 60% 80% at 85% 50%, rgba(212,175,85,.07), transparent 60%),
    radial-gradient(ellipse 100% 40% at 50% 100%, rgba(127,189,138,.05), transparent 70%);
}

/* ── Footer ─────────────────────────────────────── */
footer.site{border-top:1px solid var(--rule);background:var(--bg);padding:80px 0 32px}
footer.site .row{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:36px;align-items:start}
@media (max-width:980px){ footer.site .row{grid-template-columns:1fr 1fr;gap:36px} }
@media (max-width:540px){ footer.site .row{grid-template-columns:1fr} }
footer.site .brand .logo{display:inline-flex;align-items:center;gap:10px;margin-bottom:18px;font-family:var(--h);font-weight:600;font-size:18px;color:var(--ink)}
footer.site .brand .logo img{height:28px;width:auto;display:block}
footer.site .brand .logo .mark{
  width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #f2efe8 0%, #6f6a60 60%, #2a2620 100%);
}
footer.site .brand p{font-size:13.5px;color:var(--mute);line-height:1.55;max-width:32ch;margin:0 0 16px}
footer.site .brand .addr{font-family:var(--m);font-size:11px;color:var(--mute-2);letter-spacing:.04em;line-height:1.7}
footer.site .col h5{font-family:var(--m);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin:0 0 18px;font-weight:500}
footer.site .col ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:11px}
footer.site .col a{color:var(--ink-2);font-size:14px}
footer.site .col a:hover{color:var(--ink)}
footer.site .bot{margin-top:64px;padding-top:24px;border-top:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
footer.site .bot .copy{font-family:var(--m);font-size:11.5px;color:var(--mute-2);letter-spacing:.04em}
footer.site .bot .legal{display:flex;gap:18px;flex-wrap:wrap}
footer.site .bot .legal a{font-family:var(--m);font-size:11.5px;color:var(--mute);letter-spacing:.04em}
footer.site .bot .legal a:hover{color:var(--ink)}


/* ═════════════════════════════════════════════════
   Light theme — toggled via html[data-theme="light"]
   ═════════════════════════════════════════════════ */
html[data-theme="light"]{
  --bg:#FAFAF7;
  --bg-2:#F2F1EC;
  --bg-3:#E8E6DF;
  --bg-4:#DCDAD2;
  --rule:#E3E1DA;
  --rule-2:#CFCDC4;
  --ink:#0B0B0C;
  --ink-2:#27272A;
  --mute:#6B6B70;
  --mute-2:#9A9A9F;
  --blue:#2563EB;
  --violet:#7C3AED;
  --green:#15803D;
  --cyan:#0891B2;
  --warn:#B45309;
  --bad:#B91C1C;
}
html[data-theme="light"] nav.top{background:rgba(250,250,247,.85);}
html[data-theme="light"] .btn.primary,html[data-theme="light"] .btn.cream{background:#0B0B0C;color:#FAFAF7}
html[data-theme="light"] .btn.primary:hover,html[data-theme="light"] .btn.cream:hover{background:#000}
html[data-theme="light"] nav.top .logo img{filter:invert(1)}
html[data-theme="light"] footer.site .brand .logo img{filter:invert(1)}

/* ═════════════════════════════════════════════════
   Theme toggle button
   ═════════════════════════════════════════════════ */
.theme-toggle{
  width:36px;height:36px;padding:0;border-radius:50%;
  border:1px solid var(--rule);background:var(--bg-2);color:var(--ink-2);
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;
  transition:color .15s, border-color .15s, background .15s, transform .15s;
}
.theme-toggle:hover{color:var(--ink);border-color:var(--rule-2);transform:translateY(-1px)}
.theme-toggle svg{width:16px;height:16px;display:none}
.theme-toggle .ic-sun{display:inline-block}
html[data-theme="light"] .theme-toggle .ic-sun{display:none}
html[data-theme="light"] .theme-toggle .ic-moon{display:inline-block}
