/* ════════════════════════════════════════════════════════════════
   Mavenkopay — Developer-first payment & checkout platform
   Light · technical · Space Grotesk display · electric blue + cyan
   Sharp corners, grid lines, mono labels — "ship by this afternoon"
   ════════════════════════════════════════════════════════════════ */

:root {
  --bg:#fbfcfe;
  --bg-2:#f4f6fb;
  --bg-3:#eef1f8;
  --panel:#ffffff;
  --ink:#0a0e1a;
  --ink-2:#3d4660;
  --ink-3:#7a8499;
  --blue:#3b4cff;
  --blue-dk:#2433d6;
  --cyan:#00d4ff;
  --cyan-dk:#06b6d4;
  --good:#00b87a;
  --warn:#ff8a3d;
  --bad:#ff4d6d;
  --line:#e3e8f2;
  --line-2:#d2d9e8;
  --grid:rgba(59,76,255,.05);
  --r:6px;
  --r-s:4px;
  --disp:"Space Grotesk", "Inter", system-ui, sans-serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --ease:cubic-bezier(.22,.68,.18,1);
  --shell:1240px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html, body { overflow-x:hidden; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:15.5px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  position:relative;
}
/* faint technical grid across the whole canvas */
body::before {
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(120% 90% at 50% 0%, #000 35%, transparent 78%);
  mask-image:radial-gradient(120% 90% at 50% 0%, #000 35%, transparent 78%);
}
img,svg { display:block; max-width:100%; }
button { background:none; border:none; cursor:pointer; font:inherit; color:inherit; }
a { color:inherit; text-decoration:none; }
input,textarea,select,button { font:inherit; }
::selection { background:var(--blue); color:#fff; }

.vp-shell { width:100%; max-width:var(--shell); margin:0 auto; padding:0 32px; }

h1,h2,h3,h4 { font-family:var(--disp); font-weight:600; line-height:1.05; letter-spacing:-.02em; color:var(--ink); }
p { font-family:var(--sans); }

/* ── Reveal animation ─────────────────────────────────────── */
[data-rise] { opacity:0; transform:translateY(18px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-rise].is-in { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ [data-rise]{ opacity:1; transform:none; transition:none; } }

/* ── Eyebrow — terminal-style marker ──────────────────────── */
.vp-eyebrow {
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--mono); font-size:11px; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3);
  max-width:100%;
}
.vp-eyebrow b {
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--mono); font-weight:600; font-size:10.5px;
  color:var(--blue); letter-spacing:.14em; flex:none;
}
.vp-eyebrow b::before {
  content:""; width:7px; height:7px; border-radius:50%;
  background:var(--cyan); box-shadow:0 0 0 3px rgba(0,212,255,.18);
  animation:vp-pulse 1.7s ease-in-out infinite;
}
.vp-eyebrow > span { color:var(--ink-2); letter-spacing:.08em; font-size:10.5px; }
@keyframes vp-pulse {
  0%,100% { opacity:1; box-shadow:0 0 0 3px rgba(0,212,255,.18); }
  50% { opacity:.65; box-shadow:0 0 0 5px rgba(0,212,255,.05); }
}
@media (max-width:580px){ .vp-eyebrow { gap:8px; font-size:10px; } }

.vp-h1 { font-size:clamp(2.7rem, 6.2vw, 5.2rem); }
.vp-h2 { font-size:clamp(2.1rem, 4.4vw, 3.5rem); }
.vp-h3 { font-size:clamp(1.4rem, 2.1vw, 1.9rem); }
.vp-h1 em, .vp-h2 em, .vp-h3 em {
  font-style:normal; color:var(--blue);
}
.vp-h1 i, .vp-h2 i {
  font-style:normal; color:transparent;
  background:linear-gradient(100deg, var(--blue), var(--cyan));
  -webkit-background-clip:text; background-clip:text;
}

.vp-sec { padding:108px 0; position:relative; }
.vp-sec--alt { background:var(--bg-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.vp-sechead { display:flex; align-items:flex-end; justify-content:space-between; gap:32px; flex-wrap:wrap; margin-bottom:54px; }
.vp-sechead > div:first-child { flex:1 1 30em; min-width:0; }
.vp-sechead .vp-eyebrow { margin-bottom:18px; }
.vp-seclink {
  font-family:var(--mono); font-size:12px; font-weight:500; color:var(--ink);
  display:inline-flex; align-items:center; gap:7px; padding:9px 15px;
  border:1px solid var(--line-2); border-radius:var(--r); background:var(--panel);
  letter-spacing:.02em;
  transition:background .2s, border-color .2s, color .2s;
}
.vp-seclink:hover { background:var(--blue); border-color:var(--blue); color:#fff; }
.vp-seclink svg { width:14px; height:14px; }

/* ════════════════ BUTTONS ════════════════ */
.vp-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--sans); font-weight:600; font-size:14px;
  height:46px; padding:0 22px; border-radius:var(--r); white-space:nowrap;
  transition:background .18s, color .18s, border-color .18s, transform .2s var(--ease), box-shadow .2s var(--ease);
  position:relative;
}
.vp-btn--solid {
  background:var(--blue); color:#fff;
  box-shadow:0 1px 0 rgba(10,14,26,.04), 0 8px 22px rgba(59,76,255,.28);
}
.vp-btn--solid:hover { background:var(--blue-dk); transform:translateY(-2px); box-shadow:0 14px 30px rgba(59,76,255,.36); }
.vp-btn--ghost {
  background:var(--panel); color:var(--ink); border:1px solid var(--line-2);
}
.vp-btn--ghost:hover { border-color:var(--blue); color:var(--blue); }
.vp-btn--glow {
  background:linear-gradient(100deg, var(--blue), var(--cyan)); color:#fff;
  box-shadow:0 8px 24px rgba(0,212,255,.32);
}
.vp-btn--glow:hover { transform:translateY(-2px); box-shadow:0 14px 34px rgba(0,212,255,.42); }
.vp-btn--dark { background:var(--ink); color:#fff; }
.vp-btn--dark:hover { background:#161c2e; transform:translateY(-2px); }
.vp-btn--lg { height:54px; padding:0 28px; font-size:15px; }
.vp-btn--sm { height:38px; padding:0 16px; font-size:13px; }
.vp-btn--wide { width:100%; }
.vp-btn svg { width:15px; height:15px; }

/* ════════════════ HEADER ════════════════ */
.vp-head {
  position:sticky; top:0; z-index:100;
  background:rgba(251,252,254,.8);
  -webkit-backdrop-filter:blur(14px) saturate(140%); backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:border-color .3s, background .3s;
}
.vp-head.is-stuck { border-bottom-color:var(--line); background:rgba(251,252,254,.94); }
.vp-head__bar { display:flex; align-items:center; gap:24px; height:66px; }
.vp-logo { display:inline-flex; align-items:center; gap:9px; flex:none; }
.vp-logo__mark {
  width:28px; height:28px; border-radius:var(--r-s);
  background:var(--ink); position:relative; flex:none;
  display:flex; align-items:center; justify-content:center;
}
.vp-logo__mark::before {
  content:""; width:13px; height:13px;
  background:
    linear-gradient(135deg, var(--blue), var(--cyan));
  clip-path:polygon(0 12%, 50% 100%, 100% 12%, 78% 12%, 50% 70%, 22% 12%);
}
.vp-logo__word { font-family:var(--disp); font-weight:700; font-size:20px; letter-spacing:-.03em; color:var(--ink); }
.vp-logo__word em { font-style:normal; color:var(--blue); }

.vp-nav { display:flex; gap:2px; flex:1; justify-content:center; }
.vp-nav a {
  font-size:13.5px; font-weight:500; color:var(--ink-2); padding:8px 13px; border-radius:var(--r-s);
  transition:color .18s, background .18s;
}
.vp-nav a:hover, .vp-nav a.is-on { color:var(--ink); background:var(--bg-3); }

.vp-head__act { display:flex; align-items:center; gap:8px; flex:none; }
.vp-head__act .vp-login {
  font-size:13.5px; font-weight:500; color:var(--ink-2); padding:8px 12px;
  transition:color .18s;
}
.vp-head__act .vp-login:hover { color:var(--ink); }

/* language */
.vp-lang { position:relative; }
.vp-lang__btn {
  display:inline-flex; align-items:center; gap:5px;
  font-family:var(--mono); font-size:11.5px; color:var(--ink-2); padding:7px 10px;
  border:1px solid var(--line-2); border-radius:var(--r-s); background:var(--panel);
  transition:border-color .18s, color .18s;
}
.vp-lang__btn:hover { color:var(--ink); border-color:var(--blue); }
.vp-lang__btn svg { width:12px; height:12px; }
.vp-lang__chev { width:9px !important; height:9px !important; transition:transform .22s; }
.vp-lang.open .vp-lang__chev { transform:rotate(180deg); }
.vp-lang__menu {
  position:absolute; top:calc(100% + 7px); right:0;
  background:var(--panel);
  border:1px solid var(--line-2); border-radius:var(--r);
  padding:5px; min-width:162px; box-shadow:0 18px 50px rgba(10,14,26,.12);
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .18s, transform .18s, visibility .18s;
  z-index:120;
}
.vp-lang.open .vp-lang__menu { opacity:1; visibility:visible; transform:none; }
.vp-lang--up .vp-lang__menu { top:auto; bottom:calc(100% + 7px); }
.vp-lang__menu button {
  display:block; width:100%; text-align:left; font-size:12.5px;
  color:var(--ink-2); padding:9px 12px; border-radius:var(--r-s); transition:background .15s, color .15s;
}
.vp-lang__menu button:hover { background:var(--bg-3); color:var(--ink); }
.vp-lang__menu button.is-on { color:var(--blue); font-weight:600; }

.vp-burger { display:none; flex-direction:column; gap:4px; width:40px; height:40px; align-items:center; justify-content:center; flex:none; border:1px solid var(--line-2); border-radius:var(--r-s); background:var(--panel); }
.vp-burger span { width:15px; height:1.6px; background:var(--ink); transition:transform .22s var(--ease), opacity .18s; }
.vp-burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(5.6px) rotate(45deg); }
.vp-burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.vp-burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-5.6px) rotate(-45deg); }
.vp-mobile {
  display:none; flex-direction:column; gap:2px; padding:14px 0 18px;
  border-top:1px solid var(--line);
}
.vp-mobile[hidden]{ display:none; }
.vp-mobile.is-open { display:flex; }
.vp-mobile a { font-size:14.5px; font-weight:500; color:var(--ink-2); padding:11px 4px; }
.vp-mobile .vp-btn { margin-top:10px; }

/* ════════════════ HERO ════════════════ */
.vp-hero { padding:74px 0 90px; position:relative; overflow:hidden; }
.vp-hero__grid {
  display:grid; grid-template-columns:1.04fr .96fr; gap:54px; align-items:center;
}
.vp-hero__copy { position:relative; z-index:2; }
.vp-hero__h1 {
  font-size:clamp(2.7rem, 5.4vw, 4.7rem); margin:22px 0 0;
  line-height:1.0; letter-spacing:-.03em;
}
.vp-hero__h1 i {
  font-style:normal; color:transparent;
  background:linear-gradient(100deg, var(--blue), var(--cyan));
  -webkit-background-clip:text; background-clip:text;
}
.vp-hero__lede {
  margin:24px 0 0; max-width:36em; font-size:17px; color:var(--ink-2); line-height:1.62;
}
.vp-hero__cta { display:flex; gap:12px; margin-top:32px; flex-wrap:wrap; }
.vp-hero__small {
  margin-top:20px; display:flex; flex-wrap:wrap; gap:6px 16px;
  font-family:var(--mono); font-size:11.5px; color:var(--ink-3); letter-spacing:.02em;
}
.vp-hero__small span { display:inline-flex; align-items:center; gap:6px; }
.vp-hero__small span::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--good); }

/* code + checkout panel stack */
.vp-hero__art { position:relative; z-index:2; display:flex; flex-direction:column; gap:18px; }

/* code window */
.vp-win {
  background:var(--ink); border-radius:var(--r);
  box-shadow:0 30px 70px rgba(10,14,26,.22), 0 2px 0 rgba(10,14,26,.04);
  overflow:hidden; border:1px solid #1b2236;
}
.vp-win__bar {
  display:flex; align-items:center; gap:8px; padding:11px 14px;
  border-bottom:1px solid #1b2236; background:#0d1322;
}
.vp-win__dot { width:11px; height:11px; border-radius:50%; background:#2a3247; }
.vp-win__dot:nth-child(1){ background:#ff5f57; }
.vp-win__dot:nth-child(2){ background:#febc2e; }
.vp-win__dot:nth-child(3){ background:#28c840; }
.vp-win__file { margin-left:8px; font-family:var(--mono); font-size:11px; color:#6b7689; letter-spacing:.02em; }
.vp-win__lang { margin-left:auto; font-family:var(--mono); font-size:10px; color:#566079; letter-spacing:.08em; text-transform:uppercase; }
.vp-code-pre {
  margin:0; padding:18px 20px; font-family:var(--mono); font-size:12.7px; line-height:1.75;
  color:#c3cadb; overflow-x:auto;
}
.vp-code-pre .k { color:#7c89ff; }
.vp-code-pre .s { color:#43e0c0; }
.vp-code-pre .c { color:#566079; font-style:italic; }
.vp-code-pre .n { color:#ff9d6b; }
.vp-code-pre .f { color:#37d4ff; }
.vp-code-pre .p { color:#9aa3b8; }

/* checkout mockup */
.vp-checkout {
  background:var(--panel); border:1px solid var(--line); border-radius:var(--r);
  box-shadow:0 24px 60px rgba(10,14,26,.12);
  overflow:hidden;
}
.vp-checkout__top {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px; border-bottom:1px solid var(--line); background:var(--bg-2);
}
.vp-checkout__brand { display:flex; align-items:center; gap:9px; font-family:var(--disp); font-weight:600; font-size:14px; }
.vp-checkout__brand i {
  width:22px; height:22px; border-radius:var(--r-s); flex:none;
  background:linear-gradient(135deg, var(--blue), var(--cyan));
}
.vp-checkout__secure { font-family:var(--mono); font-size:10px; color:var(--ink-3); display:inline-flex; align-items:center; gap:5px; letter-spacing:.04em; }
.vp-checkout__secure svg { width:12px; height:12px; color:var(--good); }
.vp-checkout__body { padding:18px; display:flex; flex-direction:column; gap:13px; }
.vp-checkout__amt { display:flex; align-items:baseline; justify-content:space-between; }
.vp-checkout__amt span { font-size:13px; color:var(--ink-3); }
.vp-checkout__amt b { font-family:var(--disp); font-weight:600; font-size:1.7rem; letter-spacing:-.02em; }
.vp-ck-field { }
.vp-ck-field label { display:block; font-family:var(--mono); font-size:9.5px; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-3); margin-bottom:6px; }
.vp-ck-input {
  height:40px; border:1px solid var(--line-2); border-radius:var(--r-s);
  display:flex; align-items:center; padding:0 12px; gap:8px;
  font-family:var(--mono); font-size:12.5px; color:var(--ink-2); background:var(--bg);
}
.vp-ck-input.is-focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(59,76,255,.12); color:var(--ink); }
.vp-ck-input svg { width:20px; height:14px; flex:none; }
.vp-ck-cursor { width:1.5px; height:15px; background:var(--blue); margin-left:1px; animation:vp-blink 1.1s step-end infinite; }
@keyframes vp-blink { 50% { opacity:0; } }
.vp-ck-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.vp-ck-pay {
  height:44px; border-radius:var(--r-s); background:var(--blue); color:#fff;
  display:flex; align-items:center; justify-content:center; gap:8px;
  font-weight:600; font-size:14px; margin-top:4px;
}
.vp-ck-pay svg { width:15px; height:15px; }
.vp-ck-badges { display:flex; align-items:center; justify-content:center; gap:8px; padding-top:2px; }
.vp-ck-badges i { font-family:var(--mono); font-size:9px; color:var(--ink-3); border:1px solid var(--line-2); border-radius:3px; padding:2px 5px; letter-spacing:.04em; }

/* floating status chip on the art */
.vp-hero__chip {
  position:absolute; right:-10px; top:-16px; z-index:5;
  display:flex; align-items:center; gap:8px;
  background:var(--ink); color:#fff; border-radius:var(--r);
  padding:9px 13px; box-shadow:0 16px 36px rgba(10,14,26,.28);
  font-family:var(--mono); font-size:11px; letter-spacing:.02em;
}
.vp-hero__chip b { color:var(--cyan); font-weight:600; }
.vp-hero__chip i { width:7px; height:7px; border-radius:50%; background:var(--good); box-shadow:0 0 0 3px rgba(0,184,122,.25); }

/* ════════════════ TRUST STRIP ════════════════ */
.vp-trust { padding:42px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--bg-2); }
.vp-trust__lbl {
  display:block; text-align:center; font-family:var(--mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-3); margin-bottom:26px;
}
.vp-trust__row { display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; }
.vp-trust__logo {
  font-family:var(--disp); font-weight:600; font-size:19px; color:var(--ink-3); letter-spacing:-.02em;
  opacity:.85; transition:opacity .22s, color .22s;
  display:inline-flex; align-items:center; gap:8px;
}
.vp-trust__logo:hover { opacity:1; color:var(--ink); }
.vp-trust__logo svg { width:20px; height:20px; color:var(--blue); }

/* ════════════════ FEATURE GRID ════════════════ */
.vp-features { display:grid; grid-template-columns:repeat(3, 1fr); gap:0; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--line); }
.vp-feat {
  position:relative; padding:30px 26px 28px; background:var(--panel);
  transition:background .22s, transform .25s var(--ease);
}
.vp-feat:hover { background:var(--bg-2); }
.vp-feat__icon {
  width:42px; height:42px; border-radius:var(--r-s);
  background:var(--bg-3); border:1px solid var(--line-2);
  display:flex; align-items:center; justify-content:center; margin-bottom:20px; color:var(--blue);
}
.vp-feat__icon svg { width:20px; height:20px; }
.vp-feat__n { position:absolute; top:24px; right:26px; font-family:var(--mono); font-size:11px; color:var(--ink-3); letter-spacing:.06em; }
.vp-feat h3 { font-size:1.22rem; margin-bottom:10px; }
.vp-feat p { font-size:14px; color:var(--ink-2); line-height:1.62; }
.vp-feat__meta {
  display:inline-flex; align-items:center; gap:7px; margin-top:16px;
  font-family:var(--mono); font-size:11px; color:var(--blue); letter-spacing:.02em;
}
.vp-feat__meta::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--cyan); box-shadow:0 0 0 3px rgba(0,212,255,.16); }

/* ════════════════ HOW IT WORKS ════════════════ */
.vp-how { display:grid; grid-template-columns:repeat(4, 1fr); gap:0; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--panel); }
.vp-step {
  padding:30px 24px; border-right:1px solid var(--line); position:relative;
}
.vp-step:last-child { border-right:none; }
.vp-step__n {
  font-family:var(--mono); font-weight:600; font-size:12px; color:var(--blue);
  display:inline-flex; align-items:center; gap:9px; letter-spacing:.04em;
}
.vp-step__n::before { content:""; width:26px; height:26px; border:1px solid var(--line-2); border-radius:var(--r-s); display:inline-flex; }
.vp-step__n { position:relative; }
.vp-step__num {
  position:absolute; left:0; top:0; width:26px; height:26px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-weight:600; font-size:12px; color:var(--blue);
}
.vp-step h3 { font-size:1.15rem; margin:20px 0 11px; }
.vp-step p { font-size:13.5px; color:var(--ink-2); line-height:1.6; }
.vp-step__line {
  margin-top:16px; display:inline-flex; align-items:center; gap:7px;
  font-family:var(--mono); font-size:10.5px; color:var(--ink-3); letter-spacing:.02em;
  background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-s); padding:5px 9px;
}
.vp-step__line::before { content:"›"; color:var(--cyan); font-weight:700; }

/* ════════════════ SPLIT / DEEP DIVE ════════════════ */
.vp-split { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.vp-split--rev { direction:rtl; }
.vp-split--rev > * { direction:ltr; }
.vp-split__art {
  position:relative; aspect-ratio:1/1;
  border:1px solid var(--line); border-radius:var(--r);
  background:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px),
    var(--panel);
  background-size:32px 32px, 32px 32px, auto;
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 24px 60px rgba(10,14,26,.08);
}
.vp-split p { font-size:16px; color:var(--ink-2); line-height:1.68; margin:16px 0; }
.vp-split p em { font-style:normal; color:var(--ink); font-weight:600; }
.vp-split ul { list-style:none; margin-top:18px; }
.vp-split li {
  position:relative; padding-left:26px; margin:11px 0; font-size:14.5px; color:var(--ink-2);
  line-height:1.6;
}
.vp-split li::before {
  content:""; position:absolute; left:0; top:6px; width:15px; height:9px;
  border-left:2px solid var(--blue); border-bottom:2px solid var(--blue);
  transform:rotate(-45deg);
}
.vp-split li b { color:var(--ink); font-weight:600; }

/* ════════════════ NUMBERS STRIP ════════════════ */
.vp-numbers { padding:0; }
.vp-numbers__grid {
  display:grid; grid-template-columns:repeat(4, 1fr); gap:0;
  border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--ink);
}
.vp-num {
  padding:34px 28px; background:var(--ink);
  display:flex; flex-direction:column; gap:9px; border-right:1px solid #1b2236;
}
.vp-num:last-child { border-right:none; }
.vp-num__n {
  font-family:var(--disp); font-weight:600; font-size:clamp(2.3rem, 4.2vw, 3.2rem); line-height:1;
  color:#fff; letter-spacing:-.03em;
}
.vp-num__n b { font-weight:600; }
.vp-num__n em { font-style:normal; color:var(--cyan); }
.vp-num__l {
  font-family:var(--mono); font-size:10.5px; letter-spacing:.08em; color:var(--cyan);
  text-transform:uppercase;
}
.vp-num__d { font-size:13px; color:#9aa3b8; line-height:1.55; }

/* ════════════════ CUSTOMER QUOTES ════════════════ */
.vp-quotes { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.vp-quote {
  padding:30px 28px; background:var(--panel); border:1px solid var(--line); border-radius:var(--r);
  display:flex; flex-direction:column; gap:18px;
  transition:border-color .22s, transform .25s var(--ease);
}
.vp-quote:hover { border-color:var(--line-2); transform:translateY(-3px); box-shadow:0 18px 40px rgba(10,14,26,.07); }
.vp-quote__stars { display:flex; gap:3px; color:var(--cyan); }
.vp-quote__stars svg { width:15px; height:15px; }
.vp-quote__text { font-family:var(--sans); font-size:15.5px; line-height:1.55; color:var(--ink); font-weight:450; }
.vp-quote__text em { font-style:normal; color:var(--blue); font-weight:600; }
.vp-quote__by {
  display:flex; align-items:center; gap:13px;
  padding-top:18px; border-top:1px solid var(--line); margin-top:auto;
}
.vp-quote__av {
  width:40px; height:40px; border-radius:var(--r-s); flex:none;
  background:linear-gradient(135deg, var(--blue), var(--cyan)); color:#fff;
  display:flex; align-items:center; justify-content:center; font-family:var(--disp); font-weight:600; font-size:15px;
}
.vp-quote__name { font-size:13.5px; color:var(--ink); font-weight:600; }
.vp-quote__role { font-family:var(--mono); font-size:10.5px; color:var(--ink-3); letter-spacing:.02em; margin-top:2px; }

/* ════════════════ PRICING ════════════════ */
.vp-toggle {
  display:inline-flex; align-items:center; gap:4px; padding:4px;
  background:var(--bg-3); border:1px solid var(--line-2); border-radius:var(--r);
  margin:0 auto 44px;
}
.vp-toggle button {
  font-family:var(--mono); font-size:12px; letter-spacing:.02em; color:var(--ink-2);
  padding:8px 16px; border-radius:var(--r-s); transition:background .18s, color .18s;
}
.vp-toggle button.is-on { background:var(--panel); color:var(--ink); box-shadow:0 1px 3px rgba(10,14,26,.08); }
.vp-toggle button em { font-style:normal; color:var(--good); font-size:10px; }
.vp-toggle-wrap { display:flex; justify-content:center; }

.vp-tiers { display:grid; grid-template-columns:repeat(3, 1fr); gap:16px; }
.vp-tier {
  background:var(--panel); border:1px solid var(--line); border-radius:var(--r);
  padding:30px 28px; display:flex; flex-direction:column;
  transition:border-color .22s, transform .25s var(--ease), box-shadow .25s var(--ease);
}
.vp-tier:hover { border-color:var(--line-2); transform:translateY(-3px); box-shadow:0 20px 44px rgba(10,14,26,.08); }
.vp-tier--pop {
  border:1.5px solid var(--blue); position:relative; box-shadow:0 20px 50px rgba(59,76,255,.14);
}
.vp-tier__tag {
  position:absolute; top:-11px; left:28px;
  font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 11px; border-radius:var(--r-s);
  background:var(--blue); color:#fff; font-weight:600;
}
.vp-tier__name { font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.vp-tier__price { font-family:var(--disp); font-weight:600; font-size:3rem; line-height:1; margin:14px 0 6px; letter-spacing:-.03em; }
.vp-tier__price em { font-style:normal; color:var(--blue); font-size:1.4rem; }
.vp-tier__per { font-family:var(--mono); font-size:11.5px; color:var(--ink-3); letter-spacing:.02em; }
.vp-tier__desc { font-size:13.5px; color:var(--ink-2); line-height:1.58; margin:18px 0 20px; padding:18px 0 0; border-top:1px solid var(--line); }
.vp-tier__list { list-style:none; flex:1; display:flex; flex-direction:column; gap:11px; margin-bottom:22px; }
.vp-tier__list li {
  position:relative; padding-left:25px; font-size:13.5px; color:var(--ink-2); line-height:1.5;
}
.vp-tier__list li::before {
  content:""; position:absolute; left:0; top:5px; width:14px; height:8px;
  border-left:2px solid var(--cyan); border-bottom:2px solid var(--cyan); transform:rotate(-45deg);
}

/* comparison table (pricing page) */
.vp-cmp { width:100%; border-collapse:collapse; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--panel); }
.vp-cmp th, .vp-cmp td { padding:15px 18px; text-align:left; border-bottom:1px solid var(--line); font-size:13.5px; }
.vp-cmp thead th { font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); background:var(--bg-2); }
.vp-cmp tbody th { font-weight:500; color:var(--ink); }
.vp-cmp td { color:var(--ink-2); font-family:var(--mono); font-size:12.5px; }
.vp-cmp tr:last-child th, .vp-cmp tr:last-child td { border-bottom:none; }
.vp-cmp .yes { color:var(--good); }
.vp-cmp .no { color:var(--ink-3); }
.vp-cmp__scroll { overflow-x:auto; }

/* ════════════════ FAQ ════════════════ */
.vp-faq { max-width:880px; margin:0 auto; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--panel); }
.vp-faq details { border-bottom:1px solid var(--line); }
.vp-faq details:last-child { border-bottom:none; }
.vp-faq summary {
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  font-family:var(--disp); font-weight:600; font-size:1.12rem; cursor:pointer; list-style:none;
  padding:22px 24px; transition:color .18s, background .18s; color:var(--ink); letter-spacing:-.01em;
}
.vp-faq summary:hover { background:var(--bg-2); }
.vp-faq summary::-webkit-details-marker { display:none; }
.vp-faq summary::after {
  content:""; width:16px; height:16px; flex:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%233b4cff' stroke-width='2' stroke-linecap='round'><path d='M3 8h10M8 3v10'/></svg>");
  background-repeat:no-repeat; background-position:center; transition:transform .22s;
}
.vp-faq details[open] summary::after { transform:rotate(45deg); }
.vp-faq details[open] summary { color:var(--blue); }
.vp-faq p { padding:0 24px 22px; font-size:14.5px; color:var(--ink-2); line-height:1.68; max-width:62em; }

/* ════════════════ CTA / FINAL ════════════════ */
.vp-cta {
  padding:104px 0; text-align:center; position:relative; overflow:hidden;
  background:var(--ink); color:#fff;
}
.vp-cta::before {
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(90% 80% at 50% 50%, #000 30%, transparent 75%);
  mask-image:radial-gradient(90% 80% at 50% 50%, #000 30%, transparent 75%);
}
.vp-cta .vp-shell { position:relative; z-index:2; }
.vp-cta .vp-eyebrow { color:rgba(255,255,255,.6); justify-content:center; }
.vp-cta .vp-eyebrow > span { color:rgba(255,255,255,.7); }
.vp-cta h2 { color:#fff; font-size:clamp(2.3rem, 5vw, 4.2rem); margin:18px auto 20px; max-width:15em; }
.vp-cta h2 i { color:transparent; background:linear-gradient(100deg, #8b95ff, var(--cyan)); -webkit-background-clip:text; background-clip:text; }
.vp-cta p { font-size:17px; color:rgba(255,255,255,.72); max-width:38em; margin:0 auto 28px; }
.vp-cta__row { display:inline-flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.vp-cta .vp-btn--ghost { background:transparent; color:#fff; border-color:rgba(255,255,255,.2); }
.vp-cta .vp-btn--ghost:hover { border-color:var(--cyan); color:var(--cyan); }

/* ════════════════ FOOTER ════════════════ */
.vp-foot { padding:74px 0 28px; border-top:1px solid var(--line); background:var(--bg-2); position:relative; }
.vp-foot__top {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr 1fr; gap:36px; padding-bottom:44px;
}
.vp-foot__brand .vp-logo { margin-bottom:16px; }
.vp-foot__blurb { font-size:13.5px; color:var(--ink-2); max-width:25em; line-height:1.6; margin-bottom:18px; }
.vp-foot__badges { display:flex; flex-wrap:wrap; gap:8px; }
.vp-foot__badge {
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--mono); font-size:10px; padding:5px 10px;
  border:1px solid var(--line-2); border-radius:var(--r-s); background:var(--panel);
  color:var(--ink-2); letter-spacing:.04em;
}
.vp-foot__badge::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--good); }
.vp-foot__col h4 {
  font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.08em;
  color:var(--ink-3); margin-bottom:15px; font-weight:500;
}
.vp-foot__col a {
  display:block; font-size:13.5px; color:var(--ink-2); padding:5px 0; transition:color .18s;
}
.vp-foot__col a:hover { color:var(--blue); }
.vp-foot__base {
  display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap;
  padding-top:22px; border-top:1px solid var(--line);
  font-family:var(--mono); font-size:11.5px; color:var(--ink-3); letter-spacing:.02em;
}
.vp-foot__base a { color:var(--ink-2); }
.vp-foot__base a:hover { color:var(--blue); }
.vp-foot__big {
  font-family:var(--disp); font-weight:700;
  font-size:clamp(4.4rem, 15vw, 12rem); line-height:.82; letter-spacing:-.04em;
  color:transparent; -webkit-text-stroke:1px var(--line-2);
  text-align:center; padding:18px 0; user-select:none;
}

/* ════════════════ INNER PAGE HEAD ════════════════ */
.vp-phead { padding:64px 0 24px; }
.vp-phead__in { max-width:60em; }
.vp-phead h1 { font-size:clamp(2.3rem, 5vw, 4.3rem); margin:18px 0 22px; line-height:1.04; }
.vp-phead h1 i { font-style:normal; color:transparent; background:linear-gradient(100deg, var(--blue), var(--cyan)); -webkit-background-clip:text; background-clip:text; }
.vp-phead p { font-size:17px; color:var(--ink-2); max-width:36em; }
.vp-phead--c { text-align:center; }
.vp-phead--c .vp-phead__in { max-width:none; margin:0 auto; }
.vp-phead--c p { margin:0 auto; }

/* generic prose card grid for inner pages */
.vp-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.vp-grid3 { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.vp-card {
  background:var(--panel); border:1px solid var(--line); border-radius:var(--r); padding:28px 26px;
  transition:border-color .22s, transform .25s var(--ease);
}
.vp-card:hover { border-color:var(--line-2); transform:translateY(-3px); box-shadow:0 16px 38px rgba(10,14,26,.06); }
.vp-card__ic { width:40px; height:40px; border-radius:var(--r-s); background:var(--bg-3); border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; color:var(--blue); margin-bottom:18px; }
.vp-card__ic svg { width:19px; height:19px; }
.vp-card h3 { font-size:1.18rem; margin-bottom:10px; }
.vp-card p { font-size:13.5px; color:var(--ink-2); line-height:1.6; }
.vp-card__meta { display:inline-flex; align-items:center; gap:7px; margin-top:14px; font-family:var(--mono); font-size:10.5px; color:var(--blue); letter-spacing:.02em; }
.vp-card__meta::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--cyan); }
.vp-card ul { list-style:none; margin-top:14px; }
.vp-card li { position:relative; padding-left:22px; margin:8px 0; font-size:13px; color:var(--ink-2); line-height:1.5; }
.vp-card li::before { content:""; position:absolute; left:0; top:5px; width:12px; height:7px; border-left:2px solid var(--cyan); border-bottom:2px solid var(--cyan); transform:rotate(-45deg); }

/* feature split block reusable */
.vp-block { display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; padding:46px 0; }
.vp-block:nth-child(even) { direction:rtl; }
.vp-block:nth-child(even) > * { direction:ltr; }
.vp-block h3 { font-size:clamp(1.7rem,3vw,2.4rem); margin-bottom:16px; }
.vp-block p { font-size:15px; color:var(--ink-2); line-height:1.66; margin:12px 0; }
.vp-block__panel {
  border:1px solid var(--line); border-radius:var(--r); background:var(--panel); overflow:hidden;
  box-shadow:0 20px 50px rgba(10,14,26,.08);
}

/* ════════════════ FORMS ════════════════ */
.vp-field { margin-top:18px; }
.vp-field:first-child { margin-top:0; }
.vp-label-row { display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.vp-label { display:block; font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-2); margin-bottom:8px; }
.vp-input, .vp-textarea, .vp-select {
  width:100%; font-family:var(--sans); font-size:14.5px; color:var(--ink);
  background:var(--bg); border:1px solid var(--line-2); border-radius:var(--r-s); outline:none;
  transition:border-color .18s, box-shadow .18s, background .18s;
}
.vp-input, .vp-select { height:48px; padding:0 15px; }
.vp-textarea { min-height:130px; padding:13px 15px; resize:vertical; line-height:1.6; }
.vp-input::placeholder, .vp-textarea::placeholder { color:var(--ink-3); }
.vp-input:focus, .vp-textarea:focus, .vp-select:focus { border-color:var(--blue); background:var(--panel); box-shadow:0 0 0 3px rgba(59,76,255,.12); }
.vp-select {
  appearance:none; cursor:pointer; padding-right:42px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%237a8499' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='3 5 7 9 11 5'/></svg>");
  background-repeat:no-repeat; background-position:right 15px center;
}
.vp-input-wrap { position:relative; }
.vp-input-wrap .vp-input { padding-right:46px; }
.vp-eye { position:absolute; right:5px; top:50%; transform:translateY(-50%); width:38px; height:38px; display:flex; align-items:center; justify-content:center; color:var(--ink-3); border-radius:var(--r-s); transition:color .18s, background .18s; }
.vp-eye:hover { color:var(--ink); background:var(--bg-3); }
.vp-eye svg { width:17px; height:17px; }
.vp-field-error { display:none; margin-top:7px; font-family:var(--mono); font-size:11px; letter-spacing:.02em; color:var(--bad); }
.vp-field.is-invalid .vp-input, .vp-field.is-invalid .vp-textarea { border-color:var(--bad); }
.vp-field.is-invalid .vp-field-error { display:block; }
.vp-forgot { font-family:var(--mono); font-size:11px; color:var(--blue); }
.vp-forgot:hover { text-decoration:underline; }
.vp-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.vp-check { display:flex; align-items:center; gap:11px; margin-top:18px; cursor:pointer; font-size:13.5px; color:var(--ink-2); }
.vp-check input { position:absolute; opacity:0; width:0; height:0; }
.vp-check__box {
  flex:none; width:18px; height:18px; border:1px solid var(--line-2); border-radius:var(--r-s);
  background:var(--bg); display:flex; align-items:center; justify-content:center; color:#fff;
}
.vp-check__box svg { width:11px; height:11px; opacity:0; }
.vp-check input:checked + .vp-check__box { background:var(--blue); border-color:var(--blue); }
.vp-check input:checked + .vp-check__box svg { opacity:1; }
.vp-alert {
  display:none; align-items:center; gap:10px; margin-top:18px; padding:12px 14px;
  border:1px solid rgba(255,77,109,.35); border-radius:var(--r-s); font-size:13px; color:var(--bad);
  background:rgba(255,77,109,.06);
}
.vp-alert.is-on { display:flex; }
.vp-alert svg { width:16px; height:16px; flex:none; }
.vp-spin { display:none; width:18px; height:18px; border-radius:999px; border:2.2px solid rgba(255,255,255,.4); border-top-color:#fff; animation:vp-sp .6s linear infinite; }
.vp-btn.is-loading .vp-btn-label { display:none; }
.vp-btn.is-loading .vp-spin { display:block; }
.vp-btn.is-loading { pointer-events:none; }
@keyframes vp-sp { to { transform:rotate(360deg); } }
.vp-divider { display:flex; align-items:center; gap:14px; margin:22px 0; color:var(--ink-3); }
.vp-divider::before, .vp-divider::after { content:""; flex:1; height:1px; background:var(--line); }
.vp-divider span { font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; }
.vp-oauth { display:flex; flex-direction:column; gap:10px; }
.vp-oauth__btn {
  display:flex; align-items:center; justify-content:center; gap:10px; height:46px;
  border:1px solid var(--line-2); border-radius:var(--r-s);
  font-size:13.5px; font-weight:500; color:var(--ink); background:var(--panel);
  transition:border-color .18s, background .18s;
}
.vp-oauth__btn:hover { border-color:var(--blue); background:var(--bg-2); }

/* ════════════════ AUTH ════════════════ */
.vp-auth { padding:64px 0 110px; }
.vp-auth__wrap { width:100%; max-width:452px; margin:0 auto; }
.vp-authcard {
  background:var(--panel);
  border:1px solid var(--line); border-radius:var(--r);
  padding:36px 34px 30px;
  box-shadow:0 30px 70px rgba(10,14,26,.1);
}
.vp-auth__h { font-size:2.1rem; margin-top:8px; }
.vp-auth__h i { font-style:normal; color:transparent; background:linear-gradient(100deg, var(--blue), var(--cyan)); -webkit-background-clip:text; background-clip:text; }
.vp-auth__sub { margin:12px 0 26px; font-size:14.5px; color:var(--ink-2); }
.vp-auth__submit { margin-top:20px; }
.vp-auth__foot { margin-top:22px; text-align:center; font-size:13.5px; color:var(--ink-2); }
.vp-auth__foot a { color:var(--blue); font-weight:500; }
.vp-auth__foot a:hover { text-decoration:underline; }
.vp-auth__trust { display:flex; align-items:center; justify-content:center; gap:8px; margin-top:22px; font-family:var(--mono); font-size:10.5px; letter-spacing:.02em; color:var(--ink-3); }
.vp-auth__trust svg { width:13px; height:13px; color:var(--good); }
.vp-authdone { text-align:center; padding:6px 0; }
.vp-success {
  width:62px; height:62px; margin:0 auto 20px; border-radius:var(--r);
  background:linear-gradient(135deg, var(--blue), var(--cyan)); color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 12px 30px rgba(59,76,255,.32);
}
.vp-success svg { width:28px; height:28px; }

/* ════════════════ CONTACT ════════════════ */
.vp-contact { padding:44px 0 110px; }
.vp-contact__in { display:grid; grid-template-columns:1.2fr .8fr; gap:54px; align-items:start; }
.vp-contact__form {
  background:var(--panel); border:1px solid var(--line); border-radius:var(--r); padding:34px;
}
.vp-contact__aside { display:flex; flex-direction:column; gap:14px; }
.vp-info {
  border:1px solid var(--line); border-radius:var(--r); padding:22px; background:var(--panel);
}
.vp-info svg { width:22px; height:22px; color:var(--blue); margin-bottom:12px; }
.vp-info h3 { font-family:var(--disp); font-weight:600; font-size:1.2rem; }
.vp-info p { margin-top:8px; font-size:13.5px; color:var(--ink-2); line-height:1.6; }
.vp-info a { color:var(--blue); }
.vp-info a:hover { text-decoration:underline; }
.vp-info--accent {
  background:var(--ink); border-color:var(--ink);
}
.vp-info--accent h3 { color:#fff; }
.vp-info--accent p { color:rgba(255,255,255,.7); }
.vp-info--accent svg { color:var(--cyan); }
.vp-info--accent a { color:var(--cyan); }

/* ════════════════ LEGAL ════════════════ */
.vp-legal { padding:44px 0 110px; }
.vp-legal__in { max-width:760px; margin:0 auto; }
.vp-legal h1 { font-size:clamp(2.1rem, 4.2vw, 3rem); margin-top:14px; }
.vp-legal h1 i { font-style:normal; color:transparent; background:linear-gradient(100deg, var(--blue), var(--cyan)); -webkit-background-clip:text; background-clip:text; }
.vp-legal__meta { font-family:var(--mono); margin-top:14px; font-size:11px; letter-spacing:.02em; color:var(--ink-3); }
.vp-legal__toc {
  margin-top:30px; padding:24px 28px;
  background:var(--panel); border:1px solid var(--line); border-radius:var(--r);
}
.vp-legal__toc h4 { font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:14px; font-weight:500; }
.vp-legal__toc ol { padding-left:22px; }
.vp-legal__toc li { font-size:14px; margin:6px 0; color:var(--ink-2); }
.vp-legal__toc a { transition:color .18s; }
.vp-legal__toc a:hover { color:var(--blue); }
.vp-legal__body { margin-top:36px; }
.vp-legal__body h2 { font-family:var(--disp); font-weight:600; font-size:1.5rem; margin:36px 0 12px; scroll-margin-top:90px; }
.vp-legal__body h2:first-child { margin-top:0; }
.vp-legal__body h2 i { font-style:normal; color:var(--blue); }
.vp-legal__body p { margin:12px 0; font-size:15px; color:var(--ink-2); line-height:1.74; }
.vp-legal__body ul { margin:12px 0; padding-left:0; }
.vp-legal__body li { position:relative; padding-left:22px; margin:8px 0; font-size:15px; color:var(--ink-2); list-style:none; line-height:1.7; }
.vp-legal__body li::before { content:""; position:absolute; left:0; top:9px; width:7px; height:7px; border-radius:50%; background:var(--blue); }
.vp-legal__body a { color:var(--blue); }
.vp-legal__body a:hover { text-decoration:underline; }
.vp-legal__body strong { color:var(--ink); font-weight:600; }

/* ════════════════ CODE BLOCK (developers page) ════════════════ */
.vp-code {
  background:var(--ink); border:1px solid #1b2236; border-radius:var(--r);
  padding:22px 24px; font-family:var(--mono); font-size:12.7px; line-height:1.75;
  color:#c3cadb; overflow-x:auto; position:relative;
}
.vp-code__lbl {
  position:absolute; top:10px; right:14px;
  font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:#566079;
}
.vp-code .k { color:#7c89ff; }
.vp-code .s { color:#43e0c0; }
.vp-code .c { color:#566079; font-style:italic; }
.vp-code .n { color:#ff9d6b; }
.vp-code .f { color:#37d4ff; }
.vp-code .p { color:#9aa3b8; }

/* tabs (developers) */
.vp-tabs { display:flex; gap:4px; padding:4px; background:var(--bg-3); border:1px solid var(--line-2); border-radius:var(--r); margin-bottom:22px; flex-wrap:wrap; }
.vp-tabs button {
  font-family:var(--mono); font-size:12px; color:var(--ink-2); padding:8px 15px; border-radius:var(--r-s);
  letter-spacing:.02em; transition:background .18s, color .18s;
}
.vp-tabs button.is-on { background:var(--panel); color:var(--ink); box-shadow:0 1px 3px rgba(10,14,26,.08); }
[data-panel] { display:none; }
[data-panel].is-on { display:block; }

/* endpoint list */
.vp-endpoints { border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--panel); }
.vp-endpoint { display:flex; align-items:center; gap:14px; padding:14px 18px; border-bottom:1px solid var(--line); font-family:var(--mono); font-size:13px; }
.vp-endpoint:last-child { border-bottom:none; }
.vp-endpoint .m { font-size:10.5px; font-weight:600; padding:3px 8px; border-radius:3px; letter-spacing:.04em; flex:none; }
.vp-endpoint .m.post { background:rgba(0,184,122,.12); color:var(--good); }
.vp-endpoint .m.get { background:rgba(59,76,255,.1); color:var(--blue); }
.vp-endpoint .m.del { background:rgba(255,77,109,.1); color:var(--bad); }
.vp-endpoint .path { color:var(--ink); }
.vp-endpoint .desc { color:var(--ink-3); margin-left:auto; font-family:var(--sans); font-size:12.5px; }

/* stat band reusable */
.vp-statband { display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--panel); }
.vp-statband > div { padding:26px 24px; border-right:1px solid var(--line); }
.vp-statband > div:last-child { border-right:none; }
.vp-statband b { font-family:var(--disp); font-weight:600; font-size:2.1rem; display:block; letter-spacing:-.02em; }
.vp-statband span { font-family:var(--mono); font-size:10.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-3); margin-top:6px; display:block; }

/* logos / careers row */
.vp-roles { border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--panel); }
.vp-role { display:flex; align-items:center; gap:16px; padding:18px 22px; border-bottom:1px solid var(--line); transition:background .18s; }
.vp-role:last-child { border-bottom:none; }
.vp-role:hover { background:var(--bg-2); }
.vp-role h4 { font-family:var(--disp); font-weight:600; font-size:1.05rem; }
.vp-role span { font-family:var(--mono); font-size:11px; color:var(--ink-3); }
.vp-role .vp-role__loc { margin-left:auto; }
.vp-role .vp-role__arrow { width:18px; height:18px; color:var(--ink-3); flex:none; }

/* ════════════════ RESPONSIVE ════════════════ */
@media (max-width:1080px){
  .vp-features { grid-template-columns:1fr 1fr; }
  .vp-quotes, .vp-grid3, .vp-statband { grid-template-columns:1fr 1fr; }
  .vp-how { grid-template-columns:1fr 1fr; }
  .vp-step { border-right:none; border-bottom:1px solid var(--line); }
  .vp-step:nth-child(odd) { border-right:1px solid var(--line); }
  .vp-foot__top { grid-template-columns:1fr 1fr 1fr; gap:28px; }
  .vp-foot__brand { grid-column:1 / -1; }
}
@media (max-width:920px){
  .vp-hero__grid { grid-template-columns:1fr; gap:46px; }
  .vp-hero__art { max-width:520px; }
}
@media (max-width:860px){
  .vp-nav, .vp-head__act .vp-btn, .vp-head__act .vp-login, .vp-head__act .vp-lang { display:none; }
  .vp-burger { display:flex; }
  .vp-tiers, .vp-grid2, .vp-block { grid-template-columns:1fr; }
  .vp-block:nth-child(even) { direction:ltr; }
  .vp-numbers__grid { grid-template-columns:1fr 1fr; }
  .vp-num { border-right:none; border-bottom:1px solid #1b2236; }
  .vp-num:nth-child(odd) { border-right:1px solid #1b2236; }
  .vp-split, .vp-contact__in { grid-template-columns:1fr; gap:36px; }
  .vp-sec { padding:76px 0; }
}
@media (max-width:580px){
  .vp-shell { padding:0 18px; }
  .vp-sec { padding:60px 0; }
  .vp-hero { padding:38px 0 62px; }
  .vp-features, .vp-quotes, .vp-grid3, .vp-statband, .vp-how, .vp-numbers__grid { grid-template-columns:1fr; }
  .vp-step { border-right:none !important; border-bottom:1px solid var(--line); }
  .vp-step:last-child { border-bottom:none; }
  .vp-num { border-right:none !important; }
  .vp-foot__top { grid-template-columns:1fr; }
  .vp-logo__word { font-size:18px; }
  .vp-row { grid-template-columns:1fr; }
  .vp-trust__row { gap:18px 24px; justify-content:flex-start; }
  .vp-tier__price { font-size:2.5rem; }
  .vp-foot__big { font-size:3rem; }
  .vp-hero__chip { right:8px; top:-12px; }
}
