/* ============================================================
   Electbase — marketing site design system
   Civic-editorial tech. Ink + electric-blue + the baseline motif.
   Hand-authored, no build step. WCAG-AA, fast, no JS-gated content.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Hanken+Grotesk:wght@400;500;600;700&family=Spline+Sans+Mono:wght@400;500;600&display=swap');

:root {
  /* palette */
  --ink:        #0a1020;
  --ink-deep:   #070b16;
  --ink-soft:   #141c30;
  --paper:      #f6f6f2;
  --paper-warm: #efeee6;
  --slate:      #3a4256;
  --muted:      #6c7488;
  --line:       #d9d8cf;
  --line-dark:  #20283d;

  --electric:    #3a6bff;
  --electric-br: #6f9bff;
  --electric-dk: #2247c8;
  --glow:        rgba(58,107,255,.45);

  /* amber — the action / CTA accent (warm pop against the navy + electric scheme) */
  --amber:       #f59e0b;
  --amber-br:    #ffc24d;
  --amber-dk:    #b9740a;
  --glow-amber:  rgba(245,158,11,.42);

  /* type */
  --display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --body:    'Hanken Grotesk', system-ui, sans-serif;
  --mono:    'Spline Sans Mono', ui-monospace, monospace;

  /* fluid scale */
  --step--1: clamp(.82rem, .79rem + .15vw, .92rem);
  --step-0:  clamp(1rem, .95rem + .25vw, 1.15rem);
  --step-1:  clamp(1.25rem, 1.15rem + .5vw, 1.6rem);
  --step-2:  clamp(1.6rem, 1.4rem + 1vw, 2.3rem);
  --step-3:  clamp(2.1rem, 1.7rem + 2vw, 3.4rem);
  --step-4:  clamp(2.8rem, 2rem + 4vw, 5.6rem);
  --step-5:  clamp(3.4rem, 2.2rem + 6vw, 7.2rem);

  --maxw: 1180px;
  --radius: 14px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--body);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--electric); color: #fff; }

/* ---- layout ---- */
.wrap { width: min(100% - 2.5rem, var(--maxw)); margin-inline: auto; }
.section { padding: clamp(4rem, 9vw, 8rem) 0; position: relative; }
.eyebrow {
  font-family: var(--mono);
  font-size: var(--step--1);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--electric-dk);
  display: inline-flex; align-items: center; gap: .6rem;
}
.eyebrow::before { content: ""; width: 26px; height: 2px; background: var(--electric); display: inline-block; }
.dark .eyebrow { color: var(--electric-br); }

/* ---- type ---- */
h1, h2, h3, h4 { font-family: var(--display); font-weight: 600; line-height: 1.04; letter-spacing: -.02em; }
h1 { font-size: var(--step-5); font-weight: 600; }
h2 { font-size: var(--step-3); }
h3 { font-size: var(--step-1); letter-spacing: -.01em; }
p  { max-width: 64ch; }
.lead { font-size: var(--step-1); line-height: 1.45; color: var(--slate); font-weight: 400; }
.dark, .dark p, .dark .lead { color: #c8cee0; }
.dark h1, .dark h2, .dark h3 { color: #fff; }
em.ink-accent { font-style: italic; color: var(--electric-dk); }
.dark em.ink-accent { color: var(--electric-br); }

/* the baseline motif — a glowing rule */
.baseline { height: 2px; border: 0; background: linear-gradient(90deg, transparent, var(--electric) 18%, var(--electric-br) 50%, var(--electric) 82%, transparent); box-shadow: 0 0 22px var(--glow); opacity: .9; }

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--body); font-weight: 600; font-size: var(--step-0);
  padding: .9rem 1.5rem; border-radius: 100px; border: 1.5px solid transparent;
  cursor: pointer; transition: transform .18s ease, box-shadow .25s ease, background .2s;
  line-height: 1;
}
.btn-primary { background: var(--amber); color: var(--ink); box-shadow: 0 10px 30px -8px var(--glow-amber); }
.btn-primary:hover { background: var(--amber-br); transform: translateY(-2px); box-shadow: 0 16px 40px -10px var(--glow-amber); }
.btn-ghost { border-color: currentColor; color: var(--ink); }
.dark .btn-ghost { color: #fff; }
.btn-ghost:hover { background: var(--electric-dk); border-color: var(--electric-dk); color: #fff; transform: translateY(-2px); }
.btn .arr { transition: transform .2s; }
.btn:hover .arr { transform: translateX(3px); }

/* ---- nav ---- */
.nav { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(12px); background: color-mix(in srgb, var(--paper) 82%, transparent); border-bottom: 1px solid var(--line); }
.nav .wrap { display: flex; align-items: center; justify-content: space-between; padding-block: .9rem; }
.nav-links { display: flex; gap: 2rem; align-items: center; font-weight: 500; font-size: var(--step--1); }
.nav-links a { color: var(--slate); transition: color .15s; }
.nav-links a:hover { color: var(--electric-dk); }
.nav-cta { padding: .55rem 1.1rem; }
@media (max-width: 760px){ .nav-links a:not(.nav-cta){ display:none; } }

/* ---- logo / wordmark ---- */
.logo { display: inline-flex; align-items: baseline; gap: .1rem; font-family: var(--display); font-weight: 700; font-size: 1.4rem; letter-spacing: -.03em; color: var(--ink); }
.nav .logo { font-size: 2.8rem; }
.dark .logo { color: #fff; }
.logo .period { color: var(--electric); }

/* ---- hero ---- */
.hero { background: var(--ink); color: #fff; position: relative; overflow: hidden; padding-top: clamp(4rem, 8vw, 7rem); padding-bottom: clamp(4rem, 8vw, 7rem); }
.hero::before { /* fine grid */ content:""; position:absolute; inset:0; background-image: linear-gradient(var(--line-dark) 1px, transparent 1px), linear-gradient(90deg, var(--line-dark) 1px, transparent 1px); background-size: 56px 56px; mask-image: radial-gradient(ellipse 90% 70% at 50% 0%, #000 35%, transparent 78%); opacity:.5; }
.hero::after { /* electric glow */ content:""; position:absolute; top:-30%; left:50%; width:120%; height:90%; transform:translateX(-50%); background: radial-gradient(ellipse at center, var(--glow), transparent 60%); filter: blur(40px); opacity:.55; pointer-events:none; }
.hero .wrap { position: relative; z-index: 2; }
.hero h1 { max-width: 16ch; }
.hero .lead { max-width: 54ch; margin-top: 1.4rem; color: #cdd5e8; }
.hero-cta { display:flex; gap:1rem; flex-wrap:wrap; margin-top: 2.4rem; }
.hero-meta { margin-top: 2.4rem; display:flex; gap:1.6rem; flex-wrap:wrap; font-family:var(--mono); font-size:var(--step--1); color:#9aa4bd; letter-spacing:.03em; }
.hero-meta span { display:inline-flex; align-items:center; gap:.5rem; }
.dot { width:7px; height:7px; border-radius:50%; background:var(--electric-br); box-shadow:0 0 8px var(--glow); }

/* hero two-column: square animated illustration + copy */
.hero-grid { display: grid; grid-template-columns: minmax(280px, .82fr) 1.1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.hero-grid h1 { font-size: var(--step-4); }
.hero-below { text-align: center; margin-top: clamp(2rem, 4vw, 3.2rem); }
.hero-below .lead { margin: 1.4rem auto 0; max-width: calc(60ch + 40px); }
.hero-below .hero-cta { flex-direction: column; align-items: center; justify-content: center; }
.hero-below .hero-meta { justify-content: center; }
.hero-media { margin: 0; border-radius: 20px; overflow: hidden; border: 1px solid var(--line-dark); box-shadow: 0 34px 80px -34px rgba(0,0,0,.65); background: #fff; }
.hero-media video { display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
@media (max-width: 900px){
  .hero-grid { grid-template-columns: 1fr; gap: 2rem; }
  .hero-media { order: 2; max-width: 440px; }
}

/* grain overlay */
.grain::before { content:""; position:absolute; inset:0; pointer-events:none; opacity:.04; mix-blend-mode:overlay; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ---- cards / grid ---- */
.grid { display: grid; gap: 1.4rem; }
.cols-2 { grid-template-columns: repeat(2,1fr); }
.cols-3 { grid-template-columns: repeat(3,1fr); }
.cols-4 { grid-template-columns: repeat(4,1fr); }
@media (max-width: 880px){ .cols-3,.cols-4{ grid-template-columns: repeat(2,1fr);} }
@media (max-width: 600px){ .cols-2,.cols-3,.cols-4{ grid-template-columns: 1fr;} }

.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.7rem; transition: transform .2s ease, box-shadow .25s ease, border-color .2s; }
.card:hover { transform: translateY(-4px); box-shadow: 0 22px 50px -28px rgba(10,16,32,.4); border-color: color-mix(in srgb, var(--electric) 40%, var(--line)); }
.card h3 { margin-bottom: .5rem; }
.card .num { font-family: var(--mono); color: var(--electric-dk); font-size: var(--step--1); font-weight: 600; }
.card .ic { width: 30px; height: 30px; color: var(--electric); margin-bottom: 1rem; }

.dark .card { background: var(--ink-soft); border-color: var(--line-dark); }
.dark .card:hover { box-shadow: 0 22px 50px -26px #000; }

/* ---- no-red banner ---- */
.pledge { background: var(--ink-deep); color:#fff; text-align:center; position:relative; overflow:hidden; }
.pledge .big { font-family: var(--display); font-size: var(--step-3); max-width: 20ch; margin: .6rem auto 0; }
.pledge .strike { position: relative; }
.pledge .strike::after { content:""; position:absolute; left:-4%; right:-4%; top:54%; height:3px; background:#ff5a5a; transform: rotate(-4deg); border-radius:2px; }

/* ---- split feature ---- */
.split { display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,5vw,4.5rem); align-items:center; }
@media (max-width: 820px){ .split{ grid-template-columns:1fr; } }
.stat-row { display:flex; gap: 2.5rem; flex-wrap:wrap; margin-top: 1.6rem; }
.stat .n { font-family: var(--display); font-size: var(--step-3); color: var(--electric-dk); line-height:1; }
.dark .stat .n { color: var(--electric-br); }
.stat .l { font-family: var(--mono); font-size: var(--step--1); color: var(--muted); text-transform: uppercase; letter-spacing:.08em; margin-top:.4rem; }

/* ---- campaign-in-motion: alternating animated scene rows ---- */
.motion-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; margin-top: clamp(3rem, 6vw, 5.5rem); }
@media (max-width: 820px){ .motion-row { grid-template-columns: 1fr; gap: 1.6rem; } .motion-row .motion-card { order: -1; } }
.motion-copy h3 { font-size: var(--step-2); }
.motion-copy p { margin-top: .9rem; font-size: var(--step-1); line-height: 1.5; color: var(--slate); max-width: 46ch; }
.motion-card { margin: 0; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); background: #fff; box-shadow: 0 22px 50px -30px rgba(10,16,32,.4); }
.motion-card video { display: block; width: 100%; aspect-ratio: 16 / 9; object-fit: cover; background: #fff; }

/* fade-in on first view — enhancement only: JS adds .will-fade to off-screen
   rows, then .is-visible on scroll. Content is never hidden if JS is off. */
.reveal.will-fade { opacity: 0; transform: translateY(26px); }
.reveal.will-fade.is-visible { opacity: 1; transform: none; transition: opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
@media (prefers-reduced-motion: reduce){ .reveal.will-fade { opacity: 1 !important; transform: none !important; } }

/* lists */
.checks { list-style:none; display:grid; gap:.9rem; margin-top:1.5rem; }
.checks li { display:flex; gap:.8rem; align-items:flex-start; }
.checks svg { flex:none; width:22px; height:22px; color:var(--electric); margin-top:.15rem; }

/* ---- waitlist ---- */
.waitlist { background: var(--ink); color:#fff; position:relative; overflow:hidden; }
.wl-form { display:flex; gap:.7rem; flex-wrap:wrap; margin-top:1.8rem; max-width:520px; }
.wl-form input { flex:1; min-width:240px; padding:.95rem 1.2rem; border-radius:100px; border:1.5px solid var(--line-dark); background:var(--ink-soft); color:#fff; font-family:var(--body); font-size:var(--step-0); }
.wl-form input::placeholder { color:#7c869e; }
.wl-form input:focus { outline:none; border-color:var(--electric); box-shadow:0 0 0 4px rgba(58,107,255,.18); }
.wl-note { font-family:var(--mono); font-size:var(--step--1); color:#8b93ab; margin-top:1rem; text-align:center; margin-inline:auto; }
.wl-success { font-family:var(--display); font-size:var(--step-1); color:var(--amber-br); margin-top:1.8rem; animation: rise .5s ease both; }
/* honeypot — visually hidden, off-screen, not announced */
.hp { position:absolute !important; left:-9999px !important; top:auto; width:1px; height:1px; opacity:0; pointer-events:none; }

/* ---- footer ---- */
.footer { background: var(--ink-deep); color:#aab2c8; padding: clamp(3rem,6vw,4.5rem) 0 2.5rem; }
.footer .top { display:flex; justify-content:space-between; gap:2rem; flex-wrap:wrap; padding-bottom:2.2rem; border-bottom:1px solid var(--line-dark); }
.footer a { color:#aab2c8; transition:color .15s; }
.footer a:hover { color:var(--electric-br); }
.footer .cols { display:flex; gap:3.5rem; flex-wrap:wrap; }
.footer h4 { font-family:var(--mono); font-size:var(--step--1); text-transform:uppercase; letter-spacing:.1em; color:#fff; margin-bottom:1rem; font-weight:500; }
.footer .links { display:grid; gap:.6rem; font-size:var(--step--1); }
.footer .links button.cookie-settings-btn { background:none; border:0; padding:0; margin:0; font:inherit; text-align:left; cursor:pointer; color:#aab2c8; transition:color .15s; }
.footer .links button.cookie-settings-btn:hover { color:var(--electric-br); }
.footer .bottom { display:flex; justify-content:center; text-align:center; gap:1rem; flex-wrap:wrap; margin-top:2rem; font-family:var(--mono); font-size:var(--step--1); color:#6c768f; }

/* ---- blog ---- */
.post-card { display:block; background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; transition:transform .2s, box-shadow .25s, border-color .2s; }
.post-card:hover { transform:translateY(-4px); box-shadow:0 22px 50px -28px rgba(10,16,32,.4); border-color:color-mix(in srgb,var(--electric) 40%,var(--line)); }
.post-card .pc-body { padding:1.6rem; }
.post-card .tag { font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--electric-dk); font-weight:600; }
.post-card h3 { margin:.6rem 0; font-size:var(--step-1); }
.post-card .meta { font-family:var(--mono); font-size:var(--step--1); color:var(--muted); margin-top:1rem; }

/* article */
.article { padding-top: 3rem; }
.article-head { max-width: 760px; margin:0 auto; }
.article-head h1 { font-size: var(--step-4); margin:1rem 0; }
.prose { max-width: 720px; margin: 2.5rem auto 0; font-size: var(--step-1); line-height:1.7; color:var(--slate); }
.prose h2 { font-size: var(--step-2); color:var(--ink); margin:2.6rem 0 1rem; }
.prose h3 { font-size: var(--step-1); color:var(--ink); margin:2rem 0 .8rem; }
.prose p { max-width: none; margin-bottom: 1.3rem; }
.prose ul, .prose ol { margin: 0 0 1.4rem 1.3rem; display:grid; gap:.6rem; }
.prose strong { color: var(--ink); }
.prose a { color: var(--electric-dk); text-decoration: underline; text-underline-offset: 3px; }
.prose blockquote { border-left:3px solid var(--electric); padding-left:1.3rem; margin:2rem 0; font-family:var(--display); font-size:var(--step-2); color:var(--ink); font-style:italic; }
.callout { background:var(--paper-warm); border:1px solid var(--line); border-radius:var(--radius); padding:1.4rem 1.6rem; margin:2rem 0; font-size:var(--step-0); }
.callout .lbl { font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--electric-dk); font-weight:600; }

/* ---- cookie consent banner ---- */
.eb-cookie-wrap { position:fixed; bottom:0; left:0; width:100%; z-index:200; display:flex; justify-content:center; padding:0 1.2rem 1.2rem; pointer-events:none; }
.eb-cookie-card { pointer-events:auto; width:100%; max-width:460px; background:linear-gradient(135deg, var(--ink) 0%, var(--ink-soft) 100%); border:1px solid var(--line-dark); border-radius:var(--radius); box-shadow:0 22px 50px -20px rgba(10,16,32,.55); transform:translateY(120%); transition:transform .4s cubic-bezier(.22,1,.36,1); }
.eb-cookie-card.is-open { transform:translateY(0); }
.eb-cookie-head { padding:1.4rem 1.4rem .6rem; }
.eb-cookie-title { font-family:var(--display); font-weight:600; color:#fff; font-size:var(--step-0); margin-bottom:.5rem; }
.eb-cookie-head p { font-size:var(--step--1); color:#c8cee0; line-height:1.55; margin:0; }
.eb-cookie-head a { color:var(--electric-br); text-decoration:underline; text-underline-offset:2px; }
.eb-cookie-cats { padding:.2rem 1.4rem; }
.eb-cookie-row { display:flex; align-items:flex-start; justify-content:space-between; gap:.8rem; padding:.7rem 0; border-bottom:1px solid var(--line-dark); }
.eb-cookie-row:last-child { border-bottom:none; }
.eb-cookie-row .lbl { font-family:var(--body); font-weight:600; color:#fff; font-size:var(--step--1); }
.eb-cookie-row .lbl .always { font-weight:600; color:var(--amber-br); font-size:.68rem; text-transform:uppercase; letter-spacing:.05em; margin-left:.4rem; }
.eb-cookie-row .desc { font-size:.78rem; color:#9aa4bd; margin-top:.15rem; line-height:1.4; }
.eb-toggle { flex:0 0 auto; width:42px; height:24px; border-radius:100px; border:0; padding:0; position:relative; cursor:pointer; background:#39415a; transition:background .18s; }
.eb-toggle[aria-checked="true"] { background:var(--electric); }
.eb-toggle:disabled { opacity:.55; cursor:not-allowed; }
.eb-toggle span { position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:50%; background:#fff; box-shadow:0 1px 3px rgba(0,0,0,.35); transition:transform .18s ease; }
.eb-toggle[aria-checked="true"] span { transform:translateX(18px); }
.eb-cookie-actions { padding:1rem 1.4rem 1.4rem; display:flex; flex-direction:column; gap:.6rem; }
.eb-cookie-actions .row { display:flex; gap:.6rem; }
.eb-cookie-actions button { flex:1; font-family:var(--body); font-weight:600; font-size:var(--step--1); padding:.7rem 1rem; border-radius:100px; border:1.5px solid transparent; cursor:pointer; transition:transform .15s ease, background .15s ease; }
.eb-cookie-actions .ghost { background:rgba(255,255,255,.06); color:#c8cee0; border-color:var(--line-dark); }
.eb-cookie-actions .ghost:hover { background:rgba(255,255,255,.12); }
.eb-cookie-actions .save { background:rgba(58,107,255,.22); color:#fff; border-color:rgba(58,107,255,.4); }
.eb-cookie-actions .save:hover { background:rgba(58,107,255,.32); }
.eb-cookie-actions .accept { background:var(--amber); color:var(--ink); }
.eb-cookie-actions .accept:hover { background:var(--amber-br); transform:translateY(-1px); }
@media (max-width:520px){ .eb-cookie-wrap{ padding:0 .7rem .7rem; } }

/* ---- reveal animation ---- */
@keyframes rise { from { opacity:0; transform: translateY(22px); } to { opacity:1; transform:none; } }
.rise { animation: rise .8s cubic-bezier(.2,.7,.2,1) both; }
.d1{animation-delay:.08s} .d2{animation-delay:.18s} .d3{animation-delay:.28s} .d4{animation-delay:.38s} .d5{animation-delay:.48s}
@media (prefers-reduced-motion: reduce){ *{animation:none!important; transition:none!important; scroll-behavior:auto!important;} }

/* utilities */
.center{ text-align:center; } .mx-auto{ margin-inline:auto; }
.mt-s{ margin-top:1rem; } .mt-m{ margin-top:2rem; } .mt-l{ margin-top:3rem; }
.tag-pill{ display:inline-block; font-family:var(--mono); font-size:var(--step--1); border:1px solid var(--line); border-radius:100px; padding:.3rem .9rem; color:var(--slate); }
.dark .tag-pill{ border-color:var(--line-dark); color:#c8cee0; }
.maxch{ max-width:58ch; }

/* ---- integrations strip ---- */
.int-group-label { font-family:var(--mono); font-size:var(--step--1); text-transform:uppercase; letter-spacing:.14em; color:var(--electric-dk); margin-inline:auto; }
.int-grid { list-style:none; margin:1.1rem auto 0; padding:0; display:flex; flex-wrap:wrap; justify-content:center; gap:.8rem; max-width:880px; }
.int-chip { display:flex; align-items:center; gap:.65rem; background:#fff; border:1px solid var(--line); border-radius:12px; padding:.55rem .95rem .55rem .6rem; text-align:left; }
.int-mono { width:34px; height:34px; border-radius:9px; background:var(--chip, var(--electric)); color:#fff; font-family:var(--display); font-weight:600; font-size:1.05rem; display:grid; place-items:center; flex:0 0 auto; }
.int-meta { display:flex; flex-direction:column; line-height:1.15; }
.int-name { font-weight:600; font-size:var(--step--1); color:var(--ink); }
.int-cat { font-family:var(--mono); font-size:.68rem; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; margin-top:.15rem; }
.int-grid--soon .int-chip { background:var(--paper-warm); border-style:dashed; }
.int-grid--soon .int-mono { opacity:.7; }

/* ---- faq ---- */
.faq { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem 3rem; }
@media (max-width:780px){ .faq{ grid-template-columns:1fr; } }
.faq-item h3 { font-size:var(--step-1); }
.faq-item p { margin-top:.5rem; color:var(--slate); line-height:1.6; }

/* ---- trust band ---- */
.trust-band { background:var(--ink); color:#fff; padding:1.5rem 0; }
.trust-row { list-style:none; display:flex; flex-wrap:wrap; justify-content:center; gap:.8rem 2rem; }
.trust-item { font-family:var(--mono); font-size:var(--step--1); color:#dfe4f0; display:flex; align-items:center; gap:.5rem; }
.trust-item::before { content:"\2713"; color:var(--electric-br); font-weight:700; }

/* ---- pricing tier price ---- */
.price { font-family:var(--display); font-size:var(--step-3); color:var(--ink); line-height:1; margin:.5rem 0 .7rem; }
.price span { font-family:var(--mono); font-size:var(--step--1); color:var(--muted); }

/* ---- pricing: setup line + service tag ---- */
.setup { font-family:var(--mono); font-size:var(--step--1); color:var(--muted); margin:-.2rem 0 .9rem; }
.svc-tag { margin-top:1rem; }

/* ---- billing toggle (CSS-only; checkbox swaps monthly / annual) ---- */
.bill-cb { position:absolute; opacity:0; width:1px; height:1px; pointer-events:none; }
.bill { display:flex; flex-direction:column; align-items:center; gap:.8rem; }
.bill-track { position:relative; display:inline-flex; background:#fff; border:1px solid var(--line); border-radius:100px; padding:.32rem; cursor:pointer; }
.bill-opt { position:relative; z-index:1; min-width:104px; text-align:center; padding:.5rem 1rem; font-family:var(--mono); font-size:var(--step--1); color:var(--slate); border-radius:100px; transition:color .2s; }
.bill-opt.is-m { color:#fff; }
.bill-thumb { position:absolute; z-index:0; top:.32rem; bottom:.32rem; left:.32rem; width:calc(50% - .32rem); background:var(--electric); border-radius:100px; transition:transform .22s cubic-bezier(.2,.7,.2,1); }
.bill-cb:checked ~ .bill .bill-thumb { transform:translateX(100%); }
.bill-cb:checked ~ .bill .is-m { color:var(--slate); }
.bill-cb:checked ~ .bill .is-a { color:#fff; }
.bill-cb:focus-visible ~ .bill .bill-track { outline:3px solid var(--electric); outline-offset:2px; }
.bill-hint { font-family:var(--mono); font-size:var(--step--1); color:var(--muted); }
.bill-hint strong { color:var(--electric-dk); }

/* price + note swap driven by the toggle */
.price-a { display:none; }
.note-a { display:none; }
.bill-cb:checked ~ .grid .price-m { display:none; }
.bill-cb:checked ~ .grid .price-a { display:block; }
.bill-cb:checked ~ .bill-note .note-m { display:none; }
.bill-cb:checked ~ .bill-note .note-a { display:inline; }

/* setup fee swaps with billing toggle (waived on annual) */
.setup-a { display:none; color:var(--electric-dk); }
.bill-cb:checked ~ .grid .setup-m { display:none; }
.bill-cb:checked ~ .grid .setup-a { display:block; }

/* pricing: 4th tier (agencies & parties) drops to its own row, full width, centered */
.card-wide { grid-column: 1 / -1; text-align: center; }
.card-wide > p { margin-inline: auto; max-width: 52ch; }

/* ---- onboarding: highlighted step card ---- */
.card.highlight { border-color: var(--electric); box-shadow: 0 0 0 1px var(--electric) inset; }

/* ---- onboarding intake form / wizard ---- */
.ob-form { max-width: 760px; margin: 2.4rem auto 0; }
.ob-progress { display: flex; gap: .5rem; justify-content: center; }
.ob-dot { width: 40px; height: 5px; border-radius: 100px; background: var(--line); transition: background .25s; }
.ob-dot.is-active { background: var(--electric); }
.ob-stepcount { text-align: center; font-family: var(--mono); font-size: var(--step--1); color: var(--muted); margin-top: .8rem; }
.ob-step { border: none; padding: 0; margin: 1.6rem 0 0; min-width: 0; }
.ob-legend { font-family: var(--display); font-size: var(--step-2); padding: 0; color: var(--ink); }
.js .ob-step { display: none; }
.js .ob-step.is-active { display: block; }
.ob-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; margin-top: 1.2rem; }
@media (max-width: 600px) { .ob-grid { grid-template-columns: 1fr; } }
.ob-field { display: flex; flex-direction: column; gap: .4rem; font-family: var(--mono); font-size: var(--step--1); color: var(--slate); }
.ob-field.ob-full { grid-column: 1 / -1; margin-top: 1.1rem; }
.ob-field input, .ob-field select, .ob-field textarea {
  font-family: var(--body); font-size: var(--step-0); color: var(--ink);
  background: #fff; border: 1.5px solid var(--line); border-radius: 12px; padding: .7rem .9rem; width: 100%;
}
.ob-field textarea { resize: vertical; }
.ob-field input:focus, .ob-field select:focus, .ob-field textarea:focus {
  outline: none; border-color: var(--electric); box-shadow: 0 0 0 4px rgba(58,107,255,.15);
}
.req { color: var(--amber-dk); }
.ob-help { background: #fff; border: 1px solid var(--line); border-left: 3px solid var(--electric); border-radius: 10px; padding: .9rem 1.1rem; font-size: var(--step-0); color: var(--slate); margin-top: 1.1rem; }
.ob-help a, .ob-note a { color: var(--electric-dk); text-decoration: underline; text-underline-offset: 2px; }
.ob-note { font-family: var(--mono); font-size: var(--step--1); color: var(--muted); margin-top: 1.1rem; line-height: 1.6; }
.ob-nav { display: flex; gap: .7rem; align-items: center; margin-top: 1.8rem; }
.ob-nav .ob-next, .ob-nav .ob-submit { margin-left: auto; }
.ob-success { text-align: center; padding: 2rem 0; }
.ob-success h3 { font-family: var(--display); font-size: var(--step-3); color: var(--electric-dk); }
.ob-success p { margin-top: .8rem; color: var(--slate); }

/* make the hidden attribute authoritative (it loses to .btn display otherwise) */
[hidden] { display: none !important; }

/* the brand mark, restored beside the wordmark (same geometry as the favicon) */
.logo .mark { width: .74em; height: .74em; color: var(--electric); flex: none; }
.footer .logo .mark { color: var(--electric-br); }

/* ---- blog byline + legal boilerplate ---- */
.post-meta { font-family: var(--mono); font-size: var(--step--1); color: var(--muted); }
.post-meta a { color: var(--electric-dk); text-decoration: underline; text-underline-offset: 2px; }
.post-disclaimer { background: var(--paper-warm); border: 1px solid var(--line); border-left: 3px solid var(--amber); border-radius: 10px; padding: 1rem 1.2rem; margin-top: 2.5rem; font-size: var(--step--1); color: var(--slate); }
