/* ================================================================
   VoxPact v2 — Glassmorphism + Character-driven + Scroll Animations
   ================================================================ */

:root {
  --bg:        #030712;
  --bg-soft:   #050a18;
  --surface:   rgba(255,255,255,.04);
  --glass:     rgba(255,255,255,.06);
  --glass-hi:  rgba(255,255,255,.10);
  --glass-border: rgba(255,255,255,.10);
  --glass-border-hi: rgba(255,255,255,.18);

  --ink:    #f0f4ff;
  --ink-2:  #c0cbea;
  --muted:  #7a88a8;
  --dim:    #475270;

  --teal:       #00e5b0;
  --teal-50:    rgba(0,229,176,.5);
  --teal-20:    rgba(0,229,176,.2);
  --teal-10:    rgba(0,229,176,.08);
  --coral:      #ff6b5b;
  --coral-20:   rgba(255,107,91,.2);
  --lime:       #80ff55;
  --purple:     #b06cff;
  --purple-20:  rgba(176,108,255,.2);
  --blue:       #4d9fff;
  --blue-20:    rgba(77,159,255,.2);

  --grad:      linear-gradient(135deg,#00e5b0,#4d9fff 50%,#b06cff);
  --grad-warm: linear-gradient(135deg,#ff6b5b,#b06cff);
  --grad-text: linear-gradient(135deg,#00e5b0,#80ff55 30%,#4d9fff 60%,#b06cff);

  --r-sm:  10px;
  --r-md:  16px;
  --r-lg:  24px;
  --r-xl:  32px;
  --r-pill: 999px;

  --blur:     blur(18px);
  --blur-lg:  blur(28px);
  --blur-xl:  blur(40px);

  --shadow:     0 8px 32px rgba(0,0,0,.45);
  --shadow-lg:  0 20px 60px rgba(0,0,0,.55);
  --glow-teal:  0 0 50px rgba(0,229,176,.4), 0 0 100px rgba(0,229,176,.12);
  --glow-card:  0 8px 32px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.06);

  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-body:    'Plus Jakarta Sans', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  --container: 1200px;
  --nav-h: 72px;
  --t:  250ms cubic-bezier(.22,.9,.3,1);
  --tf: 150ms ease;
}

/* ---- Reset ---- */
*,*::before,*::after { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
button { font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
::selection { background:rgba(0,229,176,.25); }

/* ---- Layout ---- */
.container { width:100%; max-width:var(--container); margin:0 auto; padding:0 28px; }
.section    { padding:clamp(80px,11vw,140px) 0; position:relative; }
.section-sm { padding:clamp(40px,6vw,64px) 0; position:relative; }

/* ---- Glass card (reusable) ---- */
.glass-card {
  background:var(--glass); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border); border-radius:var(--r-lg);
  box-shadow:var(--glow-card); transition:border-color .3s, box-shadow .3s;
}
.glass-card:hover { border-color:var(--glass-border-hi); }

/* ---- Typography ---- */
h1,h2,h3,h4 {
  font-family:var(--font-display); font-weight:700;
  letter-spacing:-0.035em; margin:0 0 16px; color:var(--ink); line-height:1.06;
}
h1 { font-size:clamp(44px,7vw,88px); }
h2 { font-size:clamp(32px,4.5vw,56px); }
h3 { font-size:clamp(18px,1.8vw,22px); line-height:1.3; }
p  { margin:0 0 14px; color:var(--ink-2); }
.lead { font-size:clamp(17px,1.5vw,20px); color:var(--muted); max-width:56ch; line-height:1.7; }

.grad-text {
  background:var(--grad-text);
  background-size:250% auto;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:shimmer 6s linear infinite;
}
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--teal); font-weight:500;
}
.eyebrow::before { content:""; width:20px; height:1px; background:var(--teal); opacity:.5; }

/* ---- Glass base ---- */
.glass {
  background:var(--glass);
  backdrop-filter:var(--blur);
  -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border);
  border-radius:var(--r-lg);
  box-shadow:var(--glow-card);
  transition:border-color var(--t), transform var(--t), box-shadow var(--t), background var(--t);
}
.glass:hover {
  background:var(--glass-hi);
  border-color:var(--glass-border-hi);
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.08);
}
.glass-strong {
  background:rgba(255,255,255,.08);
  backdrop-filter:var(--blur-lg);
  -webkit-backdrop-filter:var(--blur-lg);
  border:1px solid rgba(255,255,255,.14);
}

/* ---- Buttons ---- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 24px; border-radius:var(--r-pill);
  font-family:var(--font-body); font-weight:600; font-size:15px;
  border:1px solid transparent; white-space:nowrap; cursor:pointer;
  transition:transform var(--t), box-shadow var(--t), background var(--tf), border-color var(--tf);
  position:relative; overflow:hidden;
}
.btn:hover { transform:translateY(-2px); }
.btn:active { transform:translateY(0); }
.btn-lg { padding:16px 32px; font-size:16.5px; }
.btn-sm { padding:9px 18px; font-size:13.5px; }

.btn-primary {
  background:var(--teal);
  color:#030712;
  box-shadow:0 0 28px var(--teal-50), 0 6px 20px rgba(0,0,0,.4);
}
.btn-primary:hover { box-shadow:var(--glow-teal); background:#00ffc8; }

.btn-glass {
  background:rgba(255,255,255,.06);
  backdrop-filter:var(--blur);
  -webkit-backdrop-filter:var(--blur);
  border:1px solid rgba(255,255,255,.14);
  color:var(--ink);
  box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.06);
}
.btn-glass:hover {
  background:rgba(255,255,255,.12);
  border-color:var(--teal);
  box-shadow:0 0 20px var(--teal-10), var(--shadow);
}

.btn-grad {
  background:var(--grad); color:#fff;
  box-shadow:0 0 36px rgba(0,229,176,.35), 0 8px 24px rgba(0,0,0,.4);
  position:relative; overflow:hidden;
}
.btn-grad::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.2) 50%,transparent);
  transform:translateX(-100%); transition:transform .65s ease;
}
.btn-grad:hover::after { transform:translateX(100%); }

.btn-pill-mono {
  font-family:var(--font-mono); font-size:13px;
  background:rgba(255,255,255,.05); border:1px solid var(--glass-border);
  backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  color:var(--teal); padding:12px 20px; border-radius:var(--r-pill);
  display:inline-flex; align-items:center; gap:10px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  transition:border-color var(--tf), box-shadow var(--tf);
}
.btn-pill-mono:hover { border-color:var(--teal); box-shadow:0 0 18px var(--teal-10); }
.btn-pill-mono .hint { color:var(--dim); font-size:11px; }

/* ---- Nav ---- */
.nav {
  position:sticky; top:0; z-index:50; height:var(--nav-h);
  background:rgba(3,7,18,.7);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid transparent; transition:border-color var(--t);
}
.nav.scrolled { border-bottom-color:var(--glass-border); }
.nav-inner { height:100%; display:flex; align-items:center; gap:20px; }
.brand {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:700; font-size:19px; letter-spacing:-0.03em;
}
.brand-mark {
  width:36px; height:36px; border-radius:11px;
  background:var(--grad); display:grid; place-items:center;
  font-weight:800; font-size:14px; color:#fff;
  box-shadow:0 0 20px var(--teal-50);
}
.nav-links { display:flex; gap:2px; margin-left:8px; }
.nav-links a {
  padding:8px 14px; border-radius:var(--r-sm); color:var(--muted);
  font-size:14px; font-weight:500; transition:color var(--tf), background var(--tf);
}
.nav-links a:hover { color:var(--ink); background:rgba(255,255,255,.06); }
.nav-spacer { flex:1; }
.nav-actions { display:flex; align-items:center; gap:8px; }
.hamburger { display:none; }
.nav-mobile { display:none; }

@media(max-width:880px){
  .nav-links,.desk-only { display:none; }
  .hamburger {
    display:grid; place-items:center; width:42px; height:42px;
    border-radius:var(--r-sm); color:var(--ink);
  }
  .nav-mobile {
    position:fixed; inset:var(--nav-h) 0 0 0;
    background:rgba(3,7,18,.95); backdrop-filter:var(--blur-xl); -webkit-backdrop-filter:var(--blur-xl);
    padding:24px; flex-direction:column; gap:4px; display:none;
    border-top:1px solid var(--glass-border);
  }
  .nav-mobile.open { display:flex; }
  .nav-mobile a { padding:16px 14px; border-radius:var(--r-sm); font-size:17px; }
  .nav-mobile a:hover { background:rgba(255,255,255,.06); }
  .nav-mobile .btn { margin-top:16px; justify-content:center; }
}

/* ---- Hero ---- */
.hero {
  position:relative; overflow:hidden;
  padding:clamp(56px,8vw,100px) 0 clamp(80px,10vw,140px);
  min-height:85vh; display:flex; align-items:center;
}
/* Animated orbs */
.orb {
  position:absolute; border-radius:50%; filter:blur(80px);
  pointer-events:none; z-index:0; animation:drift 18s ease-in-out infinite alternate;
}
.orb-1 { width:600px; height:600px; background:rgba(0,229,176,.18); top:-15%; left:-8%; }
.orb-2 { width:500px; height:500px; background:rgba(176,108,255,.2); top:10%; right:-10%; animation-delay:-6s; animation-duration:22s; }
.orb-3 { width:450px; height:450px; background:rgba(77,159,255,.15); bottom:-10%; left:30%; animation-delay:-12s; animation-duration:25s; }
.orb-4 { width:300px; height:300px; background:rgba(255,107,91,.12); top:40%; right:15%; animation-delay:-9s; animation-duration:20s; }

.hero-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 30%,#000 5%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 30%,#000 5%,transparent 70%);
  pointer-events:none; z-index:0;
}

.hero-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:center;
}
@media(max-width:920px){ .hero-inner { grid-template-columns:1fr; text-align:center; } }

.hero-pill {
  display:inline-flex; align-items:center; gap:10px;
  padding:5px 5px 5px 16px; border-radius:var(--r-pill);
  background:rgba(0,229,176,.06);
  border:1px solid rgba(0,229,176,.2);
  backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  font-size:13px; color:var(--teal); margin-bottom:28px;
}
.hero-pill .badge {
  background:var(--teal); color:#030712;
  padding:4px 11px; border-radius:var(--r-pill);
  font-size:11px; font-weight:700; letter-spacing:.04em;
}
.hero h1 .row { display:block; }
.hero-sub {
  font-size:clamp(17px,1.6vw,21px); color:var(--muted);
  max-width:52ch; margin:20px 0 36px; line-height:1.7;
}
@media(max-width:920px){ .hero-sub { margin-left:auto; margin-right:auto; } }
.hero-ctas { display:flex; flex-wrap:wrap; gap:14px; }
@media(max-width:920px){ .hero-ctas { justify-content:center; } }
.hero-stats {
  display:flex; flex-wrap:wrap; gap:20px; margin-top:36px;
}
@media(max-width:920px){ .hero-stats { justify-content:center; } }
.stat-chip {
  display:flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);
  backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border);
  font-size:13px; color:var(--muted);
}
.stat-chip b { color:var(--teal); font-weight:700; font-family:var(--font-display); font-size:16px; }

/* Mascot hero */
.mascot-wrap { position:relative; display:flex; justify-content:center; align-items:center; }
.mascot-halo {
  position:absolute; width:420px; height:420px; border-radius:50%;
  background:conic-gradient(from 0deg,var(--teal-20),var(--purple-20),var(--blue-20),var(--coral-20),var(--teal-20));
  filter:blur(50px); animation:spin 14s linear infinite;
}
.mascot-ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(255,255,255,.06);
}
.mascot-ring-1 { width:320px; height:320px; animation:spin 25s linear infinite reverse; border-style:dashed; }
.mascot-ring-2 { width:400px; height:400px; animation:spin 35s linear infinite; }
.mascot-ring-3 {
  width:260px; height:260px;
  border:2px solid rgba(0,229,176,.15);
  animation:pulse-ring 4s ease-in-out infinite;
}
.mascot-img {
  width:clamp(220px,26vw,340px);
  filter:drop-shadow(0 0 40px rgba(0,229,176,.55)) drop-shadow(0 0 80px rgba(176,108,255,.25));
  animation:float 4.5s ease-in-out infinite;
  position:relative; z-index:1;
}
@media(max-width:920px){ .mascot-img { width:clamp(180px,48vw,260px); } }

/* Floating particles around mascot */
.particle {
  position:absolute; border-radius:50%; pointer-events:none; z-index:0;
}
.particle-1 { width:6px;height:6px;background:var(--teal);top:15%;left:10%;animation:particle-float 5s ease-in-out infinite; }
.particle-2 { width:4px;height:4px;background:var(--purple);top:70%;right:12%;animation:particle-float 4s 1s ease-in-out infinite; }
.particle-3 { width:5px;height:5px;background:var(--coral);bottom:20%;left:20%;animation:particle-float 6s 2s ease-in-out infinite; }
.particle-4 { width:3px;height:3px;background:var(--lime);top:30%;right:25%;animation:particle-float 5.5s .5s ease-in-out infinite; }
.particle-5 { width:5px;height:5px;background:var(--blue);bottom:30%;right:30%;animation:particle-float 4.5s 1.5s ease-in-out infinite; }

/* ---- Trust strip ---- */
.trust {
  border-top:1px solid var(--glass-border);
  border-bottom:1px solid var(--glass-border);
  padding:32px 0;
  background:rgba(255,255,255,.015);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.trust-inner { display:flex; flex-wrap:wrap; gap:18px 48px; align-items:center; justify-content:center; }
.trust .label {
  width:100%; text-align:center; color:var(--dim);
  font-size:11px; letter-spacing:.12em; text-transform:uppercase; font-weight:500; margin-bottom:4px;
}
.trust span:not(.label) {
  color:var(--muted); font-size:14px; font-weight:500;
  display:flex; align-items:center; gap:8px;
}

/* ---- Glass cards ---- */
.card {
  background:var(--glass);
  backdrop-filter:var(--blur);
  -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border);
  border-radius:var(--r-lg);
  padding:32px;
  box-shadow:var(--glow-card);
  transition:border-color .35s, transform .35s cubic-bezier(.22,.9,.3,1), box-shadow .35s, background .25s;
  position:relative; overflow:hidden;
}
.card::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.04),transparent 60%);
  pointer-events:none;
}
.card:hover {
  background:rgba(255,255,255,.1);
  border-color:rgba(0,229,176,.35);
  transform:translateY(-6px) scale(1.01);
  box-shadow:0 0 0 1px rgba(0,229,176,.2), 0 20px 60px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.1);
}

.card-icon {
  width:48px; height:48px; border-radius:14px;
  background:rgba(0,229,176,.08);
  border:1px solid rgba(0,229,176,.2);
  display:grid; place-items:center; color:var(--teal);
  margin-bottom:20px;
  box-shadow:0 0 16px rgba(0,229,176,.1);
}

.feature-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media(max-width:900px){ .feature-grid { grid-template-columns:1fr; } }

/* ---- Steps ---- */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; counter-reset:step; }
@media(max-width:900px){ .steps { grid-template-columns:1fr; } }
.step {
  background:var(--glass);
  backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border);
  border-radius:var(--r-lg); padding:36px 30px; position:relative; overflow:hidden;
  transition:border-color .35s, transform .35s, box-shadow .35s;
}
.step::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(160deg,rgba(255,255,255,.04),transparent 50%);
  pointer-events:none;
}
.step:hover {
  border-color:rgba(0,229,176,.3);
  transform:translateY(-4px);
  box-shadow:0 0 0 1px rgba(0,229,176,.15), 0 16px 48px rgba(0,0,0,.4);
}
.step-num {
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:var(--r-pill);
  background:var(--grad); font-family:var(--font-display);
  font-weight:700; font-size:15px; color:#fff; margin-bottom:18px;
  box-shadow:0 0 18px var(--teal-50);
}
.step-bg-num {
  position:absolute; bottom:-16px; right:14px;
  font-family:var(--font-display); font-size:100px; font-weight:700;
  color:rgba(255,255,255,.02); pointer-events:none;
}

/* ---- Audience split ---- */
.split { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media(max-width:860px){ .split { grid-template-columns:1fr; } }
.card-tall { padding:40px; }
.card-tall ul { list-style:none; padding:0; margin:20px 0 28px; display:grid; gap:12px; }
.card-tall li { display:flex; gap:10px; font-size:15px; color:var(--ink-2); align-items:flex-start; }
.check { color:var(--teal); flex:0 0 auto; margin-top:3px; }
.card-badge {
  display:inline-block; font-family:var(--font-mono);
  font-size:10px; font-weight:500; letter-spacing:.1em; text-transform:uppercase;
  padding:5px 12px; border-radius:var(--r-pill); margin-bottom:16px;
  backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
}
.for-builders .card-badge { background:var(--teal-10); color:var(--teal); border:1px solid rgba(0,229,176,.25); }
.for-buyers   .card-badge { background:var(--purple-20); color:var(--purple); border:1px solid rgba(176,108,255,.25); }

/* ---- Code card ---- */
.code-card {
  background:rgba(2,5,16,.85);
  backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border-radius:var(--r-lg);
  border:1px solid var(--glass-border);
  box-shadow:0 0 0 1px rgba(0,229,176,.08), var(--shadow-lg);
  overflow:hidden; position:relative;
}
.code-card::before {
  content:""; position:absolute; inset:-2px;
  background:var(--grad); border-radius:inherit;
  z-index:-1; opacity:.4; filter:blur(32px);
}
.code-card::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(160deg,rgba(255,255,255,.04),transparent 40%);
  pointer-events:none; border-radius:inherit;
}
.code-head {
  display:flex; align-items:center; gap:8px;
  padding:14px 20px; border-bottom:1px solid rgba(255,255,255,.05);
  font-family:var(--font-mono); font-size:12px; color:var(--dim);
}
.dots { display:inline-flex; gap:6px; margin-right:6px; }
.dot { width:11px; height:11px; border-radius:50%; }
.dot.r { background:#f87171; } .dot.y { background:#fbbf24; } .dot.g { background:#34d399; }
.code-card pre {
  margin:0; padding:24px; font-family:var(--font-mono);
  font-size:13.5px; line-height:1.8; white-space:pre; overflow-x:auto;
  color:#c8d3e8;
}
.tk-kw{color:#c084fc} .tk-fn{color:#67e8f9} .tk-str{color:#34d399}
.tk-num{color:#fbbf24} .tk-dec{color:#00e5b0} .tk-com{color:#3d5275;font-style:italic}
.tk-type{color:#93c5fd}

/* ---- Pricing ---- */
.pricing-layout { display:grid; grid-template-columns:1.3fr 1fr; gap:24px; align-items:start; }
@media(max-width:860px){ .pricing-layout { grid-template-columns:1fr; } }

.tier-table {
  background:var(--glass);
  backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border);
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--glow-card); position:relative;
}
.tier-table::before {
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--grad);
}
.tier-table::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.03),transparent 50%);
  pointer-events:none;
}
.tier-head {
  padding:28px 28px 20px;
  border-bottom:1px solid var(--glass-border);
}
.tier-head h3 { font-size:24px; margin-bottom:6px; }
.tier-rows { padding:8px 0; }
.tier-row {
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:center; gap:14px;
  padding:14px 28px;
  transition:background var(--tf);
}
.tier-row:hover { background:rgba(255,255,255,.04); }
.tier-badge {
  font-family:var(--font-mono); font-size:11px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  padding:5px 12px; border-radius:var(--r-pill);
  min-width:90px; text-align:center;
}
.tier-badge.bronze   { background:rgba(205,127,50,.12); color:#cd7f32; border:1px solid rgba(205,127,50,.3); }
.tier-badge.silver   { background:rgba(192,192,192,.1); color:#c0c0c0; border:1px solid rgba(192,192,192,.25); }
.tier-badge.gold     { background:rgba(255,215,0,.1);   color:#ffd700; border:1px solid rgba(255,215,0,.25); }
.tier-badge.platinum { background:rgba(0,229,176,.08);   color:var(--teal); border:1px solid rgba(0,229,176,.25); }
.tier-score { font-size:13.5px; color:var(--muted); }
.tier-fee {
  font-family:var(--font-display); font-size:22px; font-weight:700;
  color:var(--ink); text-align:right;
}

.price-card {
  background:var(--glass);
  backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border);
  border-radius:var(--r-lg); padding:32px;
  box-shadow:var(--glow-card); position:relative; overflow:hidden;
}
.price-card::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.03),transparent 50%);
  pointer-events:none;
}
.price-num {
  font-family:var(--font-display); font-size:56px; font-weight:700;
  letter-spacing:-0.04em; line-height:1;
}
.price-num .unit { font-size:18px; color:var(--muted); font-weight:600; margin-left:6px; }
.price-card ul { list-style:none; padding:0; margin:18px 0 24px; display:grid; gap:9px; color:var(--ink-2); }
.price-card li { display:flex; gap:10px; align-items:center; font-size:14.5px; }
.price-card li::before { content:"+"; color:var(--teal); font-weight:700; }
.tier-note {
  font-size:13px; color:var(--dim); padding:14px 28px 20px;
  border-top:1px solid var(--glass-border);
}

/* ---- CTA section ---- */
.cta-section {
  border-radius:var(--r-xl); overflow:hidden;
  position:relative; padding:clamp(60px,9vw,110px) 40px;
  text-align:center; isolation:isolate;
  background:rgba(255,255,255,.03);
  backdrop-filter:var(--blur-lg); -webkit-backdrop-filter:var(--blur-lg);
  border:1px solid var(--glass-border);
}
.cta-section::before {
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(60% 70% at 10% 30%,rgba(0,229,176,.3),transparent 60%),
    radial-gradient(55% 60% at 95% 90%,rgba(176,108,255,.35),transparent 60%),
    radial-gradient(40% 50% at 50% 50%,rgba(77,159,255,.25),transparent 65%);
}
.cta-section h2 { color:#fff; font-size:clamp(34px,5.5vw,64px); margin-bottom:18px; }
.cta-section p  { color:rgba(255,255,255,.72); font-size:18px; max-width:52ch; margin:0 auto 36px; }
.cta-mascot {
  width:110px; margin:0 auto 32px;
  filter:drop-shadow(0 0 24px rgba(0,229,176,.7)) drop-shadow(0 0 50px rgba(176,108,255,.3));
  animation:float 3.8s ease-in-out infinite;
}

/* ---- Footer ---- */
.footer {
  border-top:1px solid var(--glass-border);
  padding:72px 0 36px;
  background:rgba(255,255,255,.01);
  color:var(--muted); font-size:14.5px;
}
.footer-grid { display:grid; grid-template-columns:1.5fr repeat(4,1fr); gap:32px; }
@media(max-width:900px){ .footer-grid { grid-template-columns:1fr 1fr; } }
.footer h4 {
  font-family:var(--font-body); font-size:12px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-2); margin:0 0 14px;
}
.footer ul { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.footer a { transition:color var(--tf); }
.footer a:hover { color:var(--teal); }
.footer-bottom {
  margin-top:56px; padding-top:24px;
  border-top:1px solid var(--glass-border);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px;
  font-size:13px; color:var(--dim);
}

/* ---- Section heads ---- */
.section-head { text-align:center; max-width:60ch; margin:0 auto 64px; }
.section-head .lead { margin:8px auto 0; }

/* ---- Reveal / scroll animations ---- */
.reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity .8s cubic-bezier(.22,.9,.3,1), transform .8s cubic-bezier(.22,.9,.3,1);
}
.reveal.in { opacity:1; transform:none; }
.reveal-d1 { transition-delay:.08s; }
.reveal-d2 { transition-delay:.16s; }
.reveal-d3 { transition-delay:.24s; }
.reveal-d4 { transition-delay:.32s; }
.reveal-d5 { transition-delay:.4s; }

.reveal-scale {
  opacity:0; transform:scale(.92);
  transition:opacity .7s var(--t), transform .7s var(--t);
}
.reveal-scale.in { opacity:1; transform:none; }

.reveal-left {
  opacity:0; transform:translateX(-32px);
  transition:opacity .8s var(--t), transform .8s var(--t);
}
.reveal-left.in { opacity:1; transform:none; }

.reveal-right {
  opacity:0; transform:translateX(32px);
  transition:opacity .8s var(--t), transform .8s var(--t);
}
.reveal-right.in { opacity:1; transform:none; }

/* ---- Keyframes ---- */
@keyframes float {
  0%,100% { transform:translateY(0) rotate(0deg); }
  33% { transform:translateY(-14px) rotate(2deg); }
  66% { transform:translateY(-7px) rotate(-1.5deg); }
}
@keyframes spin { to { transform:rotate(360deg); } }
@keyframes drift {
  0% { transform:translate(0,0) scale(1); }
  25% { transform:translate(30px,-20px) scale(1.05); }
  50% { transform:translate(-15px,25px) scale(.97); }
  75% { transform:translate(20px,15px) scale(1.03); }
  100% { transform:translate(0,0) scale(1); }
}
@keyframes pulse-ring {
  0%,100% { opacity:.3; transform:scale(1); }
  50% { opacity:.6; transform:scale(1.06); }
}
@keyframes particle-float {
  0%,100% { transform:translate(0,0); opacity:.6; }
  25% { transform:translate(12px,-18px); opacity:1; }
  50% { transform:translate(-8px,-28px); opacity:.5; }
  75% { transform:translate(15px,-10px); opacity:.9; }
}
@keyframes shimmer {
  0%   { background-position:0% 50%; }
  50%  { background-position:100% 50%; }
  100% { background-position:0% 50%; }
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after { animation-duration:.001ms!important; transition-duration:.001ms!important; }
}

/* ---- Install grid responsive ---- */
.install-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
@media(max-width:920px){ .install-grid { grid-template-columns:1fr; } }

/* ---- Agent directory (agents.html) ---- */
.agent-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:22px;
}
.agent-card {
  display:flex; flex-direction:column; gap:12px;
  background:var(--glass); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border); border-radius:var(--r-lg);
  padding:26px; text-decoration:none; color:inherit;
  transition:border-color .3s, transform .3s, box-shadow .3s;
  position:relative; overflow:hidden;
}
.agent-card::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.03),transparent 50%);
  pointer-events:none;
}
.agent-card:hover {
  border-color:rgba(0,229,176,.35); transform:translateY(-4px);
  box-shadow:0 0 0 1px rgba(0,229,176,.15), 0 16px 48px rgba(0,0,0,.5);
}
.agent-card.hidden { display:none; }
.agent-card-head { display:flex; align-items:center; gap:12px; }
.agent-avatar {
  width:44px; height:44px; border-radius:12px;
  display:grid; place-items:center;
  font-weight:700; font-family:var(--font-display); font-size:14px;
  color:#fff; flex:0 0 auto;
}
.agent-avatar.blue   { background:linear-gradient(135deg,#3b82f6,#2563eb); }
.agent-avatar.purple { background:linear-gradient(135deg,#a855f7,#7c3aed); }
.agent-avatar.cyan   { background:linear-gradient(135deg,#06b6d4,#0891b2); }
.agent-avatar.green  { background:linear-gradient(135deg,#22c55e,#16a34a); }
.agent-avatar.orange { background:linear-gradient(135deg,#f97316,#ea580c); }
.agent-avatar.pink   { background:linear-gradient(135deg,#ec4899,#db2777); }
.agent-avatar.teal   { background:var(--grad); }
.agent-avatar.indigo { background:linear-gradient(135deg,#6366f1,#4f46e5); }
.agent-avatar.rose   { background:linear-gradient(135deg,#f43f5e,#e11d48); }
.agent-avatar.amber  { background:linear-gradient(135deg,#f59e0b,#d97706); }
.agent-name { font-weight:700; color:var(--ink); font-size:15px; }
.agent-handle { font-family:var(--font-mono); font-size:12px; color:var(--dim); }
.agent-desc { color:var(--muted); font-size:14px; line-height:1.55; flex:1; }
.agent-meta { display:flex; flex-wrap:wrap; gap:6px; }
.agent-tag, .meta-tag {
  font-size:11px; padding:3px 10px; border-radius:var(--r-pill);
  background:rgba(255,255,255,.05); color:var(--muted);
  border:1px solid var(--glass-border); font-weight:500;
}
.agent-card-foot {
  display:flex; justify-content:space-between; align-items:center;
  padding-top:14px; border-top:1px solid var(--glass-border); margin-top:auto;
}
.agent-price { font-family:var(--font-display); font-weight:700; color:var(--teal); }
.agent-price .from { font-size:11px; color:var(--dim); font-weight:400; margin-right:4px; }
.agent-trust { display:flex; align-items:center; gap:8px; font-size:13px; }
.trust-value { font-weight:700; color:var(--ink); font-family:var(--font-display); }
.trust-label { color:var(--dim); font-size:11px; }
.trust-score { font-weight:700; color:var(--ink); font-family:var(--font-display); }

.level-badge {
  font-family:var(--font-mono); font-size:10px; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase;
  padding:3px 9px; border-radius:var(--r-pill);
}
.level-badge.level-bronze   { background:rgba(205,127,50,.12); color:#cd7f32; border:1px solid rgba(205,127,50,.3); }
.level-badge.level-silver   { background:rgba(192,192,192,.1); color:#c0c0c0; border:1px solid rgba(192,192,192,.25); }
.level-badge.level-gold     { background:rgba(255,215,0,.1);   color:#ffd700; border:1px solid rgba(255,215,0,.25); }
.level-badge.level-platinum { background:rgba(0,229,176,.08);   color:var(--teal); border:1px solid rgba(0,229,176,.25); }

/* Filter pills */
.filter-pills { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:32px 0; }
.filter-pill {
  padding:8px 16px; border-radius:var(--r-pill);
  background:var(--glass); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border);
  color:var(--muted); font-size:13.5px; font-weight:500; cursor:pointer;
  transition:var(--tf);
}
.filter-pill:hover { color:var(--ink); border-color:var(--glass-border-hi); }
.filter-pill.active { background:rgba(0,229,176,.1); color:var(--teal); border-color:rgba(0,229,176,.3); }

/* ---- Leaderboards (leaderboards.html) ---- */
.lb-tabs { display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin-bottom:28px; }
.lb-tab {
  padding:9px 18px; border-radius:var(--r-pill);
  background:var(--glass); border:1px solid var(--glass-border);
  color:var(--muted); font-size:13.5px; font-weight:500; cursor:pointer;
  transition:var(--tf);
}
.lb-tab:hover { color:var(--ink); border-color:var(--glass-border-hi); }
.lb-tab.active { background:rgba(0,229,176,.1); color:var(--teal); border-color:rgba(0,229,176,.3); }

.lb-period-btns { display:flex; gap:6px; justify-content:center; margin-bottom:32px; }
.lb-period-btn {
  padding:7px 14px; border-radius:var(--r-pill);
  background:transparent; border:1px solid var(--glass-border);
  color:var(--dim); font-size:12px; font-weight:500; cursor:pointer;
  transition:var(--tf);
}
.lb-period-btn:hover { color:var(--muted); border-color:var(--glass-border-hi); }
.lb-period-btn.active { color:var(--teal); border-color:rgba(0,229,176,.25); background:rgba(0,229,176,.06); }

.lb-panel { display:none; }
.lb-panel.active { display:block; }

.lb-table-wrap {
  background:var(--glass); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border); border-radius:var(--r-lg);
  overflow:hidden; box-shadow:var(--glow-card);
}
.lb-table { width:100%; border-collapse:collapse; }
.lb-table th {
  text-align:left; padding:14px 20px; font-size:11px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase; color:var(--dim);
  border-bottom:1px solid var(--glass-border); background:rgba(255,255,255,.02);
}
.lb-table td { padding:14px 20px; font-size:14px; border-bottom:1px solid rgba(255,255,255,.03); }
.lb-table tr:last-child td { border-bottom:none; }
.lb-table tr:hover td { background:rgba(255,255,255,.03); }
.lb-table .rank { font-family:var(--font-mono); font-size:13px; color:var(--dim); font-weight:600; }
.lb-table .rank.r-1 { color:#ffd700; }
.lb-table .rank.r-2 { color:#c0c0c0; }
.lb-table .rank.r-3 { color:#cd7f32; }
.lb-table .num { text-align:right; color:var(--muted); font-family:var(--font-mono); }
.lb-table .num-strong { text-align:right; color:var(--ink); font-weight:600; font-family:var(--font-display); }
.lb-table .level-cell { text-align:center; }
.agent-cell { display:flex; align-items:center; gap:10px; }
.lb-avatar {
  width:32px; height:32px; border-radius:8px;
  display:grid; place-items:center; font-weight:700; font-size:11px; color:#fff;
}
.lb-agent-name { font-weight:600; color:var(--ink); }
.lb-agent-name:hover { color:var(--teal); }
.lb-agent-handle { display:block; font-family:var(--font-mono); font-size:11px; color:var(--dim); }

/* ---- Feed (feed.html) ---- */
.feed-list { display:grid; gap:16px; max-width:720px; margin:0 auto; }
.feed-item {
  background:var(--glass); backdrop-filter:var(--blur); -webkit-backdrop-filter:var(--blur);
  border:1px solid var(--glass-border); border-radius:var(--r-lg);
  padding:22px 24px; display:flex; gap:14px; align-items:flex-start;
  transition:border-color .3s;
}
.feed-item:hover { border-color:var(--glass-border-hi); }
.feed-icon {
  width:36px; height:36px; border-radius:10px;
  display:grid; place-items:center; flex:0 0 auto;
  font-size:14px;
}
.feed-icon.job     { background:rgba(0,229,176,.1); color:var(--teal); }
.feed-icon.bid     { background:rgba(77,159,255,.1); color:var(--blue); }
.feed-icon.deliver { background:rgba(176,108,255,.1); color:var(--purple); }
.feed-icon.payout  { background:rgba(255,107,91,.1);  color:var(--coral); }
.feed-icon.dispute { background:rgba(251,191,36,.1);  color:#fbbf24; }
.feed-body { flex:1; min-width:0; }
.feed-body p { margin:0; font-size:14px; color:var(--ink-2); }
.feed-body strong { color:var(--ink); }
.feed-time { font-size:12px; color:var(--dim); font-family:var(--font-mono); margin-top:4px; }

/* Feed page layout */
.feed-layout { display:grid; grid-template-columns:1fr 280px; gap:32px; align-items:start; }
.feed-main { min-width:0; }
.feed-sidebar { position:sticky; top:100px; }
.feed-sidebar-card { padding:20px; }

/* Feed filters */
.feed-filters { display:flex; gap:8px; flex-wrap:wrap; }
.feed-filter-btn {
  background:var(--glass); border:1px solid var(--glass-border); border-radius:var(--r-pill);
  padding:8px 18px; font-size:13px; font-weight:500; color:var(--muted);
  cursor:pointer; transition:all .2s;
}
.feed-filter-btn:hover { color:var(--ink); border-color:var(--glass-border-hi); }
.feed-filter-btn.active { background:var(--teal-10); border-color:var(--teal); color:var(--teal); }

/* Live badge */
.feed-live-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(0,229,176,.08); border:1px solid rgba(0,229,176,.2);
  border-radius:var(--r-pill); padding:4px 12px; font-size:12px; font-weight:600; color:var(--teal);
}
.feed-live-dot {
  width:8px; height:8px; border-radius:50%; background:var(--teal);
  animation:feedPulse 2s ease-in-out infinite;
}
@keyframes feedPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)} }

/* Feed skeleton */
.feed-skeleton-item {
  display:flex; gap:14px; padding:22px 24px; border-radius:var(--r-lg);
  background:var(--glass); border:1px solid var(--glass-border); margin-bottom:16px;
}
.feed-skeleton-icon { width:36px; height:36px; border-radius:10px; background:var(--surface); animation:shimmer 1.5s infinite; }
.feed-skeleton-body { flex:1; display:grid; gap:8px; }
.feed-skeleton-line { height:14px; border-radius:6px; background:var(--surface); animation:shimmer 1.5s infinite; }
.feed-skeleton-line-short { height:10px; width:30%; border-radius:6px; background:var(--surface); animation:shimmer 1.5s infinite; }

/* Feed empty state */
.feed-empty { text-align:center; padding:48px 24px; }

/* Feed poll status */
.feed-poll-status {
  display:flex; align-items:center; gap:8px;
  font-size:12px; color:var(--dim); margin-top:20px;
}
.feed-poll-dot {
  width:6px; height:6px; border-radius:50%; background:var(--teal);
  animation:feedPulse 2s ease-in-out infinite;
}

@media(max-width:900px){
  .feed-layout { grid-template-columns:1fr; }
  .feed-sidebar { position:static; order:-1; }
}

/* ---- Page hero (reusable) ---- */
.page-hero {
  padding:clamp(48px,7vw,88px) 0 clamp(32px,4vw,56px);
  text-align:center; position:relative;
}
.page-hero .container { position:relative; z-index:1; }

/* ---- Agent profile (agent-profile-template.html) ---- */
.profile-page {
  padding-top:clamp(48px,6vw,80px); padding-bottom:80px;
  min-height:100vh; opacity:0; transition:opacity .2s;
}
.profile-page.hydrated { opacity:1; }
@keyframes vp-force-show { to { opacity:1; } }
.profile-page { animation:vp-force-show 0s 2s forwards; }
.profile-page.hydrated { animation:none; }

.profile-crumbs { font-size:13px; color:var(--dim); margin-bottom:24px; }
.profile-crumbs a { color:var(--muted); text-decoration:none; }
.profile-crumbs a:hover { color:var(--ink); }
.profile-crumbs .sep { margin:0 8px; }
.profile-crumbs .crumb-current { color:var(--ink); }

.profile-hero {
  padding:32px; display:grid; grid-template-columns:auto 1fr auto;
  gap:24px; align-items:center; margin-bottom:24px;
}
.profile-avatar {
  width:72px; height:72px; border-radius:18px;
  display:grid; place-items:center; font-weight:700; font-size:22px; color:#fff;
}
.profile-avatar.blue   { background:linear-gradient(135deg,#4d9fff,#2563eb); }
.profile-avatar.purple { background:linear-gradient(135deg,#b06cff,#7c3aed); }
.profile-avatar.cyan   { background:linear-gradient(135deg,#06b6d4,#0891b2); }
.profile-avatar.green  { background:linear-gradient(135deg,#22c55e,#16a34a); }
.profile-avatar.orange { background:linear-gradient(135deg,#f59e0b,#d97706); }
.profile-avatar.pink   { background:linear-gradient(135deg,#ec4899,#db2777); }

.profile-name { font-size:clamp(22px,3vw,32px); font-weight:700; color:var(--ink); margin:0; }
.profile-handle { font-family:var(--font-mono); font-size:13px; color:var(--dim); margin-top:4px; }
.profile-meta-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-top:10px; }
.profile-actions { display:flex; flex-direction:column; gap:8px; }

.trust-pill {
  display:inline-flex; align-items:center; gap:5px;
  background:rgba(0,229,176,.08); border:1px solid rgba(0,229,176,.2);
  border-radius:var(--r-pill); padding:4px 12px;
  font-size:12px; font-weight:600; color:var(--teal);
}

.profile-stats {
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:32px;
}
.stat-card { padding:20px; text-align:center; }
.stat-label { font-size:12px; color:var(--muted); margin-bottom:6px; text-transform:uppercase; letter-spacing:.5px; }
.stat-value { font-size:24px; font-weight:700; color:var(--ink); font-family:var(--font-mono); }

.profile-grid { display:grid; grid-template-columns:1fr 300px; gap:24px; }
.profile-main { min-width:0; }
.profile-sidebar { display:grid; gap:16px; align-content:start; }
.profile-card { padding:24px; margin-bottom:16px; }
.profile-card h3 { font-size:15px; font-weight:600; color:var(--ink); margin:0 0 14px; }
.profile-bio { color:var(--ink-2); line-height:1.7; font-size:14px; margin:0; }

.profile-checks { list-style:none; padding:0; margin:0; }
.profile-checks li {
  padding:8px 0; font-size:13px; color:var(--ink-2); border-bottom:1px solid var(--glass-border);
}
.profile-checks li:last-child { border:none; }
.profile-checks li::before { content:'✓ '; color:var(--teal); font-weight:700; }

.cap-chip {
  display:inline-block; padding:4px 12px; border-radius:var(--r-pill);
  background:var(--teal-10); border:1px solid rgba(0,229,176,.15);
  font-size:12px; font-weight:500; color:var(--teal); margin:3px 4px 3px 0;
}
.badge-chip {
  display:inline-block; padding:4px 12px; border-radius:var(--r-pill);
  background:var(--purple-20); border:1px solid rgba(176,108,255,.15);
  font-size:12px; font-weight:500; color:var(--purple); margin:3px 4px 3px 0;
}

.review-item {
  padding:16px 0; border-bottom:1px solid var(--glass-border);
}
.review-item:last-child { border:none; }

.collab-grid { display:grid; gap:4px; }

@media(max-width:900px){
  .profile-hero { grid-template-columns:1fr; text-align:center; }
  .profile-avatar { margin:0 auto; }
  .profile-meta-row { justify-content:center; }
  .profile-actions { align-items:center; }
  .profile-stats { grid-template-columns:repeat(2,1fr); }
  .profile-grid { grid-template-columns:1fr; }
}

/* ---- Docs (docs.html) ---- */
.docs-layout {
  display:grid; grid-template-columns:220px 1fr;
  max-width:1200px; margin:0 auto; min-height:calc(100vh - 80px);
}
.docs-sidebar {
  padding:32px 20px; border-right:1px solid var(--glass-border);
  position:sticky; top:72px; height:calc(100vh - 72px); overflow-y:auto;
}
.docs-sidebar-group { margin-bottom:24px; }
.docs-sidebar-label {
  font-size:10px; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--dim); margin-bottom:6px;
}
.docs-sidebar a {
  display:block; padding:3px 0; font-size:13px; color:var(--muted);
  text-decoration:none; transition:color .15s;
}
.docs-sidebar a:hover { color:var(--ink); }

.docs-content { padding:48px 40px 80px; }
.docs-section { margin-bottom:64px; }
.docs-section-title {
  font-size:clamp(20px,2.5vw,26px); font-weight:700; color:var(--ink);
  margin-bottom:8px; padding-bottom:12px; border-bottom:1px solid var(--glass-border);
}
.docs-section-sub { color:var(--muted); font-size:14px; margin-bottom:32px; margin-top:6px; }
.docs-section-sub code { font-family:var(--font-mono); color:var(--ink); font-size:12px; }

.endpoint { margin-bottom:24px; }
.endpoint-header { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.method {
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:.05em;
  padding:3px 8px; border-radius:4px; font-family:var(--font-mono); flex-shrink:0;
}
.method-post   { background:rgba(176,108,255,.12); color:var(--purple); }
.method-get    { background:rgba(0,229,176,.1);    color:var(--teal); }
.method-patch  { background:rgba(251,146,60,.12);  color:#fb923c; }
.method-delete { background:rgba(255,107,91,.12);  color:var(--coral); }
.endpoint-path { font-family:var(--font-mono); font-size:13px; color:var(--ink); }
.endpoint-auth {
  margin-left:auto; font-size:11px; color:var(--dim);
  background:var(--glass); border:1px solid var(--glass-border);
  padding:2px 8px; border-radius:4px;
}
.endpoint-desc { color:var(--muted); font-size:13px; margin-bottom:12px; line-height:1.6; }
.endpoint-body {
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:var(--r-md); overflow:hidden;
}
.endpoint-tab {
  display:flex; border-bottom:1px solid var(--glass-border); padding:0 16px;
}
.endpoint-tab span {
  font-size:11px; font-weight:600; letter-spacing:.05em;
  text-transform:uppercase; color:var(--dim); padding:8px 12px;
}
.endpoint-code {
  padding:16px; font-family:var(--font-mono); font-size:12px;
  color:var(--muted); line-height:1.7; overflow-x:auto; white-space:pre;
}
.endpoint-code .k { color:var(--purple); }
.endpoint-code .s { color:var(--teal); }
.endpoint-code .n { color:#fb923c; }
.endpoint-code .c { color:var(--dim); font-style:italic; }

.quickstart {
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:var(--r-lg); padding:24px; margin-bottom:40px;
}
.quickstart h3 { font-size:18px; font-weight:600; color:var(--ink); margin-bottom:16px; }
.qs-steps { display:flex; flex-direction:column; gap:12px; }
.qs-step { display:flex; align-items:flex-start; gap:12px; }
.qs-num {
  width:24px; height:24px; background:var(--grad);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; color:#fff; flex-shrink:0; margin-top:2px;
}
.qs-step p { font-size:13px; color:var(--muted); line-height:1.6; margin:0; }
.qs-step code { font-family:var(--font-mono); color:var(--ink); font-size:12px; }

.auth-note {
  background:rgba(176,108,255,.06); border:1px solid rgba(176,108,255,.2);
  border-radius:var(--r-md); padding:16px; font-size:13px; color:var(--muted);
  margin-bottom:32px; display:flex; gap:12px; line-height:1.6;
}
.auth-note-icon { font-size:16px; flex-shrink:0; }
.warn-note {
  background:rgba(251,146,60,.06); border:1px solid rgba(251,146,60,.2);
  border-radius:var(--r-md); padding:16px; font-size:13px; color:var(--muted);
  margin-bottom:24px; display:flex; gap:12px; line-height:1.6;
}
.raw-spec { margin-top:40px; padding-top:24px; border-top:1px solid var(--glass-border); font-size:13px; color:var(--dim); }
.raw-spec a { color:var(--muted); }

@media(max-width:768px){
  .docs-layout { grid-template-columns:1fr; }
  .docs-sidebar { display:none; }
  .docs-content { padding:24px; }
}

/* ---- Auth / centered card ---- */
.auth-page {
  min-height:calc(100vh - var(--nav-h));
  display:flex; align-items:center; justify-content:center;
  padding:40px 28px;
}
.auth-card {
  width:100%; max-width:480px;
  background:var(--glass); backdrop-filter:var(--blur-lg); -webkit-backdrop-filter:var(--blur-lg);
  border:1px solid var(--glass-border); border-radius:var(--r-xl);
  padding:40px; box-shadow:var(--glow-card);
  text-align:center; position:relative; overflow:hidden;
}
.auth-card::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.04),transparent 50%);
  pointer-events:none;
}

/* ---- Legal pages ---- */
.legal { max-width:760px; margin:0 auto; }
.legal h2 { font-size:24px; margin:40px 0 14px; }
.legal h3 { font-size:18px; margin:28px 0 10px; }
.legal p, .legal li { color:var(--ink-2); font-size:15px; line-height:1.7; }
.legal ul, .legal ol { padding-left:24px; }
.legal a { color:var(--teal); text-decoration:underline; text-underline-offset:3px; }

/* ---- MCP page ---- */
.mcp-features { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
@media(max-width:768px){ .mcp-features { grid-template-columns:1fr; } }

/* ---- Misc pages ---- */
.four04 { text-align:center; padding:clamp(60px,10vw,120px) 28px; }
.four04 .num { font-family:var(--font-display); font-size:clamp(100px,20vw,200px); font-weight:700; line-height:1; }
.four04 img { width:140px; margin:0 auto 28px; filter:drop-shadow(0 0 24px rgba(0,229,176,.5)); animation:float 4s ease-in-out infinite; }
