/* ==========================================================================
   Voluno — Layout & componenten
   ========================================================================== */

/* ---------- Dag-nacht lucht (vaste achtergrond, scroll = tijd) ----------- */
.sky{position:fixed;inset:0;z-index:var(--z-sky);pointer-events:none;background:var(--paper)}
.sky__layer{position:absolute;inset:0;opacity:0;will-change:opacity}
.sky__layer--morning{opacity:1;background:linear-gradient(180deg,#E7F0FF 0%,#F4F8FF 55%,#FFFFFF 100%)}
.sky__layer--midday {background:linear-gradient(180deg,#DCE9FF 0%,#F2F7FF 60%,#FFFFFF 100%)}
.sky__layer--golden {background:linear-gradient(180deg,#FBD89A 0%,#FCE9C4 48%,#FFF7E8 100%)}
/* avond: warme gouden naglans → rose → diep blauw (geen grijze waas) */
.sky__layer--dusk   {background:linear-gradient(180deg,#F6BE80 0%,#E0926A 28%,#C17288 52%,#7B6FA6 74%,#3E4576 100%)}
.sky__layer--night  {background:linear-gradient(180deg,#243f68 0%,#16294a 55%,#0f1c3d 100%)}
/* zon — reist mee, warmt op, dooft 's nachts */
.sky__sun{position:absolute;left:50%;top:12%;width:min(46vw,460px);aspect-ratio:1;margin-left:calc(min(46vw,460px) / -2);border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(255,244,214,.55) 38%,rgba(255,221,150,0) 70%);
  will-change:transform,opacity;opacity:.9}

/* ---- Rand-vignet (optioneel, via body-class) ---- */
.edge{position:fixed;inset:0;z-index:45;pointer-events:none;
  background:radial-gradient(125% 115% at 50% 46%, transparent 56%, var(--edge-col, transparent) 100%)}
body.vig-corner{--edge-col:rgba(30,58,95,.06)}   /* hoekvignet ~4-6% */
/* body.vig-phase: --edge-col wordt door JS gezet (fase-gekoppeld) */

/* ----------------------------- Navigatie -------------------------------- */
/* nav = puur glas: alleen blur, geen tint/rand/schaduw. De vaste lucht schijnt erdoorheen,
   dus de nav versmelt automatisch met elke fase. Tekstcontrast schakelt op drempel (body.nav-dark). */
.nav{position:fixed;inset:0 0 auto 0;z-index:var(--z-nav);display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--gutter)}
/* progressieve blur (variant A): zacht uitlopend masker → geen harde waas-grens waar tekst eronder schuift */
.nav::before{content:"";position:absolute;left:0;right:0;top:0;bottom:-24px;z-index:-1;pointer-events:none;
  -webkit-backdrop-filter:blur(14px) saturate(1.03);backdrop-filter:blur(14px) saturate(1.03);
  -webkit-mask-image:linear-gradient(to bottom,#000 0,#000 50%,transparent 100%);
          mask-image:linear-gradient(to bottom,#000 0,#000 50%,transparent 100%)}
.wordmark{font-family:var(--f-sans);font-weight:800;font-size:27px;letter-spacing:.06em;line-height:1;color:var(--brand-d);transition:color .2s linear}
/* tagline schakelt exact mee met het logo (zelfde nav-dark, zelfde .2s) + haartje schaduw voor leesbaarheid op de overgang */
.wordmark span{display:block;font-size:9.5px;letter-spacing:.16em;font-weight:500;margin-top:4px;color:var(--warm);
  text-shadow:0 1px 2px rgba(255,255,255,.45);transition:color .2s linear,text-shadow .2s linear}
.nav__actions{display:flex;align-items:center;gap:16px}
body.nav-dark .wordmark{color:#fff}
body.nav-dark .wordmark span{color:rgba(255,255,255,.82);text-shadow:0 1px 2px rgba(15,28,61,.55)}
.nav__link:hover::after{right:0}

/* ----------------------------- Knoppen ---------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:48px;padding:0 26px;border-radius:var(--r-pill);
  font-weight:600;font-size:15px;letter-spacing:.01em;white-space:nowrap;
  transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),background var(--dur-fast),border-color var(--dur-fast);
  touch-action:manipulation}
.btn .arrow{transition:transform var(--dur-fast) var(--ease-out)}
.btn:hover .arrow{transform:translateX(3px)}
.btn--gold{background:linear-gradient(180deg,var(--gold-m),var(--gold));color:#fff;box-shadow:var(--sh-gold)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 16px 34px -10px rgba(200,144,10,.55)}
.btn--gold:active{transform:translateY(0)}
.btn--line{border:1px solid var(--border);background:rgba(255,255,255,.55);color:var(--ink)}
.btn--line:hover{transform:translateY(-2px);border-color:var(--brand);box-shadow:0 10px 24px -12px rgba(96,165,250,.6)}
.btn--navy{background:var(--brand-x);color:#fff;box-shadow:0 12px 28px -14px rgba(30,58,95,.55);
  transition:transform var(--dur-fast) var(--ease-out),background .2s linear,color .2s linear,box-shadow var(--dur-fast)}
.btn--navy:hover{transform:translateY(-2px);background:#22456f;box-shadow:0 16px 32px -14px rgba(30,58,95,.6)}
.btn--navy:active{transform:translateY(0)}
/* donkere fase: navy-knop in de nav wordt een lichte pil → blijft leesbaar op navy */
body.nav-dark .nav .btn--navy{background:#fff;color:var(--brand-x);box-shadow:0 12px 26px -14px rgba(0,0,0,.45)}
body.nav-dark .nav .btn--navy:hover{background:#fff;transform:translateY(-2px)}
.btn--sm{min-height:42px;padding:0 20px;font-size:14px}

/* ------------------------------- Hero ----------------------------------- */
.hero{position:relative;z-index:var(--z-base);min-height:100dvh;display:flex;align-items:center;
  padding:clamp(110px,16vh,160px) var(--gutter) clamp(70px,10vh,110px)}
.hero__inner{max-width:var(--maxw);margin:0 auto;width:100%;
  display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(32px,5vw,72px);align-items:center}

/* donkerder goud voor kleine labels → contrast AA op licht (≈4.5:1) */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:#8A6207}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--gold-m)}

.hero h1{font-family:var(--f-display);font-weight:600;font-size:clamp(2.7rem,6.4vw,4.7rem);line-height:1.04;letter-spacing:-.01em;color:var(--brand-x);margin:18px 0 0}
.hero h1 em{font-style:italic;color:#B5820A;font-weight:600} /* iets dieper goud → AA op licht */
.hero__sub{font-size:clamp(1.05rem,1.6vw,1.3rem);font-weight:300;color:#475873;max-width:34ch;margin-top:22px;line-height:1.55}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero__trust{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-top:30px;font-size:13.5px;color:#475569;font-weight:400}
.hero__trust .sep{width:4px;height:4px;border-radius:50%;background:var(--brand);opacity:.6}

.hero__visual{position:relative;justify-self:center;display:flex;align-items:center;justify-content:center}
/* zachte studiogloed achter het product (haakt aan op de zon/ochtendlucht) */
.hero__visual::before{content:"";position:absolute;width:96%;aspect-ratio:1/1.15;left:50%;top:47%;transform:translate(-50%,-50%);
  background:radial-gradient(circle at 50% 44%, rgba(255,248,228,.95) 0%, rgba(255,248,228,.4) 38%, rgba(255,248,228,0) 64%);z-index:-1}
/* echte transparante uitknip → natuurlijke slagschaduw via drop-shadow */
.hero__visual img{width:clamp(230px,29vw,384px);
  filter:drop-shadow(0 32px 40px rgba(30,58,95,.30)) drop-shadow(0 10px 14px rgba(30,58,95,.12));
  /* eenmalige settle bij laden (opkomen + zacht schalen), daarna de rustige zweef */
  animation:heroSettle 1.25s var(--ease-out) both, floaty 7s var(--ease-in-out) 1.5s infinite}
@keyframes heroSettle{from{opacity:0;transform:translateY(30px) scale(.965)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* scroll-cue */
.scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--warm);z-index:var(--z-base)}
.scrollcue .line{width:1px;height:34px;background:linear-gradient(var(--warm),transparent);position:relative;overflow:hidden}
.scrollcue .line::after{content:"";position:absolute;top:-50%;left:0;width:1px;height:50%;background:var(--gold);animation:cueDrop 2s var(--ease-in-out) infinite}
@keyframes cueDrop{0%{top:-50%}60%,100%{top:100%}}

/* -------------------- Reveal (eenmalige fade-up) ------------------------ */
[data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
[data-reveal].is-in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}

/* ===================== H2 — De weglek + de deadline ===================== */
.weglek{position:relative;z-index:var(--z-base);min-height:100dvh;display:flex;align-items:center;
  padding:clamp(96px,13vh,150px) var(--gutter)}
.weglek__inner{max-width:880px;margin:0 auto;width:100%;min-width:0;text-align:center}  /* min-width:0 → flex-kind mag krimpen, geen horizontale overflow */
.weglek h2{font-family:var(--f-display);font-weight:600;font-size:clamp(2.05rem,5.6vw,4rem);line-height:1.07;
  letter-spacing:-.01em;color:var(--brand-x);margin:14px 0 0;overflow-wrap:break-word}
.weglek h2 em{font-style:italic;color:#B5820A;white-space:nowrap}  /* "bijna gratis weg." breekt nooit los van elkaar */
/* twee contrastregels: overdag licht/vluchtig, 's avonds zwaarder (de kostenpost) */
.weglek__lines{margin:28px auto 0;max-width:34ch;display:flex;flex-direction:column;gap:6px}
.weglek__lines p{margin:0;font-size:clamp(1.05rem,1.7vw,1.3rem);line-height:1.5}
.weglek__day{color:#5E6E86;font-weight:300}
.weglek__eve{color:#1E293B;font-weight:500}
.weglek__eve b{color:#8A6207;font-weight:600}

/* de 2027-teller: groot, feitelijk, gouden cijfers in mono met tabular-nums */
.deadline{margin-top:clamp(40px,6vh,68px)}
.deadline__label{font-size:13.5px;letter-spacing:.05em;color:#475569;font-weight:400;text-transform:none}
/* 3-koloms grid → het GETAL staat exact in het paginamidden, "nog"/"dagen" flankeren symmetrisch */
.deadline__big{display:grid;grid-template-columns:1fr auto 1fr;align-items:baseline;column-gap:.26em;margin-top:8px}
.deadline__pre{justify-self:end}
.deadline__unit{justify-self:start}
.deadline__pre,.deadline__unit{font-family:var(--f-display);font-style:italic;font-weight:600;
  font-size:clamp(1.3rem,3vw,2.1rem);color:var(--brand-x)}
.deadline__num{font-family:var(--f-mono);font-weight:600;font-variant-numeric:tabular-nums;
  font-size:clamp(3.4rem,10vw,7rem);line-height:.92;color:#B5820A;letter-spacing:-.02em}

/* ----------------------- Sticky countdown-chip (§5) --------------------- */
.chip{position:fixed;right:clamp(16px,2.4vw,28px);bottom:clamp(16px,2.4vw,28px);z-index:70;
  display:inline-flex;align-items:center;gap:8px;padding:10px 12px 10px 16px;border-radius:var(--r-pill);
  background:linear-gradient(180deg,#1e3a5f,#16294a);border:1px solid rgba(232,168,32,.5);
  box-shadow:0 16px 38px -14px rgba(15,28,61,.65);color:#fff;overflow:hidden;
  opacity:0;transform:translateY(14px) scale(.97);pointer-events:none;
  transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
/* fluisterzacht ruitpatroon */
.chip::before{content:"";position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none;
  background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.045) 0 1px,transparent 1px 7px),
                   repeating-linear-gradient(-45deg,rgba(255,255,255,.045) 0 1px,transparent 1px 7px)}
.chip.is-on{opacity:1;transform:none;pointer-events:auto}
.chip__main{position:relative;z-index:1;display:inline-flex;align-items:baseline;gap:6px;
  background:none;border:0;cursor:pointer;color:inherit;font-family:var(--f-sans);font-size:13px;letter-spacing:.01em;padding:0;white-space:nowrap}
.chip__main .chip__date{opacity:.78;font-weight:400}
.chip__main b{font-family:var(--f-mono);font-weight:600;font-variant-numeric:tabular-nums;color:#E8A820;font-size:14px}
.chip__close{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;flex:none;
  width:22px;height:22px;border-radius:50%;border:0;cursor:pointer;background:rgba(255,255,255,.12);color:#fff;
  font-size:14px;line-height:1;transition:background .15s}
.chip__close:hover{background:rgba(255,255,255,.24)}

/* ---------------- Sticky mobiele CTA (alleen mobiel) -------------------- */
/* garandeert: vanaf elk punt 1 tik → calculator. Verschijnt zodra de hero voorbij is. */
.mcta{position:fixed;left:14px;right:14px;bottom:calc(14px + env(safe-area-inset-bottom));z-index:56;
  display:none;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:0 24px;border-radius:var(--r-pill);
  background:linear-gradient(180deg,var(--gold-m),var(--gold));color:#fff;font-weight:600;font-size:16px;letter-spacing:.01em;
  box-shadow:0 14px 30px -8px rgba(200,144,10,.5),0 6px 16px rgba(15,28,61,.22);
  opacity:0;transform:translateY(18px) scale(.98);pointer-events:none;
  transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
.mcta.is-on{opacity:1;transform:none;pointer-events:auto}
.mcta__arrow{transition:transform var(--dur-fast) var(--ease-out)}
.mcta:active{transform:translateY(1px)}
@media (max-width:560px){ .mcta{display:flex} }

/* ================= H3 — Zo werkt het (flow-visual, uit de offerte) ======= */
.werkt{position:relative;z-index:var(--z-base);padding:clamp(74px,12vh,140px) var(--gutter)}
.werkt__inner{max-width:1180px;margin:0 auto;width:100%;text-align:center}
.werkt h2{font-family:var(--f-display);font-weight:600;font-size:clamp(2.05rem,5.2vw,3.6rem);line-height:1.05;
  letter-spacing:-.01em;color:var(--brand-x);margin:14px 0 0}
.werkt h2 em{font-style:italic;color:#B5820A}

/* glas-kaart over de lucht */
/* frameless: de visual is onderdeel van de pagina (node-blokjes dragen zelf de structuur) */
.werkt__card{margin-top:clamp(28px,4.5vh,46px);text-align:left;padding:0}
.werkt__tabs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:18px}
.ft{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--r-pill);border:1px solid var(--border);
  background:rgba(255,255,255,.6);color:#475569;font-family:var(--f-sans);font-weight:600;font-size:13.5px;cursor:pointer;
  transition:background .18s,border-color .18s,color .18s,box-shadow .18s}
.ft svg{color:var(--warm);transition:color .18s}
.ft:hover{border-color:var(--brand)}
.ft.is-active{background:var(--brand-x);border-color:var(--brand-x);color:#fff;box-shadow:0 10px 24px -12px rgba(30,58,95,.6)}
.ft.is-active svg{color:#E8A820}

.flowsvg{width:100%;height:auto;display:block;margin:0 auto;max-width:980px}
.flowsvg--m{display:none;max-width:460px}
.werkt__desc{margin:16px auto 0;font-size:clamp(1rem,1.5vw,1.16rem);line-height:1.6;color:#37485f;max-width:58ch;text-align:center;min-height:3.2em;transition:opacity .2s}
.werkt__desc b{color:#8A6207;font-weight:600}

.werkt__facts{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:14px 44px;margin:clamp(26px,4vh,40px) 0 0;padding:0}
.werkt__facts li{display:flex;flex-direction:column;gap:1px;text-align:center}
.werkt__fact-n{font-family:var(--f-display);font-weight:600;font-size:clamp(1.25rem,2vw,1.7rem);color:var(--brand-x);line-height:1.12;font-variant-numeric:lining-nums;font-feature-settings:"lnum" 1}
.werkt__fact-l{font-size:12.5px;letter-spacing:.02em;color:var(--warm);font-weight:400}

@keyframes flowfwd{to{stroke-dashoffset:-13}}

/* ------------------------------ Responsive ------------------------------ */
.lbl-short{display:none}
@media (max-width: 860px){
  .hero__inner{grid-template-columns:1fr;gap:30px;text-align:left}
  .hero__visual{order:2;justify-self:center;margin-top:6px}
  .hero__visual img{width:clamp(200px,54vw,250px);animation-duration:8s}
  .nav-secondary{display:none}
  .wordmark{font-size:23px;letter-spacing:.05em}
}
@media (max-width: 560px){
  .nav{padding-left:18px;padding-right:18px}
  /* op smal mobiel geen nav-CTA: de hero-CTA staat er al, de sticky mobiele CTA volgt later */
  .nav__actions{display:none}
  .weglek h2{font-size:1.95rem;line-height:1.12}
  .weglek__lines{max-width:30ch}
  .weglek__lines p{font-size:1.04rem}
  .deadline__num{font-size:4.2rem}
  .deadline__pre,.deadline__unit{font-size:1.35rem}
  .chip__main{font-size:12.5px}
  .chip{bottom:calc(84px + env(safe-area-inset-bottom))}   /* boven de sticky CTA */
  .werkt h2{font-size:2rem;line-height:1.1}
  .werkt__facts{gap:12px 30px;margin-top:24px}
}
@media (max-width: 480px){
  .hero{padding-top:96px}
  .hero__cta .btn{flex:1 1 auto}
}

/* Mobiel: de brede flow wordt verticaal herschikt + compact (tabs + flow in één scherm) */
@media (max-width: 860px){
  .flowsvg--d{display:none}
  .flowsvg--m{display:block;max-width:460px}
  .werkt{padding-left:14px;padding-right:14px}   /* meer breedte voor de flow op mobiel */
  .werkt__card{padding:16px}
  .werkt__tabs{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:12px}
  .ft{justify-content:center;padding:9px 14px;font-size:13px}
  .werkt__desc{min-height:0;margin-top:12px}
}

/* ============ H6+H7 — Wat het je oplevert (ladder + calculator) ========= */
.oplevert{position:relative;z-index:var(--z-base);padding:clamp(74px,12vh,140px) var(--gutter)}
.oplevert__inner{max-width:var(--maxw);margin:0 auto;width:100%;text-align:center}
.oplevert h2{font-family:var(--f-display);font-weight:600;font-size:clamp(2.05rem,5.2vw,3.6rem);line-height:1.05;letter-spacing:-.01em;color:var(--brand-x);margin:14px 0 0}
.oplevert h2 em{font-style:italic;color:#B5820A}

.ladder{max-width:600px;margin:clamp(28px,4.5vh,46px) auto 0;text-align:left}
.ladder__intro{font-size:clamp(1rem,1.4vw,1.12rem);color:#475873;font-weight:300;text-align:center;max-width:54ch;margin:0 auto 18px}
.ladder__rows{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}
.ladder__row{display:grid;grid-template-columns:58px 1fr auto;align-items:center;gap:14px;padding:10px 16px;border-radius:var(--r-sm);background:rgba(255,255,255,.5);border:1px solid var(--border-l)}
.ladder__row.is-key{background:var(--gold-lt);border-color:#F0D9A0}
.ladder__yr{font-family:var(--f-mono);font-weight:600;font-size:14px;color:var(--brand-x)}
.ladder__track{height:8px;border-radius:99px;background:rgba(30,58,95,.08);overflow:hidden}
.ladder__track i{display:block;height:100%;width:0;border-radius:99px;background:linear-gradient(90deg,#E8A820,#C8900A);transition:width 1.1s var(--ease-out)}
.ladder__amt{font-family:var(--f-mono);font-weight:600;font-size:15px;color:#8A6207;font-variant-numeric:tabular-nums;min-width:78px;text-align:right}
.ladder__note{font-size:13px;color:var(--warm);text-align:center;margin-top:14px;font-weight:400}

/* calculator — variant A: resultaat als held, één glaspodium */
.calcA{max-width:600px;margin:clamp(34px,5vh,56px) auto 0;background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(16px) saturate(1.05);backdrop-filter:blur(16px) saturate(1.05);
  border:1px solid rgba(255,255,255,.75);border-radius:24px;box-shadow:0 30px 70px -30px rgba(30,58,95,.42);padding:clamp(28px,4vw,40px) clamp(22px,4vw,40px) clamp(22px,3vw,30px);text-align:center}
.calcA__lab{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#8A6207}
.calcA__big{font-family:var(--f-display);font-weight:600;font-size:clamp(3.6rem,9vw,5.4rem);line-height:1;color:#B5820A;margin:6px 0 12px;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.calcA__per{font-size:13.5px;color:var(--warm);margin-bottom:26px}
.calcA__stats{display:flex;justify-content:center;margin:0 auto 26px;max-width:460px}
.calcA__stats div{flex:1;padding:0 8px}
.calcA__stats div+div{border-left:1px solid var(--border-l)}
.calcA__stats .s-v{display:block;font-family:var(--f-mono);font-weight:600;font-size:clamp(15px,2vw,18px);color:var(--brand-x)}
.calcA__stats .s-l{display:block;font-size:11.5px;color:var(--warm);margin-top:3px;line-height:1.3}
.calcA__sliders{text-align:left;padding:24px 4px 4px;border-top:1px solid var(--border-l)}
.calc__slider+.calc__slider{margin-top:22px}
.calc__slider label{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;font-weight:500;color:#475569;margin-bottom:12px}
.calc__slider label b{font-family:var(--f-mono);font-weight:600;color:var(--brand-x);font-size:15px}
.range{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:99px;cursor:pointer;
  background:linear-gradient(90deg,var(--brand-d) 0,var(--brand-d) var(--fill,40%),#cdddf5 var(--fill,40%),#cdddf5 100%)}
.range::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:#fff;border:2px solid var(--brand-d);box-shadow:0 5px 14px -3px rgba(30,58,95,.5)}
.range::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;border:2px solid var(--brand-d)}
.mm{display:flex;justify-content:space-between;font-size:11px;color:var(--warm);margin-top:7px}
.calcA__cta{width:100%;margin-top:26px}
.calcA__disc{font-size:11.5px;color:var(--warm);margin-top:12px}

/* ================= H8 — Waarom Voluno + Trustpilot ===================== */
.waarom{position:relative;z-index:var(--z-base);padding:clamp(74px,12vh,140px) var(--gutter)}
.waarom__inner{max-width:var(--maxw);margin:0 auto;width:100%;text-align:center}
/* op de schemer-/avondlucht: lichte kop met haartje schaduw → AA op elk scrollmoment */
.waarom .eyebrow{color:#E8C271}
.waarom .eyebrow::before{background:#E8C271}
.waarom h2{font-family:var(--f-display);font-weight:600;font-size:clamp(2.05rem,5.2vw,3.6rem);line-height:1.05;letter-spacing:-.01em;color:#fff;margin:14px 0 0;text-shadow:0 2px 18px rgba(15,28,61,.45)}
.waarom h2 em{font-style:italic;color:#F2C14E}
/* pijlers — variant A: verfijnde lijst (geen blokjes), goud-ring-iconen */
.pijlers{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(28px,4vw,54px);margin-top:clamp(28px,4.5vh,46px);text-align:left;
  background:rgba(255,255,255,.5);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.68);border-radius:var(--r-lg);padding:6px clamp(24px,3vw,38px);box-shadow:0 26px 60px -30px rgba(30,58,95,.38)}
.pijler{display:flex;gap:18px;align-items:flex-start;padding:24px 0;border-top:1px solid var(--border-l)}
.pijler:nth-child(1),.pijler:nth-child(2){border-top:0}
.pijler__ic{flex:none;width:48px;height:48px;border-radius:50%;border:1px solid rgba(200,144,10,.45);display:flex;align-items:center;justify-content:center;color:var(--gold)}
.pijler__ic svg{width:24px;height:24px}
.pijler h3{font-family:var(--f-display);font-weight:600;font-size:1.32rem;color:var(--brand-x);line-height:1.15;margin:0}
.pijler p{font-size:13.5px;color:#475873;margin-top:3px;line-height:1.5;font-weight:300}

/* Trustpilot — carrousel met echte Trustpilot-groene sterren */
.trust{margin:clamp(30px,4vh,48px) auto 0;max-width:600px;text-align:center}
.trust__logo{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:18px;color:#fff;margin-bottom:12px}
.trust__logo svg{width:21px;height:21px}
.trust__rating{display:flex;justify-content:center;gap:4px;margin-bottom:9px}
.tstar{width:32px;height:32px;border-radius:6px;background:#00B67A;display:inline-flex;align-items:center;justify-content:center}
.tstar--half{background:linear-gradient(90deg,#00B67A 0,#00B67A 50%,#dcdce6 50%,#dcdce6 100%)}  /* halve ster = 4,5 */
.tstar svg{width:21px;height:21px;fill:#fff}
.trust__meta{font-size:12.5px;color:rgba(255,255,255,.82);margin-bottom:22px}
.trust__meta b{font-weight:600;color:#fff}
.trust__car{position:relative;overflow:hidden;border-radius:20px}
.trust__track{display:flex;transition:transform .55s var(--ease-out)}
.trust__slide{flex:0 0 100%;padding:4px}
/* sterren bovenaan vast, naam/datum onderaan vast, quote vult het midden → geen pixelverschil tussen slides */
.trust__card{background:#fff;border-radius:20px;padding:clamp(30px,4vw,40px) clamp(28px,5vw,54px);box-shadow:0 26px 60px -30px rgba(15,28,61,.5);min-height:206px;display:flex;flex-direction:column}
.trust__mini{display:flex;justify-content:center;gap:3px;flex:none}
.trust__mini .tstar{width:25px;height:25px;border-radius:5px}
.trust__mini .tstar svg{width:16px;height:16px}
.trust__quote{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  font-family:var(--f-display);font-weight:600;font-style:italic;font-size:clamp(1.35rem,2.4vw,1.7rem);line-height:1.36;color:var(--brand-x);max-width:30ch;margin:18px auto;padding:0}
.trust__by{font-size:13px;color:var(--warm);flex:none;line-height:1.5}
.trust__src{opacity:.72}
.trust__nav{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;border:0;cursor:pointer;background:rgba(255,255,255,.9);color:var(--brand-x);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px -8px rgba(15,28,61,.5);z-index:2}
.trust__nav:hover{background:#fff}.trust__nav--prev{left:6px}.trust__nav--next{right:6px}
.trust__nav svg{width:18px;height:18px}
.trust__dots{display:flex;justify-content:center;gap:8px;margin-top:18px}
.trust__dots button{width:8px;height:8px;border-radius:50%;border:0;background:rgba(255,255,255,.4);cursor:pointer;padding:0;transition:background .2s,width .2s}
.trust__dots button.on{background:#fff;width:22px;border-radius:99px}

@media (max-width:860px){
  .pijlers{grid-template-columns:1fr;padding:4px clamp(20px,5vw,28px)}
  .pijler:nth-child(2){border-top:1px solid var(--border-l)}
}
@media (max-width:520px){
  .ladder__row{grid-template-columns:48px 1fr auto;gap:10px;padding:9px 12px}
  .trust__quote{font-size:1.32rem}.trust__nav{display:none}
}

/* ================= H10 — Nacht: afsluiting + aanvraag =================== */
.nacht{position:relative;z-index:var(--z-base);padding:clamp(80px,13vh,150px) var(--gutter) 0;color:#fff;overflow:hidden}
.nacht__ruit{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.6;
  background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.04) 0 1px,transparent 1px 24px),
                   repeating-linear-gradient(-45deg,rgba(255,255,255,.04) 0 1px,transparent 1px 24px)}
.nacht__inner{max-width:var(--maxw);margin:0 auto;width:100%}
.eyebrow--night{color:#E8C271}
.eyebrow--night::before{background:#E8C271}
.nacht h2{font-family:var(--f-display);font-weight:600;font-size:clamp(2.1rem,5.4vw,4rem);line-height:1.05;letter-spacing:-.01em;color:#fff;margin:14px 0 0;max-width:18ch}
.nacht h2 em{font-style:italic;color:#F2C14E}
.nacht__sub{font-size:clamp(1.02rem,1.5vw,1.22rem);font-weight:300;color:rgba(255,255,255,.82);max-width:46ch;margin-top:18px;line-height:1.55}

.nacht__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,56px);align-items:start;margin-top:clamp(34px,5vh,56px);scroll-margin-top:clamp(86px,13vh,130px)}

/* formulier-kaart */
.aanvraag{background:#fff;border-radius:var(--r-lg);padding:clamp(22px,3vw,32px);box-shadow:0 30px 70px -28px rgba(0,0,0,.55);color:var(--ink)}
.aanvraag__fields{display:flex;flex-direction:column;gap:14px}
.aanvraag__field label{display:block;font-size:13px;font-weight:600;color:var(--brand-x);margin-bottom:6px}
.aanvraag__field input{width:100%;height:50px;padding:0 16px;border:1px solid var(--border);border-radius:var(--r-sm);font:inherit;font-weight:400;color:var(--ink);background:var(--paper);transition:border-color .15s,box-shadow .15s}
.aanvraag__field input::placeholder{color:#9aa7b8}
.aanvraag__field input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(96,165,250,.25)}
.aanvraag__submit{width:100%;margin-top:18px}
.aanvraag__privacy{font-size:12px;color:var(--warm);margin-top:14px;text-align:center;font-weight:400}
/* bevestiging in dezelfde kaart */
.aanvraag.is-sent .aanvraag__fields,.aanvraag.is-sent .aanvraag__submit,.aanvraag.is-sent .aanvraag__privacy{display:none}
.aanvraag__success{display:none;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:18px 6px}
.aanvraag.is-sent .aanvraag__success{display:flex}
.aanvraag__success-ic{width:52px;height:52px;border-radius:50%;background:rgba(22,163,74,.12);display:flex;align-items:center;justify-content:center;color:var(--green)}
.aanvraag__success h3{font-family:var(--f-display);font-weight:600;font-size:1.55rem;color:var(--brand-x)}
.aanvraag__success p{font-size:14.5px;color:var(--warm);max-width:34ch}

/* checklist + traject */
.nacht__aside{display:flex;flex-direction:column;gap:28px;padding-top:4px}
.checklist{list-style:none;padding:0;display:flex;flex-direction:column;gap:13px}
.checklist li{position:relative;padding-left:30px;font-size:15px;color:rgba(255,255,255,.92)}
.checklist li::before{content:"";position:absolute;left:0;top:2px;width:19px;height:19px;border-radius:50%;background:rgba(232,168,32,.16);border:1px solid #E8A820}
.checklist li::after{content:"";position:absolute;left:6.5px;top:6px;width:5px;height:9px;border:solid #E8C271;border-width:0 2px 2px 0;transform:rotate(45deg)}
.traject__label{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.traject__steps{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:11px}
.traject__steps li{display:flex;align-items:center;gap:12px;font-size:14.5px;color:rgba(255,255,255,.86)}
.traject__steps li span{flex:none;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-weight:600;font-size:14px;color:#0f1c3d;background:linear-gradient(180deg,#E8A820,#C8900A)}

/* compacte FAQ */
.faq{margin-top:clamp(40px,6vh,72px);max-width:680px}
.faq .eyebrow--night{display:inline-flex;margin-bottom:10px}
.faq details{border-bottom:1px solid rgba(255,255,255,.14);padding:14px 0}
.faq summary{cursor:pointer;list-style:none;font-weight:500;font-size:16px;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;line-height:1;color:#E8C271;font-weight:300}
.faq details[open] summary::after{content:"–"}
.faq details p{margin-top:10px;font-size:14.5px;color:rgba(255,255,255,.78);font-weight:300;max-width:62ch}

/* footer */
.site-footer{margin-top:clamp(48px,8vh,88px);padding:28px 0 36px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;flex-direction:column;gap:8px;align-items:center;text-align:center}
.site-footer__brand{font-family:var(--f-sans);font-weight:800;font-size:20px;letter-spacing:.06em;color:#fff}
.site-footer__meta,.site-footer__copy{font-size:12.5px;color:rgba(255,255,255,.5)}
.site-footer__links{font-size:12.5px;color:rgba(255,255,255,.72)}
.site-footer__links a{transition:color .15s}
.site-footer__links a:hover{color:#E8C271}

@media (max-width:760px){ .nacht__grid{grid-template-columns:1fr;gap:30px} }

/* ---- Micro-vertrouwen (Trustpilot-sterren bij de beslismomenten) ---- */
.microtrust{display:flex;align-items:center;justify-content:center;gap:8px;font-size:12.5px;color:var(--warm);font-weight:400}
.microtrust b{font-weight:600;color:var(--ink)}
.microtrust__stars{display:inline-flex;gap:2px}
.microtrust__stars .tstar{width:16px;height:16px;border-radius:3px}
.microtrust__stars .tstar svg{width:11px;height:11px;fill:#fff}
.calcA .microtrust{margin:18px 0 0}
.aanvraag .microtrust{margin:14px 0 0}

/* ---- Belknop (tweede pad, vooral mobiel) ---- */
.nacht__call{margin-bottom:24px}
.belknop{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:50px;padding:0 22px;border-radius:var(--r-pill);
  border:1.5px solid var(--gold);background:rgba(232,168,32,.06);color:#E8C271;font-weight:600;font-size:15px;
  transition:background .15s,border-color .15s,color .15s,transform var(--dur-fast) var(--ease-out)}
.belknop:hover{background:rgba(232,168,32,.14);border-color:var(--gold-m);color:#F2C14E;transform:translateY(-2px)}
.belknop:active{transform:translateY(0)}
.belknop svg{width:18px;height:18px;flex:none}
.belknop__hours{display:block;text-align:center;font-size:12px;color:rgba(255,255,255,.6);margin-top:9px}

/* ---------------------- Cookietoestemming (AVG) ------------------------- */
/* Rustige navy-glas balk onderaan; pixel laadt pas na 'Accepteren'. */
.cookiebar{position:fixed;left:0;right:0;bottom:0;z-index:var(--z-modal);
  display:flex;align-items:center;justify-content:center;gap:clamp(14px,3vw,34px);flex-wrap:wrap;
  padding:15px clamp(18px,5vw,40px) calc(15px + env(safe-area-inset-bottom));
  background:rgba(15,28,61,.88);-webkit-backdrop-filter:blur(16px) saturate(1.05);backdrop-filter:blur(16px) saturate(1.05);
  border-top:1px solid rgba(255,255,255,.12);box-shadow:0 -18px 44px -22px rgba(15,28,61,.7);
  color:rgba(255,255,255,.9);font-size:13.5px;line-height:1.5;
  animation:cookieRise var(--dur-mid) var(--ease-out) both}
.cookiebar[hidden]{display:none}
@keyframes cookieRise{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cookiebar__text{max-width:62ch;margin:0}
.cookiebar__text a{color:#fff;text-decoration:underline;text-underline-offset:2px;white-space:nowrap}
.cookiebar__actions{display:flex;align-items:center;gap:10px;flex:none}
.cookiebar .btn{min-height:44px;padding:0 22px;font-size:14px}
.cookiebar__decline{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.24);color:rgba(255,255,255,.92)}
.cookiebar__decline:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}
.cookiebar__decline:active{transform:translateY(0)}
@media (max-width:560px){
  .cookiebar{flex-direction:column;align-items:stretch;text-align:center;gap:12px;padding-bottom:calc(15px + env(safe-area-inset-bottom))}
  .cookiebar__actions{justify-content:stretch}
  .cookiebar__actions .btn{flex:1}
}

/* ---------------------- Reduced motion ---------------------------------- */
@media (prefers-reduced-motion: reduce){
  .hero__visual img,.scrollcue .line::after,.sky__sun{animation:none !important}
  [data-reveal]{opacity:1 !important;transform:none !important;transition:none !important}
  .scrollcue{display:none}
  .cookiebar{animation:none}
}
