/* ============================================================
   CivielControl — marketing site
   Tokens lifted verbatim from the live app brand kit.
   ============================================================ */

:root{
  /* Surfaces — warm "beton/papier" */
  --paper:     oklch(0.984 0.004 80);
  --surface:   #ffffff;
  --surface-2: oklch(0.974 0.005 80);
  --surface-3: oklch(0.955 0.006 78);
  /* Ink */
  --ink:   oklch(0.255 0.012 60);  --ink-2: oklch(0.46 0.012 62);
  --ink-3: oklch(0.60 0.010 64);   --ink-4: oklch(0.72 0.008 70);
  /* Lines */
  --line: oklch(0.905 0.006 75);   --line-2: oklch(0.86 0.008 72);   --line-strong: oklch(0.78 0.010 70);
  /* Amber — the only signal colour */
  --amber: oklch(0.70 0.165 62);   --amber-deep: oklch(0.60 0.155 56);   --amber-ink: oklch(0.46 0.12 56);
  --amber-soft: oklch(0.955 0.038 78);  --amber-line: oklch(0.86 0.07 72);
  /* Status */
  --red: oklch(0.585 0.165 30);    --green: oklch(0.595 0.115 152);
  --red-soft: oklch(0.955 0.035 32);  --green-soft: oklch(0.955 0.032 152);
  /* Dark "night" panels */
  --night: oklch(0.255 0.012 65);  --night-2: oklch(0.305 0.013 65);
  --night-line: oklch(0.36 0.014 65);  --night-ink: oklch(0.80 0.010 75);  --night-ink2: oklch(0.62 0.012 72);
  /* Shape */
  --radius: 9px; --radius-sm: 6px; --radius-lg: 14px;
  --shadow-sm: 0 1px 2px rgba(40,32,20,.05), 0 1px 1px rgba(40,32,20,.04);
  --shadow:    0 4px 14px rgba(40,32,20,.07), 0 1px 3px rgba(40,32,20,.05);
  --shadow-lg: 0 18px 48px rgba(40,32,20,.16), 0 4px 12px rgba(40,32,20,.08);

  --maxw: 1200px;
  --pad: clamp(20px, 5vw, 64px);
  --font: "Archivo", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--font);
  background:var(--paper);
  color:var(--ink);
  font-size:18px;
  line-height:1.6;
  letter-spacing:-0.003em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; height:auto; }
a{ color:inherit; }
::selection{ background:var(--amber-soft); }

h1,h2,h3,h4{ font-weight:700; letter-spacing:-0.02em; line-height:1.05; margin:0; text-wrap:balance; }
p{ margin:0; text-wrap:pretty; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
.wrap-narrow{ max-width:840px; margin:0 auto; padding-inline:var(--pad); }

/* ---- Eyebrow / mono labels ---- */
.eyebrow{
  font-family:var(--mono);
  font-size:13px;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.16em;
  color:var(--amber-ink);
  margin:0 0 18px;
  display:flex; align-items:center; gap:10px;
}
.eyebrow::before{
  content:""; width:22px; height:3px; flex:none;
  background-image:repeating-linear-gradient(-45deg, var(--amber) 0 4px, var(--ink) 4px 8px);
}
.eyebrow.plain::before{ display:none; }

.mono{ font-family:var(--mono); font-feature-settings:"tnum" 1; }

/* ---- Hazard stripe ---- */
.hazard{
  background-image:repeating-linear-gradient(-45deg, var(--amber) 0 9px, var(--ink) 9px 18px);
}
.hazard-rule{ height:5px; width:100%; }
.hazard-edge{ position:relative; }
.hazard-edge::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:5px;
  background-image:repeating-linear-gradient(-45deg, var(--amber) 0 7px, var(--ink) 7px 14px);
}

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  font-family:var(--font);
  font-weight:600;
  font-size:16px;
  letter-spacing:-0.01em;
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:13px 22px;
  border-radius:var(--radius);
  border:1px solid transparent;
  cursor:pointer;
  text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, background .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; flex:none; }
.btn-primary{
  background:linear-gradient(180deg, var(--amber) 0%, var(--amber-deep) 100%);
  color:#fff;
  box-shadow:var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-primary:hover{ transform:translateY(-1px); box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.18); }
.btn-ghost{
  background:var(--surface);
  color:var(--ink);
  border-color:var(--line-2);
  box-shadow:var(--shadow-sm);
}
.btn-ghost:hover{ border-color:var(--line-strong); transform:translateY(-1px); }
.btn-dark{
  background:var(--night-2); color:#fff; border-color:var(--night-line);
}
.btn-dark:hover{ background:var(--night); transform:translateY(-1px); }
.btn-on-dark{ background:#fff; color:var(--ink); }
.btn-on-dark:hover{ transform:translateY(-1px); box-shadow:var(--shadow-lg); }
.btn-ghost-dark{ background:transparent; color:var(--night-ink); border-color:var(--night-line); }
.btn-ghost-dark:hover{ color:#fff; border-color:var(--night-ink2); }
.btn-lg{ padding:16px 28px; font-size:17px; }
.btn-block{ width:100%; }

:where(a,button,input,select,textarea):focus-visible{
  outline:3px solid var(--amber);
  outline-offset:2px;
  border-radius:var(--radius-sm);
}

/* ============================================================
   Header
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:60;
  background:color-mix(in oklch, var(--paper) 88%, transparent);
  backdrop-filter:saturate(1.4) blur(12px);
  border-bottom:1px solid var(--line);
}
.site-header .bar{
  display:flex; align-items:center; gap:24px;
  height:72px;
}
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; flex:none; }
.brand-tile{
  width:40px; height:40px; border-radius:9px; flex:none;
  background:linear-gradient(180deg, var(--amber) 0%, var(--amber-deep) 100%);
  display:grid; place-items:center;
  box-shadow:var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,.25);
}
.brand-tile svg{ width:22px; height:22px; }
.brand-name{ font-weight:800; font-size:20px; letter-spacing:-0.03em; color:var(--ink); line-height:1; }
.brand-eyebrow{ font-family:var(--mono); font-size:9.5px; letter-spacing:0.18em; color:var(--ink-3); text-transform:uppercase; margin-top:3px; }

.nav{ display:flex; align-items:center; gap:4px; margin-left:auto; }
.nav a{
  text-decoration:none; color:var(--ink-2); font-weight:500; font-size:15.5px;
  padding:9px 14px; border-radius:var(--radius-sm);
  transition:color .15s, background .15s;
}
.nav a:hover{ color:var(--ink); background:var(--surface-3); }
.nav a.active{ color:var(--ink); }

.header-actions{ display:flex; align-items:center; gap:14px; flex:none; }

/* NL/EN segmented toggle — mirrors the app */
.lang{
  display:inline-flex; align-items:center;
  background:var(--surface-3); border:1px solid var(--line-2);
  border-radius:8px; padding:3px; gap:2px;
}
.lang button{
  font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:0.05em;
  border:0; background:transparent; color:var(--ink-3);
  padding:5px 10px; border-radius:5px; cursor:pointer; line-height:1;
  transition:background .15s, color .15s;
}
.lang button[aria-pressed="true"]{ background:var(--surface); color:var(--ink); box-shadow:var(--shadow-sm); }

.nav-toggle{
  display:none; width:42px; height:42px; border-radius:var(--radius-sm);
  border:1px solid var(--line-2); background:var(--surface);
  align-items:center; justify-content:center; cursor:pointer;
}
.nav-toggle svg{ width:22px; height:22px; }

@media (max-width: 940px){
  .nav, .header-actions .btn-demo-header{ display:none; }
  .nav-toggle{ display:flex; }
  .site-header .bar{ height:64px; }
}

/* mobile drawer */
.mobile-nav{
  display:none;
  border-bottom:1px solid var(--line);
  background:var(--surface);
}
.mobile-nav.open{ display:block; }
.mobile-nav .wrap{ padding-block:14px 22px; }
.mobile-nav a{
  display:block; text-decoration:none; color:var(--ink);
  font-weight:600; font-size:18px; padding:13px 4px;
  border-bottom:1px solid var(--line);
}
.mobile-nav .btn{ margin-top:16px; }

/* ============================================================
   Sections / rhythm
   ============================================================ */
section{ position:relative; }
.section{ padding-block:clamp(64px, 9vw, 116px); }
.section-tight{ padding-block:clamp(48px, 6vw, 80px); }
.section-head{ max-width:680px; margin-bottom:48px; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .eyebrow{ justify-content:center; }
.section-head h2{ font-size:clamp(30px, 4.4vw, 46px); }
.section-head p{ color:var(--ink-2); font-size:clamp(17px, 2vw, 20px); margin-top:18px; }

.bg-surface{ background:var(--surface); }
.bg-2{ background:var(--surface-2); }
.bg-night{ background:var(--night); color:var(--night-ink); }
.bg-night h1,.bg-night h2,.bg-night h3{ color:#fff; }
.divider{ border:0; border-top:1px solid var(--line); margin:0; }

/* ============================================================
   Device frames
   ============================================================ */
.browser{
  border-radius:13px;
  background:var(--surface);
  border:1px solid var(--line-2);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.browser-bar{
  display:flex; align-items:center; gap:8px;
  padding:11px 15px;
  background:var(--surface-3);
  border-bottom:1px solid var(--line);
}
.browser-dots{ display:flex; gap:7px; }
.browser-dots i{ width:11px; height:11px; border-radius:50%; background:var(--line-strong); display:block; }
.browser-url{
  flex:1; margin-left:8px; height:26px; border-radius:7px;
  background:var(--surface); border:1px solid var(--line);
  display:flex; align-items:center; gap:7px; padding:0 12px;
  font-family:var(--mono); font-size:12px; color:var(--ink-3);
  max-width:340px;
}
.browser-url svg{ width:12px; height:12px; opacity:.6; }
.browser img{ width:100%; display:block; }

.phone{
  border-radius:34px;
  background:var(--ink);
  padding:9px;
  box-shadow:var(--shadow-lg);
  width:262px;
}
.phone-screen{
  border-radius:27px; overflow:hidden; background:#fff;
  position:relative; border:1px solid rgba(0,0,0,.4);
}
.phone-screen img{ width:100%; display:block; }
.phone-notch{
  position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:78px; height:20px; background:var(--ink); border-radius:11px; z-index:2;
}

/* ============================================================
   Hero
   ============================================================ */
.hero{ padding-top:clamp(40px, 6vw, 72px); padding-bottom:clamp(56px, 8vw, 96px); overflow:hidden; }
.hero-grid{
  display:grid; grid-template-columns:1.02fr 1.18fr; gap:clamp(36px, 5vw, 72px);
  align-items:center;
}
.hero h1{ font-size:clamp(38px, 5.6vw, 66px); letter-spacing:-0.035em; }
.hero .lede{ font-size:clamp(18px, 2.1vw, 21px); color:var(--ink-2); margin-top:22px; max-width:30ch; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero-note{
  margin-top:22px; font-family:var(--mono); font-size:13px; color:var(--ink-3);
  display:flex; align-items:center; gap:9px;
}
.hero-note b{ color:var(--green); font-weight:600; }
.hero-visual{ position:relative; }
.hero-visual .browser{ transform:perspective(2200px) rotateY(-7deg) rotateX(2deg); transform-origin:left center; }
.hero-phone{
  position:absolute; right:-14px; bottom:-44px; width:160px; z-index:3;
}
@media (max-width: 980px){
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .hero .lede{ max-width:48ch; }
  .hero-visual .browser{ transform:none; }
  .hero-phone{ width:128px; right:6px; bottom:-30px; }
}

/* ============================================================
   Trust strip
   ============================================================ */
.trust{ padding-block:34px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--surface-2); }
.trust-row{ display:flex; align-items:center; gap:clamp(18px,3vw,42px); flex-wrap:wrap; justify-content:space-between; }
.trust-label{ font-family:var(--mono); font-size:12.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-3); flex:none; }
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{
  font-family:var(--mono); font-size:13px; font-weight:500; letter-spacing:0.02em;
  padding:8px 14px; border-radius:100px;
  background:var(--surface); border:1px solid var(--line-2); color:var(--ink-2);
  display:inline-flex; align-items:center; gap:8px;
}
.chip i{ width:6px; height:6px; border-radius:50%; background:var(--amber); display:block; }

/* placeholder client logos */
.logos{ display:flex; align-items:center; gap:clamp(20px,4vw,52px); flex-wrap:wrap; }
.logo-ph{
  display:flex; align-items:center; gap:9px;
  font-weight:700; font-size:17px; letter-spacing:-0.02em; color:var(--ink-4);
}
.logo-ph svg{ width:24px; height:24px; opacity:.55; }

/* ============================================================
   Feature rows (alternating)
   ============================================================ */
.feature{
  display:grid; grid-template-columns:1fr 1.12fr; gap:clamp(40px, 6vw, 88px);
  align-items:center;
}
.feature.flip .feature-text{ order:2; }
.feature.flip .feature-media{ order:1; }
.feature + .feature{ margin-top:clamp(72px, 9vw, 128px); }
.feature h3{ font-size:clamp(26px, 3.3vw, 38px); margin-top:14px; }
.feature .feature-lede{ color:var(--ink-2); font-size:clamp(17px,1.9vw,19px); margin-top:18px; }
.feature-list{ list-style:none; padding:0; margin:26px 0 0; display:flex; flex-direction:column; gap:14px; }
.feature-list li{ display:flex; gap:13px; align-items:flex-start; font-size:16.5px; color:var(--ink); }
.feature-list .tick{
  flex:none; width:24px; height:24px; border-radius:7px; margin-top:1px;
  background:var(--amber-soft); border:1px solid var(--amber-line);
  display:grid; place-items:center;
}
.feature-list .tick svg{ width:14px; height:14px; color:var(--amber-deep); }
.feature-cta{ margin-top:30px; display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.text-link{
  font-weight:600; color:var(--amber-ink); text-decoration:none;
  display:inline-flex; align-items:center; gap:7px; font-size:16px;
}
.text-link svg{ width:16px; height:16px; transition:transform .15s; }
.text-link:hover svg{ transform:translateX(3px); }

.feature-media{ position:relative; }
.feature-phones{ display:flex; gap:18px; justify-content:center; align-items:flex-end; }
.feature-phones .phone:nth-child(2){ margin-bottom:34px; }

@media (max-width: 900px){
  .feature{ grid-template-columns:1fr; gap:36px; }
  .feature.flip .feature-text{ order:0; }
  .feature.flip .feature-media{ order:0; }
  .feature-phones .phone{ width:210px; }
  .feature-phones .phone:nth-child(2){ margin-bottom:0; }
}

/* ============================================================
   Problem -> solution
   ============================================================ */
.ps-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.ps-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:26px 26px 28px; box-shadow:var(--shadow-sm);
}
.ps-card .ps-pain{ display:flex; align-items:center; gap:11px; color:var(--ink-3); font-size:15px; }
.ps-card .ps-pain svg{ width:18px; height:18px; color:var(--red); flex:none; }
.ps-card h3{ font-size:21px; margin:16px 0 9px; letter-spacing:-0.02em; }
.ps-card p{ color:var(--ink-2); font-size:16px; }
.ps-card .ps-arrow{ font-family:var(--mono); font-size:12px; color:var(--amber-ink); letter-spacing:0.08em; text-transform:uppercase; margin-top:14px; display:inline-flex; gap:7px; align-items:center; }
@media (max-width: 760px){ .ps-grid{ grid-template-columns:1fr; } }

/* ============================================================
   How it works
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; counter-reset:step; }
.step{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:30px 28px 34px; position:relative; box-shadow:var(--shadow-sm);
}
.step-num{
  font-family:var(--mono); font-size:14px; font-weight:600; color:var(--amber-ink);
  width:42px; height:42px; border-radius:11px; display:grid; place-items:center;
  background:var(--amber-soft); border:1px solid var(--amber-line); margin-bottom:20px;
}
.step h3{ font-size:21px; margin-bottom:10px; }
.step p{ color:var(--ink-2); font-size:16px; }
.step-link{ margin-top:18px; }
@media (max-width: 820px){ .steps{ grid-template-columns:1fr; } }

/* ============================================================
   Stat band (dark)
   ============================================================ */
.stat-band{ background:var(--night); color:var(--night-ink); padding-block:clamp(56px,7vw,92px); position:relative; overflow:hidden; }
.stat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,4vw,56px); }
.stat .stat-num{ font-family:var(--mono); font-weight:500; font-size:clamp(40px,6vw,62px); color:#fff; letter-spacing:-0.04em; line-height:1; }
.stat .stat-num .u{ color:var(--amber); }
.stat .stat-label{ margin-top:14px; color:var(--night-ink); font-size:16px; max-width:24ch; }
.stat .stat-eyebrow{ font-family:var(--mono); font-size:12px; letter-spacing:0.16em; text-transform:uppercase; color:var(--night-ink2); margin-bottom:18px; }
@media (max-width: 760px){ .stat-grid{ grid-template-columns:1fr; gap:36px; } }

/* ============================================================
   Pricing
   ============================================================ */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch; }
.price-card{
  background:var(--surface); border:1px solid var(--line-2); border-radius:var(--radius-lg);
  padding:32px 30px 34px; display:flex; flex-direction:column; box-shadow:var(--shadow-sm);
  position:relative;
}
.price-card.featured{ border-color:var(--amber-line); box-shadow:var(--shadow-lg); }
.price-card.featured::before{
  content:""; position:absolute; inset:0 0 auto 0; height:5px; border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  background-image:repeating-linear-gradient(-45deg, var(--amber) 0 9px, var(--ink) 9px 18px);
}
.price-tag{ display:inline-flex; align-self:flex-start; font-family:var(--mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--amber-ink); background:var(--amber-soft); border:1px solid var(--amber-line); padding:5px 11px; border-radius:100px; margin-bottom:18px; }
.price-name{ font-size:24px; font-weight:700; letter-spacing:-0.02em; }
.price-desc{ color:var(--ink-2); font-size:15.5px; margin-top:8px; min-height:46px; }
.price-amount{ display:flex; align-items:baseline; gap:6px; margin:22px 0 4px; }
.price-amount .val{ font-family:var(--mono); font-weight:600; font-size:46px; letter-spacing:-0.03em; color:var(--ink); }
.price-amount .per{ color:var(--ink-3); font-size:15px; }
.price-sub{ font-size:14px; color:var(--ink-3); font-family:var(--mono); }
.price-feats{ list-style:none; padding:24px 0 0; margin:24px 0 28px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:13px; }
.price-feats li{ display:flex; gap:11px; align-items:flex-start; font-size:15.5px; color:var(--ink); }
.price-feats svg{ width:18px; height:18px; color:var(--green); flex:none; margin-top:2px; }
.price-card .btn{ margin-top:auto; }
.price-note{ text-align:center; color:var(--ink-3); font-size:14px; font-family:var(--mono); margin-top:26px; }
@media (max-width: 900px){ .price-grid{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; } }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:820px; margin-inline:auto; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{
  width:100%; text-align:left; background:none; border:0; cursor:pointer;
  padding:24px 0; display:flex; align-items:flex-start; justify-content:space-between; gap:20px;
  font-family:var(--font); font-weight:600; font-size:19px; color:var(--ink); letter-spacing:-0.01em;
}
.faq-q .ic{ flex:none; width:26px; height:26px; border-radius:7px; border:1px solid var(--line-2); display:grid; place-items:center; transition:transform .2s, background .2s; }
.faq-q .ic svg{ width:16px; height:16px; color:var(--ink-2); }
.faq-q[aria-expanded="true"] .ic{ background:var(--amber-soft); border-color:var(--amber-line); transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-a-inner{ padding:0 0 24px; color:var(--ink-2); font-size:16.5px; max-width:64ch; }

/* ============================================================
   CTA band (dark + hazard)
   ============================================================ */
.cta-band{ background:var(--night); color:var(--night-ink); position:relative; overflow:hidden; }
.cta-band .hazard-rule{ height:6px; }
.cta-inner{ padding-block:clamp(60px,8vw,104px); text-align:center; }
.cta-inner h2{ font-size:clamp(30px,4.6vw,52px); color:#fff; max-width:18ch; margin-inline:auto; }
.cta-inner p{ color:var(--night-ink); font-size:clamp(17px,2vw,20px); margin:20px auto 0; max-width:46ch; }
.cta-inner .hero-cta{ justify-content:center; }

/* ============================================================
   SEO page hero (sub-pages)
   ============================================================ */
.subhero{ padding-top:clamp(48px,6vw,84px); padding-bottom:clamp(40px,5vw,64px); }
.subhero-grid{ display:grid; grid-template-columns:1.05fr 1.1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.subhero h1{ font-size:clamp(34px,5vw,56px); letter-spacing:-0.035em; }
.subhero .lede{ font-size:clamp(18px,2.1vw,21px); color:var(--ink-2); margin-top:22px; max-width:36ch; }
.breadcrumb{ display:flex; gap:8px; align-items:center; font-family:var(--mono); font-size:13px; color:var(--ink-3); margin-bottom:24px; }
.breadcrumb a{ text-decoration:none; color:var(--ink-3); }
.breadcrumb a:hover{ color:var(--amber-ink); }
.breadcrumb svg{ width:13px; height:13px; }
@media (max-width: 920px){ .subhero-grid{ grid-template-columns:1fr; gap:36px; } }

/* keyword inline list */
.kw-row{ display:flex; flex-wrap:wrap; gap:10px; margin-top:30px; }
.kw{ font-family:var(--mono); font-size:13px; color:var(--ink-3); padding:7px 13px; border:1px solid var(--line); border-radius:100px; background:var(--surface); }

/* mini benefit grid for sub-pages */
.bene-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.bene{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:26px 24px 28px; box-shadow:var(--shadow-sm); }
.bene .bene-ic{ width:44px; height:44px; border-radius:11px; background:var(--surface-3); border:1px solid var(--line-2); display:grid; place-items:center; margin-bottom:18px; }
.bene .bene-ic svg{ width:22px; height:22px; color:var(--ink); }
.bene h3{ font-size:19px; margin-bottom:9px; }
.bene p{ color:var(--ink-2); font-size:15.5px; }
@media (max-width: 820px){ .bene-grid{ grid-template-columns:1fr; } }

/* ============================================================
   Demo page
   ============================================================ */
.demo-grid{ display:grid; grid-template-columns:1.15fr 1fr; gap:clamp(40px,5vw,72px); align-items:start; }
.form-card{ background:var(--surface); border:1px solid var(--line-2); border-radius:var(--radius-lg); padding:clamp(26px,3vw,40px); box-shadow:var(--shadow); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:600; font-size:15px; margin-bottom:8px; color:var(--ink); }
.field label .req{ color:var(--amber-deep); }
.field input, .field select, .field textarea{
  width:100%; font-family:var(--font); font-size:16px; color:var(--ink);
  padding:13px 15px; border-radius:var(--radius); border:1px solid var(--line-2);
  background:var(--surface-2); transition:border-color .15s, background .15s;
}
.field input:focus, .field select:focus, .field textarea:focus{ background:var(--surface); border-color:var(--amber); outline:none; box-shadow:0 0 0 3px var(--amber-soft); }
.field input[aria-invalid="true"], .field select[aria-invalid="true"], .field textarea[aria-invalid="true"]{ border-color:var(--red); background:var(--red-soft); }
.form-errors{ background:var(--red-soft); border:1px solid color-mix(in oklch, var(--red) 40%, var(--line)); border-radius:var(--radius); padding:13px 16px; margin-bottom:18px; color:var(--ink); font-weight:600; font-size:15px; }
.field textarea{ resize:vertical; min-height:96px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-hint{ font-family:var(--mono); font-size:12.5px; color:var(--ink-3); margin-top:8px; }
.form-success{ display:none; background:var(--green-soft); border:1px solid color-mix(in oklch, var(--green) 40%, var(--line)); border-radius:var(--radius); padding:20px 22px; color:var(--ink); }
.form-success.show{ display:block; }
.form-success .fs-title{ font-weight:700; display:flex; align-items:center; gap:10px; }
.form-success svg{ width:22px; height:22px; color:var(--green); }

.demo-aside{ position:sticky; top:96px; }
.demo-aside .browser{ margin-top:26px; }
.demo-points{ list-style:none; padding:0; margin:24px 0 0; display:flex; flex-direction:column; gap:16px; }
.demo-points li{ display:flex; gap:13px; align-items:flex-start; font-size:16.5px; }
.demo-points .tick{ flex:none; width:26px; height:26px; border-radius:8px; background:var(--amber-soft); border:1px solid var(--amber-line); display:grid; place-items:center; }
.demo-points .tick svg{ width:15px; height:15px; color:var(--amber-deep); }
@media (max-width: 880px){ .demo-grid{ grid-template-columns:1fr; } .field-row{ grid-template-columns:1fr; } .demo-aside{ position:static; } }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{ background:var(--night); color:var(--night-ink); padding-block:clamp(56px,7vw,80px) 0; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; }
.footer-brand .brand-name{ color:#fff; }
.footer-brand .brand-eyebrow{ color:var(--night-ink2); }
.footer-brand p{ color:var(--night-ink); font-size:15.5px; margin-top:18px; max-width:34ch; }
.footer-col h4{ font-family:var(--mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:var(--night-ink2); font-weight:500; margin-bottom:18px; }
.footer-col a{ display:block; text-decoration:none; color:var(--night-ink); font-size:15.5px; padding:6px 0; transition:color .15s; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{
  border-top:1px solid var(--night-line); padding-block:24px;
  display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap;
}
.footer-legal{ font-family:var(--mono); font-size:12.5px; color:var(--night-ink2); display:flex; gap:18px; flex-wrap:wrap; }
.footer-bottom .lang button[aria-pressed="true"]{ background:var(--night-2); color:#fff; }
.footer-bottom .lang{ background:var(--night-2); border-color:var(--night-line); }
.footer-bottom .lang button{ color:var(--night-ink2); }
@media (max-width: 820px){ .footer-top{ grid-template-columns:1fr 1fr; gap:32px; } .footer-brand{ grid-column:1 / -1; } }
@media (max-width: 520px){ .footer-top{ grid-template-columns:1fr; } }

/* ============================================================
   Scroll reveal
   ============================================================ */
[data-reveal]{ opacity:0; transform:translateY(18px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.08s; }
[data-reveal][data-delay="2"]{ transition-delay:.16s; }
[data-reveal][data-delay="3"]{ transition-delay:.24s; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; transition:none !important; }
}

/* lang visibility helpers (JS toggles [data-lang] on <html>) */
html[data-lang="en"] .lang-nl{ display:none; }
html[data-lang="nl"] .lang-en{ display:none; }

/* skip link */
.skip{ position:absolute; left:-9999px; top:0; background:var(--ink); color:#fff; padding:12px 18px; border-radius:0 0 8px 0; z-index:100; font-weight:600; }
.skip:focus{ left:0; }

/* utility */
.center{ text-align:center; }
.mt-s{ margin-top:14px; }
.muted{ color:var(--ink-3); }
