/* InnoDIGI — ultimate premium dark UI */

/* --- Inter (self-hosted, variable weight 400-700) --- */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../assets/fonts/inter-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../assets/fonts/inter-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  --logo-blue: #2167b1;
  --logo-blue-mid: #2a6fc0;
  /* WCAG 1.4.3: bodylinks min. 4,5:1 op donkere achtergrond (#0c0a10) */
  --link: #4a9aed;
  --link-hover: #f47d4f;
  --logo-orange: #f47d4f;
  --purple-void: #0c0a10;
  --purple-950: #12101a;
  --purple-900: #181522;
  --purple-800: #221c30;
  --purple-700: #2d2440;
  --surface: rgba(255, 255, 255, 0.035);
  --surface-2: rgba(255, 255, 255, 0.065);
  --surface-glass: rgba(255, 255, 255, 0.04);
  --border: rgba(255, 255, 255, 0.09);
  --border-bright: rgba(255, 255, 255, 0.14);
  --text: #f4f2f8;
  --text-muted: #9d91b8;
  --wrap: min(1180px, calc(100% - 3.5rem));
  --radius: 16px;
  --radius-sm: 10px;
  --font: "Inter", system-ui, -apple-system, sans-serif;
  --ease: cubic-bezier(0.25, 0.1, 0.25, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --header-h: 4rem;
  --shadow-elevated: 0 24px 64px rgba(0, 0, 0, 0.45);
  --shadow-glow-sm: 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
}

*, *::before, *::after { box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  color-scheme: dark;
  /* Horizontale overflow onderdrukken (o.a. tijdens mobiel menu); clip voorkomt korte scrollbalk-flits */
  overflow-x: hidden;
  overflow-x: clip;
  /* 2.4.11 / sticky header: gefocuste ankers niet onder de balk */
  scroll-padding-top: calc(var(--header-h) + 0.75rem);
}
html[data-theme="light"] {
  color-scheme: light;
}
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

/* Hoger contrast op verzoek van het systeem (WCAG 1.4.6 / gebruikersvoorkeur) */
@media (prefers-contrast: more) {
  :root {
    --text-muted: #c5bdd8;
    --border: rgba(255, 255, 255, 0.2);
    --border-bright: rgba(255, 255, 255, 0.28);
  }
  html[data-theme="light"] {
    --text-muted: #3d3750;
    --border: rgba(22, 18, 33, 0.22);
    --border-bright: rgba(22, 18, 33, 0.3);
  }
}

/* Page load curtain — fades out after load */
.page-curtain {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--purple-void);
  pointer-events: none;
  opacity: 1;
  transition: opacity 1.8s cubic-bezier(0.25, 0, 0, 1);
}
body:not(.is-loading) .page-curtain { opacity: 0; }

body {
  margin: 0;
  font-family: var(--font);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--text);
  background: var(--purple-void);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: clip;
}

::selection { background: rgba(33, 103, 177, 0.45); color: #fff; }
:focus-visible {
  outline: 3px solid var(--link);
  outline-offset: 2px;
}
.btn:focus-visible, .header__menu-btn:focus-visible { outline-offset: 2px; }
img { max-width: 100%; height: auto; display: block; }
/* 1.4.1: niet alleen kleur — onderstreping voor typische tekstlinks */
a {
  color: var(--link);
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.2em;
}
a:hover { color: var(--link-hover); }
.header__links a,
.header__logo,
.bento__cell,
.menu-table__row,
.skip-link,
.btn {
  text-decoration: none;
}

.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.skip-link {
  position: absolute; left: 1rem; top: -100px; z-index: 2000;
  padding: 0.65rem 1rem; background: var(--logo-orange); color: var(--purple-950);
  font-weight: 600; font-size: 0.9rem; border-radius: var(--radius-sm); text-decoration: none;
}
.skip-link:focus { top: 1rem; }

.wrap { width: var(--wrap); margin-inline: auto; }

/* Skiplink landt op <main tabindex="-1"> — focus zichtbaar houden */
#main:focus {
  outline: none;
}
#main:focus-visible {
  outline: 3px solid var(--link);
  outline-offset: 0.35rem;
  border-radius: var(--radius-sm);
}

.gradient-text {
  background: linear-gradient(100deg, #fff 0%, var(--logo-blue-mid) 50%, var(--logo-orange) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
@media (forced-colors: active) {
  .gradient-text,
  .hero__title-strong,
  .scroll-story__panel-title {
    background: none !important;
    -webkit-text-fill-color: CanvasText !important;
    color: CanvasText !important;
  }
  .btn--line {
    border: 2px solid ButtonBorder !important;
  }
  a {
    text-decoration: underline;
  }
  .header__submenu a[aria-current="page"],
  .header__links > li > a[aria-current="page"],
  .header__links > li > a.is-nav-active {
    outline: 2px solid Highlight;
    outline-offset: 2px;
  }
}

/* Background */
.bg-gradient {
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(100% 70% at 15% -5%, rgba(33,103,177,0.22), transparent 52%),
    radial-gradient(80% 55% at 95% 5%, rgba(241,101,50,0.07), transparent 48%),
    radial-gradient(65% 45% at 50% 105%, rgba(45,36,64,0.75), transparent 58%),
    linear-gradient(180deg, var(--purple-950) 0%, var(--purple-void) 45%, #0a0812 100%);
}
.bg-gradient__mesh {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.028) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse 85% 65% at 50% 35%, black 15%, transparent 72%);
  -webkit-mask-image: radial-gradient(ellipse 85% 65% at 50% 35%, black 15%, transparent 72%);
}
.bg-gradient__vignette {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 75% 60% at 50% 50%, transparent 40%, rgba(0,0,0,0.5) 100%);
}
.bg-gradient__grain {
  position: absolute; inset: 0; opacity: 0.035;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Section divider */
.divider {
  width: min(900px, 86%);
  height: 1px;
  margin: 0 auto 2rem;
  background: linear-gradient(90deg, transparent, rgba(33,103,177,0.4), rgba(241,101,50,0.3), transparent);
  opacity: 0.7;
}
.divider--contact {
  margin-bottom: clamp(0.65rem, 1.5vw, 1rem);
  opacity: 0.55;
}

/* Header */
.header {
  position: sticky; top: 0; z-index: 100; height: var(--header-h);
  display: flex; align-items: center;
  background: rgba(18,16,26,0.72);
  backdrop-filter: blur(16px) saturate(1.15);
  -webkit-backdrop-filter: blur(16px) saturate(1.15);
  border-bottom: 1px solid transparent;
  transition: border-color 0.35s var(--ease-out), background 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
}
.header.is-scrolled {
  border-bottom-color: var(--border);
  background: rgba(18,16,26,0.88);
  box-shadow: 0 1px 0 rgba(255,255,255,0.04), 0 12px 40px rgba(0,0,0,0.35);
}
.header__bar { display: flex; align-items: center; justify-content: space-between; gap: 1.25rem; }
.header__logo img { height: 34px; width: auto; }

.header__menu-btn {
  display: none; width: 2.75rem; height: 2.75rem; padding: 0;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--surface); cursor: pointer; position: relative;
}
.header__menu-icon, .header__menu-icon::before, .header__menu-icon::after {
  display: block; width: 1.1rem; height: 2px; background: var(--text);
  position: absolute; left: 50%; transform: translateX(-50%);
  transition: transform 0.2s var(--ease), opacity 0.2s;
}
.header__menu-icon { top: 50%; margin-top: -1px; }
.header__menu-icon::before, .header__menu-icon::after { content: ""; }
.header__menu-icon::before { top: -6px; }
.header__menu-icon::after { top: 6px; }
.header__menu-btn[aria-expanded="true"] .header__menu-icon { background: transparent; }
.header__menu-btn[aria-expanded="true"] .header__menu-icon::before { transform: translateX(-50%) translateY(6px) rotate(45deg); }
.header__menu-btn[aria-expanded="true"] .header__menu-icon::after { transform: translateX(-50%) translateY(-6px) rotate(-45deg); }
.header__menu-btn[aria-expanded="true"] {
  border-color: rgba(241, 101, 50, 0.55);
  background: rgba(241, 101, 50, 0.1);
}
.header__nav { display: flex; align-items: center; gap: 2rem; }
.header__links { display: flex; align-items: center; gap: 1.5rem; list-style: none; margin: 0; padding: 0; }
.header__links a {
  text-decoration: none; color: var(--text-muted); font-weight: 500; font-size: 0.92rem;
  position: relative; padding-bottom: 2px; transition: color 0.25s var(--ease-out);
}
.header__links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 1px;
  background: linear-gradient(90deg, var(--logo-orange), var(--logo-blue-mid));
  transition: width 0.35s var(--ease-out);
}
.header__links a:hover { color: var(--text); }
.header__links a:hover::after { width: 100%; }
.header__links a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
/* Actieve hoofdnav: huidige pagina of (homepage) gekozen anker */
.header__links > li > a[aria-current="page"],
.header__links > li > a.is-nav-active {
  color: var(--text);
  font-weight: 600;
}
.header__links > li > a[aria-current="page"]::after,
.header__links > li > a.is-nav-active::after {
  width: 100%;
}
/* Diensten-label actief als een dienstpagina open is */
.header__item--has-sub:has(.header__submenu a[aria-current="page"]) > a {
  color: var(--text);
  font-weight: 600;
}
.header__item--has-sub:has(.header__submenu a[aria-current="page"]) > a::after {
  width: 100%;
}
.header__item--has-sub {
  position: relative;
}
.header__submenu {
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 769px) {
  .header__submenu {
    position: absolute;
    left: 0;
    top: calc(100% + 0.35rem);
    z-index: 150;
    min-width: 15.5rem;
    padding: 0.4rem 0;
    background: rgba(18, 16, 26, 0.98);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: 0 20px 48px rgba(0, 0, 0, 0.45);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-6px);
    transition:
      opacity 0.22s var(--ease-out),
      visibility 0.22s,
      transform 0.22s var(--ease-out);
  }
  /* Onzichtbare brug: muis kan submenu bereiken zonder hover te verliezen */
  .header__submenu::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -0.45rem;
    height: 0.45rem;
  }
  .header__item--has-sub:hover .header__submenu,
  .header__item--has-sub:focus-within .header__submenu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }
  .header__submenu a {
    display: block;
    padding: 0.55rem 1.05rem;
    font-size: 0.88rem;
    white-space: nowrap;
  }
  .header__submenu a::after {
    display: none;
  }
  .header__submenu a:hover {
    background: rgba(33, 103, 177, 0.12);
    color: var(--text);
  }
  .header__submenu a[aria-current="page"] {
    background: rgba(33, 103, 177, 0.22);
    color: var(--text);
    font-weight: 600;
    box-shadow: inset 3px 0 0 var(--logo-orange);
  }
  .header__submenu a[aria-current="page"]:hover {
    background: rgba(33, 103, 177, 0.28);
    color: var(--text);
  }
}
html[data-theme="light"] .header__submenu {
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 20px 48px rgba(33, 103, 177, 0.12);
}
html[data-theme="light"] .header__submenu a[aria-current="page"] {
  background: rgba(33, 103, 177, 0.1);
  color: var(--text);
}
.header__cta { flex-shrink: 0; }

/* Kleurenthema (donker = standaard) */
.theme-switch {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.85rem;
  height: 1.65rem;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface);
  cursor: pointer;
  transition: border-color 0.25s var(--ease-out), background 0.25s var(--ease-out),
    box-shadow 0.25s var(--ease-out);
}
.theme-switch:hover {
  border-color: var(--border-bright);
  background: var(--surface-2);
}
.theme-switch[aria-checked="true"] {
  border-color: rgba(241, 101, 50, 0.5);
  box-shadow: 0 0 0 2px rgba(33, 103, 177, 0.22);
  background: rgba(33, 103, 177, 0.12);
}
html[data-theme="light"] .theme-switch[aria-checked="true"] {
  border-color: rgba(154, 52, 18, 0.45);
  box-shadow: 0 0 0 2px rgba(33, 103, 177, 0.15);
  background: rgba(33, 103, 177, 0.08);
}
.theme-switch:focus-visible {
  outline: 3px solid var(--link);
  outline-offset: 2px;
}
.theme-switch__track {
  position: relative;
  width: 2.1rem;
  height: 1.1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
}
html[data-theme="light"] .theme-switch__track {
  background: rgba(26, 21, 40, 0.08);
  box-shadow: 0 0 0 1px rgba(26, 21, 40, 0.08) inset;
}
.theme-switch__thumb {
  position: absolute;
  top: 50%;
  left: 2px;
  width: 0.85rem;
  height: 0.85rem;
  margin-top: -0.425rem;
  border-radius: 50%;
  background: linear-gradient(145deg, #f4f2f8, #9d91b8);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
  transition: transform 0.3s var(--ease-out), background 0.3s var(--ease-out),
    box-shadow 0.3s var(--ease-out);
  overflow: hidden;
}
.theme-switch__thumb::before,
.theme-switch__thumb::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 0.5rem;
  height: 0.5rem;
  pointer-events: none;
  transition: opacity 0.3s var(--ease-out);
}
.theme-switch__thumb::before {
  opacity: 0.85;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23000'%3E%3Cpath d='M21.64 13a1 1 0 0 0-1.05-.14 8.05 8.05 0 0 1-3.37.73A8.15 8.15 0 0 1 9.08 5.49a8.59 8.59 0 0 1 .25-2 1 1 0 0 0-.35-1 1 1 0 0 0-1.06-.07A10 10 0 1 0 21.77 14a1 1 0 0 0-.13-1Z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.theme-switch__thumb::after {
  opacity: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M12 18a6 6 0 1 1 0-12 6 6 0 0 1 0 12Zm0-2a4 4 0 1 0 0-8 4 4 0 0 0 0 8ZM11 1h2v3h-2V1Zm0 19h2v3h-2v-3ZM3.515 4.929l1.414-1.414L7.05 5.636 5.636 7.05 3.515 4.93ZM16.95 18.364l1.414-1.414 2.121 2.121-1.414 1.414-2.121-2.121Zm2.121-14.85 1.414 1.415-2.121 2.121-1.414-1.414 2.121-2.121ZM5.636 16.95l1.414 1.414-2.121 2.121-1.414-1.414 2.121-2.121ZM23 11v2h-3v-2h3ZM4 11v2H1v-2h3Z'/%3E%3C/svg%3E") center/contain no-repeat;
}
html[data-theme="light"] .theme-switch__thumb::before {
  opacity: 0;
}
html[data-theme="light"] .theme-switch__thumb::after {
  opacity: 0.9;
}
html[data-theme="light"] .theme-switch__thumb {
  transform: translateX(1.05rem);
  background: linear-gradient(145deg, #2a6fc0, #1a4a80);
  box-shadow: 0 1px 5px rgba(33, 103, 177, 0.45);
}

/* Offcanvas-overlay: standaard uit; op smalle schermen zie @media hieronder */
.nav-backdrop {
  display: none;
}

@media (max-width: 768px) {
  /*
   * Vaste header: sticky faalt o.a. door overflow-x op html; fixed houdt de menubalk in beeld.
   * backdrop-filter op .header geeft een containing block → fixed nav klemt aan header i.p.v. viewport
   * (menu “bovenaan de site” i.p.v. onder de balk). Zonder blur op mobiel: echte viewport-fixed drawer.
   */
  html {
    /* Voorkomt layoutverspringing als de klassieke scrollbar wél zichtbaar blijft */
    scrollbar-gutter: stable;
  }
  /* Geen overflow:hidden op html (veroorzaakt zelf flits); fixed body + rechter-compensatie i.p.v. layoutverspringing */
  html.is-mobile-nav-open {
    height: 100%;
    overscroll-behavior: none;
    padding-right: var(--mobile-nav-scrollbar-gap, 0px);
  }
  html.is-mobile-nav-open .header,
  html.is-mobile-nav-open .nav-backdrop {
    padding-right: var(--mobile-nav-scrollbar-gap, 0px);
  }
  body.is-mobile-nav-open {
    overscroll-behavior: none;
  }
  :root {
    /* Rij: safe-area + verticale lucht; body/backdrop gebruiken dezelfde hoogte als de gesloten balk */
    --header-h: calc(3.75rem + max(0.5rem, env(safe-area-inset-top, 0px)));
  }
  body {
    padding-top: var(--header-h);
  }
  .header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 200;
    height: auto;
    min-height: var(--header-h);
    align-items: stretch;
    /* Wrapper geen eigen scrollport (flits); het paneel .header__nav scrollt intern */
    overflow-x: clip;
    overflow-y: clip;
    padding-top: max(0.5rem, env(safe-area-inset-top, 0px));
    padding-bottom: 0.5rem;
    box-sizing: border-box;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    background: rgba(18, 16, 26, 0.97);
  }
  .header.is-scrolled {
    background: rgba(18, 16, 26, 0.98);
  }
  /* Geen .wrap-beperking: volle breedte, geen 100vw-breakout (scrollbar + rechtergleuf) */
  .header .wrap.header__bar {
    width: 100%;
    max-width: none;
    margin-inline: 0;
    padding-inline: 0;
  }
  /* Grid: eerste rij vaste min-hoogte zodat logo + knop echt verticaal gecentreerd zijn (flex align-content doet niets bij één regel) */
  .header__bar {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: minmax(3.25rem, auto) auto;
    align-items: center;
    column-gap: 1.25rem;
    row-gap: 0;
  }
  .header__logo {
    grid-column: 1;
    grid-row: 1;
    margin-inline-start: clamp(1rem, 5vw, 1.75rem);
  }
  .header__menu-btn {
    grid-column: 2;
    grid-row: 1;
    display: block;
    margin-inline-end: clamp(1rem, 5vw, 1.75rem);
  }
  .nav-backdrop {
    display: block;
    position: fixed;
    left: 0;
    right: 0;
    top: var(--header-h);
    bottom: 0;
    z-index: 180;
    background: rgba(6, 4, 12, 0.52);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.28s var(--ease), visibility 0.28s;
  }
  .nav-backdrop.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  /* Paneel zit in de flow onder logo/hamburger — klapt naar beneden uit i.p.v. over de balk heen */
  .header__nav {
    grid-column: 1 / -1;
    grid-row: 2;
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    box-sizing: border-box;
    min-height: 0;
    max-height: 0;
    overflow: hidden;
    overscroll-behavior: contain;
    flex-direction: column;
    align-items: stretch;
    padding: 0;
    margin-bottom: 0;
    background: rgba(14, 8, 24, 0.98);
    border-top: none;
    border-bottom: 1px solid transparent;
    opacity: 0;
    pointer-events: none;
    transition: max-height 0.38s var(--ease-out), opacity 0.28s var(--ease), padding 0.28s var(--ease),
      border-color 0.28s var(--ease);
  }
  /* Tijdens max-height-transitie geen overflow-y:auto → voorkomt korte zichtbare scrollbar op het paneel */
  .header__nav.is-open {
    max-height: min(85dvh, 36rem);
    overflow-x: hidden;
    overflow-y: hidden;
    padding: 1rem clamp(1rem, 5vw, 1.75rem) 1.25rem;
    border-top: 1px solid var(--border);
    border-bottom-color: var(--border);
    opacity: 1;
    pointer-events: auto;
  }
  .header__nav.is-open.is-open-done {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .header__nav.is-open.is-open-done::-webkit-scrollbar {
    width: 0;
    height: 0;
  }
  .header__links { flex-direction: column; align-items: stretch; gap: 0; }
  .header__links > li { border-bottom: 1px solid var(--border); }
  .header__submenu {
    padding: 0 0 0.35rem 0.85rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    margin-top: -0.15rem;
  }
  html[data-theme="light"] .header__submenu {
    border-top-color: rgba(22, 18, 33, 0.08);
  }
  .header__submenu li {
    border-bottom: none;
  }
  .header__submenu a {
    display: block;
    padding: 0.55rem 0;
    font-size: 0.88rem;
    color: var(--text-muted);
  }
  .header__submenu a::after {
    display: none;
  }
  .header__submenu a[aria-current="page"] {
    color: var(--text);
    font-weight: 600;
    background: rgba(33, 103, 177, 0.16);
    box-shadow: inset 3px 0 0 var(--logo-orange);
    border-radius: var(--radius-sm);
  }
  .header__links a {
    display: block;
    padding: 0.85rem 0;
  }
  .header__links a::after { display: none; }
  .theme-switch { align-self: center; margin-top: 0.5rem; }
  .header__cta { margin-top: 0.75rem; text-align: center; align-self: stretch; box-sizing: border-box; }
}

/* WhatsApp — top teaser (sitebreed) */
.wa-teaser {
  position: relative;
  z-index: 99;
  background: linear-gradient(105deg, rgba(37, 211, 102, 0.14) 0%, rgba(33, 103, 177, 0.16) 52%, rgba(244, 125, 79, 0.1) 100%);
  border-bottom: 1px solid rgba(37, 211, 102, 0.22);
}
.wa-teaser__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.65rem 1.1rem;
  padding: 0.5rem 0;
  min-height: 2.65rem;
}
.wa-teaser__badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: rgba(37, 211, 102, 0.18);
  color: #25d366;
  flex-shrink: 0;
}
.wa-teaser__icon {
  width: 1.08rem;
  height: 1.08rem;
  display: block;
}
.wa-teaser__copy {
  margin: 0;
  font-size: 0.84rem;
  line-height: 1.45;
  color: var(--text-muted);
  text-align: center;
  flex: 1 1 14rem;
  max-width: 38rem;
}
.wa-teaser__copy strong {
  color: var(--text);
  font-weight: 600;
}
.wa-teaser__sep {
  opacity: 0.45;
  margin: 0 0.25rem;
}
.wa-teaser__line {
  white-space: normal;
}
.wa-teaser__link-inline {
  color: #25d366;
  font-weight: 600;
  text-decoration: underline;
  text-decoration-color: rgba(37, 211, 102, 0.45);
  text-underline-offset: 0.14em;
  margin-left: 0.15rem;
}
.wa-teaser__link-inline:hover {
  color: #1ebe57;
  text-decoration-color: rgba(30, 190, 87, 0.65);
}
html[data-theme="light"] .wa-teaser__link-inline {
  color: #159c4a;
}
html[data-theme="light"] .wa-teaser__link-inline:hover {
  color: #0d7a3a;
}
/* Smal: geen knop, groene link in de zin (.btn komt later in stylesheet en zou display overschrijven) */
.wa-teaser .btn.wa-teaser__btn {
  display: none;
  flex-shrink: 0;
}
.wa-teaser .btn.wa-teaser__btn-mail {
  display: none;
  flex-shrink: 0;
}
.wa-teaser__link-inline--mail {
  color: var(--logo-orange);
  text-decoration-color: rgba(241, 101, 50, 0.45);
}
.wa-teaser__link-inline--mail:hover {
  color: #e85528;
  text-decoration-color: rgba(232, 85, 40, 0.65);
}
html[data-theme="light"] .wa-teaser__link-inline--mail {
  color: #c44a1e;
}
html[data-theme="light"] .wa-teaser__link-inline--mail:hover {
  color: #a53d18;
}
.wa-teaser .btn.wa-teaser__btn-mail {
  border-color: var(--logo-orange);
  color: var(--logo-orange);
}
.wa-teaser .btn.wa-teaser__btn-mail:hover {
  background: rgba(241, 101, 50, 0.12);
  border-color: #e85528;
  color: #fff;
}
html[data-theme="light"] .wa-teaser .btn.wa-teaser__btn-mail:hover {
  color: #1a0a04;
}
@media (min-width: 720px) {
  .wa-teaser__link-inline {
    display: none;
  }
  .wa-teaser .btn.wa-teaser__btn {
    display: inline-flex;
  }
  .wa-teaser .btn.wa-teaser__btn-mail {
    display: inline-flex;
  }
  .wa-teaser__inner {
    justify-content: flex-start;
  }
  .wa-teaser__copy {
    text-align: left;
    flex: 1 1 auto;
  }
}
html[data-theme="light"] .wa-teaser {
  background: linear-gradient(105deg, rgba(37, 211, 102, 0.1) 0%, rgba(33, 103, 177, 0.09) 52%, rgba(244, 125, 79, 0.07) 100%);
  border-bottom-color: rgba(37, 211, 102, 0.26);
}

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.72rem 1.25rem; font-family: var(--font); font-weight: 600;
  font-size: 0.9rem; border-radius: 999px; text-decoration: none;
  border: 1px solid transparent; cursor: pointer;
  transition: background 0.3s var(--ease-out), color 0.25s var(--ease-out),
    border-color 0.3s var(--ease-out), transform 0.25s var(--ease-out), box-shadow 0.35s var(--ease-out);
}
.btn:active { transform: scale(0.98) translateY(0); }

.btn--solid {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--logo-orange), #e85528); color: #1a0a04;
  box-shadow: 0 1px 0 rgba(255,255,255,0.2) inset, 0 4px 24px rgba(241,101,50,0.32);
}
.btn--solid::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,0.28) 50%, transparent 60%);
  transform: translateX(-120%);
  transition: transform 0.55s cubic-bezier(0.4, 0, 0, 1);
  pointer-events: none;
}
.btn--solid:hover::after { transform: translateX(120%); }
.btn--solid:hover {
  color: #1a0a04; filter: brightness(1.06);
  box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 8px 32px rgba(241,101,50,0.4);
  transform: translateY(-1px);
}
.btn--line {
  position: relative; overflow: hidden;
  background: transparent; border-color: var(--border); color: var(--text);
}
.btn--line::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,0.1) 50%, transparent 60%);
  transform: translateX(-120%);
  transition: transform 0.55s cubic-bezier(0.4, 0, 0, 1);
  pointer-events: none;
}
.btn--line:hover::after { transform: translateX(120%); }
.btn--line:hover { border-color: rgba(33,103,177,0.45); background: rgba(33,103,177,0.12); color: var(--text); }
.btn--inverse { background: #fff; color: var(--purple-900); }
.btn--inverse:hover { color: var(--purple-900); filter: brightness(1.03); }
.btn--wa {
  position: relative;
  overflow: hidden;
  padding: 0.55rem 1.1rem;
  font-size: 0.84rem;
  background: linear-gradient(135deg, #25d366 0%, #1ebe57 100%);
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow: 0 2px 14px rgba(37, 211, 102, 0.35), 0 1px 0 rgba(255, 255, 255, 0.2) inset;
}
.btn--wa:hover {
  color: #fff !important;
  filter: brightness(1.07);
  transform: translateY(-1px);
  box-shadow: 0 4px 22px rgba(37, 211, 102, 0.45), 0 1px 0 rgba(255, 255, 255, 0.25) inset;
}
html[data-theme="light"] .btn--wa {
  color: #fff !important;
}

/* Hero */
.hero { position: relative; padding: clamp(2.5rem,6vw,4.5rem) 0 clamp(3rem,8vw,5rem); overflow: hidden; }
/* Subpagina’s: zelfde hero als home, iets compactere titel voor lange koppen */
.hero--sub {
  border-bottom: 1px solid var(--border);
}
/* Contact: hero vloeit door naar formulier — minder bodem-witruimte */
.hero--sub.hero--contact {
  padding-bottom: clamp(1rem, 2.5vw, 1.75rem);
}
.hero--sub .hero__title {
  font-size: clamp(2rem, 4.4vw, 3.25rem);
}
.hero__aura {
  position: absolute; width: min(90vw,720px); height: min(90vw,520px); top: -15%; left: -8%;
  background: radial-gradient(closest-side, rgba(33,103,177,0.2) 0%, rgba(33,103,177,0.06) 45%, transparent 70%);
  filter: blur(4px); pointer-events: none; z-index: 0;
}
.hero__gridline {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 100% 96px; background-position: 0 4.5rem;
  mask-image: linear-gradient(180deg, black 0%, transparent 85%);
  -webkit-mask-image: linear-gradient(180deg, black 0%, transparent 85%);
  pointer-events: none; z-index: 0;
}
.hero__grid {
  position: relative; z-index: 1; display: grid;
  grid-template-columns: minmax(0,1.1fr) minmax(320px,420px);
  gap: clamp(2rem,6vw,4.5rem); align-items: center;
}
@media (max-width: 900px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__visual { order: -1; }
}

/* Hero intro stagger (Apple keynote feel: bigger travel, slower ease) */
[data-hero-reveal] {
  opacity: 0; transform: translateY(2.5rem) scale(0.98);
  filter: blur(4px);
  transition: opacity 0.9s cubic-bezier(0.4, 0, 0, 1),
    transform 0.9s cubic-bezier(0.4, 0, 0, 1),
    filter 0.9s cubic-bezier(0.4, 0, 0, 1);
}
[data-hero-reveal].is-visible { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }

.kicker { display: flex; align-items: center; gap: 0.65rem; margin: 0 0 1rem; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--link); }
.kicker__line { width: 2rem; height: 2px; background: linear-gradient(90deg, var(--logo-orange), var(--logo-blue-mid)); border-radius: 2px; }
.hero__main { max-width: 42rem; }
.hero__title { margin: 0 0 1rem; font-size: clamp(2.2rem,5vw,3.75rem); font-weight: 700; line-height: 1.1; letter-spacing: -0.04em; }
.hero__title-strong {
  display: inline-block; margin-top: 0.15em;
  padding-bottom: 0.1em; margin-bottom: -0.1em;
  background: linear-gradient(100deg, #fff 0%, #c5d8f0 35%, var(--logo-blue-mid) 65%, var(--logo-orange) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  animation: gradient-pan 9s ease-in-out infinite alternate;
}
@keyframes gradient-pan { 0% { background-position: 0% 50%; } 100% { background-position: 100% 50%; } }

.hero__subtitle { margin: 0 0 1rem; font-size: 1.08rem; color: var(--text-muted); max-width: 36rem; }
.hero__lead { margin: 0 0 1.5rem; color: var(--text-muted); max-width: 38rem; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 0.65rem; }

.hero__proof {
  list-style: none; margin: 1.75rem 0 0; padding: 0;
  display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 0.75rem;
}
.hero__proof li {
  padding: 1rem 1rem 0.9rem; border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}
.hero__proof strong { display: block; margin: 0 0 0.25rem; font-size: 0.88rem; font-weight: 600; color: var(--text); }
.hero__proof span { display: block; font-size: 0.8rem; line-height: 1.45; color: var(--text-muted); }
@media (max-width: 900px) { .hero__proof { grid-template-columns: 1fr; } }

/* Showcase */
.hero__visual { position: relative; }
.showcase {
  position: relative; min-height: 34rem; perspective: 1400px;
  /* Afgestemd op hero stagger + curtain fade; samen met showcaseCounterDelayMs in main.js */
  --showcase-motion-delay: 0.9s;
}
.showcase__orbit { position: absolute; border-radius: 50%; border: 1px solid rgba(255,255,255,0.08); pointer-events: none; animation: orbit-spin 30s linear infinite; }
.showcase__orbit--a { width: 24rem; height: 24rem; top: 1rem; left: 2rem; opacity: 0.7; }
.showcase__orbit--b { width: 18rem; height: 18rem; right: 0; bottom: 2.5rem; border-color: rgba(33,103,177,0.18); animation-direction: reverse; animation-duration: 24s; }
@keyframes orbit-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

.showcase__window {
  position: relative; z-index: 2; overflow: hidden; width: min(100%,23rem);
  margin: 2.5rem auto 0; border-radius: 1.4rem;
  border: 1px solid rgba(255,255,255,0.1);
  background: linear-gradient(180deg, rgba(255,255,255,0.08), transparent 14%),
    linear-gradient(160deg, rgba(255,255,255,0.05), rgba(255,255,255,0.015));
  box-shadow: 0 0 0 1px rgba(255,255,255,0.05) inset, 0 32px 80px rgba(0,0,0,0.45);
  backdrop-filter: blur(20px) saturate(1.12); -webkit-backdrop-filter: blur(20px) saturate(1.12);
  transform-style: preserve-3d;
  /* Geen transition op transform: tilt wordt per frame via JS gezet — anders loopt de kaart uit sync met de spotlight */
  transition: box-shadow 0.35s var(--ease-out);
}
.showcase__window::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px; z-index: 2;
  background: conic-gradient(from 180deg, rgba(255,255,255,0.03), rgba(33,103,177,0.35), rgba(241,101,50,0.25), rgba(255,255,255,0.03));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; opacity: 0.6; pointer-events: none;
}
/* Spotlight achter chrome/canvas (z-index), niet erover — anders een vlakke vlek over de mockup */
.showcase__window::after {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background: radial-gradient(circle at var(--mx,50%) var(--my,30%), rgba(255,255,255,0.12), transparent 28%);
  pointer-events: none; opacity: 0.9;
}
.showcase__chrome {
  position: relative; z-index: 1;
  display: flex; gap: 0.35rem; padding: 0.8rem 0.9rem; border-bottom: 1px solid rgba(255,255,255,0.07);
}
.showcase__chrome span { width: 0.55rem; height: 0.55rem; border-radius: 50%; background: rgba(255,255,255,0.18); }
.showcase__chrome span:nth-child(1) { background: rgba(241,101,50,0.7); }
.showcase__chrome span:nth-child(2) { background: rgba(255,255,255,0.28); }
.showcase__chrome span:nth-child(3) { background: rgba(33,103,177,0.75); }
.showcase__canvas { position: relative; z-index: 1; padding: 1.1rem 1.15rem 1.2rem; isolation: isolate; }
.showcase__canvas::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 20%, rgba(241,101,50,0.12), transparent 32%),
    radial-gradient(circle at 18% 28%, rgba(33,103,177,0.18), transparent 38%);
  pointer-events: none;
}
.showcase__nav { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; }
.showcase__badge {
  box-shadow: var(--shadow-glow-sm), 0 16px 42px rgba(0,0,0,0.34);
  backdrop-filter: blur(16px) saturate(1.2); -webkit-backdrop-filter: blur(16px) saturate(1.2);
  position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 0.45rem;
  padding: 0.45rem 0.7rem; border-radius: 999px; background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1); font-size: 0.72rem; font-weight: 600; color: var(--text);
}
.showcase__nav-pill {
  position: relative; z-index: 1; padding: 0.38rem 0.62rem; border-radius: 999px;
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08);
  font-size: 0.68rem; font-weight: 600; color: var(--text-muted);
}
.showcase__eyebrow { position: relative; z-index: 1; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--logo-blue-mid); }
.showcase__hero-card {
  position: relative; z-index: 1; margin-top: 0.95rem; padding: 1rem; border-radius: 1rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.022));
  border: 1px solid rgba(255,255,255,0.08);
}
.showcase__headline { position: relative; z-index: 1; width: 100%; height: 0.95rem; margin-top: 0.1rem; border-radius: 999px; background: linear-gradient(90deg, rgba(255,255,255,0.92), rgba(197,216,240,0.55)); }
.showcase__headline--short { width: 72%; margin-top: 0.55rem; }
.showcase__progress { margin-top: 0.9rem; height: 0.42rem; border-radius: 999px; background: rgba(255,255,255,0.08); overflow: hidden; }
.showcase__progress-bar {
  display: block; width: 62%; height: 100%; border-radius: inherit;
  background: linear-gradient(90deg, var(--logo-blue-mid), var(--logo-orange));
  animation: progress-glow 6s ease-in-out var(--showcase-motion-delay) infinite alternate;
}
@keyframes progress-glow { from { transform: scaleX(0.94); transform-origin: left center; filter: brightness(0.95); } to { transform: scaleX(1); transform-origin: left center; filter: brightness(1.08); } }
.showcase__metrics { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; margin-top: 1.15rem; }
.showcase__metric { padding: 0.95rem; border-radius: 1rem; background: rgba(255,255,255,0.045); border: 1px solid rgba(255,255,255,0.08); }
.showcase__metric-value { display: block; font-size: 1.05rem; font-weight: 700; letter-spacing: -0.02em; color: var(--text); }
.showcase__metric-label { display: block; margin-top: 0.18rem; font-size: 0.72rem; color: var(--text-muted); }
.showcase__analytics { position: relative; z-index: 1; display: grid; grid-template-columns: 1.25fr 0.9fr; gap: 0.7rem; margin-top: 0.8rem; }
.showcase__analytics-card, .showcase__analytics-side { padding: 0.95rem; border-radius: 1rem; background: rgba(255,255,255,0.042); border: 1px solid rgba(255,255,255,0.08); }
.showcase__analytics-label { display: block; margin-bottom: 0.22rem; font-size: 0.68rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-muted); }
.showcase__analytics-card strong { display: block; font-size: 0.92rem; font-weight: 600; color: var(--text); }
.showcase__bars { display: grid; grid-template-columns: repeat(5,1fr); gap: 0.3rem; align-items: end; height: 2.75rem; margin-top: 0.75rem; }
.showcase__bars span {
  display: block; border-radius: 999px 999px 0.35rem 0.35rem;
  background: linear-gradient(180deg, rgba(33,103,177,0.92), rgba(241,101,50,0.72));
  animation: bar-wave 4.8s ease-in-out infinite;
}
.showcase__bars span:nth-child(1) { height: 48%; animation-delay: var(--showcase-motion-delay); }
.showcase__bars span:nth-child(2) { height: 74%; animation-delay: calc(var(--showcase-motion-delay) + 0.15s); }
.showcase__bars span:nth-child(3) { height: 92%; animation-delay: calc(var(--showcase-motion-delay) + 0.3s); }
.showcase__bars span:nth-child(4) { height: 66%; animation-delay: calc(var(--showcase-motion-delay) + 0.45s); }
.showcase__bars span:nth-child(5) { height: 84%; animation-delay: calc(var(--showcase-motion-delay) + 0.6s); }
@keyframes bar-wave { 0%,100% { transform: scaleY(0.92); filter: brightness(0.92); } 50% { transform: scaleY(1.04); filter: brightness(1.08); } }
.showcase__analytics-kpi { display: block; font-size: 1.05rem; font-weight: 700; color: var(--text); }
.showcase__analytics-copy { display: block; margin-top: 0.18rem; font-size: 0.72rem; line-height: 1.45; color: var(--text-muted); }
.showcase__analytics-side .showcase__analytics-copy { font-size: 0.66rem; line-height: 1.4; }
.showcase__uptime-bar {
  display: block;
  margin-top: 0.55rem;
  height: 5px;
  border-radius: 3px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
}
.showcase__uptime-bar-fill {
  display: block;
  height: 100%;
  width: 0%;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--logo-blue-mid), var(--logo-orange));
  transition: none;
}
.showcase__cards { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; margin-top: 1rem; }
.showcase__card { padding: 1rem 0.95rem; border-radius: 1rem; background: linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.02)); border: 1px solid rgba(255,255,255,0.08); }
.showcase__card-kicker { display: block; margin-bottom: 0.25rem; font-size: 0.68rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--logo-orange); }
.showcase__card strong { display: block; font-size: 0.9rem; line-height: 1.35; font-weight: 600; color: var(--text); }
.showcase__cursor {
  position: absolute; z-index: 2; width: 1.2rem; height: 1.2rem; right: 2.6rem; bottom: 5.8rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,0.95), rgba(255,255,255,0.1) 68%, transparent 72%);
  filter: blur(0.2px);
  animation: cursor-float 5.5s ease-in-out var(--showcase-motion-delay) infinite alternate;
}
.showcase__cursor::before { content: ""; position: absolute; inset: 0.2rem; border-radius: inherit; background: linear-gradient(135deg, var(--logo-orange), var(--logo-blue-mid)); }
.showcase__glowline {
  position: absolute; left: 1.2rem; right: 1.2rem; bottom: 0.95rem; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(33,103,177,0.65), rgba(241,101,50,0.55), transparent);
  opacity: 0.75;
}
@keyframes cursor-float { 0% { transform: translate3d(0,0,0); } 100% { transform: translate3d(12px,-8px,0); } }

/* ──────────────────────────────────────────────────────
   Hero-visual varianten (subpagina's)
   Elke pagina krijgt een modifier op .showcase en
   unieke innerlijke content in .showcase__canvas.
   ────────────────────────────────────────────────────── */

@keyframes hv-pulse {
  0%, 100% { transform: scale(1); opacity: 0.8; }
  50% { transform: scale(1.05); opacity: 1; }
}
@keyframes hv-shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
@keyframes hv-blink {
  0%, 90%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* ── Webdesign ── */
.showcase--design .showcase__orbit--a { border-color: rgba(150, 100, 255, 0.15); }
.showcase--design .showcase__orbit--b { border-color: rgba(200, 150, 255, 0.12); }

.hv-typo { margin-top: 1rem; }
.hv-typo__line {
  height: 0.7rem; border-radius: 999px; margin-bottom: 0.55rem;
  background: linear-gradient(90deg, rgba(255,255,255,0.8), rgba(200,180,255,0.4));
}
.hv-typo__line:first-child {
  height: 1.4rem; width: 85%;
  background: linear-gradient(90deg, #fff 0%, rgba(150,120,255,0.7) 60%, rgba(241,101,50,0.5) 100%);
  background-size: 200% 100%;
  animation: hv-shimmer 6s ease-in-out var(--showcase-motion-delay) infinite;
}
.hv-typo__line:nth-child(2) { width: 72%; opacity: 0.6; }
.hv-typo__line:nth-child(3) { width: 55%; opacity: 0.4; }

.hv-palette {
  display: flex; gap: 0.65rem; margin-top: 1.1rem; padding: 0.85rem 1rem;
  border-radius: 1rem; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
}
.hv-palette__dot {
  width: 2rem; height: 2rem; border-radius: 50%;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  animation: hv-pulse 4s ease-in-out infinite;
}
.hv-palette__dot:nth-child(1) { background: #2167b1; animation-delay: calc(var(--showcase-motion-delay) + 0s); }
.hv-palette__dot:nth-child(2) { background: #4a9aed; animation-delay: calc(var(--showcase-motion-delay) + 0.3s); }
.hv-palette__dot:nth-child(3) { background: #f47d4f; animation-delay: calc(var(--showcase-motion-delay) + 0.6s); }
.hv-palette__dot:nth-child(4) { background: #9d91b8; animation-delay: calc(var(--showcase-motion-delay) + 0.9s); }
.hv-palette__dot:nth-child(5) { background: #f4f2f8; animation-delay: calc(var(--showcase-motion-delay) + 1.2s); }

.hv-wireframe {
  display: grid; grid-template-columns: 1.2fr 0.8fr; grid-template-rows: 5rem 3.5rem; gap: 0.55rem;
  margin-top: 0.9rem;
}
.hv-wireframe__block {
  border-radius: 0.75rem; border: 1px dashed rgba(255,255,255,0.12);
  background: rgba(150,120,255,0.06);
}
.hv-wireframe__block:first-child {
  grid-row: 1 / -1; border-style: solid; background: rgba(150,120,255,0.1);
}

.hv-devices {
  display: flex; align-items: flex-end; justify-content: center; gap: 1rem; margin-top: 1rem;
}
.hv-device {
  border-radius: 0.5rem; border: 1.5px solid rgba(255,255,255,0.15);
  background: rgba(150,120,255,0.05);
}
.hv-device--desktop { width: 7rem; height: 4.5rem; }
.hv-device--phone { width: 2.2rem; height: 4rem; border-radius: 0.6rem; }

/* ── HTML webdesign hero graphic (statische site / broncode) ── */
.showcase--html .hv-typo,
.showcase--html .hv-palette,
.showcase--html .hv-wireframe,
.showcase--html .hv-devices {
  display: none;
}
.showcase--html .showcase__orbit--a { border-color: rgba(33, 103, 177, 0.22); }
.showcase--html .showcase__orbit--b { border-color: rgba(241, 101, 50, 0.14); }
.showcase--html .showcase__badge {
  background: linear-gradient(135deg, rgba(33, 103, 177, 0.35), rgba(241, 101, 50, 0.22));
  border: 1px solid rgba(255, 255, 255, 0.12);
}
.showcase-html {
  margin-top: 0.85rem;
  border-radius: 0.85rem;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(180deg, rgba(12, 14, 22, 0.95), rgba(22, 18, 34, 0.88));
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
}
.showcase-html__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.45rem 0.65rem;
  background: rgba(0, 0, 0, 0.35);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.showcase-html__file {
  font-family: ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, monospace;
  letter-spacing: 0.02em;
  text-transform: none;
  color: rgba(255, 255, 255, 0.82);
}
.showcase-html__pill {
  padding: 0.2rem 0.45rem;
  border-radius: 999px;
  font-size: 0.55rem;
  background: rgba(33, 103, 177, 0.25);
  border: 1px solid rgba(33, 103, 177, 0.35);
  color: rgba(255, 255, 255, 0.88);
}
.showcase-html__body {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0;
  min-height: 7.5rem;
}
.showcase-html__gutter {
  padding: 0.55rem 0.35rem 0.55rem 0.5rem;
  text-align: right;
  font-family: ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, monospace;
  font-size: 0.58rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.28);
  background: rgba(0, 0, 0, 0.2);
  border-right: 1px solid rgba(255, 255, 255, 0.06);
  user-select: none;
}
.showcase-html__code {
  padding: 0.5rem 0.6rem 0.65rem;
  font-family: ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, monospace;
  font-size: 0.58rem;
  line-height: 1.5;
  color: rgba(220, 225, 235, 0.92);
}
.showcase-html__code p {
  margin: 0 0 0.35rem;
}
.showcase-html__code p:last-child { margin-bottom: 0; }
.showcase-html__kw { color: rgba(241, 101, 50, 0.95); }
.showcase-html__tag { color: rgba(129, 180, 255, 0.95); }
.showcase-html__txt { color: rgba(255, 255, 255, 0.88); }
.showcase-html__cmt { color: rgba(255, 255, 255, 0.38); font-style: italic; }
.showcase-html__mini {
  margin-top: 0.45rem !important;
  padding-top: 0.4rem;
  border-top: 1px dashed rgba(255, 255, 255, 0.1);
  font-size: 0.52rem;
  color: rgba(255, 255, 255, 0.55);
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.showcase-html__bolt {
  width: 0.35rem;
  height: 0.55rem;
  border-radius: 1px;
  background: linear-gradient(180deg, var(--logo-orange), var(--logo-blue-mid));
  animation: showcase-html-pulse 2.2s ease-in-out infinite;
}
@keyframes showcase-html-pulse {
  0%, 100% { opacity: 1; transform: scaleY(1); }
  50% { opacity: 0.65; transform: scaleY(1.15); }
}

/* ── Hosting / infra ── */
.showcase--infra .showcase__orbit--a { border-color: rgba(50, 200, 120, 0.12); }
.showcase--infra .showcase__orbit--b { border-color: rgba(50, 180, 100, 0.1); }

.hv-servers { margin-top: 1rem; display: flex; flex-direction: column; gap: 0.55rem; }
.hv-server {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.75rem 0.9rem; border-radius: 0.8rem;
  background: rgba(50,200,120,0.06); border: 1px solid rgba(50,200,120,0.12);
}
.hv-server__led {
  width: 0.5rem; height: 0.5rem; border-radius: 50%; flex-shrink: 0;
  background: #4ade80; box-shadow: 0 0 8px rgba(74,222,128,0.5);
  animation: hv-blink 3s ease-in-out var(--showcase-motion-delay) infinite;
}
.hv-server:nth-child(2) .hv-server__led { animation-delay: calc(var(--showcase-motion-delay) + 0.7s); }
.hv-server:nth-child(3) .hv-server__led { animation-delay: calc(var(--showcase-motion-delay) + 1.4s); }
.hv-server__bar { flex: 1; height: 0.4rem; border-radius: 999px; background: rgba(255,255,255,0.08); overflow: hidden; }
.hv-server__bar-fill {
  display: block; height: 100%; border-radius: inherit;
  background: linear-gradient(90deg, rgba(50,200,120,0.7), rgba(33,103,177,0.7));
  transform-origin: left center;
}
.hv-server:nth-child(1) .hv-server__bar-fill { width: 78%; animation: hv-bar-grow 1.8s cubic-bezier(0.25,0.8,0.25,1) var(--showcase-motion-delay) both; }
.hv-server:nth-child(2) .hv-server__bar-fill { width: 45%; animation: hv-bar-grow 1.8s cubic-bezier(0.25,0.8,0.25,1) calc(var(--showcase-motion-delay) + 0.25s) both; }
.hv-server:nth-child(3) .hv-server__bar-fill { width: 62%; animation: hv-bar-grow 1.8s cubic-bezier(0.25,0.8,0.25,1) calc(var(--showcase-motion-delay) + 0.5s) both; }
@keyframes hv-bar-grow { from { transform: scaleX(0); } to { transform: scaleX(1); } }
.hv-server__label { font-size: 0.65rem; font-weight: 600; color: var(--text-muted); white-space: nowrap; }

.hv-uptime {
  display: flex; align-items: center; gap: 1.2rem; margin-top: 1rem;
  padding: 1rem; border-radius: 1rem;
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
}
.hv-uptime__ring { position: relative; width: 4.5rem; height: 4.5rem; flex-shrink: 0; }
.hv-uptime__ring-svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.hv-uptime__ring-bg { fill: none; stroke: rgba(255,255,255,0.08); stroke-width: 4; }
.hv-uptime__ring-fill {
  fill: none; stroke: url(#hv-grad-uptime); stroke-width: 4;
  stroke-dasharray: 125.66; stroke-dashoffset: 0.13;
  stroke-linecap: round;
}
.hv-uptime__value {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: 0.82rem; font-weight: 700; color: var(--text);
}
.hv-uptime__detail { flex: 1; }
.hv-uptime__label {
  display: block; font-size: 0.68rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--text-muted); margin-bottom: 0.25rem;
}
.hv-uptime__desc { font-size: 0.78rem; color: var(--text); font-weight: 600; }

.hv-network { display: grid; grid-template-columns: 1fr 1fr; gap: 0.55rem; margin-top: 0.8rem; }
.hv-network__node {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.7rem; border-radius: 0.75rem;
  background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.07);
}
.hv-network__dot { width: 0.6rem; height: 0.6rem; border-radius: 50%; flex-shrink: 0; background: var(--logo-blue-mid); }
.hv-network__text { font-size: 0.68rem; font-weight: 600; color: var(--text-muted); }

/* ── Software / code ── */
.showcase--code .showcase__orbit--a { border-color: rgba(56, 189, 248, 0.12); }
.showcase--code .showcase__orbit--b { border-color: rgba(34, 211, 238, 0.1); }

.hv-editor {
  margin-top: 0.9rem; border-radius: 0.8rem; overflow: hidden;
  background: rgba(0,0,0,0.3); border: 1px solid rgba(255,255,255,0.07);
}
.hv-editor__lines {
  padding: 0.8rem 0.9rem;
  font-family: "SF Mono", "Fira Code", "Consolas", monospace;
  font-size: 0.62rem; line-height: 1.7;
}
.hv-editor__line { display: flex; gap: 0.7rem; white-space: nowrap; }
.hv-editor__ln { color: rgba(255,255,255,0.18); min-width: 1.2rem; text-align: right; user-select: none; }
.hv-editor__code { color: rgba(255,255,255,0.55); }
.hv-c-kw  { color: rgba(198,120,221,0.9); }
.hv-c-fn  { color: rgba(97,175,239,0.9); }
.hv-c-str { color: rgba(152,195,121,0.85); }
.hv-c-op  { color: rgba(86,182,194,0.8); }
.hv-c-num { color: rgba(209,154,102,0.9); }

.hv-terminal {
  margin-top: 0.65rem; padding: 0.7rem 0.9rem; border-radius: 0.8rem;
  background: rgba(0,0,0,0.4); border: 1px solid rgba(255,255,255,0.06);
  font-family: "SF Mono", "Fira Code", monospace; font-size: 0.62rem;
}
.hv-terminal__prompt { color: rgba(74,222,128,0.8); }
.hv-terminal__cmd { color: rgba(255,255,255,0.6); }
.hv-terminal__cursor {
  display: inline-block; width: 0.45rem; height: 0.85em; margin-left: 0.15rem;
  background: rgba(255,255,255,0.6); vertical-align: middle;
  animation: hv-blink 1.2s step-end infinite;
}

.hv-modules { display: grid; grid-template-columns: 1fr 1fr; gap: 0.55rem; margin-top: 0.7rem; }
.hv-module {
  padding: 0.75rem; border-radius: 0.8rem;
  background: rgba(56,189,248,0.05); border: 1px solid rgba(56,189,248,0.1);
}
.hv-module__icon {
  display: inline-block; width: 1.4rem; height: 1.4rem; border-radius: 0.4rem;
  background: linear-gradient(135deg, rgba(56,189,248,0.3), rgba(34,211,238,0.2));
  margin-bottom: 0.35rem;
}
.hv-module__name { display: block; font-size: 0.68rem; font-weight: 600; color: var(--text); }
.hv-module__desc { display: block; font-size: 0.6rem; color: var(--text-muted); margin-top: 0.1rem; }

/* ── Onderhoud / maintain ── */
.showcase--maintain .showcase__orbit--a { border-color: rgba(251, 191, 36, 0.12); }
.showcase--maintain .showcase__orbit--b { border-color: rgba(245, 158, 11, 0.1); }

.hv-shield {
  display: flex; align-items: center; justify-content: center;
  margin: 1rem auto 0; width: 4.5rem; height: 5.2rem;
}
.hv-shield__icon {
  width: 100%; height: 100%;
  background: linear-gradient(180deg, rgba(74,222,128,0.25), rgba(74,222,128,0.05));
  border: 1.5px solid rgba(74,222,128,0.3);
  border-radius: 50% 50% 50% 50% / 40% 40% 60% 60%;
  display: flex; align-items: center; justify-content: center;
  animation: hv-pulse 5s ease-in-out var(--showcase-motion-delay) infinite;
}
.hv-shield__check { font-size: 1.6rem; color: #4ade80; }

.hv-checklist { margin-top: 1rem; display: flex; flex-direction: column; gap: 0.45rem; }
.hv-check {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.6rem 0.8rem; border-radius: 0.7rem;
  background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.07);
}
.hv-check__box {
  width: 1.1rem; height: 1.1rem; border-radius: 0.3rem; flex-shrink: 0;
  background: rgba(74,222,128,0.15); border: 1px solid rgba(74,222,128,0.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.6rem; color: #4ade80;
}
.hv-check__text { font-size: 0.72rem; color: var(--text-muted); }

.hv-versions { display: flex; gap: 0.55rem; margin-top: 0.9rem; flex-wrap: wrap; }
.hv-version {
  padding: 0.4rem 0.7rem; border-radius: 999px;
  background: rgba(251,191,36,0.08); border: 1px solid rgba(251,191,36,0.15);
  font-size: 0.62rem; font-weight: 600; color: rgba(251,191,36,0.8);
}

.hv-scan {
  margin-top: 0.8rem; padding: 0.85rem; border-radius: 0.8rem;
  background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.07);
  text-align: center;
}
.hv-scan__label { font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); }
.hv-scan__time { display: block; margin-top: 0.2rem; font-size: 0.88rem; font-weight: 700; color: var(--text); }

/* ── Archivering / archive ── */
.showcase--archive .showcase__orbit--a { border-color: rgba(241, 101, 50, 0.12); }
.showcase--archive .showcase__orbit--b { border-color: rgba(241, 101, 50, 0.08); }

.hv-docs { position: relative; margin-top: 1.1rem; height: 6.5rem; }
.hv-doc {
  position: absolute; width: 80%; height: 5rem; border-radius: 0.8rem;
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
  padding: 0.7rem;
}
.hv-doc::before {
  content: ""; display: block; height: 0.5rem; width: 60%; border-radius: 999px;
  background: rgba(255,255,255,0.15); margin-bottom: 0.4rem;
}
.hv-doc::after {
  content: ""; display: block; height: 0.4rem; width: 40%; border-radius: 999px;
  background: rgba(255,255,255,0.08);
}
.hv-doc:nth-child(1) { left: 0; top: 0; z-index: 3; background: rgba(241,101,50,0.07); border-color: rgba(241,101,50,0.15); }
.hv-doc:nth-child(2) { left: 8%; top: 0.7rem; z-index: 2; }
.hv-doc:nth-child(3) { left: 16%; top: 1.4rem; z-index: 1; opacity: 0.6; }

.hv-timeline {
  display: flex; align-items: flex-start; margin-top: 1rem;
  padding: 0.8rem 0.6rem; border-radius: 0.8rem;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.07);
}
.hv-timeline__item { flex: 1; display: flex; flex-direction: column; align-items: center; position: relative; }
.hv-timeline__item::before {
  content: ""; position: absolute; top: 0.25rem; left: 50%; width: 100%;
  height: 2px; background: rgba(255,255,255,0.1);
}
.hv-timeline__item:last-child::before { display: none; }
.hv-timeline__dot {
  width: 0.6rem; height: 0.6rem; border-radius: 50%; position: relative; z-index: 1;
  background: var(--logo-orange); box-shadow: 0 0 8px rgba(241,101,50,0.3);
}
.hv-timeline__item:first-child .hv-timeline__dot { background: rgba(255,255,255,0.2); box-shadow: none; }
.hv-timeline__year { margin-top: 0.35rem; font-size: 0.58rem; font-weight: 600; color: var(--text-muted); }

.hv-warc {
  display: inline-flex; align-items: center; gap: 0.4rem;
  margin-top: 0.8rem; padding: 0.45rem 0.75rem; border-radius: 999px;
  background: rgba(241,101,50,0.1); border: 1px solid rgba(241,101,50,0.2);
  font-size: 0.65rem; font-weight: 700; color: var(--logo-orange); letter-spacing: 0.08em;
}

.hv-storage {
  margin-top: 0.7rem; padding: 0.75rem; border-radius: 0.8rem;
  background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.07);
}
.hv-storage__label { display: block; font-size: 0.62rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); margin-bottom: 0.35rem; }
.hv-storage__bar { height: 0.4rem; border-radius: 999px; background: rgba(255,255,255,0.08); overflow: hidden; }
.hv-storage__bar-fill {
  display: block; height: 100%; width: 67%; border-radius: inherit;
  background: linear-gradient(90deg, var(--logo-orange), var(--logo-blue-mid));
  transform-origin: left center;
  animation: hv-bar-grow 2s cubic-bezier(0.25,0.8,0.25,1) var(--showcase-motion-delay) both;
}

/* ── Advisering / strategy ── */
.showcase--strategy .showcase__orbit--a { border-color: rgba(33, 103, 177, 0.18); }
.showcase--strategy .showcase__orbit--b { border-color: rgba(33, 103, 177, 0.12); animation-duration: 28s; }

.hv-roadmap { margin-top: 1rem; position: relative; padding-left: 1.4rem; }
.hv-roadmap::before {
  content: ""; position: absolute; left: 0.38rem; top: 0.4rem; bottom: 0.4rem; width: 2px;
  background: linear-gradient(180deg, var(--logo-blue-mid), rgba(241,101,50,0.5));
  border-radius: 999px;
}
.hv-milestone { position: relative; padding: 0.55rem 0.7rem 0.55rem 0; }
.hv-milestone::before {
  content: ""; position: absolute; left: calc(-1.22rem - 0.5px); top: 0.75rem;
  width: 0.6rem; height: 0.6rem; border-radius: 50%;
  background: var(--logo-blue-mid); box-shadow: 0 0 8px rgba(33,103,177,0.4);
}
.hv-milestone:last-child::before { background: var(--logo-orange); box-shadow: 0 0 8px rgba(241,101,50,0.4); }
.hv-milestone__title { font-size: 0.76rem; font-weight: 600; color: var(--text); }
.hv-milestone__desc { font-size: 0.62rem; color: var(--text-muted); margin-top: 0.1rem; }

.hv-priorities { display: flex; gap: 0.45rem; margin-top: 0.9rem; }
.hv-priority {
  flex: 1; padding: 0.55rem; border-radius: 0.65rem; text-align: center;
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
}
.hv-priority--high { background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.2); color: rgba(252,165,165,0.9); }
.hv-priority--mid  { background: rgba(251,191,36,0.08); border: 1px solid rgba(251,191,36,0.15); color: rgba(253,224,71,0.8); }
.hv-priority--low  { background: rgba(74,222,128,0.08); border: 1px solid rgba(74,222,128,0.15); color: rgba(134,239,172,0.8); }

.hv-kpis { display: grid; grid-template-columns: 1fr 1fr; gap: 0.55rem; margin-top: 0.7rem; }
.hv-kpi {
  padding: 0.75rem; border-radius: 0.8rem;
  background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.07);
}
.hv-kpi__value { display: block; font-size: 1rem; font-weight: 700; color: var(--text); }
.hv-kpi__label { display: block; font-size: 0.62rem; color: var(--text-muted); margin-top: 0.1rem; }

/* ── Portfolio / gallery ── */
.showcase--gallery .showcase__orbit--a { border-color: rgba(241, 101, 50, 0.1); animation-duration: 26s; }
.showcase--gallery .showcase__orbit--b { border-color: rgba(150, 100, 255, 0.1); }

.hv-filters { display: flex; gap: 0.4rem; margin-top: 0.9rem; flex-wrap: wrap; }
.hv-filter {
  padding: 0.3rem 0.6rem; border-radius: 999px;
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08);
  font-size: 0.6rem; font-weight: 600; color: var(--text-muted);
}
.hv-filter--active { background: rgba(33,103,177,0.15); border-color: rgba(33,103,177,0.25); color: var(--link); }

.hv-mosaic { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0.45rem; margin-top: 0.75rem; }
.hv-tile {
  border-radius: 0.6rem; min-height: 3.2rem;
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(135deg, rgba(33,103,177,0.12), rgba(255,255,255,0.04));
  position: relative; overflow: hidden;
}
.hv-tile::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.3));
}
.hv-tile:nth-child(1) { grid-row: span 2; min-height: 6.8rem; background: linear-gradient(135deg, rgba(33,103,177,0.18), rgba(150,100,255,0.08)); }
.hv-tile:nth-child(2) { background: linear-gradient(135deg, rgba(241,101,50,0.15), rgba(255,255,255,0.04)); }
.hv-tile:nth-child(3) { background: linear-gradient(135deg, rgba(74,222,128,0.1), rgba(255,255,255,0.04)); }
.hv-tile:nth-child(4) { background: linear-gradient(135deg, rgba(150,100,255,0.12), rgba(255,255,255,0.04)); }
.hv-tile:nth-child(5) { grid-column: span 2; background: linear-gradient(135deg, rgba(56,189,248,0.1), rgba(33,103,177,0.08)); }
.hv-tile:nth-child(6) { grid-column: span 3; min-height: 2.8rem; background: linear-gradient(90deg, rgba(241,101,50,0.1), rgba(33,103,177,0.1)); }

.hv-gallery-count {
  margin-top: 0.7rem; padding: 0.65rem; border-radius: 0.7rem;
  background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.07);
  text-align: center;
}
.hv-gallery-count__num { font-size: 1.1rem; font-weight: 700; color: var(--text); }
.hv-gallery-count__label { font-size: 0.62rem; color: var(--text-muted); margin-left: 0.3rem; }

/* ── Contact / connect ── */
.showcase--connect .showcase__orbit--a { border-color: rgba(251, 113, 133, 0.12); }
.showcase--connect .showcase__orbit--b { border-color: rgba(244, 114, 182, 0.1); }

.hv-status {
  display: flex; align-items: center; gap: 0.4rem; margin-top: 0.8rem;
  padding: 0.4rem 0.7rem; border-radius: 999px; width: fit-content;
  background: rgba(74,222,128,0.08); border: 1px solid rgba(74,222,128,0.15);
}
.hv-status__dot {
  width: 0.45rem; height: 0.45rem; border-radius: 50%; background: #4ade80;
  animation: hv-blink 2.5s ease-in-out infinite;
}
.hv-status__text { font-size: 0.65rem; font-weight: 600; color: rgba(74,222,128,0.8); }

.hv-chat { margin-top: 0.8rem; display: flex; flex-direction: column; gap: 0.55rem; }
.hv-bubble {
  max-width: 78%; padding: 0.65rem 0.85rem; border-radius: 1rem;
  font-size: 0.72rem; line-height: 1.45;
}
.hv-bubble--in {
  align-self: flex-start; color: var(--text);
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  border-bottom-left-radius: 0.3rem;
}
.hv-bubble--out {
  align-self: flex-end; color: #fff;
  background: linear-gradient(135deg, rgba(33,103,177,0.35), rgba(33,103,177,0.2));
  border: 1px solid rgba(33,103,177,0.25);
  border-bottom-right-radius: 0.3rem;
}

.hv-response {
  margin-top: 0.7rem; padding: 0.8rem; border-radius: 0.8rem;
  background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.07);
  text-align: center;
}
.hv-response__value { display: block; font-size: 0.95rem; font-weight: 700; color: var(--text); }
.hv-response__label { display: block; font-size: 0.62rem; color: var(--text-muted); margin-top: 0.1rem; }

.hv-contact-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 0.55rem; margin-top: 0.65rem; }
.hv-contact-card {
  padding: 0.7rem; border-radius: 0.75rem;
  background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.07);
}
.hv-contact-card__icon {
  display: block; font-size: 0.62rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--logo-orange); margin-bottom: 0.2rem;
}
.hv-contact-card__text { font-size: 0.72rem; font-weight: 600; color: var(--text); }
.hv-contact-card--wide { grid-column: 1 / -1; }

/* Light-thema aanpassingen voor hero-visuele varianten */

/* Gedeeld: glasachtige kaarten en randen donkerder in licht thema */
html[data-theme="light"] .hv-palette,
html[data-theme="light"] .hv-uptime,
html[data-theme="light"] .hv-network__node,
html[data-theme="light"] .hv-check,
html[data-theme="light"] .hv-scan,
html[data-theme="light"] .hv-storage,
html[data-theme="light"] .hv-kpi,
html[data-theme="light"] .hv-response,
html[data-theme="light"] .hv-contact-card,
html[data-theme="light"] .hv-gallery-count,
html[data-theme="light"] .hv-module,
html[data-theme="light"] .showcase__canvas .hv-timeline {
  background: rgba(22,18,33,0.04); border-color: rgba(22,18,33,0.1);
}

/* ── Webdesign (design) ── */
html[data-theme="light"] .showcase--design .showcase__orbit--a { border-color: rgba(100,60,200,0.15); }
html[data-theme="light"] .showcase--design .showcase__orbit--b { border-color: rgba(140,100,220,0.12); }
html[data-theme="light"] .hv-typo__line {
  background: linear-gradient(90deg, rgba(22,18,33,0.6), rgba(100,60,200,0.25));
}
html[data-theme="light"] .hv-typo__line:first-child {
  background: linear-gradient(90deg, var(--text) 0%, var(--logo-blue-mid) 60%, var(--logo-orange) 100%);
  background-size: 200% 100%;
}
html[data-theme="light"] .hv-palette__dot { box-shadow: 0 4px 12px rgba(0,0,0,0.12); }
html[data-theme="light"] .hv-wireframe__block {
  border-color: rgba(100,60,200,0.2); background: rgba(100,60,200,0.06);
}
html[data-theme="light"] .hv-wireframe__block:first-child { background: rgba(100,60,200,0.1); }
html[data-theme="light"] .hv-device { border-color: rgba(22,18,33,0.15); background: rgba(100,60,200,0.04); }
html[data-theme="light"] .showcase--html .showcase__orbit--a { border-color: rgba(33, 103, 177, 0.2); }
html[data-theme="light"] .showcase--html .showcase__orbit--b { border-color: rgba(241, 101, 50, 0.15); }
html[data-theme="light"] .showcase-html {
  border-color: rgba(22, 18, 33, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(236, 232, 248, 0.92));
  box-shadow: 0 12px 32px rgba(33, 103, 177, 0.1);
}
html[data-theme="light"] .showcase-html__bar {
  background: rgba(22, 18, 33, 0.04);
  border-bottom-color: rgba(22, 18, 33, 0.08);
}
html[data-theme="light"] .showcase-html__file { color: rgba(22, 18, 33, 0.85); }
html[data-theme="light"] .showcase-html__gutter {
  color: rgba(22, 18, 33, 0.28);
  background: rgba(22, 18, 33, 0.03);
  border-right-color: rgba(22, 18, 33, 0.08);
}
html[data-theme="light"] .showcase-html__code { color: rgba(22, 18, 33, 0.88); }
html[data-theme="light"] .showcase-html__txt { color: rgba(22, 18, 33, 0.9); }
html[data-theme="light"] .showcase-html__cmt { color: rgba(22, 18, 33, 0.4); }
html[data-theme="light"] .showcase-html__mini {
  border-top-color: rgba(22, 18, 33, 0.1);
  color: rgba(22, 18, 33, 0.55);
}

/* ── Hosting (infra) ── */
html[data-theme="light"] .showcase--infra .showcase__orbit--a { border-color: rgba(22,163,74,0.15); }
html[data-theme="light"] .showcase--infra .showcase__orbit--b { border-color: rgba(22,163,74,0.1); }
html[data-theme="light"] .hv-server {
  background: rgba(22,163,74,0.06); border-color: rgba(22,163,74,0.15);
}
html[data-theme="light"] .hv-server__led {
  background: #16a34a; box-shadow: 0 0 6px rgba(22,163,74,0.4);
}
html[data-theme="light"] .hv-server__bar { background: rgba(22,18,33,0.06); }
html[data-theme="light"] .hv-server__bar-fill {
  background: linear-gradient(90deg, rgba(22,163,74,0.7), rgba(33,103,177,0.6));
}
html[data-theme="light"] .hv-uptime__ring-bg { stroke: rgba(22,18,33,0.08); }
html[data-theme="light"] .hv-network__dot { background: var(--logo-blue-mid); }

/* ── Software (code) ── */
html[data-theme="light"] .showcase--code .showcase__orbit--a { border-color: rgba(14,116,144,0.15); }
html[data-theme="light"] .showcase--code .showcase__orbit--b { border-color: rgba(6,182,212,0.1); }
html[data-theme="light"] .hv-editor {
  background: rgba(22,18,33,0.05); border-color: rgba(22,18,33,0.1);
}
html[data-theme="light"] .hv-editor__ln { color: rgba(22,18,33,0.25); }
html[data-theme="light"] .hv-editor__code { color: rgba(22,18,33,0.6); }
html[data-theme="light"] .hv-c-kw  { color: rgba(147,51,234,0.85); }
html[data-theme="light"] .hv-c-fn  { color: rgba(37,99,235,0.85); }
html[data-theme="light"] .hv-c-str { color: rgba(22,163,74,0.8); }
html[data-theme="light"] .hv-c-op  { color: rgba(14,116,144,0.8); }
html[data-theme="light"] .hv-c-num { color: rgba(194,65,12,0.85); }
html[data-theme="light"] .hv-terminal {
  background: rgba(22,18,33,0.06); border-color: rgba(22,18,33,0.08);
}
html[data-theme="light"] .hv-terminal__prompt { color: rgba(22,163,74,0.7); }
html[data-theme="light"] .hv-terminal__cmd { color: rgba(22,18,33,0.55); }
html[data-theme="light"] .hv-terminal__cursor { background: rgba(22,18,33,0.5); }
html[data-theme="light"] .hv-module {
  background: rgba(14,116,144,0.05); border-color: rgba(14,116,144,0.12);
}
html[data-theme="light"] .hv-module__icon {
  background: linear-gradient(135deg, rgba(14,116,144,0.25), rgba(6,182,212,0.15));
}

/* ── Onderhoud (maintain) ── */
html[data-theme="light"] .showcase--maintain .showcase__orbit--a { border-color: rgba(202,138,4,0.15); }
html[data-theme="light"] .showcase--maintain .showcase__orbit--b { border-color: rgba(217,119,6,0.1); }
html[data-theme="light"] .hv-shield__icon {
  background: linear-gradient(180deg, rgba(22,163,74,0.18), rgba(22,163,74,0.04));
  border-color: rgba(22,163,74,0.25);
}
html[data-theme="light"] .hv-shield__check { color: #16a34a; }
html[data-theme="light"] .hv-check__box {
  background: rgba(22,163,74,0.1); border-color: rgba(22,163,74,0.25);
  color: #16a34a;
}
html[data-theme="light"] .hv-version {
  background: rgba(202,138,4,0.08); border-color: rgba(202,138,4,0.18);
  color: rgba(161,98,7,0.9);
}

/* ── Archivering (archive) ── */
html[data-theme="light"] .showcase--archive .showcase__orbit--a { border-color: rgba(194,65,12,0.12); }
html[data-theme="light"] .showcase--archive .showcase__orbit--b { border-color: rgba(194,65,12,0.08); }
html[data-theme="light"] .hv-doc {
  background: rgba(22,18,33,0.03); border-color: rgba(22,18,33,0.1);
}
html[data-theme="light"] .hv-doc::before { background: rgba(22,18,33,0.12); }
html[data-theme="light"] .hv-doc::after { background: rgba(22,18,33,0.07); }
html[data-theme="light"] .hv-doc:nth-child(1) {
  background: rgba(241,101,50,0.06); border-color: rgba(241,101,50,0.15);
}
html[data-theme="light"] .hv-timeline__item::before { background: rgba(22,18,33,0.1); }
html[data-theme="light"] .hv-timeline__dot { box-shadow: 0 0 6px rgba(241,101,50,0.25); }
html[data-theme="light"] .hv-timeline__item:first-child .hv-timeline__dot { background: rgba(22,18,33,0.15); }
html[data-theme="light"] .hv-warc {
  background: rgba(241,101,50,0.08); border-color: rgba(241,101,50,0.18);
}
html[data-theme="light"] .hv-storage__bar { background: rgba(22,18,33,0.06); }

/* ── Advisering (strategy) ── */
html[data-theme="light"] .showcase--strategy .showcase__orbit--a { border-color: rgba(33,103,177,0.18); }
html[data-theme="light"] .showcase--strategy .showcase__orbit--b { border-color: rgba(33,103,177,0.12); }
html[data-theme="light"] .hv-roadmap::before {
  background: linear-gradient(180deg, var(--logo-blue-mid), rgba(241,101,50,0.45));
}
html[data-theme="light"] .hv-milestone::before { box-shadow: 0 0 6px rgba(33,103,177,0.3); }
html[data-theme="light"] .hv-milestone:last-child::before { box-shadow: 0 0 6px rgba(241,101,50,0.3); }
html[data-theme="light"] .hv-priority--high { background: rgba(220,38,38,0.08); border-color: rgba(220,38,38,0.18); color: rgba(185,28,28,0.85); }
html[data-theme="light"] .hv-priority--mid  { background: rgba(202,138,4,0.07); border-color: rgba(202,138,4,0.16); color: rgba(161,98,7,0.8); }
html[data-theme="light"] .hv-priority--low  { background: rgba(22,163,74,0.07); border-color: rgba(22,163,74,0.16); color: rgba(21,128,61,0.8); }

/* ── Portfolio (gallery) ── */
html[data-theme="light"] .showcase--gallery .showcase__orbit--a { border-color: rgba(194,65,12,0.1); }
html[data-theme="light"] .showcase--gallery .showcase__orbit--b { border-color: rgba(100,60,200,0.1); }
html[data-theme="light"] .hv-filter {
  background: rgba(22,18,33,0.04); border-color: rgba(22,18,33,0.1);
}
html[data-theme="light"] .hv-filter--active {
  background: rgba(33,103,177,0.1); border-color: rgba(33,103,177,0.2);
}
html[data-theme="light"] .hv-tile { border-color: rgba(22,18,33,0.08); }
html[data-theme="light"] .hv-tile:nth-child(1) { background: linear-gradient(135deg, rgba(33,103,177,0.12), rgba(100,60,200,0.06)); }
html[data-theme="light"] .hv-tile:nth-child(2) { background: linear-gradient(135deg, rgba(241,101,50,0.1), rgba(22,18,33,0.02)); }
html[data-theme="light"] .hv-tile:nth-child(3) { background: linear-gradient(135deg, rgba(22,163,74,0.08), rgba(22,18,33,0.02)); }
html[data-theme="light"] .hv-tile:nth-child(4) { background: linear-gradient(135deg, rgba(100,60,200,0.08), rgba(22,18,33,0.02)); }
html[data-theme="light"] .hv-tile:nth-child(5) { background: linear-gradient(135deg, rgba(14,116,144,0.08), rgba(33,103,177,0.05)); }
html[data-theme="light"] .hv-tile:nth-child(6) { background: linear-gradient(90deg, rgba(241,101,50,0.07), rgba(33,103,177,0.07)); }
html[data-theme="light"] .hv-tile::after { background: linear-gradient(180deg, transparent 50%, rgba(255,255,255,0.3)); }

/* ── Contact (connect) ── */
html[data-theme="light"] .showcase--connect .showcase__orbit--a { border-color: rgba(225,29,72,0.1); }
html[data-theme="light"] .showcase--connect .showcase__orbit--b { border-color: rgba(236,72,153,0.08); }
html[data-theme="light"] .hv-status {
  background: rgba(22,163,74,0.06); border-color: rgba(22,163,74,0.15);
}
html[data-theme="light"] .hv-status__dot { background: #16a34a; }
html[data-theme="light"] .hv-status__text { color: rgba(21,128,61,0.8); }
html[data-theme="light"] .hv-bubble--in {
  background: rgba(22,18,33,0.04); border-color: rgba(22,18,33,0.1);
}
html[data-theme="light"] .hv-bubble--out {
  background: linear-gradient(135deg, rgba(33,103,177,0.15), rgba(33,103,177,0.08));
  border-color: rgba(33,103,177,0.18); color: var(--text);
}
html[data-theme="light"] .hv-contact-card__icon { color: var(--logo-orange); }

@media (prefers-reduced-motion: reduce) {
  .hv-palette__dot,
  .hv-server__led,
  .hv-server__bar-fill,
  .hv-shield__icon,
  .hv-terminal__cursor,
  .hv-status__dot,
  .hv-typo__line:first-child { animation: none !important; }
  .hv-server__bar-fill { transform: scaleX(1) !important; }
}

@media (max-width: 900px) {
  .showcase { min-height: auto; padding-top: 1rem; }
  .showcase__window { width: min(100%,24rem); }
  .showcase__analytics, .showcase__cards { grid-template-columns: 1fr; }
}
/* Subpagina’s: heldere kop + leesbare bodytekst */
.page-hero {
  position: relative;
  padding: clamp(2.25rem, 5vw, 3.75rem) 0 clamp(1.75rem, 4vw, 2.75rem);
  overflow: hidden;
}
.page-hero__gridline {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px);
  background-size: 100% 88px;
  background-position: 0 3.5rem;
  mask-image: linear-gradient(180deg, black 0%, transparent 88%);
  -webkit-mask-image: linear-gradient(180deg, black 0%, transparent 88%);
  pointer-events: none;
  z-index: 0;
}
.page-hero .wrap {
  position: relative;
  z-index: 1;
}
.page-hero__title {
  margin: 0 0 0.85rem;
  font-size: clamp(2rem, 4.2vw, 3.1rem);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.035em;
  max-width: 22ch;
}
.page-hero__lead {
  margin: 0;
  font-size: 1.05rem;
  color: var(--text-muted);
  max-width: 40rem;
  line-height: 1.65;
}
.page-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.35rem;
}

.prose {
  max-width: 44rem;
}
.prose > *:first-child {
  margin-top: 0;
}
.prose > *:last-child {
  margin-bottom: 0;
}
.prose h2 {
  margin: 2rem 0 0.65rem;
  font-size: clamp(1.25rem, 2.2vw, 1.45rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.prose h2:first-child {
  margin-top: 0;
}
.prose h3 {
  margin: 1.35rem 0 0.45rem;
  font-size: 1.05rem;
  font-weight: 600;
}
.prose p {
  margin: 0 0 0.9rem;
  color: var(--text-muted);
  font-size: 0.98rem;
  line-height: 1.65;
}
.prose ul,
.prose ol {
  margin: 0 0 1rem;
  padding-left: 1.2rem;
  color: var(--text-muted);
  font-size: 0.98rem;
  line-height: 1.6;
}
.prose li {
  margin-bottom: 0.35rem;
}
.prose a {
  font-weight: 500;
}
.prose hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 2.5rem 0;
}
.prose--wide {
  max-width: min(52rem, 100%);
}
.table-wrap {
  overflow-x: auto;
  margin: 1.25rem 0;
  -webkit-overflow-scrolling: touch;
}
.simple-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
  line-height: 1.45;
}
.simple-table th,
.simple-table td {
  border: 1px solid var(--border);
  padding: 0.65rem 0.75rem;
  text-align: left;
  vertical-align: top;
}
.simple-table thead th {
  background: var(--surface);
  color: var(--text);
  font-weight: 600;
}
.simple-table tbody th[scope="row"] {
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-muted);
  font-weight: 600;
  min-width: 6.5rem;
}
html[data-theme="light"] .simple-table tbody th[scope="row"] {
  background: rgba(22, 18, 33, 0.04);
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.85rem;
  margin: 1.25rem 0 0;
  list-style: none;
  padding: 0;
}
.feature-grid__item {
  margin: 0;
  padding: 1.1rem 1.15rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--surface-glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.feature-grid__item strong {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.92rem;
  color: var(--text);
}
.feature-grid__item span {
  font-size: 0.88rem;
  color: var(--text-muted);
  line-height: 1.5;
}

.price-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.85rem;
  margin: 1.25rem 0 0;
}
.price-card {
  padding: 1.2rem 1.2rem 1.15rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--surface-glass);
}
.price-card__label {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--logo-orange);
}
.price-card__title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  font-weight: 600;
}
.price-card__list {
  margin: 0 0 1rem;
  padding-left: 1rem;
  font-size: 0.88rem;
  color: var(--text-muted);
  line-height: 1.55;
}
.price-card__note {
  margin: 0;
  font-size: 0.82rem;
  color: var(--text-muted);
}
.price-card .btn {
  margin-top: 0.35rem;
}

.related-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1.25rem;
}
.related-strip a {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 0.85rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
  color: var(--text-muted);
  transition: border-color 0.25s var(--ease-out), color 0.25s var(--ease-out), background 0.25s var(--ease-out);
}
.related-strip a:hover {
  border-color: rgba(33, 103, 177, 0.4);
  color: var(--text);
  background: rgba(33, 103, 177, 0.1);
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));
  gap: 0.85rem;
  margin-top: 1.1rem;
}
.portfolio-grid__cell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 7.25rem;
  height: 7.25rem;
  padding: 0.5rem 0.65rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow-glow-sm);
  transition: transform 0.35s var(--ease-out), border-color 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
  box-sizing: border-box;
}
.portfolio-grid__cell:hover {
  transform: translateY(-3px);
  border-color: rgba(33, 103, 177, 0.35);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.2);
}
.portfolio-grid__cell img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
  filter: none;
}
html[data-theme="light"] .portfolio-grid__cell {
  background: #fff;
  border-color: var(--border);
}

.portfolio-cases-intro {
  margin: 0 0 1.75rem;
  max-width: 44rem;
  font-size: 1.02rem;
  line-height: 1.65;
  color: var(--text-muted);
}
.portfolio-cases {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
  gap: 1rem;
  margin-top: 0.25rem;
}
.portfolio-case {
  display: flex;
  flex-direction: column;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--surface-glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  overflow: hidden;
  box-shadow: var(--shadow-glow-sm);
  transition: border-color 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out), transform 0.35s var(--ease-out);
}
.portfolio-case:hover {
  border-color: rgba(33, 103, 177, 0.35);
  box-shadow: var(--shadow-glow-sm), 0 20px 48px rgba(0, 0, 0, 0.28);
  transform: translateY(-3px);
}
.portfolio-case__media {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.25);
}
.portfolio-case__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}
.portfolio-case__body {
  padding: 1.05rem 1.15rem 1.15rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.portfolio-case__domain {
  margin: 0 0 0.45rem;
  font-size: 1.02rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.25;
}
.portfolio-case__domain a {
  color: var(--text);
  text-decoration: none;
}
.portfolio-case__domain a:hover {
  color: var(--link);
}
.portfolio-case__text {
  margin: 0 0 0.85rem;
  flex: 1;
  font-size: 0.9rem;
  line-height: 1.58;
  color: var(--text-muted);
}
.portfolio-case__cta {
  font-size: 0.84rem;
  font-weight: 600;
  align-self: flex-start;
}
.portfolio-quotes {
  margin-top: 0.5rem;
}
.portfolio-quotes .quotes {
  margin-top: 1rem;
}
@media (max-width: 768px) {
  .portfolio-cases {
    grid-template-columns: 1fr;
  }
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  align-items: start;
}
@media (min-width: 768px) {
  .contact-grid {
    grid-template-columns: 1.6fr 1fr;
  }
}
.contact-card {
  text-align: left;
  padding: 1.5rem 1.5rem 1.35rem;
  align-self: start;
}
.contact-card > .h2 {
  margin-top: 0;
}
.contact-card__intro {
  margin: 0 0 0.5rem;
  color: var(--text-muted);
  font-size: 0.95rem;
  line-height: 1.6;
}
.contact-section__follow {
  margin-top: 2rem;
}

/* Contact form */
.contact-form {
  text-align: left;
  padding: 2rem 2rem 1.75rem;
}
.contact-form > .h2 {
  margin-top: 0;
}
.contact-form__intro {
  margin: 0 0 1.5rem;
  color: var(--text-muted);
  font-size: 0.95rem;
  line-height: 1.6;
}
.contact-form__row--half {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 520px) {
  .contact-form__row--half {
    grid-template-columns: 1fr;
  }
}
.contact-form__field {
  margin-bottom: 1rem;
}
.contact-form__field label {
  display: block;
  margin-bottom: 0.35rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--text);
}
.contact-form__field label span {
  color: var(--logo-orange);
}
.contact-form__field input,
.contact-form__field select,
.contact-form__field textarea {
  display: block;
  width: 100%;
  padding: 0.65rem 0.85rem;
  font-family: var(--font);
  font-size: 0.9rem;
  color: var(--text);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  outline: none;
  transition: border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out), background 0.25s var(--ease-out);
}
.contact-form__field input::placeholder,
.contact-form__field textarea::placeholder {
  color: var(--text-muted);
  opacity: 0.5;
}
/* Custom select dropdown */
.cf-select {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.65rem 0.85rem;
  font-family: var(--font);
  font-size: 0.9rem;
  color: var(--text-muted);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer !important;
  outline: none;
  transition: border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out), background 0.25s var(--ease-out);
  user-select: none;
}
.cf-select.has-value {
  color: var(--text);
}
.cf-select:focus,
.cf-select.is-open {
  border-color: var(--logo-blue-mid);
  box-shadow: 0 0 0 3px rgba(33, 103, 177, 0.18);
  background: rgba(255, 255, 255, 0.06);
}
.cf-select.is-invalid {
  border-color: #e74c3c;
  box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.15);
}
.cf-select__display {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cf-select__chevron {
  flex-shrink: 0;
  color: var(--text-muted);
  transition: transform 0.3s var(--ease-out);
}
.cf-select.is-open .cf-select__chevron {
  transform: rotate(180deg);
}
.cf-select__list {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 50;
  margin: 0;
  padding: 0.35rem 0;
  list-style: none;
  background: var(--purple-800);
  border: 1px solid rgba(33, 103, 177, 0.35);
  border-radius: var(--radius-sm);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.45);
  overflow: hidden;
  animation: cf-select-open 0.28s cubic-bezier(0.33, 1.05, 0.64, 1) both;
}
.cf-select.is-open .cf-select__list {
  display: block;
}
@keyframes cf-select-open {
  from {
    opacity: 0;
    transform: translateY(-8px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.cf-select__list li {
  padding: 0.55rem 0.85rem;
  font-size: 0.88rem;
  color: var(--text-muted);
  cursor: pointer !important;
  transition: background 0.15s ease, color 0.15s ease;
}
.cf-select__list li:hover,
.cf-select__list li.is-focused {
  background: rgba(33, 103, 177, 0.18);
  color: var(--text);
}
.cf-select__list li.is-selected {
  color: var(--logo-orange);
  font-weight: 600;
}

/* Light theme */
html[data-theme="light"] .cf-select {
  background: rgba(255, 255, 255, 0.7);
  border-color: rgba(22, 18, 33, 0.12);
}
html[data-theme="light"] .cf-select:focus,
html[data-theme="light"] .cf-select.is-open {
  background: #fff;
  border-color: var(--logo-blue-mid);
}
html[data-theme="light"] .cf-select__list {
  background: #fff;
  border-color: rgba(33, 103, 177, 0.22);
  box-shadow: 0 16px 48px rgba(33, 103, 177, 0.12);
}
html[data-theme="light"] .cf-select__list li:hover,
html[data-theme="light"] .cf-select__list li.is-focused {
  background: rgba(33, 103, 177, 0.08);
}
.contact-form__field input:focus,
.contact-form__field select:focus,
.contact-form__field textarea:focus {
  border-color: var(--logo-blue-mid);
  box-shadow: 0 0 0 3px rgba(33, 103, 177, 0.18);
  background: rgba(255, 255, 255, 0.06);
}
.contact-form__field input.is-invalid,
.contact-form__field select.is-invalid,
.contact-form__field textarea.is-invalid {
  border-color: #e74c3c;
  box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.15);
}
.contact-form__field textarea {
  resize: vertical;
  min-height: 6rem;
}
.contact-form,
.contact-form * {
  cursor: auto !important;
}
.contact-form a {
  cursor: pointer !important;
}
.contact-form__field select,
.contact-form__submit {
  cursor: pointer !important;
}
.contact-form__recaptcha {
  margin-bottom: 1.25rem;
}
.contact-form__footer {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.contact-form__submit {
  flex-shrink: 0;
}
.contact-form__submit:disabled {
  opacity: 0.55;
  pointer-events: none;
}
.contact-form__status {
  margin: 0;
  font-size: 0.85rem;
  line-height: 1.4;
}
.contact-form__status--success {
  color: #27ae60;
}
.contact-form__status--error {
  color: #e74c3c;
}
.grecaptcha-badge {
  visibility: hidden !important;
}
.contact-form__recaptcha-notice {
  margin: 0.75rem 0 0;
  font-size: 0.72rem;
  color: var(--text-muted);
  opacity: 0.6;
}
.contact-form__recaptcha-notice a {
  color: var(--text-muted);
  text-decoration: underline;
}

/* Light theme overrides */
html[data-theme="light"] .contact-form__field input,
html[data-theme="light"] .contact-form__field select,
html[data-theme="light"] .contact-form__field textarea {
  background: rgba(255, 255, 255, 0.7);
  border-color: rgba(22, 18, 33, 0.12);
}
html[data-theme="light"] .contact-form__field input:focus,
html[data-theme="light"] .contact-form__field select:focus,
html[data-theme="light"] .contact-form__field textarea:focus {
  background: #fff;
  border-color: var(--logo-blue-mid);
}
html[data-theme="light"] .contact-form__field select option {
  background: #fff;
  color: var(--purple-900);
}
.contact-card__dl {
  margin: 1rem 0 0;
  display: grid;
  gap: 0.65rem 1rem;
}
.contact-card__dl div {
  display: grid;
  grid-template-columns: 5rem 1fr;
  gap: 0.25rem 0.75rem;
  font-size: 0.92rem;
}
.contact-card__dl dt {
  margin: 0;
  font-weight: 600;
  color: var(--text-muted);
}
.contact-card__dl dd {
  margin: 0;
  color: var(--text);
}

@media (max-width: 520px) {
  .contact-card__dl div {
    grid-template-columns: 1fr;
  }
}

/* Marquee */
.marquee {
  position: relative;
  padding: 0.85rem 0; overflow: hidden;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
  mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
}
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__track { display: flex; width: max-content; animation: marquee-scroll 40s linear infinite; }
.marquee__content {
  display: flex; align-items: center; gap: 0.35rem; white-space: nowrap;
  font-size: 0.82rem; font-weight: 600; letter-spacing: 0.04em; color: var(--text-muted);
  padding-right: 0.35rem;
}
.marquee__content i {
  display: inline-block; width: 0.38rem; height: 0.38rem; margin: 0 0.8rem;
  border-radius: 50%; background: linear-gradient(135deg, var(--logo-orange), var(--logo-blue-mid));
  flex-shrink: 0;
}
@keyframes marquee-scroll { from { transform: translateX(0); } to { transform: translateX(-33.333%); } }

/* Blocks */
.block {
  padding: clamp(3rem,7vw,5rem) 0; position: relative;
  transform: translateY(var(--sp, 0));
}
/* Contact: blok met formulier sluit aan op hero */
.block--contact-connect {
  padding-top: clamp(0.35rem, 1.2vw, 0.85rem);
}
.block--about { background: linear-gradient(180deg, transparent 0%, rgba(255,255,255,0.02) 40%, transparent 100%); }
.block--quotes { background: radial-gradient(ellipse 80% 60% at 50% 100%, rgba(33,103,177,0.08), transparent 65%); }

.block__head { margin-bottom: 2.25rem; }
.block__head--tight { margin-bottom: 1.5rem; }
.block__head-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem 2rem; align-items: end; }
@media (max-width: 720px) { .block__head-row { grid-template-columns: 1fr; } }
.block__intro { margin: 0; color: var(--text-muted); font-size: 1.02rem; max-width: 32rem; }
.block__intro--narrow { max-width: 26rem; }
.eyebrow { margin: 0 0 0.35rem; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--logo-orange); }
.h2 { margin: 0; font-size: clamp(1.65rem,3vw,2.15rem); font-weight: 700; letter-spacing: -0.025em; line-height: 1.15; }
.h2--light { color: #fff; }

/* Split about */
.split { display: grid; grid-template-columns: minmax(180px,260px) 1fr; gap: clamp(1.5rem,4vw,3rem); align-items: start; }
@media (max-width: 768px) {
  .split { grid-template-columns: 1fr; }
  /* Geen parallax-transform: anders breekt position:sticky voor de koppenkolom */
  .block--about {
    transform: none;
    will-change: auto;
  }
  /* Gewone pagina-flow: koppen boven de inhoud, alles scrollt mee (geen fixed/sticky-trucs) */
  .block--about .split__sticky {
    position: static;
  }
}
.split__sticky { position: sticky; top: calc(var(--header-h) + 1rem); align-self: start; }
.lede { margin: 0 0 1.75rem; font-size: 1.08rem; color: var(--text-muted); max-width: 40rem; }
.feature-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.85rem; }
.feature-list__item { display: grid; grid-template-columns: auto 1fr; gap: 1rem 1.25rem; padding: 1.25rem 1.35rem; }
.feature-list__n { font-size: 0.8rem; font-weight: 700; color: var(--logo-orange); font-variant-numeric: tabular-nums; padding-top: 0.15rem; }
.feature-list__title { margin: 0 0 0.35rem; font-size: 1rem; font-weight: 600; }
.feature-list__text { margin: 0; font-size: 0.95rem; color: var(--text-muted); }

/* Cards */
.card {
  position: relative; border-radius: var(--radius); border: 1px solid var(--border);
  background: var(--surface-glass);
  backdrop-filter: blur(14px) saturate(1.1); -webkit-backdrop-filter: blur(14px) saturate(1.1);
  box-shadow: var(--shadow-glow-sm);
  transition: border-color 0.35s var(--ease-out), background 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out), transform 0.35s var(--ease-out);
}
.card::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px;
  background: linear-gradient(145deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.02) 40%, transparent 65%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; opacity: 0.7;
}

/* Glow-on-hover: radial spot follows mouse via JS + shimmer sweep */
.card--glow::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background:
    radial-gradient(400px circle at var(--glow-x, 50%) var(--glow-y, 50%), rgba(33,103,177,0.14), transparent 55%),
    linear-gradient(105deg, transparent 40%, rgba(255,255,255,0.04) 50%, transparent 60%);
  background-size: 100% 100%, 200% 100%;
  background-position: center, -100% 0;
  opacity: 0;
  transition: opacity 0.45s var(--ease-out), background-position 0.6s cubic-bezier(0.4,0,0,1);
}
.card--glow:hover::after {
  opacity: 1;
  background-position: center, 200% 0;
}

.card--accent { background: linear-gradient(145deg, rgba(33,103,177,0.22), rgba(40,26,66,0.5)); border-color: rgba(33,103,177,0.35); }
.card--accent:hover { border-color: rgba(241,101,50,0.4); }

/* Bento */
.bento { display: grid; grid-template-columns: repeat(6,1fr); gap: 0.85rem; }
@media (max-width: 900px) { .bento { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px) { .bento { grid-template-columns: 1fr; } }
.bento__cell {
  grid-column: span 2; display: flex; flex-direction: column;
  padding: 1.35rem 1.35rem 1.25rem; text-decoration: none; color: inherit; min-height: 100%;
  transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out), border-color 0.35s var(--ease-out);
}
.bento__cell:nth-child(1), .bento__cell:nth-child(2) { grid-column: span 3; }
.bento__cell:hover {
  transform: translateY(-5px) scale(1.008);
  box-shadow: var(--shadow-glow-sm), 0 0 0 1px rgba(33,103,177,0.25), 0 28px 64px rgba(0,0,0,0.45);
  border-color: rgba(33,103,177,0.35);
}
.bento__cell--wide { grid-column: span 2; }
@media (max-width: 900px) { .bento__cell:nth-child(1), .bento__cell:nth-child(2), .bento__cell, .bento__cell--wide { grid-column: span 2; } }
@media (max-width: 520px) { .bento__cell:nth-child(1), .bento__cell:nth-child(2), .bento__cell, .bento__cell--wide { grid-column: span 1; } }
.bento__meta { font-size: 0.72rem; font-weight: 700; color: var(--logo-orange); margin-bottom: 0.5rem; }
.bento__title { margin: 0 0 0.45rem; font-size: 1.08rem; font-weight: 600; }
.bento__text { margin: 0 0 0.85rem; flex: 1; font-size: 0.92rem; color: var(--text-muted); }
.bento__link {
  display: inline-flex; align-items: center; gap: 0.25rem;
  font-size: 0.85rem; font-weight: 600; color: var(--link);
  transition: color 0.25s, gap 0.35s var(--ease-out);
}
.bento__cell:hover .bento__link { color: var(--logo-orange); gap: 0.45rem; }

/* Scroll story — sticky viewport, scroll-gestuurde lagen (Apple-achtig) */
.block--scroll-story {
  --story-p: 0;
  --story-hint: 1;
  --story-scroll-cue: 0;
  /* Grenzen v/d kaartwissels = floor(p * 3) in main.js — dots op zelfde % */
  --story-step-0: 0%;
  --story-step-1: 33.333333%;
  --story-step-2: 66.666666%;
  padding: 0;
  height: 400vh;
  transform: none;
  will-change: auto;
  scroll-margin-top: calc(var(--header-h) + 0.5rem);
}
.block--scroll-story .divider { margin-bottom: 0; }
.scroll-story__sticky {
  position: sticky;
  top: 0;
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding: calc(var(--header-h) + 1.25rem) 0 clamp(2rem, 5vw, 3rem);
  box-sizing: border-box;
  /* Voortgangsbalk breekt uit tot 100vw; scenes blijven binnen .scroll-story__visual */
  overflow: visible;
}
/* Geo background shapes — scroll-driven via --story-p */
.scroll-story__geo {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}
.scroll-story__wrap { position: relative; z-index: 1; }
/* Vaste scroll-indicator: zichtbaar tijdens sticky “scrub”, verdwijnt tegen het eind van de sectie */
.scroll-story__viewport-cue {
  position: fixed;
  z-index: 160;
  left: 50%;
  bottom: max(1rem, calc(env(safe-area-inset-bottom, 0px) + 0.5rem));
  transform: translateX(-50%);
  pointer-events: none;
  opacity: var(--story-scroll-cue);
  transition: opacity 0.45s var(--ease-out);
}
.scroll-story__viewport-cue-icon {
  display: flex;
  color: rgba(255, 255, 255, 0.88);
  animation: scroll-story-cue-nudge 1.25s ease-in-out infinite;
  filter: drop-shadow(0 2px 14px rgba(0, 0, 0, 0.45)) drop-shadow(0 0 20px rgba(33, 103, 177, 0.35));
}
@keyframes scroll-story-cue-nudge {
  0%, 100% { transform: translateY(0); opacity: 0.82; }
  50% { transform: translateY(10px); opacity: 1; }
}
.sg {
  position: absolute;
  display: block;
  pointer-events: none;
}
.sg--tri {
  width: 130px;
  height: 130px;
  top: 14%;
  left: 4%;
  background: rgba(33,103,177,0.24);
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  transform:
    translate(
      calc(var(--story-p, 0) * 200px),
      calc(var(--story-p, 0) * 140px)
    )
    rotate(calc(var(--story-p, 0) * 118deg));
}
.sg--ring {
  width: 100px;
  height: 100px;
  top: 8%;
  right: 12%;
  border: 2px solid rgba(33,103,177,0.32);
  border-radius: 50%;
  transform:
    translate(
      calc(var(--story-p, 0) * -115px),
      calc(var(--story-p, 0) * 248px)
    )
    scale(calc(0.76 + var(--story-p, 0) * 0.52));
}
.sg--diamond {
  width: 70px;
  height: 70px;
  bottom: 28%;
  left: 8%;
  border: 2px solid rgba(241,101,50,0.3);
  transform:
    translate(
      calc(var(--story-p, 0) * 142px),
      calc(var(--story-p, 0) * -198px)
    )
    rotate(calc(45deg + var(--story-p, 0) * 175deg));
}
.sg--hex {
  width: 110px;
  height: 110px;
  bottom: 18%;
  right: 6%;
  background: rgba(33,103,177,0.22);
  clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
  transform:
    translate(
      calc(var(--story-p, 0) * -170px),
      calc(var(--story-p, 0) * -222px)
    )
    rotate(calc(var(--story-p, 0) * -72deg))
    scale(calc(0.84 + var(--story-p, 0) * 0.38));
}
.sg--cross {
  width: 50px;
  height: 50px;
  top: 45%;
  right: 18%;
  transform:
    translate(
      calc(var(--story-p, 0) * -88px),
      calc(var(--story-p, 0) * 126px)
    )
    rotate(calc(var(--story-p, 0) * 142deg));
}
.sg--cross::before,
.sg--cross::after {
  content: "";
  position: absolute;
  background: rgba(255,255,255,0.24);
  border-radius: 1px;
}
.sg--cross::before {
  width: 100%;
  height: 2px;
  top: 50%;
  left: 0;
  margin-top: -1px;
}
.sg--cross::after {
  width: 2px;
  height: 100%;
  left: 50%;
  top: 0;
  margin-left: -1px;
}
.sg--dot-a {
  width: 8px;
  height: 8px;
  top: 30%;
  left: 18%;
  border-radius: 50%;
  background: rgba(241,101,50,0.28);
  transform:
    translate(
      calc(var(--story-p, 0) * 100px),
      calc(var(--story-p, 0) * 168px)
    );
}
.sg--dot-b {
  width: 6px;
  height: 6px;
  bottom: 35%;
  right: 22%;
  border-radius: 50%;
  background: rgba(33,103,177,0.3);
  transform:
    translate(
      calc(var(--story-p, 0) * -72px),
      calc(var(--story-p, 0) * -142px)
    );
}
.sg--square {
  width: 55px;
  height: 55px;
  top: 65%;
  left: 15%;
  border: 2px solid rgba(255,255,255,0.22);
  transform:
    translate(
      calc(var(--story-p, 0) * 126px),
      calc(var(--story-p, 0) * -100px)
    )
    rotate(calc(15deg + var(--story-p, 0) * 132deg));
}
.sg--tri-b {
  width: 65px;
  height: 65px;
  top: 6%;
  left: 42%;
  background: rgba(241,101,50,0.24);
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  transform:
    translate(
      calc(var(--story-p, 0) * -88px),
      calc(var(--story-p, 0) * 154px)
    )
    rotate(calc(180deg + var(--story-p, 0) * -98deg));
}
.sg--arc {
  width: 80px;
  height: 40px;
  top: 52%;
  left: 2%;
  border: 2px solid rgba(33,103,177,0.28);
  border-bottom: none;
  border-radius: 80px 80px 0 0;
  transform:
    translate(
      calc(var(--story-p, 0) * 112px),
      calc(var(--story-p, 0) * -84px)
    )
    rotate(calc(var(--story-p, 0) * 58deg));
}
.sg--ring-sm {
  width: 45px;
  height: 45px;
  bottom: 10%;
  left: 45%;
  border: 2px solid rgba(241,101,50,0.28);
  border-radius: 50%;
  transform:
    translate(
      calc(var(--story-p, 0) * 88px),
      calc(var(--story-p, 0) * -126px)
    )
    scale(calc(1.14 - var(--story-p, 0) * 0.46));
}
.sg--dash-a {
  width: 40px;
  height: 2px;
  top: 22%;
  right: 30%;
  background: rgba(255,255,255,0.22);
  border-radius: 1px;
  transform:
    translate(
      calc(var(--story-p, 0) * -142px),
      calc(var(--story-p, 0) * 70px)
    )
    rotate(calc(-15deg + var(--story-p, 0) * 74deg));
}
.sg--dash-b {
  width: 55px;
  height: 2px;
  bottom: 42%;
  left: 30%;
  background: rgba(33,103,177,0.26);
  border-radius: 1px;
  transform:
    translate(
      calc(var(--story-p, 0) * 100px),
      calc(var(--story-p, 0) * -112px)
    )
    rotate(calc(35deg + var(--story-p, 0) * -108deg));
}
.sg--dot-c {
  width: 10px;
  height: 10px;
  top: 75%;
  right: 35%;
  border-radius: 50%;
  background: rgba(241,101,50,0.26);
  transform:
    translate(
      calc(var(--story-p, 0) * -58px),
      calc(var(--story-p, 0) * 100px)
    );
}
/* Geen width: 100% — dat overschrijft .wrap en zet tekst tegen de viewportrand */
.scroll-story__eyebrow { margin-bottom: 0.5rem; }
.scroll-story__title { margin-bottom: 0.5rem; max-width: 20em; }
.scroll-story__lede {
  margin: 0 0 1.75rem;
  max-width: 36rem;
  font-size: 0.98rem;
  color: var(--text-muted);
  line-height: 1.55;
}
.scroll-story__layout {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(0, 1.05fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
}
.scroll-story__visual {
  position: relative;
  aspect-ratio: 1;
  max-width: min(100%, 420px);
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  isolation: isolate;
}
.scroll-story__glow {
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(closest-side, rgba(33,103,177,0.35) 0%, transparent 70%),
    radial-gradient(closest-side, rgba(241,101,50,0.12) 55%, transparent 72%);
  pointer-events: none;
  opacity: 0.85;
  animation: ss-glow-drift 14s ease-in-out infinite alternate;
}
@keyframes ss-glow-drift {
  from { transform: translate(-6%, -5%) scale(1); }
  to { transform: translate(8%, 7%) scale(1.1); }
}
.scroll-story__scene {
  position: absolute;
  inset: 8%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 0;
  transition: opacity 0.4s cubic-bezier(0.4, 0, 0, 1), transform 0.45s cubic-bezier(0.4, 0, 0, 1), visibility 0.4s;
  transform: translateY(22px) scale(0.965);
}
[data-scroll-story][data-active-step="0"] .scroll-story__scene[data-scene="0"],
[data-scroll-story][data-active-step="1"] .scroll-story__scene[data-scene="1"],
[data-scroll-story][data-active-step="2"] .scroll-story__scene[data-scene="2"] {
  opacity: 1;
  visibility: visible;
  z-index: 1;
  transform: translateY(0) scale(1);
}

/* Scene: design / browser */
.ss-browser {
  width: 100%;
  max-width: 280px;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,0.12);
  background: linear-gradient(165deg, rgba(255,255,255,0.09), rgba(255,255,255,0.02));
  box-shadow: 0 24px 56px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.05) inset;
  overflow: hidden;
}
.ss-browser__chrome {
  display: flex;
  gap: 0.35rem;
  padding: 0.65rem 0.75rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.ss-browser__chrome span {
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background: rgba(255,255,255,0.2);
}
.ss-browser__chrome span:nth-child(1) { background: rgba(241,101,50,0.85); }
.ss-browser__chrome span:nth-child(3) { background: rgba(33,103,177,0.85); }
.ss-browser__canvas {
  position: relative;
  padding: 0.85rem 0.75rem 1rem;
  min-height: 11rem;
}
.ss-browser__grid {
  position: absolute;
  inset: 0.65rem 0.6rem 0.5rem;
  background-image:
    linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 22px 22px;
  animation: ss-grid-pan 14s linear infinite;
  opacity: 0.62;
  border-radius: 0.5rem;
  pointer-events: none;
}
@keyframes ss-grid-pan {
  from { background-position: 0 0; }
  to { background-position: 22px 22px; }
}
.ss-browser__shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(118deg, transparent 35%, rgba(255,255,255,0.07) 48%, transparent 62%);
  background-size: 200% 100%;
  animation: ss-shine 5.5s ease-in-out infinite;
  pointer-events: none;
}
@keyframes ss-shine {
  0%, 100% { background-position: 140% 0; }
  50% { background-position: -45% 0; }
}
.ss-browser__hero {
  position: relative;
  height: 2.4rem;
  border-radius: 0.55rem;
  background: linear-gradient(100deg, rgba(255,255,255,0.88), rgba(197,216,240,0.45));
  margin-bottom: 0.55rem;
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}
.ss-browser__row {
  position: relative;
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.55rem;
}
.ss-browser__chip {
  flex: 1;
  height: 0.55rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.12);
}
.ss-browser__chip--short { flex: 0.55; }
.ss-browser__cards {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.35rem;
}
.ss-browser__cards span {
  height: 2.1rem;
  border-radius: 0.45rem;
  background: linear-gradient(180deg, rgba(33,103,177,0.35), rgba(255,255,255,0.06));
  border: 1px solid rgba(255,255,255,0.08);
  animation: ss-card-breathe 4s ease-in-out infinite;
}
.ss-browser__cards span:nth-child(2) { animation-delay: 0.4s; }
.ss-browser__cards span:nth-child(3) { animation-delay: 0.8s; }
@keyframes ss-card-breathe {
  0%, 100% { transform: translateY(0); filter: brightness(0.92); }
  50% { transform: translateY(-6px); filter: brightness(1.12); }
}
.ss-design-orbit {
  position: absolute;
  inset: -12%;
  border: 1px solid rgba(33,103,177,0.32);
  border-radius: 50%;
  pointer-events: none;
  animation: ss-orbit 17s linear infinite;
}
@keyframes ss-orbit { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* Scene: hosting */
.ss-host-stack {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: min(100%, 240px);
}
.ss-host-blade {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0.7rem;
  border-radius: 0.55rem;
  background: linear-gradient(90deg, rgba(255,255,255,0.07), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 12px 32px rgba(0,0,0,0.35);
}
.ss-host-led {
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background: var(--logo-orange);
  box-shadow: 0 0 12px rgba(241,101,50,0.75);
  animation: ss-led-pulse 2.4s ease-in-out infinite;
}
.ss-host-blade:nth-child(2) .ss-host-led { animation-delay: 0.35s; }
.ss-host-blade:nth-child(3) .ss-host-led { animation-delay: 0.7s; }
@keyframes ss-led-pulse {
  0%, 100% { opacity: 0.7; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.28); }
}
.ss-host-bar {
  height: 0.38rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(33,103,177,0.5), rgba(241,101,50,0.45));
  animation: ss-bar-flow 4s ease-in-out infinite alternate;
}
.ss-host-blade:nth-child(2) .ss-host-bar { animation-delay: 0.5s; }
.ss-host-blade:nth-child(3) .ss-host-bar { animation-delay: 1s; }
@keyframes ss-bar-flow {
  from { transform: scaleX(0.72); transform-origin: left center; opacity: 0.78; }
  to { transform: scaleX(1); transform-origin: left center; opacity: 1; }
}
.ss-host-ring {
  position: absolute;
  width: min(72%, 300px);
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(241,101,50,0.28);
  pointer-events: none;
  animation: ss-ring-pulse 5s ease-in-out infinite;
}
.ss-host-ring--b {
  width: min(88%, 360px);
  border-color: rgba(33,103,177,0.26);
  animation-duration: 6.5s;
  animation-direction: reverse;
}
@keyframes ss-ring-pulse {
  0%, 100% { transform: scale(0.9); opacity: 0.45; }
  50% { transform: scale(1.06); opacity: 0.95; }
}

/* Scene: code / integratie */
.ss-code-frame {
  width: min(100%, 280px);
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,0.11);
  background: linear-gradient(180deg, rgba(18,16,28,0.95), rgba(34,28,48,0.88));
  overflow: hidden;
  box-shadow: 0 28px 64px rgba(0,0,0,0.45);
}
.ss-code-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.55rem 0.75rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  background: rgba(0,0,0,0.2);
}
.ss-code-dot {
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background: rgba(241,101,50,0.9);
}
.ss-code-title {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.ss-code-body { padding: 0.85rem 0.75rem 1rem; position: relative; }
.ss-code-line {
  height: 0.42rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.1);
  margin-bottom: 0.45rem;
  max-width: 100%;
  animation: ss-line-glow 4s ease-in-out infinite alternate;
}
.ss-code-line--ind { margin-left: 1rem; max-width: 88%; animation-delay: 0.3s; }
.ss-code-line--short { max-width: 52%; animation-delay: 0.6s; }
@keyframes ss-line-glow {
  from { opacity: 0.55; filter: brightness(0.82); }
  to { opacity: 1; filter: brightness(1.18); }
}
.ss-code-nodes {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.85rem;
  padding-top: 0.65rem;
  border-top: 1px dashed rgba(255,255,255,0.1);
}
.ss-node {
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--logo-blue-mid), var(--logo-orange));
  box-shadow: 0 0 14px rgba(33,103,177,0.45);
  animation: ss-node-pop 3.2s ease-in-out infinite;
}
.ss-node:nth-child(3) { animation-delay: 0.5s; }
.ss-node:nth-child(5) { animation-delay: 1s; }
@keyframes ss-node-pop {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.32); }
}
.ss-node-arc {
  flex: 1;
  height: 2px;
  margin: 0 0.15rem;
  background: linear-gradient(90deg, transparent, rgba(33,103,177,0.55), rgba(241,101,50,0.45), transparent);
  animation: ss-arc-flow 2.8s ease-in-out infinite;
}
@keyframes ss-arc-flow {
  0%, 100% { opacity: 0.22; transform: scaleX(0.92); }
  50% { opacity: 1; transform: scaleX(1); }
}

.scroll-story__copy {
  position: relative;
  min-height: 11.5rem;
}
.scroll-story__panel {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.4s cubic-bezier(0.4, 0, 0, 1), transform 0.45s cubic-bezier(0.4, 0, 0, 1), visibility 0.4s;
  transform: translateY(18px);
}
[data-scroll-story][data-active-step="0"] .scroll-story__panel[data-story-panel="0"],
[data-scroll-story][data-active-step="1"] .scroll-story__panel[data-story-panel="1"],
[data-scroll-story][data-active-step="2"] .scroll-story__panel[data-story-panel="2"] {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}
.scroll-story__panel-title {
  margin: 0 0 0.65rem;
  font-size: clamp(1.15rem, 2.2vw, 1.45rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  background: linear-gradient(100deg, #fff 0%, #d8d2e8 40%, var(--logo-blue-mid) 72%, var(--logo-orange) 100%);
  background-size: 180% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.scroll-story__panel-text {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.62;
  color: var(--text-muted);
  max-width: 38rem;
}
.scroll-story__meta {
  margin-top: 1.75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
}
/* Paginabrede voortgang: breekt uit het .wrap-midden naar 100vw (horizontale scroll → html overflow-x) */
.scroll-story__rail-bleed {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  align-self: stretch;
  box-sizing: border-box;
}
.scroll-story__rail {
  position: relative;
  width: 100%;
  padding: 12px 0 14px;
  box-sizing: border-box;
}
.scroll-story__rail-track {
  height: 4px;
  border-radius: 0;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
}
.scroll-story__rail-fill {
  display: block;
  height: 100%;
  width: 100%;
  transform-origin: left center;
  transform: scaleX(var(--story-p, 0));
  background: linear-gradient(90deg, var(--logo-blue-mid), var(--logo-orange));
  border-radius: 0;
  transition: transform 0.12s linear;
}
.scroll-story__rail-markers {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}
.scroll-story__marker {
  position: absolute;
  top: 50%;
  width: 11px;
  height: 11px;
  padding: 0;
  margin: 0;
  border-radius: 50%;
  box-sizing: border-box;
  background: var(--purple-900);
  border: 2px solid rgba(255,255,255,0.22);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.35);
  transition: transform 0.35s var(--ease-out), border-color 0.35s, background 0.35s, box-shadow 0.35s;
  z-index: 2;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.scroll-story__marker::before {
  content: "";
  position: absolute;
  /* WCAG 2.5.8: min. ca. 24×24 px aanraakgebied (11px + 2×17 inset) */
  inset: -17px;
  border-radius: 50%;
}
/* Dots op p = 0, 1/3, 2/3 (zelfde als Math.floor(p * 3) in main.js) */
.scroll-story__marker[data-marker="0"] {
  left: var(--story-step-0);
  transform: translateY(-50%);
}
.scroll-story__marker[data-marker="1"] {
  left: var(--story-step-1);
  transform: translate(-50%, -50%);
}
.scroll-story__marker[data-marker="2"] {
  left: var(--story-step-2);
  transform: translate(-50%, -50%);
}
.scroll-story__marker[data-marker="0"].is-upcoming {
  background: rgba(12,10,16,0.95);
  border-color: rgba(255,255,255,0.12);
  transform: translateY(-50%) scale(0.9);
}
.scroll-story__marker[data-marker="0"].is-current {
  background: linear-gradient(145deg, var(--logo-blue-mid), var(--logo-orange));
  border-color: rgba(255,255,255,0.45);
  box-shadow:
    0 0 0 2px rgba(33,103,177,0.35),
    0 0 18px rgba(241,101,50,0.4);
  transform: translateY(-50%) scale(1.12);
}
.scroll-story__marker[data-marker="0"].is-done {
  background: rgba(33,103,177,0.55);
  border-color: rgba(33,103,177,0.85);
  transform: translateY(-50%) scale(1);
}
.scroll-story__marker[data-marker="1"].is-upcoming,
.scroll-story__marker[data-marker="2"].is-upcoming {
  background: rgba(12,10,16,0.95);
  border-color: rgba(255,255,255,0.12);
  transform: translate(-50%, -50%) scale(0.9);
}
.scroll-story__marker[data-marker="1"].is-current,
.scroll-story__marker[data-marker="2"].is-current {
  background: linear-gradient(145deg, var(--logo-blue-mid), var(--logo-orange));
  border-color: rgba(255,255,255,0.45);
  box-shadow:
    0 0 0 2px rgba(33,103,177,0.35),
    0 0 18px rgba(241,101,50,0.4);
  transform: translate(-50%, -50%) scale(1.12);
}
.scroll-story__marker[data-marker="1"].is-done,
.scroll-story__marker[data-marker="2"].is-done {
  background: rgba(33,103,177,0.55);
  border-color: rgba(33,103,177,0.85);
  transform: translate(-50%, -50%) scale(1);
}
.scroll-story__nav {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.scroll-story__nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 1.5px solid rgba(255,255,255,0.15);
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, color 0.2s, opacity 0.2s, transform 0.15s var(--ease-out);
}
.scroll-story__nav-btn:hover:not(:disabled) {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.3);
  color: #fff;
  transform: scale(1.08);
}
.scroll-story__nav-btn:active:not(:disabled) {
  transform: scale(0.95);
}
.scroll-story__nav-btn:disabled {
  opacity: 0.25;
  cursor: default;
}
.scroll-story__nav-label {
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.55);
  min-width: 3ch;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.scroll-story__hint {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: var(--story-hint, 1);
  transition: opacity 0.35s var(--ease-out);
}
.scroll-story__hint-icon {
  width: 1.35rem;
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--logo-blue-mid), var(--logo-orange));
  box-shadow: 0 0 12px rgba(241,101,50,0.35);
  animation: ss-hint-nudge 2s ease-in-out infinite;
}
.scroll-story__hint-icon::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin: -3px 0 0 auto;
  border-left: 5px solid var(--logo-orange);
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
}
@keyframes ss-hint-nudge {
  0%, 100% { transform: translateX(0); opacity: 0.85; }
  50% { transform: translateX(9px); opacity: 1; }
}

.scroll-story--static {
  height: auto !important;
  padding: clamp(3rem, 7vw, 4.5rem) 0 !important;
  transform: translateY(var(--sp, 0));
  will-change: transform;
}
.scroll-story--static .scroll-story__sticky {
  position: relative;
  min-height: 0;
  padding: 0;
  overflow: visible;
  align-items: flex-start;
}
.scroll-story--static .scroll-story__layout {
  grid-template-columns: 1fr;
}
.scroll-story--static .scroll-story__visual {
  max-width: 320px;
  margin-bottom: 0.5rem;
}
.scroll-story--static .scroll-story__scene {
  opacity: 1 !important;
  transform: none !important;
  position: relative;
  inset: auto;
  display: none;
  pointer-events: none;
}
.scroll-story--static .scroll-story__scene[data-scene="0"] { display: flex; }
.scroll-story--static .scroll-story__copy {
  min-height: 0;
}
.scroll-story--static .scroll-story__panel {
  position: relative;
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto;
  margin-bottom: 1.75rem;
}
.scroll-story--static .scroll-story__panel:last-child { margin-bottom: 0; }
.scroll-story--static .scroll-story__rail-bleed,
.scroll-story--static .scroll-story__hint,
.scroll-story--static .scroll-story__nav,
.scroll-story--static .scroll-story__viewport-cue { display: none; }
.scroll-story--static .scroll-story__lede { display: none; }
.scroll-story--static .scroll-story__meta { display: none; }
.scroll-story--static .scroll-story__geo {
  opacity: 0.7;
}
.scroll-story--static .sg { animation: sg-float 12s ease-in-out infinite alternate; }
.scroll-story--static .sg:nth-child(even) { animation-direction: alternate-reverse; }
.scroll-story--static .sg:nth-child(3n)   { animation-duration: 16s; }
.scroll-story--static .sg:nth-child(3n+1) { animation-duration: 14s; }
.scroll-story--static .sg:nth-child(5n)   { animation-duration: 18s; }
@keyframes sg-float {
  0%   { translate: 0 0; }
  100% { translate: 24px -20px; }
}

/* ≤1023px: gelijk aan main.js isLayoutNarrow — geen decoratieve mockups; layout werkt ook zonder JS */
@media (max-width: 1023px) {
  /* Geen oranje “spot” rechtsboven in de pagina-achtergrond */
  .bg-gradient {
    background:
      radial-gradient(100% 70% at 15% -5%, rgba(33, 103, 177, 0.22), transparent 52%),
      radial-gradient(65% 45% at 50% 105%, rgba(45, 36, 64, 0.75), transparent 58%),
      linear-gradient(180deg, var(--purple-950) 0%, var(--purple-void) 45%, #0a0812 100%);
  }
  .hero__grid {
    grid-template-columns: 1fr;
  }
  .hero__visual {
    display: none !important;
  }
  /* Geen 400vh / geen sticky-min-height: anders enorme lege ruimte onder de kop (ook vóór JS-hydratie) */
  .block--scroll-story {
    height: auto !important;
    min-height: 0;
  }
  .block--scroll-story.scroll-story--static {
    padding: clamp(1.75rem, 5vw, 2.75rem) 0 !important;
  }
  .scroll-story__geo {
    display: none !important;
  }
  .scroll-story__sticky {
    position: relative !important;
    top: auto;
    min-height: 0 !important;
    align-items: flex-start;
    padding: 0.75rem 0 clamp(1.25rem, 4vw, 1.75rem);
  }
  .scroll-story__layout {
    grid-template-columns: 1fr;
  }
  .scroll-story__visual {
    display: none !important;
  }
  .scroll-story__copy {
    min-height: 0 !important;
  }
  /* Stap-UI verborgen; alle drie panelen onder elkaar (niet absolute + 11.5rem) */
  [data-scroll-story] .scroll-story__lede,
  [data-scroll-story] .scroll-story__rail-bleed,
  [data-scroll-story] .scroll-story__hint,
  [data-scroll-story] .scroll-story__nav,
  [data-scroll-story] .scroll-story__meta,
  [data-scroll-story] .scroll-story__viewport-cue {
    display: none !important;
  }
  [data-scroll-story] .scroll-story__panel {
    position: relative !important;
    left: auto;
    right: auto;
    top: auto;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
    margin-bottom: 1.5rem;
  }
  [data-scroll-story] .scroll-story__panel:last-child {
    margin-bottom: 0;
  }
  .scroll-story__glow {
    animation: none !important;
  }
  .showcase__orbit {
    display: none;
  }
  .showcase__window {
    margin-top: 1rem;
    transform: none !important;
  }
  .showcase__progress-bar,
  .showcase__bars span,
  .showcase__cursor {
    animation: none !important;
  }
  .ss-design-orbit,
  .ss-browser__grid,
  .ss-browser__shine,
  .ss-browser__cards span,
  .ss-host-led,
  .ss-host-bar,
  .ss-host-ring,
  .ss-code-line,
  .ss-node,
  .ss-node-arc {
    animation: none !important;
  }
}

/* News grid */
.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-flow: dense;
  gap: 1rem;
}
.news-card--wide { grid-column: span 2; }
.news-card {
  display: flex; flex-direction: column;
  padding: 1.5rem 1.5rem 1.35rem;
  text-decoration: none; color: inherit;
  transition: transform 0.45s var(--ease-out), box-shadow 0.45s var(--ease-out), border-color 0.35s var(--ease-out);
}
.news-card:hover {
  transform: translateY(-5px) scale(1.008);
  box-shadow: var(--shadow-glow-sm), 0 0 0 1px rgba(33,103,177,0.25), 0 28px 64px rgba(0,0,0,0.45);
  border-color: rgba(33,103,177,0.35);
}
.news-card--featured {
  grid-column: span 2;
  grid-row: span 2;
  padding: 2rem 2rem 1.75rem;
}
.news-card__badge {
  display: inline-block; width: fit-content;
  padding: 0.2rem 0.6rem; margin-bottom: 0.75rem;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: #fff; background: var(--logo-orange);
  border-radius: 4px;
}
.news-card__date {
  display: block; margin-bottom: 0.5rem;
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--logo-orange);
}
.news-card__title {
  margin: 0 0 0.5rem;
  font-size: 1.1rem; font-weight: 700; line-height: 1.25;
}
.news-card--featured .news-card__title {
  font-size: clamp(1.35rem, 2.5vw, 1.65rem);
}
.news-card__text {
  margin: 0 0 auto;
  font-size: 0.92rem; line-height: 1.55; color: var(--text-muted);
  padding-bottom: 1rem;
}
.news-card--featured .news-card__text {
  font-size: 1rem;
}
.news-card__link {
  display: inline-flex; align-items: center; gap: 0.25rem;
  font-size: 0.85rem; font-weight: 600; color: var(--link);
  transition: color 0.25s, gap 0.35s var(--ease-out);
}
.news-card:hover .news-card__link { color: var(--logo-orange); gap: 0.45rem; }

@media (max-width: 900px) {
  .news-grid { grid-template-columns: repeat(2, 1fr); }
  .news-card--featured { grid-column: span 2; grid-row: span 1; }
  .news-card--wide { grid-column: span 2; }
}
@media (max-width: 560px) {
  .news-grid { grid-template-columns: 1fr; }
  .news-card--featured,
  .news-card--wide { grid-column: span 1; }
}

/* Article */
.article-hero-img {
  width: 100%; max-height: 28rem; object-fit: cover; border-radius: var(--radius);
  margin-bottom: 2rem;
}
.article-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 0.75rem 1.5rem;
  margin-bottom: 1.5rem; font-size: 0.85rem; color: var(--text-muted);
}
.article-meta__date { font-weight: 600; }
.article-meta__back {
  display: inline-flex; align-items: center; gap: 0.3rem;
  color: var(--link); text-decoration: none; font-weight: 500;
  transition: color 0.2s, gap 0.25s;
}
.article-meta__back:hover { color: var(--logo-orange); gap: 0.5rem; }
.article-more {
  margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border);
}
.article-more__title {
  font-size: 0.75rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--text-muted); margin: 0 0 1rem;
}
.article-more__grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem;
}
.article-more__card {
  display: block; padding: 1rem; border-radius: calc(var(--radius) - 2px);
  background: rgba(255,255,255,0.03); border: 1px solid var(--border);
  text-decoration: none; transition: background 0.25s, border-color 0.25s;
}
.article-more__card:hover {
  background: rgba(255,255,255,0.06); border-color: var(--link);
}
.article-more__card-date {
  display: block; font-size: 0.72rem; color: var(--text-muted); margin-bottom: 0.3rem;
}
.article-more__card-title {
  font-size: 0.9rem; font-weight: 600; color: var(--text); line-height: 1.35;
}

/* Article prev/next arrows — large screens only */
.article-nav { display: none; }

@media (min-width: 1200px) {
  .article-nav {
    display: block; position: fixed; top: 50%; z-index: 90;
    transform: translateY(-50%);
  }
  .article-nav--prev { left: clamp(0.75rem, 2vw, 1.5rem); }
  .article-nav--next { right: clamp(0.75rem, 2vw, 1.5rem); }

  .article-nav__link {
    display: flex; align-items: center; justify-content: center;
    width: 3rem; height: 3rem; border-radius: 50%;
    background: var(--surface); border: 1px solid var(--border);
    color: var(--text-muted); text-decoration: none;
    font-size: 1.25rem; line-height: 1;
    transition: background 0.2s, color 0.2s, border-color 0.2s, box-shadow 0.2s;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  }
  .article-nav__link:hover {
    color: var(--logo-orange); border-color: var(--logo-orange);
    background: rgba(255,255,255,0.06);
    box-shadow: 0 4px 16px rgba(0,0,0,0.18);
  }

  .article-nav__label {
    position: absolute; top: 50%; white-space: nowrap; pointer-events: none;
    font-size: 0.78rem; font-weight: 600; color: var(--text-muted);
    opacity: 0; transition: opacity 0.2s, transform 0.2s;
  }
  .article-nav--prev .article-nav__label {
    left: 100%; margin-left: 0.6rem; transform: translateY(-50%) translateX(-4px);
  }
  .article-nav--next .article-nav__label {
    right: 100%; margin-right: 0.6rem; transform: translateY(-50%) translateX(4px);
    text-align: right;
  }
  .article-nav__link:hover + .article-nav__label,
  .article-nav__link:focus-visible + .article-nav__label {
    opacity: 1; transform: translateY(-50%) translateX(0);
  }
}

/* CTA */
.block--cta { padding: clamp(2.5rem,6vw,3.5rem) 0; }
.cta {
  position: relative; display: flex; flex-wrap: wrap; align-items: center;
  justify-content: space-between; gap: 1.75rem; padding: clamp(1.75rem,4vw,2.5rem);
  border-radius: calc(var(--radius) + 4px);
  background: linear-gradient(135deg, rgba(255,255,255,0.06) 0%, transparent 42%),
    linear-gradient(120deg, rgba(33,103,177,0.42) 0%, rgba(40,26,66,0.92) 52%, var(--purple-900) 100%);
  border: 1px solid rgba(33,103,177,0.38);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.05) inset, 0 32px 64px rgba(0,0,0,0.4);
  overflow: hidden;
  will-change: transform; transition: box-shadow 0.3s var(--ease-out);
}
.cta:hover {
  box-shadow: 0 0 0 1px rgba(255,255,255,0.08) inset, 0 32px 80px rgba(0,0,0,0.5), 0 0 0 1px rgba(33,103,177,0.5);
}
.cta::before { content: ""; position: absolute; top: -40%; right: -20%; width: 55%; height: 120%; background: radial-gradient(circle, rgba(241,101,50,0.12) 0%, transparent 65%); pointer-events: none; }
.cta__copy, .cta__action { position: relative; z-index: 1; }
.cta__action {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
}
.cta__p, .cta__links { margin: 0 0 0.65rem; color: rgba(255,255,255,0.84); max-width: 38rem; font-size: 0.98rem; }
.cta__links:last-child { margin-bottom: 0; }
.cta__links a {
  color: #fff;
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 0.18em;
}
.cta__links a:hover { color: var(--logo-orange); }

/* Duo */
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem,4vw,2.5rem); }
@media (max-width: 768px) { .duo { grid-template-columns: 1fr; } }
.duo__head { margin-bottom: 1rem; }
.duo__intro { margin: 0.5rem 0 0; color: var(--text-muted); font-size: 0.95rem; }
.duo__box { padding: 1.35rem 1.4rem; }
.duo__box-text { margin: 0; color: var(--text-muted); font-size: 0.95rem; }
.duo__box-text--flush {
  margin-bottom: 0;
  margin-top: 1rem;
}

/* Quotes */
.quotes { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 768px) { .quotes { grid-template-columns: 1fr; } }
.quote {
  margin: 0; padding: 1.75rem 1.75rem 1.5rem;
  transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out), border-color 0.35s var(--ease-out);
}
.quote:hover {
  transform: translateY(-3px) scale(1.005);
  box-shadow: var(--shadow-glow-sm), 0 20px 50px rgba(0,0,0,0.35);
  border-color: rgba(33,103,177,0.4);
}
.quote__mark {
  display: block; font-size: 3.5rem; line-height: 0.85; font-weight: 700;
  background: linear-gradient(180deg, var(--logo-blue-mid), var(--logo-orange));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  margin-bottom: 0.35rem; user-select: none;
}
.quote::after {
  content: ""; position: absolute; left: 0; top: 1.25rem; bottom: 1.25rem; width: 3px;
  border-radius: 3px; background: linear-gradient(180deg, var(--logo-blue-mid), var(--logo-orange));
  pointer-events: none;
}
.quote__body { margin: 0 0 1.1rem; font-size: 1.06rem; line-height: 1.58; font-style: italic; color: var(--text); }
.quote__by { font-size: 0.88rem; }
.quote__by cite { font-style: normal; font-weight: 600; display: block; }
.quote__by span { color: var(--text-muted); }

/* Home: testimonials slider (bron: portfolio.html) */
.quotes-slider {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  align-items: stretch;
  margin-top: 0.5rem;
  /* Breder dan .wrap: vul de volledige viewport */
  width: 100vw;
  margin-left: calc(50% - 50vw);
  padding-inline: clamp(1rem, 3vw, 3rem);
  box-sizing: border-box;
}
.quotes-slider__viewport {
  overflow-x: hidden;
  overflow-y: hidden;
  scrollbar-width: none;
  container-type: inline-size;
  container-name: quotes-view;
  outline: none;
  cursor: grab;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 6%,
    black 94%,
    transparent 100%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 6%,
    black 94%,
    transparent 100%
  );
}
.quotes-slider__viewport * {
  user-select: none;
  -webkit-user-select: none;
}
.quotes-slider__viewport.is-dragging {
  cursor: grabbing;
}
.quotes-slider__viewport::-webkit-scrollbar { display: none; }
.quotes-slider__track {
  display: flex;
  flex-direction: row;
  gap: 1rem;
  width: max-content;
  padding: 0.15rem 0;
  padding-left: 7%;
  will-change: transform;
}
.quotes-slider__track .quote {
  margin: 0;
  flex: 0 0 100%;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
@container quotes-view (min-width: 769px) {
  .quotes-slider__track .quote {
    flex: 0 0 calc((100cqw - 2 * 1rem) / 3);
    width: calc((100cqw - 2 * 1rem) / 3);
    max-width: calc((100cqw - 2 * 1rem) / 3);
  }
}
.quotes-slider__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  width: 36px;
  height: 36px;
  padding: 0;
  flex-shrink: 0;
  border: 1.5px solid rgba(255,255,255,0.15);
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, color 0.2s, opacity 0.2s, transform 0.15s var(--ease-out);
}
.quotes-slider__btn:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.3);
  color: #fff;
  transform: scale(1.08);
}
.quotes-slider__btn:active {
  transform: scale(0.95);
}
.quotes-slider__btn:focus-visible {
  outline: 2px solid var(--logo-blue-mid);
  outline-offset: 2px;
}

/* Menu table */
.menu-table { display: flex; flex-direction: column; gap: 0.55rem; }
.menu-table__row {
  display: grid; grid-template-columns: minmax(120px,180px) 1fr auto;
  gap: 1rem 1.5rem; align-items: center; padding: 1.1rem 1.25rem;
  text-decoration: none; color: inherit;
  transition: transform 0.35s var(--ease-out), border-color 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
}
.menu-table__row:hover { transform: translateX(6px); border-color: rgba(33,103,177,0.35); box-shadow: -3px 0 0 var(--logo-orange); }
.menu-table__name { font-weight: 600; }
.menu-table__desc { font-size: 0.92rem; color: var(--text-muted); }
.menu-table__go { color: var(--logo-orange); font-weight: 600; transition: transform 0.3s var(--ease-out); }
.menu-table__row:hover .menu-table__go { transform: translateX(4px); }
@media (max-width: 640px) { .menu-table__row { grid-template-columns: 1fr; gap: 0.35rem; } .menu-table__go { display: none; } }

/* Tech stack */
.block--stack .wrap {
  max-width: min(960px, calc(100% - 3.5rem));
}
.stack-block__intro { max-width: 32rem; margin-bottom: 1.75rem; }
.stack-block__text { margin: 0.65rem 0 0; color: var(--text-muted); }
.tech-row {
  list-style: none; margin: 0; padding: 0;
  position: relative;
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  align-items: flex-start;
  /* Voorkomt dat regels uitrekken over min-height (packing); anders staat een gewikkeld item te laag */
  align-content: flex-start;
  /* Hoogte gesloten pill: li-border + knop-padding + regel (gelijk aan .tech-row__btn) */
  --tech-pill-outer-h: calc(2px + 0.9rem + 1.35 * 0.78rem);
}

.tech-row li {
  flex: 0 0 auto;
  position: relative;
  z-index: 1;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(34,28,48,0.85);
  transition:
    border-color 0.5s cubic-bezier(0.4, 0, 0, 1),
    background 0.5s cubic-bezier(0.4, 0, 0, 1),
    box-shadow 0.5s cubic-bezier(0.4, 0, 0, 1),
    border-radius 0.5s cubic-bezier(0.4, 0, 0, 1);
}

.tech-row__spacer {
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 0 0 auto;
  align-self: flex-start;
  visibility: hidden;
  pointer-events: none;
  border: none;
  background: transparent;
  box-sizing: border-box;
}

.tech-row li:hover {
  border-color: rgba(241,101,50,0.45);
  background: rgba(33,103,177,0.12);
}

.tech-row li.is-open {
  --tech-panel-max-h: calc(3 * var(--tech-pill-outer-h) + 2 * 0.5rem + 3px);
  position: absolute;
  z-index: 25;
  left: 0;
  top: 0;
  flex: 0 0 auto;
  width: var(--tech-open-w, min(340px, var(--tech-popout-max-w, 100%)));
  max-width: min(340px, var(--tech-popout-max-w, 100%));
  max-height: var(--tech-open-max-h, var(--tech-panel-max-h));
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: var(--radius);
  border-color: rgba(33,103, 177, 0.55);
  /* Volledig dekkend — geen transparantie door onderliggende pills */
  background: linear-gradient(165deg, var(--purple-700) 0%, var(--purple-800) 48%, #1a1526 100%);
  box-shadow: var(--shadow-glow-sm), 0 20px 48px rgba(0, 0, 0, 0.35);
  transition:
    width 0.58s cubic-bezier(0.33, 1.05, 0.64, 1),
    max-height 0.58s cubic-bezier(0.33, 1.05, 0.64, 1),
    box-shadow 0.45s ease,
    border-color 0.35s ease,
    background 0.4s ease;
}

.tech-row li.is-open .tech-row__btn {
  flex: 0 0 auto;
}

.tech-row__btn {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.45rem 0.85rem;
  font-family: var(--font);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.25s var(--ease-out);
}
/* WCAG 2.5.8: grotere aanraakdoelen op touch */
@media (pointer: coarse) {
  .tech-row__btn {
    min-height: 44px;
    padding: 0.55rem 1rem;
  }
  .theme-switch {
    min-width: 44px;
    min-height: 44px;
  }
  .scroll-story__nav-btn {
    width: 44px;
    height: 44px;
  }
}

.tech-row__btn::after {
  content: "+";
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--logo-orange);
  transition: transform 0.35s var(--ease-out);
}

.is-open .tech-row__btn::after {
  transform: rotate(45deg);
}

.tech-row__btn:hover,
.is-open .tech-row__btn {
  color: var(--text);
}

.tech-row__detail {
  display: none;
}

.is-open .tech-row__detail {
  display: block;
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.15) transparent;
  cursor: auto;
}

.is-open .tech-row__detail::-webkit-scrollbar { width: 4px; }
.is-open .tech-row__detail::-webkit-scrollbar-track { background: transparent; }
.is-open .tech-row__detail::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.18);
  border-radius: 4px;
}
.is-open .tech-row__detail::-webkit-scrollbar-corner { background: transparent; }


.tech-row__detail > p {
  margin: 0;
  padding: 0.15rem 0.85rem 0.75rem;
  font-size: 0.85rem;
  line-height: 1.55;
  color: var(--text-muted);
  animation: tech-detail-reveal 0.52s 0.22s cubic-bezier(0.33, 1.05, 0.64, 1) both;
}

@keyframes tech-detail-reveal {
  from {
    opacity: 0;
    transform: translateY(-16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .tech-row li.is-open {
    transition: none;
  }
  .tech-row__detail > p {
    animation: none;
  }
}

/* Contact */
.contact-wrap { max-width: 640px; margin-inline: auto; text-align: center; }
.contact-hero { padding: clamp(2rem,5vw,3.25rem); }
.contact-hero__title { margin-bottom: 0.75rem; font-size: clamp(1.85rem,3.5vw,2.5rem); }
.contact-hero__p { margin: 0 0 1.5rem; color: var(--text-muted); font-size: 1.05rem; }
.contact-hero__actions { display: flex; flex-wrap: wrap; gap: 0.65rem; justify-content: center; }

/* Footer */
.footer { padding: clamp(2.5rem,5vw,3.5rem) 0 2rem; border-top: 1px solid var(--border); background: linear-gradient(180deg, transparent, rgba(0,0,0,0.25)); }
.footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2rem 2.5rem; margin-bottom: 2.5rem; }
@media (max-width: 768px) { .footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .footer__top { grid-template-columns: 1fr; } }
.footer__brand img { height: 30px; width: auto; }
.footer__tag { margin: 0.35rem 0 0; font-size: 0.88rem; color: var(--text-muted); }
.footer__col-title { margin: 0 0 0.65rem; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--logo-orange); }
.footer__links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.35rem; }
.footer__links a { font-size: 0.9rem; color: var(--text-muted); text-decoration: none; transition: color 0.2s; }
.footer__links a:hover { color: var(--link); }
.footer__bottom { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 0.75rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.footer__legal { margin: 0; font-size: 0.82rem; color: var(--text-muted); }
.footer__legal-links { display: flex; flex-wrap: wrap; gap: 0.5rem 1.25rem; list-style: none; margin: 0; padding: 0; }
.footer__legal-links a { font-size: 0.8rem; color: var(--text-muted); text-decoration: none; transition: color 0.2s; }
.footer__legal-links a:hover { color: var(--link); }
.footer__seo-links {
  display: flex; flex-wrap: wrap; gap: 0.35rem 1rem;
  list-style: none; margin: 0; padding: 1rem 0 0;
  border-top: 1px solid var(--border);
}
.footer__seo-links a {
  font-size: 0.75rem; color: var(--text-muted); text-decoration: none;
  opacity: 0.7; transition: opacity 0.2s, color 0.2s;
}
.footer__seo-links a:hover { opacity: 1; color: var(--link); }

/* Scroll reveal (Apple-achtig: langzaam, ruimtelijk) */
[data-animate] {
  opacity: 0; transform: translateY(1.5rem) scale(0.99);
  transition: opacity 0.75s cubic-bezier(0.4, 0, 0, 1),
    transform 0.75s cubic-bezier(0.4, 0, 0, 1);
}
[data-animate].is-visible { opacity: 1; transform: translateY(0) scale(1); }

.feature-list__item[data-animate]:nth-child(1) { transition-delay: 0.04s; }
.feature-list__item[data-animate]:nth-child(2) { transition-delay: 0.08s; }
.feature-list__item[data-animate]:nth-child(3) { transition-delay: 0.12s; }
.feature-list__item[data-animate]:nth-child(4) { transition-delay: 0.16s; }
.bento__cell[data-animate]:nth-child(1) { transition-delay: 0.03s; }
.bento__cell[data-animate]:nth-child(2) { transition-delay: 0.06s; }
.bento__cell[data-animate]:nth-child(3) { transition-delay: 0.09s; }
.bento__cell[data-animate]:nth-child(4) { transition-delay: 0.12s; }
.bento__cell[data-animate]:nth-child(5) { transition-delay: 0.15s; }
.menu-table__row[data-animate]:nth-child(1) { transition-delay: 0.03s; }
.menu-table__row[data-animate]:nth-child(2) { transition-delay: 0.06s; }
.menu-table__row[data-animate]:nth-child(3) { transition-delay: 0.09s; }
.menu-table__row[data-animate]:nth-child(4) { transition-delay: 0.12s; }
.menu-table__row[data-animate]:nth-child(5) { transition-delay: 0.15s; }
.menu-table__row[data-animate]:nth-child(6) { transition-delay: 0.18s; }

/* Hero proof stagger */
.hero__proof li {
  opacity: 0; transform: translateY(1rem) scale(0.96);
  transition: opacity 0.6s cubic-bezier(0.4, 0, 0, 1),
    transform 0.6s cubic-bezier(0.4, 0, 0, 1);
}
.hero__proof li:nth-child(1) { transition-delay: 0.75s; }
.hero__proof li:nth-child(2) { transition-delay: 0.85s; }
.hero__proof li:nth-child(3) { transition-delay: 0.95s; }
[data-hero-reveal].is-visible .hero__proof li,
.hero__proof.is-visible li { opacity: 1; transform: translateY(0) scale(1); }

/* ========== Licht thema (donker blijft standaard via :root) ========== */
html[data-theme="light"] {
  --purple-void: #f3f1f8;
  --purple-950: #e8e4f0;
  --purple-900: #ded8e8;
  --purple-800: #cfc8dc;
  --purple-700: #c0b6cf;
  --surface: rgba(22, 18, 33, 0.045);
  --surface-2: rgba(22, 18, 33, 0.075);
  --surface-glass: rgba(255, 255, 255, 0.78);
  --border: rgba(22, 18, 33, 0.12);
  --border-bright: rgba(22, 18, 33, 0.18);
  --text: #16121f;
  --text-muted: #5a526e;
  --shadow-elevated: 0 24px 64px rgba(33, 103, 177, 0.14);
  --shadow-glow-sm: 0 0 0 1px rgba(22, 18, 33, 0.06) inset;
  /* WCAG 1.4.3 op lichte achtergrond */
  --link: #174f86;
  --link-hover: #9a3412;
}

/* Oranje eyebrow op lichte page: brand-oranje (2,4:1) haalt AA niet; donkerder sienna */
html[data-theme="light"] .eyebrow {
  color: #9a3412;
}

html[data-theme="light"] ::selection {
  background: rgba(33, 103, 177, 0.22);
  color: var(--text);
}

html[data-theme="light"] .bg-gradient {
  background:
    radial-gradient(100% 70% at 15% -5%, rgba(33, 103, 177, 0.14), transparent 52%),
    radial-gradient(80% 55% at 95% 5%, rgba(241, 101, 50, 0.09), transparent 48%),
    radial-gradient(65% 45% at 50% 105%, rgba(193, 182, 207, 0.45), transparent 58%),
    linear-gradient(180deg, var(--purple-950) 0%, var(--purple-void) 45%, #ebe6f2 100%);
}

html[data-theme="light"] .bg-gradient__mesh {
  background-image:
    linear-gradient(rgba(22, 18, 33, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(22, 18, 33, 0.05) 1px, transparent 1px);
}

html[data-theme="light"] .bg-gradient__vignette {
  background: radial-gradient(ellipse 75% 60% at 50% 50%, transparent 42%, rgba(33, 103, 177, 0.06) 100%);
}

html[data-theme="light"] .bg-gradient__grain {
  opacity: 0.022;
}

@media (max-width: 1023px) {
  html[data-theme="light"] .bg-gradient {
    background:
      radial-gradient(100% 70% at 15% -5%, rgba(33, 103, 177, 0.14), transparent 52%),
      radial-gradient(65% 45% at 50% 105%, rgba(193, 182, 207, 0.45), transparent 58%),
      linear-gradient(180deg, var(--purple-950) 0%, var(--purple-void) 45%, #ebe6f2 100%);
  }
}

html[data-theme="light"] .header {
  background: rgba(255, 255, 255, 0.76);
}

html[data-theme="light"] .header.is-scrolled {
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 1px 0 rgba(22, 18, 33, 0.08), 0 12px 40px rgba(33, 103, 177, 0.08);
}

@media (max-width: 768px) {
  html[data-theme="light"] .header {
    background: rgba(255, 255, 255, 0.98);
  }
  html[data-theme="light"] .header.is-scrolled {
    background: rgba(255, 255, 255, 0.98);
  }
  html[data-theme="light"] .header__nav {
    background: rgba(255, 255, 255, 0.98);
  }
  html[data-theme="light"] .nav-backdrop {
    background: rgba(22, 18, 33, 0.38);
  }
}


html[data-theme="light"] .gradient-text {
  background: linear-gradient(100deg, var(--text) 0%, var(--logo-blue-mid) 48%, var(--logo-orange) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme="light"] .hero__title-strong {
  /* background-shorthand reset background-clip; zonder text-clip zie je een rechthoek i.p.v. gradient-tekst */
  background: linear-gradient(100deg, #16121f 0%, #4a6fa8 38%, var(--logo-blue-mid) 62%, var(--logo-orange) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

html[data-theme="light"] .hero__gridline {
  background-image: linear-gradient(rgba(22, 18, 33, 0.06) 1px, transparent 1px);
}

html[data-theme="light"] .hero__proof li {
  border-color: var(--border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), var(--surface));
}

html[data-theme="light"] .marquee {
  background: rgba(33, 103, 177, 0.04);
}

html[data-theme="light"] .block--about {
  background: linear-gradient(180deg, transparent 0%, rgba(33, 103, 177, 0.03) 40%, transparent 100%);
}

html[data-theme="light"] .block--quotes {
  background: radial-gradient(ellipse 80% 60% at 50% 100%, rgba(33, 103, 177, 0.06), transparent 65%);
}

html[data-theme="light"] .h2--light {
  color: var(--text);
}

html[data-theme="light"] .cta {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.9) 0%, transparent 42%),
    linear-gradient(120deg, rgba(33, 103, 177, 0.18) 0%, rgba(241, 101, 50, 0.06) 45%, var(--purple-900) 100%);
  border-color: rgba(33, 103, 177, 0.22);
  box-shadow: 0 0 0 1px rgba(22, 18, 33, 0.05) inset, 0 24px 56px rgba(33, 103, 177, 0.1);
}

html[data-theme="light"] .cta__p,
html[data-theme="light"] .cta__links {
  color: var(--text-muted);
}

html[data-theme="light"] .cta__links a {
  color: var(--link);
}

html[data-theme="light"] .cta__links a:hover {
  color: var(--link-hover);
}

html[data-theme="light"] .footer {
  background: linear-gradient(180deg, transparent, rgba(33, 103, 177, 0.04));
}

html[data-theme="light"] .card--accent {
  background: linear-gradient(145deg, rgba(33, 103, 177, 0.12), rgba(241, 101, 50, 0.05));
  border-color: rgba(33, 103, 177, 0.28);
}

html[data-theme="light"] .card--accent:hover {
  border-color: rgba(241, 101, 50, 0.35);
}

html[data-theme="light"] .bento__cell:hover {
  box-shadow: var(--shadow-glow-sm), 0 0 0 1px rgba(33, 103, 177, 0.2), 0 28px 64px rgba(33, 103, 177, 0.12);
}

html[data-theme="light"] .news-card:hover {
  box-shadow: var(--shadow-glow-sm), 0 0 0 1px rgba(33, 103, 177, 0.2), 0 28px 64px rgba(33, 103, 177, 0.12);
}

html[data-theme="light"] .quote:hover {
  box-shadow: var(--shadow-glow-sm), 0 20px 50px rgba(33, 103, 177, 0.12);
}

html[data-theme="light"] .tech-row li {
  background: rgba(255, 255, 255, 0.92);
}

html[data-theme="light"] .tech-row li.is-open {
  background: linear-gradient(180deg, #e8eef8 0%, #ffffff 55%, #fafbfd 100%);
  border-color: rgba(33, 103, 177, 0.38);
  box-shadow: var(--shadow-glow-sm), 0 20px 48px rgba(33, 103, 177, 0.14);
}

html[data-theme="light"] .is-open .tech-row__detail {
  scrollbar-color: rgba(22, 18, 33, 0.2) transparent;
}

html[data-theme="light"] .is-open .tech-row__detail::-webkit-scrollbar-thumb {
  background: rgba(22, 18, 33, 0.2);
}

html[data-theme="light"] .scroll-story__panel-title {
  background: linear-gradient(100deg, #16121f 0%, #3d5a80 40%, var(--logo-blue-mid) 72%, var(--logo-orange) 100%);
  background-size: 180% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html[data-theme="light"] .scroll-story__rail-track {
  background: rgba(22, 18, 33, 0.08);
}

html[data-theme="light"] .scroll-story__marker[data-marker="0"].is-upcoming,
html[data-theme="light"] .scroll-story__marker[data-marker="1"].is-upcoming,
html[data-theme="light"] .scroll-story__marker[data-marker="2"].is-upcoming {
  background: rgba(255, 255, 255, 0.95);
  border-color: rgba(22, 18, 33, 0.15);
}

html[data-theme="light"] .scroll-story__nav-btn {
  border-color: rgba(22, 18, 33, 0.18);
  background: rgba(255, 255, 255, 0.65);
  color: rgba(22, 18, 33, 0.65);
}

html[data-theme="light"] .scroll-story__nav-btn:hover:not(:disabled) {
  background: rgba(33, 103, 177, 0.1);
  border-color: rgba(33, 103, 177, 0.35);
  color: var(--text);
}

html[data-theme="light"] .quotes-slider__btn {
  border-color: rgba(22, 18, 33, 0.18);
  background: rgba(255, 255, 255, 0.65);
  color: rgba(22, 18, 33, 0.65);
}

html[data-theme="light"] .quotes-slider__btn:hover {
  background: rgba(33, 103, 177, 0.1);
  border-color: rgba(33, 103, 177, 0.35);
  color: var(--text);
}

html[data-theme="light"] .scroll-story__nav-label {
  color: rgba(22, 18, 33, 0.5);
}

html[data-theme="light"] .scroll-story__viewport-cue-icon {
  color: rgba(22, 18, 33, 0.52);
  filter: drop-shadow(0 2px 12px rgba(33, 103, 177, 0.2));
}

html[data-theme="light"] .showcase__window {
  border-color: var(--border);
  box-shadow: 0 0 0 1px rgba(22, 18, 33, 0.04) inset, 0 32px 80px rgba(33, 103, 177, 0.12);
}
/* Licht thema: echte (heldere) spotlight achter de UI — hete kern + zachte kegel, volgt --mx/--my */
html[data-theme="light"] .showcase__window::after {
  opacity: 1;
  background:
    radial-gradient(
      ellipse 36% 30% at var(--mx, 50%) var(--my, 30%),
      rgba(255, 255, 255, 0.98) 0%,
      rgba(255, 252, 248, 0.55) 32%,
      transparent 62%
    ),
    radial-gradient(
      ellipse 120% 105% at var(--mx, 50%) var(--my, 30%),
      rgba(255, 255, 255, 0.55) 0%,
      rgba(197, 216, 240, 0.22) 40%,
      transparent 70%
    );
}

html[data-theme="light"] .showcase__orbit {
  border-color: rgba(22, 18, 33, 0.1);
}

html[data-theme="light"] .showcase__orbit--b {
  border-color: rgba(33, 103, 177, 0.22);
}

/* Witte knop op lichte CTA: --purple-900 is daar pastel; tekst = bodykleur voor contrast */
html[data-theme="light"] .btn--inverse {
  color: var(--text);
  border: 1px solid rgba(22, 18, 33, 0.14);
}
html[data-theme="light"] .btn--inverse:hover {
  color: var(--text);
  filter: none;
  border-color: rgba(33, 103, 177, 0.35);
  background: #faf9fc;
}

html[data-theme="light"] .btn--line::after {
  background: linear-gradient(105deg, transparent 40%, rgba(33, 103, 177, 0.08) 50%, transparent 60%);
}

html[data-theme="light"] .ss-browser {
  border-color: var(--border);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.95), rgba(236, 232, 248, 0.85));
  box-shadow: 0 24px 56px rgba(33, 103, 177, 0.1), 0 0 0 1px rgba(22, 18, 33, 0.04) inset;
}

html[data-theme="light"] .ss-host-blade {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.92), rgba(236, 232, 248, 0.75));
  border-color: var(--border);
  box-shadow: 0 12px 32px rgba(33, 103, 177, 0.08);
}

html[data-theme="light"] .ss-code-frame {
  border-color: var(--border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(232, 228, 242, 0.92));
  box-shadow: 0 28px 64px rgba(33, 103, 177, 0.12);
}

html[data-theme="light"] .ss-code-header {
  border-bottom-color: var(--border);
  background: rgba(22, 18, 33, 0.04);
}

html[data-theme="light"] .ss-code-line {
  background: rgba(22, 18, 33, 0.12);
}

html[data-theme="light"] .ss-code-nodes {
  border-top-color: rgba(22, 18, 33, 0.12);
}

@media (prefers-reduced-motion: reduce) {
  html, body, a, button, .btn, .header__menu-btn, .theme-switch, .tech-row__btn {
    cursor: auto !important;
  }
  [data-animate], [data-hero-reveal] { opacity: 1; transform: none; filter: none; transition: none; }
  .hero__proof li { opacity: 1; transform: none; transition: none; }
  .hero__title-strong {
    animation: none;
    background: linear-gradient(100deg, #fff 0%, var(--logo-blue-mid) 50%, var(--logo-orange) 100%);
    background-size: 100% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
  }
  html[data-theme="light"] .hero__title-strong {
    animation: none;
    background: linear-gradient(100deg, #16121f 0%, var(--logo-blue-mid) 50%, var(--logo-orange) 100%);
    background-size: 100% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
  }
  .showcase__orbit, .showcase__progress-bar, .showcase__bars span, .showcase__cursor { animation: none; }
  .showcase__window { transform: none !important; }
  .marquee__track { animation: none; }
  .page-curtain { display: none; }
  .btn--solid::after, .btn--line::after { display: none; }
  .scroll-story__glow,
  .ss-design-orbit,
  .ss-browser__grid,
  .ss-browser__shine,
  .ss-browser__cards span,
  .ss-host-led,
  .ss-host-bar,
  .ss-host-ring,
  .ss-code-line,
  .ss-node,
  .ss-node-arc,
  .scroll-story__hint-icon { animation: none !important; }
  .scroll-story__viewport-cue-icon { animation: none !important; }
  .scroll-story__geo { display: none; }
  .showcase-html__bolt { animation: none !important; }
}
