/* ============================================================
   AgentWallet.com — Design system
   Dark-mode-first · Editorial × Terminal × Cyber
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Instrument+Serif:ital@0;1&family=JetBrains+Mono:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap');

:root{
  /* palette — dark canvas */
  --bg:#07070A;
  --bg-2:#0C0C11;
  --bg-3:#131319;
  --panel:#15151C;
  --panel-2:#1C1C25;
  --line:#24242E;
  --line-2:#2E2E3A;
  --ink:#F6F6F4;
  --ink-2:#B9B9C0;
  --mute:#7E7E89;
  --mute-2:#55555F;

  /* signature accents (Tweakable via --accent / --accent-2) */
  --accent:#D6FD38;       /* acid lime — pulls from Payouts DNA */
  --accent-2:#69E3FF;     /* electric cyan */
  --accent-3:#C084FF;     /* iris violet */
  --accent-warm:#FFB45C;  /* amber */
  --accent-hot:#FF4D6D;   /* hot pink */

  --good:#4ADE80;
  --warn:#FACC15;
  --bad:#FF6B7A;

  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-2xl:40px;

  --f-display:'Space Grotesk', ui-sans-serif, system-ui, sans-serif;
  --f-serif:'Instrument Serif', 'Times New Roman', serif;
  --f-body:'Inter', ui-sans-serif, system-ui, sans-serif;
  --f-mono:'JetBrains Mono', ui-monospace, Menlo, monospace;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow-md: 0 8px 28px rgba(0,0,0,.35), 0 2px 6px rgba(0,0,0,.25);
  --shadow-lg: 0 40px 120px rgba(0,0,0,.55), 0 12px 32px rgba(0,0,0,.35);
  --glow: 0 0 0 1px color-mix(in oklch, var(--accent) 30%, transparent),
          0 0 32px color-mix(in oklch, var(--accent) 25%, transparent);
}

/* light mode */
html[data-theme="light"]{
  --bg:#F7F6F1;
  --bg-2:#EFEEE6;
  --bg-3:#E7E6DD;
  --panel:#FFFFFF;
  --panel-2:#FBFAF5;
  --line:#E3E2DA;
  --line-2:#CFCEC3;
  --ink:#0A0A0B;
  --ink-2:#3A3A40;
  --mute:#6B6B73;
  --mute-2:#9A9A9F;
}

*{box-sizing:border-box;-webkit-font-smoothing:antialiased}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--f-body);font-size:16px;line-height:1.55}
html{scroll-behavior:smooth}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;cursor:pointer;color:inherit}
::selection{background:var(--accent);color:#000}

/* noise + grid background (subtle) */
body{
  background:
    radial-gradient(1200px 700px at 80% -10%, color-mix(in oklch, var(--accent) 14%, transparent), transparent 60%),
    radial-gradient(900px 500px at -10% 20%, color-mix(in oklch, var(--accent-2) 10%, transparent), transparent 60%),
    var(--bg);
  background-attachment:fixed;
}
html[data-theme="light"] body{
  background:
    radial-gradient(1200px 700px at 80% -10%, color-mix(in oklch, var(--accent) 22%, transparent), transparent 60%),
    radial-gradient(900px 500px at -10% 20%, color-mix(in oklch, var(--accent-2) 14%, transparent), transparent 60%),
    var(--bg);
}

.wrap{max-width:1360px;margin:0 auto;padding:0 28px}
.wrap-wide{max-width:1520px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:980px;margin:0 auto;padding:0 28px}

/* ——— Type ——— */
.eyebrow{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-2);font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 10px var(--accent);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}

.h-display{
  font-family:var(--f-display);font-weight:500;
  font-size:clamp(52px,8.4vw,148px);line-height:.92;letter-spacing:-.04em;margin:0;
  text-wrap:balance;
}
.h1{font-family:var(--f-display);font-weight:500;font-size:clamp(40px,5.6vw,84px);line-height:1;letter-spacing:-.035em;margin:0;text-wrap:balance}
.h2{font-family:var(--f-display);font-weight:500;font-size:clamp(32px,4.2vw,60px);line-height:1.02;letter-spacing:-.03em;margin:0;text-wrap:balance}
.h3{font-family:var(--f-display);font-weight:500;font-size:clamp(22px,2.2vw,34px);line-height:1.12;letter-spacing:-.02em;margin:0}
.h4{font-family:var(--f-display);font-weight:500;font-size:20px;line-height:1.2;letter-spacing:-.01em;margin:0}
.serif{font-family:var(--f-serif);font-weight:400;font-style:italic;letter-spacing:-.005em}
.lead{font-size:clamp(17px,1.3vw,20px);line-height:1.5;color:var(--ink-2);max-width:62ch;margin:0;text-wrap:pretty}
.kicker{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);font-weight:500}
.mono{font-family:var(--f-mono)}

.grad-text{
  background:linear-gradient(100deg, var(--accent) 0%, var(--accent-2) 55%, var(--accent-3) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hl{background:var(--accent);color:#000;padding:0 .15em;border-radius:4px}
.under{box-shadow: inset 0 -.3em 0 0 color-mix(in oklch, var(--accent) 65%, transparent)}

/* ——— Buttons ——— */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;font-weight:500;font-size:14.5px;line-height:1;border:1px solid transparent;transition:.18s ease;white-space:nowrap;font-family:var(--f-body)}
.btn-primary{background:var(--accent);color:#000;border-color:var(--accent)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 32px color-mix(in oklch, var(--accent) 40%, transparent)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{background:var(--panel);border-color:var(--ink)}
.btn-sm{padding:9px 14px;font-size:12.5px}
.btn-arr::after{content:"→";display:inline-block;transition:.2s}
.btn-arr:hover::after{transform:translateX(3px)}

/* ——— Cards / surfaces ——— */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.card-tight{padding:18px}
.glass{background:color-mix(in oklch, var(--panel) 70%, transparent);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border:1px solid var(--line)}

/* ——— Section ——— */
section{padding:120px 0;position:relative}
section.tight{padding:72px 0}

/* ——— Chip / tag ——— */
.chip{display:inline-flex;align-items:center;gap:7px;padding:5px 10px;border:1px solid var(--line-2);border-radius:999px;background:var(--panel);font-family:var(--f-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}
.chip .d{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.chip-warn .d{background:var(--warn);box-shadow:0 0 8px var(--warn)}
.chip-good .d{background:var(--good);box-shadow:0 0 8px var(--good)}
.chip-hot .d{background:var(--accent-hot);box-shadow:0 0 8px var(--accent-hot)}

/* ——— NAV ——— */
.nav{
  position:sticky;top:0;z-index:80;
  background:color-mix(in oklch, var(--bg) 78%, transparent);
  backdrop-filter:saturate(140%) blur(18px);-webkit-backdrop-filter:saturate(140%) blur(18px);
  border-bottom:1px solid var(--line);
}
.nav-row{display:flex;align-items:center;gap:28px;height:64px;padding:0 28px;max-width:1520px;margin:0 auto}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--f-display);font-weight:600;font-size:17px;letter-spacing:-.02em;flex-shrink:0}
.logo-mark{width:26px;height:26px;border-radius:8px;background:var(--accent);display:grid;place-items:center;color:#000;font-family:var(--f-display);font-weight:700;font-size:14px;box-shadow:0 0 0 1px rgba(0,0,0,.1), 0 8px 16px color-mix(in oklch, var(--accent) 30%, transparent);position:relative}
.logo-mark::after{content:"";position:absolute;inset:3px;border-radius:5px;border:1px solid rgba(0,0,0,.25)}
.logo-text{display:flex;align-items:baseline;gap:1px}
.logo-text b{font-weight:600}
.logo-text .dot{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:10px}
.nav-link{padding:7px 12px;border-radius:8px;font-size:13.5px;font-weight:500;color:var(--ink-2);transition:.15s}
.nav-link:hover{background:var(--panel);color:var(--ink)}
.nav-link.active{color:var(--ink)}
.nav-spacer{flex:1}
.nav-right{display:flex;align-items:center;gap:8px}
.nav-poweredby{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);padding:6px 10px;border:1px dashed var(--line-2);border-radius:999px}
.nav-poweredby b{color:var(--ink-2);font-weight:500}

/* burger */
.nav-burger{
  display:none;width:40px;height:40px;border-radius:10px;border:1px solid var(--line-2);
  background:var(--panel);cursor:pointer;padding:0;position:relative;flex-shrink:0;
}
.nav-burger span{position:absolute;left:10px;right:10px;height:1.5px;background:var(--ink);transition:.25s}
.nav-burger span:nth-child(1){top:14px}
.nav-burger span:nth-child(2){top:19px}
.nav-burger span:nth-child(3){top:24px}
body.nav-open .nav-burger span:nth-child(1){top:19px;transform:rotate(45deg)}
body.nav-open .nav-burger span:nth-child(2){opacity:0}
body.nav-open .nav-burger span:nth-child(3){top:19px;transform:rotate(-45deg)}

/* mobile drawer — hidden by default on desktop, shown inside media query below */
.nav-drawer{
  display:none;position:fixed;top:60px;left:0;right:0;bottom:0;
  height:calc(100vh - 60px);height:calc(100dvh - 60px);
  z-index:79;
  background:#0a0a0a;
  padding:20px 18px 32px;flex-direction:column;gap:2px;
  overflow-y:auto;
}
.nav-drawer .nav-link{
  padding:16px 14px;font-size:17px;border-radius:12px;
  border-bottom:1px solid var(--line);border-radius:0;color:var(--ink)
}
.nav-drawer .nav-link:last-of-type{border-bottom:none}
.nav-drawer .nav-link.active{color:var(--accent)}
.nav-drawer-cta{margin-top:20px;display:flex;flex-direction:column;gap:12px}
.nav-drawer-cta .btn{justify-content:center;padding:14px 18px;font-size:15px}
.nav-drawer-pb{
  margin-top:18px;padding-top:18px;border-top:1px solid var(--line);
  font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mute);text-align:center;
}
.nav-drawer-pb b{color:var(--ink-2);font-weight:500}

/* ——— HERO ——— */
.hero{position:relative;padding:56px 0 90px;overflow:hidden}
.hero-inner{position:relative;z-index:2}
.hero-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:16px}
.hero-head{font-family:var(--f-display);font-weight:500;font-size:clamp(56px,9.4vw,168px);line-height:.9;letter-spacing:-.045em;margin:0;text-wrap:balance;position:relative}
.hero-head .line{display:block}
.hero-head .serif{color:var(--accent)}
.hero-head .outline{
  -webkit-text-stroke:1.5px var(--ink);color:transparent;
}
.hero-head .morph{position:relative;display:inline-block}
.hero-sub{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;margin-top:56px;align-items:end}
.hero-sub p{font-size:clamp(17px,1.35vw,22px);line-height:1.45;color:var(--ink-2);max-width:44ch;margin:0}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.hero-stats{display:flex;gap:28px;margin-top:44px;flex-wrap:wrap;align-items:center;border-top:1px solid var(--line);padding-top:24px}
.hero-stat .n{font-family:var(--f-display);font-weight:500;font-size:32px;letter-spacing:-.025em;line-height:1}
.hero-stat .l{font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin-top:6px}

/* backdrop grid */
.grid-bg{
  position:absolute;inset:-1px;pointer-events:none;z-index:1;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse at 70% 10%, #000 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at 70% 10%, #000 0%, transparent 70%);
  opacity:.5;
}

/* ——— Hero diptych — terminal + agent card ——— */
.hero-showcase{
  display:grid;grid-template-columns:1.08fr 1fr;gap:22px;margin-top:80px;position:relative;
}
@media(max-width:1100px){.hero-showcase{grid-template-columns:1fr}}

/* terminal */
.term{
  background:#05060A;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:0;overflow:hidden;box-shadow:var(--shadow-lg);
  position:relative;min-height:480px;display:flex;flex-direction:column;
}
.term::before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(0deg, transparent 0px, transparent 2px, rgba(255,255,255,.012) 3px, transparent 4px);
  pointer-events:none;z-index:1;
}
.term-bar{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--line);background:#0A0B10}
.term-bar .d{width:11px;height:11px;border-radius:50%;background:#2A2A30}
.term-bar .d.r{background:#FF5F57}.term-bar .d.y{background:#FEBC2E}.term-bar .d.g{background:#28C840}
.term-bar .t{flex:1;text-align:center;font-family:var(--f-mono);font-size:11px;color:var(--mute);letter-spacing:.06em}
.term-bar .t b{color:var(--accent);font-weight:500}
.term-body{padding:22px 26px;font-family:var(--f-mono);font-size:13.5px;line-height:1.75;color:var(--ink);flex:1;position:relative;z-index:2}
.term-line{white-space:pre-wrap}
.term-line .cmt{color:var(--mute)}
.term-line .str{color:var(--accent)}
.term-line .num{color:var(--accent-2)}
.term-line .key{color:var(--accent-3)}
.term-line .ok{color:var(--good)}
.term-line .warn{color:var(--warn)}
.term-line .prompt{color:var(--accent);font-weight:600}
.term-line.spacer{height:.6em}
.term-cursor{display:inline-block;width:8px;height:16px;background:var(--accent);animation:blink 1s steps(2) infinite;vertical-align:-2px;margin-left:2px;box-shadow:0 0 8px var(--accent)}
@keyframes blink{50%{opacity:0}}

/* agent passport card */
.passport-stage{
  position:relative;min-height:480px;
  border:1px solid var(--line);border-radius:var(--r-lg);
  background:
    radial-gradient(600px 300px at 30% 20%, color-mix(in oklch, var(--accent) 10%, transparent), transparent 60%),
    linear-gradient(180deg, var(--panel), var(--bg-2));
  overflow:hidden;padding:32px;display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:var(--shadow-lg);
}
.passport-stage::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:44px 44px;mask-image:radial-gradient(circle at 50% 50%, #000 0%, transparent 75%);
  opacity:.4;
}
.passport{
  position:relative;z-index:2;align-self:center;width:88%;max-width:380px;
  background:linear-gradient(135deg, #0E0F14, #141522 65%, #0A0B12);
  border:1px solid color-mix(in oklch, var(--accent) 22%, var(--line));
  border-radius:18px;padding:22px;aspect-ratio:1.586/1;
  box-shadow:var(--shadow-lg), 0 0 0 1px rgba(255,255,255,.03) inset;
  display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;
  transform:rotate(-3deg);
}
.passport::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(400px 200px at 120% 0%, color-mix(in oklch, var(--accent) 30%, transparent), transparent 55%);
}
.passport-head{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:2}
.passport-title{font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600}
.passport-iss{font-family:var(--f-mono);font-size:8.5px;letter-spacing:.14em;color:var(--mute-2);text-align:right;line-height:1.5}
.passport-chip{
  width:38px;height:28px;border-radius:5px;
  background:linear-gradient(135deg,#C9A967,#8B6914 60%, #C9A967);
  position:relative;
}
.passport-chip::before,.passport-chip::after{content:"";position:absolute;background:rgba(0,0,0,.4)}
.passport-chip::before{left:8px;right:8px;top:0;height:1px;box-shadow:0 7px 0 rgba(0,0,0,.4), 0 14px 0 rgba(0,0,0,.4), 0 21px 0 rgba(0,0,0,.4), 0 27px 0 rgba(0,0,0,.4)}
.passport-chip::after{top:8px;bottom:8px;left:14px;width:1px;box-shadow:10px 0 0 rgba(0,0,0,.4)}
.passport-mid{display:flex;align-items:center;gap:12px;position:relative;z-index:2}
.passport-id{font-family:var(--f-mono);font-weight:600;font-size:22px;letter-spacing:.03em;color:var(--ink)}
.passport-id .mute{color:var(--mute-2)}
.passport-foot{display:flex;justify-content:space-between;align-items:end;position:relative;z-index:2}
.passport-kv .k{font-family:var(--f-mono);font-size:7.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute-2)}
.passport-kv .v{font-family:var(--f-mono);font-size:11px;color:var(--ink);font-weight:500;margin-top:2px}
.passport-seal{
  width:44px;height:44px;border-radius:50%;
  background:conic-gradient(from 180deg, var(--accent), var(--accent-2), var(--accent-3), var(--accent));
  display:grid;place-items:center;color:#000;font-family:var(--f-display);font-weight:700;font-size:9px;letter-spacing:.12em;
  position:relative;
}
.passport-seal::before{content:"";position:absolute;inset:3px;background:#0a0a0f;border-radius:50%}
.passport-seal span{position:relative;color:var(--accent);font-family:var(--f-mono);font-size:8px;letter-spacing:.1em}

/* floating attribute tags around the passport */
.attr{
  position:absolute;z-index:3;
  background:color-mix(in oklch, var(--panel) 82%, transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line-2);border-radius:10px;padding:8px 12px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.04em;
  color:var(--ink);display:flex;align-items:center;gap:8px;line-height:1.2;
  box-shadow:var(--shadow-md);
  animation:floaty 5s ease-in-out infinite;
}
.attr .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.attr .k{color:var(--mute);text-transform:uppercase;font-size:8.5px;letter-spacing:.14em;font-weight:600}
.attr .v{color:var(--ink)}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

.attr-a{top:14%;left:-4%;animation-delay:0s}
.attr-b{top:8%;right:-2%;animation-delay:.6s}
.attr-c{bottom:30%;left:-6%;animation-delay:1.2s}
.attr-d{bottom:14%;right:-3%;animation-delay:1.8s}
.attr-e{bottom:46%;right:-8%;animation-delay:2.4s}

.passport-orbit{
  position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(circle at 50% 60%, transparent 0%, transparent 36%, color-mix(in oklch, var(--accent) 8%, transparent) 37%, transparent 38%),
             radial-gradient(circle at 50% 60%, transparent 0%, transparent 46%, color-mix(in oklch, var(--accent-2) 6%, transparent) 47%, transparent 48%);
}

/* ——— Marquee ——— */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:18px 0;overflow:hidden;position:relative;
  background:linear-gradient(90deg, var(--bg), var(--bg-2), var(--bg));
}
.marquee-track{display:flex;gap:56px;animation:marq 48s linear infinite;white-space:nowrap;font-family:var(--f-mono);font-size:13px;color:var(--ink-2);letter-spacing:.04em}
.marquee-track span{display:inline-flex;align-items:center;gap:10px}
.marquee-track .d{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);flex-shrink:0}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ——— Primitives trio ——— */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:56px}
@media(max-width:900px){.trio{grid-template-columns:1fr}}
.trio-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px;position:relative;overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:space-between;gap:20px;
  transition:.3s;
}
.trio-card:hover{border-color:color-mix(in oklch, var(--accent) 45%, var(--line));transform:translateY(-3px)}
.trio-card .num{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;color:var(--accent);font-weight:600}
.trio-card h3{font-family:var(--f-display);font-weight:500;font-size:28px;letter-spacing:-.02em;margin:10px 0 0;line-height:1.05}
.trio-card h3 em{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--accent)}
.trio-card p{color:var(--ink-2);font-size:14px;line-height:1.5;margin:10px 0 0}
.trio-vis{
  height:160px;border:1px solid var(--line);border-radius:12px;
  background:linear-gradient(180deg, var(--bg-3), var(--bg-2));
  display:grid;place-items:center;font-family:var(--f-mono);position:relative;overflow:hidden;
}

/* ——— Wizard scroll ——— */
.wiz{display:grid;grid-template-columns:1fr 1.15fr;gap:56px;margin-top:72px;align-items:start}
@media(max-width:1100px){.wiz{grid-template-columns:1fr}}
.wiz-left{position:sticky;top:120px;align-self:start}
.wiz-left h2{margin-bottom:16px}
.wiz-steps{display:flex;flex-direction:column;gap:2px;margin-top:36px;border-left:1px solid var(--line);padding-left:20px}
.wiz-step{display:flex;gap:12px;align-items:baseline;padding:10px 0;color:var(--mute);font-size:14px;cursor:pointer;position:relative;transition:.2s}
.wiz-step::before{content:"";position:absolute;left:-25px;top:18px;width:8px;height:8px;border-radius:50%;background:var(--line-2);border:1px solid var(--bg);transition:.2s}
.wiz-step.active{color:var(--ink)}
.wiz-step.active::before{background:var(--accent);box-shadow:0 0 10px var(--accent)}
.wiz-step .num{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.16em;color:var(--mute);width:32px;flex-shrink:0}
.wiz-step.active .num{color:var(--accent)}
.wiz-step .lab{font-family:var(--f-display);font-weight:500;font-size:17px;letter-spacing:-.01em}
.wiz-right{display:flex;flex-direction:column;gap:16px}
.wiz-panel{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px;min-height:320px;transition:.3s;position:relative;overflow:hidden;
}
.wiz-panel.focus{border-color:color-mix(in oklch, var(--accent) 40%, var(--line));box-shadow:0 20px 48px color-mix(in oklch, var(--accent) 12%, transparent)}
.wiz-panel .num{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;color:var(--accent);font-weight:600}
.wiz-panel h3{font-family:var(--f-display);font-weight:500;font-size:24px;letter-spacing:-.02em;margin:8px 0 6px}
.wiz-panel .desc{color:var(--ink-2);font-size:14px;margin-bottom:18px;max-width:52ch}
.wiz-body{margin-top:10px}

/* ——— Use cases ——— */
.uc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:56px}
@media(max-width:1000px){.uc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:700px){.uc-grid{grid-template-columns:1fr}}
.uc-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:0;display:flex;flex-direction:column;overflow:hidden;min-height:460px;
  transition:.3s;
}
.uc-card:hover{border-color:color-mix(in oklch, var(--accent) 40%, var(--line));transform:translateY(-3px)}
.uc-card .hd{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;background:var(--panel-2)}
.uc-card .num{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.18em;color:var(--accent);font-weight:600}
.uc-card .cat{font-family:var(--f-mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);padding:3px 8px;border:1px solid var(--line-2);border-radius:100px}
.uc-card .bd{padding:20px;display:flex;flex-direction:column;gap:14px;flex:1}
.uc-card h3{font-family:var(--f-display);font-weight:500;font-size:20px;line-height:1.12;letter-spacing:-.02em;margin:0}
.uc-card h3 em{font-family:var(--f-serif);font-weight:400;font-style:italic;color:var(--accent);display:block;margin-top:2px}
.uc-card .desc{font-size:13px;line-height:1.5;color:var(--ink-2);margin:0}
.flow{background:var(--bg-3);border:1px solid var(--line);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:0}
.flow-node{background:var(--panel);border:1px solid var(--line);border-radius:7px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;gap:10px;font-family:var(--f-mono);font-size:10.5px}
.flow-node.agent{background:color-mix(in oklch, var(--accent) 8%, var(--panel));border-color:color-mix(in oklch, var(--accent) 40%, var(--line-2))}
.flow-node .k{font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);font-weight:600}
.flow-node .v{color:var(--ink)}
.flow-node.agent .k{color:var(--accent)}
.flow-arrow{height:14px;display:flex;justify-content:center;align-items:center;position:relative}
.flow-arrow::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--line);transform:translateX(-.5px)}
.flow-arrow span{background:var(--bg-3);padding:0 6px;font-family:var(--f-mono);font-size:9px;color:var(--mute);letter-spacing:.08em;position:relative}
.why{background:color-mix(in oklch, var(--accent) 6%, var(--bg-3));border:1px solid color-mix(in oklch, var(--accent) 20%, var(--line));border-radius:8px;padding:11px 13px;font-size:12px;line-height:1.5;color:var(--ink-2);margin-top:auto}
.why b{color:var(--accent);font-family:var(--f-mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;margin-right:4px;font-weight:600}

/* ——— Developer ——— */
.dev{display:grid;grid-template-columns:1fr 1.15fr;gap:40px;margin-top:56px;align-items:start}
@media(max-width:1000px){.dev{grid-template-columns:1fr}}
.dev-list{display:flex;flex-direction:column;gap:10px}
.dev-row{padding:18px 20px;border:1px solid var(--line);border-radius:12px;background:var(--panel);cursor:pointer;transition:.2s}
.dev-row:hover,.dev-row.on{border-color:color-mix(in oklch, var(--accent) 40%, var(--line));background:color-mix(in oklch, var(--accent) 5%, var(--panel))}
.dev-row .t{font-family:var(--f-display);font-weight:500;font-size:16px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.dev-row .t .m{font-family:var(--f-mono);font-size:10.5px;color:var(--accent);padding:3px 7px;border:1px solid color-mix(in oklch, var(--accent) 40%, var(--line));border-radius:4px;background:color-mix(in oklch, var(--accent) 8%, transparent);text-transform:uppercase;letter-spacing:.1em}
.dev-row .d{font-size:13px;color:var(--ink-2);margin-top:4px}
.dev-code{
  background:#05060A;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:0;overflow:hidden;font-family:var(--f-mono);font-size:13px;
  min-height:440px;display:flex;flex-direction:column;
}
.dev-code .hd{padding:12px 16px;border-bottom:1px solid var(--line);display:flex;gap:8px;align-items:center;background:#0A0B10}
.dev-code .hd .t{flex:1;text-align:center;font-family:var(--f-mono);font-size:11px;color:var(--mute);letter-spacing:.06em}
.dev-code .bd{padding:20px 24px;line-height:1.7;color:var(--ink-2);white-space:pre;overflow:auto;flex:1}
.dev-code .cm{color:var(--mute)}
.dev-code .k{color:var(--accent-3)}
.dev-code .s{color:var(--accent)}
.dev-code .n{color:var(--accent-2)}
.dev-code .p{color:var(--accent);font-weight:600}
.dev-code .o{color:var(--good)}

/* ——— Manifesto block ——— */
.manif{
  padding:140px 0;position:relative;overflow:hidden;
  background:radial-gradient(800px 400px at 50% 50%, color-mix(in oklch, var(--accent) 18%, transparent), transparent 70%);
}
.manif-text{font-family:var(--f-display);font-weight:500;font-size:clamp(32px,4.6vw,72px);line-height:1.06;letter-spacing:-.03em;text-wrap:balance;max-width:22ch;margin:0 auto;text-align:center}
.manif-text em{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--accent)}
.manif-sub{margin-top:28px;color:var(--ink-2);text-align:center;max-width:52ch;margin-left:auto;margin-right:auto;font-size:16px}

/* ——— Ticker ——— */
.ticker{
  background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:16px 0;overflow:hidden;
}
.ticker-track{display:flex;gap:32px;animation:marq 60s linear infinite;white-space:nowrap;font-family:var(--f-mono);font-size:12.5px}
.ticker-item{display:inline-flex;align-items:center;gap:10px;padding:6px 12px;border:1px solid var(--line);border-radius:100px;background:var(--bg-2)}
.ticker-item .d{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.ticker-item .ag{color:var(--accent);font-weight:500}
.ticker-item .amt{color:var(--ink);font-weight:600}
.ticker-item .rail{color:var(--mute);font-size:10px;letter-spacing:.12em;text-transform:uppercase}

/* ——— CTA final ——— */
.final-cta{
  padding:140px 0;text-align:center;position:relative;overflow:hidden;
}
.final-cta::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(600px 300px at 50% 50%, color-mix(in oklch, var(--accent) 18%, transparent), transparent 70%);
}
.final-cta > *{position:relative;z-index:1}
.final-cta .btns{margin-top:36px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.final-cta .small{color:var(--mute);font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;margin-top:24px}

/* ——— Footer ——— */
footer{border-top:1px solid var(--line);padding:56px 0 32px;background:var(--bg-2)}
.foot{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:32px}
@media(max-width:900px){.foot{grid-template-columns:1fr 1fr}}
.foot h4{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin:0 0 14px;font-weight:600}
.foot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.foot a{color:var(--ink-2);font-size:14px;transition:.15s}
.foot a:hover{color:var(--accent)}
.foot-bot{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-family:var(--f-mono);font-size:11px;color:var(--mute);letter-spacing:.06em}

/* ——— Tweaks panel ——— */
.tweaks{
  position:fixed;bottom:76px;right:20px;z-index:100;
  background:color-mix(in oklch, var(--panel) 92%, transparent);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid var(--line-2);border-radius:16px;
  padding:16px;width:280px;box-shadow:var(--shadow-lg);
  display:none;
}
.tweaks.on{display:block}
.tweaks h4{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin:0 0 12px;font-weight:600;display:flex;align-items:center;gap:8px}
.tweaks h4::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.tweak-row{margin-bottom:14px}
.tweak-row label{display:block;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);margin-bottom:6px}
.swatches{display:flex;gap:6px;flex-wrap:wrap}
.sw{width:24px;height:24px;border-radius:6px;cursor:pointer;border:1px solid var(--line-2);transition:.15s}
.sw.on{box-shadow:0 0 0 2px var(--bg), 0 0 0 3px var(--ink)}
.seg{display:flex;gap:0;border:1px solid var(--line-2);border-radius:8px;overflow:hidden}
.seg button{flex:1;padding:7px;font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);background:transparent}
.seg button.on{background:var(--accent);color:#000}
.tweak-close{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;background:var(--panel-2);color:var(--mute);display:grid;place-items:center;font-size:14px}

/* ——— reveal on scroll ——— */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ——— responsive ——— */
@media(max-width:960px){
  .nav-row{gap:14px;padding:0 18px;height:60px}
  .nav-links{display:none}
  .nav-poweredby{display:none}
  .nav-right .btn{display:none}
  .nav-burger{display:block}
  .nav-drawer{display:none}
  body.nav-open .nav-drawer{display:flex}
  .nav-drawer .nav-poweredby{display:inline-block}
  .hero-sub{grid-template-columns:1fr;gap:24px}
  .dev-code .bd{font-size:11.5px}
  section{padding:80px 0}
  section.tight{padding:56px 0}
}
@media(max-width:600px){
  .nav-row{padding:0 14px}
  .logo{font-size:15px}
  .logo-mark{width:24px;height:24px;font-size:13px}
  .nav-burger{width:38px;height:38px}
  section{padding:64px 0}
  .container,.wrap{padding-left:18px;padding-right:18px}
}
body.nav-open{overflow:hidden}
