/* ---------------------------------------------------------------
   J&J Verhuur — Design System
   Editorial-outdoor: forest green + warm amber on cream,
   Fraunces (display serif) + Manrope (humanist sans).
--------------------------------------------------------------- */

/* ===============================
   Tokens
   =============================== */
:root {
  /* Colour — forest, river, sun */
  --c-primary:        #1B6B3A;   /* forest green */
  --c-primary-dark:   #0E4924;   /* deep evergreen, headers/footer */
  --c-primary-light:  #4CAF72;   /* sprout green, hover states */
  --c-primary-tint:   #E6F1E9;   /* faint green wash for blocks */

  --c-accent:         #E07A24;   /* warm amber-orange — matches J&J logo */
  --c-accent-dark:    #B85B14;
  --c-accent-light:   #FCD34D;
  --c-accent-tint:    #FFF4E0;

  --c-water:          #1E88C6;
  --c-ebike:          #6D43C0;   /* purple — e-bike badge only */
  --c-ebike-tint:     #EFE8FB;

  --c-ink:            #181814;   /* body text */
  --c-ink-soft:       #4A4A42;   /* secondary text */
  --c-ink-muted:      #8A8A82;   /* meta, captions */
  --c-line:           #DDD9CE;   /* hairlines */

  --c-cream:          #F7F2E7;   /* warm off-white background */
  --c-cream-deep:     #EFE7D2;   /* alt section bg */
  --c-paper:          #FFFDF8;   /* card surface */
  --c-white:          #FFFFFF;

  --c-success:        #16A34A;
  --c-error:          #DC2626;

  /* Type */
  --ff-display: 'Fraunces', 'Source Serif 4', Georgia, serif;
  --ff-body:    'Manrope', 'Helvetica Neue', system-ui, sans-serif;
  --ff-mono:    'JetBrains Mono', ui-monospace, monospace;

  /* Spacing — 8px base */
  --s-1:  4px;   --s-2:  8px;   --s-3: 12px;   --s-4: 16px;
  --s-5: 24px;   --s-6: 32px;   --s-7: 40px;   --s-8: 56px;
  --s-9: 72px;   --s-10: 96px;  --s-11: 128px;

  /* Radius */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --r-xl: 22px;
  --r-pill: 999px;

  /* Shadows */
  --sh-sm: 0 1px 2px rgba(20, 25, 15, .06), 0 0 0 1px rgba(20, 25, 15, .04);
  --sh-md: 0 8px 24px -10px rgba(20, 25, 15, .18), 0 2px 6px -2px rgba(20, 25, 15, .06);
  --sh-lg: 0 24px 60px -20px rgba(20, 25, 15, .25), 0 6px 20px -8px rgba(20, 25, 15, .10);

  /* Layout */
  --maxw: 1240px;
  --maxw-narrow: 840px;
  --gutter: 24px;

  /* Motion */
  --ease-out:  cubic-bezier(.2, .7, .2, 1);
  --ease-soft: cubic-bezier(.4, .0, .2, 1);
  --t-quick: 160ms;
  --t-base:  280ms;
  --t-slow:  520ms;
}

/* ===============================
   Reset / base
   =============================== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  font-family: var(--ff-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--c-ink);
  background: var(--c-cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "ss02", "kern";
  padding-top: var(--site-top-h, 110px);
}

img, svg, video {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration-color: rgba(27, 107, 58, .35);
  text-underline-offset: 3px;
  transition: color var(--t-quick) var(--ease-out),
              text-decoration-color var(--t-quick) var(--ease-out);
}
a:hover { color: var(--c-primary); text-decoration-color: var(--c-primary); }

button {
  font: inherit;
  color: inherit;
  cursor: pointer;
  border: 0;
  background: transparent;
}

::selection { background: var(--c-accent); color: var(--c-ink); }

:focus-visible {
  outline: 2px solid var(--c-primary);
  outline-offset: 3px;
  border-radius: var(--r-sm);
}

/* ===============================
   Typography
   =============================== */
.eyebrow {
  font-family: var(--ff-body);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-primary);
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
.eyebrow::before {
  content: "";
  width: 28px; height: 1px;
  background: currentColor;
  display: inline-block;
}

h1, h2, h3, h4 {
  font-family: var(--ff-display);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--c-primary-dark);
  font-variation-settings: "opsz" 144, "SOFT" 30;
}

.h-display {
  font-size: clamp(2.5rem, 5.6vw, 4.5rem);
  letter-spacing: -0.025em;
  line-height: 1.02;
  font-weight: 500;
}

h1 { font-size: clamp(2.25rem, 4.6vw, 3.6rem); }
h2 { font-size: clamp(1.85rem, 3.4vw, 2.6rem); line-height: 1.1; }
h3 { font-size: clamp(1.25rem, 1.8vw, 1.5rem); line-height: 1.25; }
h4 { font-size: 1.1rem; line-height: 1.3; font-weight: 600; font-variation-settings: "opsz" 24; }

.lede {
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  line-height: 1.55;
  color: var(--c-ink-soft);
  max-width: 60ch;
}

.serif-italic { font-family: var(--ff-display); font-style: italic; font-weight: 400; }

.script-accent {
  font-family: var(--ff-display);
  font-style: italic;
  font-weight: 400;
  color: var(--c-accent);
}

.small-caps {
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--c-ink-soft);
}

/* ===============================
   Layout primitives
   =============================== */
.container {
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.container--narrow { max-width: var(--maxw-narrow); }

section { padding-block: var(--s-10); }
@media (max-width: 720px) { section { padding-block: var(--s-8); } }

.split { display: grid; gap: var(--s-7); }
@media (min-width: 880px) {
  .split-2 { grid-template-columns: 1fr 1fr; }
  .split-3 { grid-template-columns: 1fr 1fr 1fr; }
  .split-asym { grid-template-columns: 5fr 7fr; gap: var(--s-8); align-items: center; }
}

.stack > * + * { margin-top: var(--s-4); }
.stack-lg > * + * { margin-top: var(--s-6); }

/* ===============================
   Buttons
   =============================== */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 14px 24px;
  border-radius: var(--r-pill);
  font-family: var(--ff-body);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: .005em;
  white-space: nowrap;
  transition: transform var(--t-quick) var(--ease-out),
              background var(--t-quick) var(--ease-out),
              color var(--t-quick) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out),
              filter var(--t-quick) var(--ease-out);
  text-decoration: none;
  line-height: 1;
  isolation: isolate;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  background: linear-gradient(180deg, #F09238 0%, var(--c-accent) 60%, #CB6810 100%);
  color: #1A1305;
  font-weight: 600;
  letter-spacing: .01em;
  box-shadow:
    inset 0 1px 0 rgba(255, 230, 190, .65),
    inset 0 -1.5px 0 rgba(120, 50, 5, .22),
    0 1px 2px rgba(20, 25, 15, .08),
    0 8px 18px -8px rgba(184, 91, 20, .5);
}
.btn--primary:hover {
  background: linear-gradient(180deg, #F4A04A 0%, #DB7820 60%, #B45A10 100%);
  color: #1A1305;
  box-shadow:
    inset 0 1px 0 rgba(255, 230, 190, .65),
    inset 0 -1.5px 0 rgba(120, 50, 5, .28),
    0 2px 4px rgba(20, 25, 15, .1),
    0 14px 26px -10px rgba(184, 91, 20, .6);
}
.btn--primary:active {
  box-shadow:
    inset 0 2px 4px rgba(120, 50, 5, .25),
    0 1px 2px rgba(20, 25, 15, .08);
  filter: brightness(.97);
}
.btn--primary:focus-visible {
  outline: 3px solid rgba(224, 122, 36, .4);
  outline-offset: 3px;
}

.btn--secondary {
  background: var(--c-primary-dark);
  color: #FFF;
}
.btn--secondary:hover { background: var(--c-primary); color: #FFF; }

.btn--ghost {
  background: transparent;
  color: var(--c-primary-dark);
  box-shadow: inset 0 0 0 1.5px var(--c-primary-dark);
}
.btn--ghost:hover {
  background: var(--c-primary-dark);
  color: #FFF;
}

.btn--ghost-light {
  background: transparent;
  color: #FFF;
  box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.7);
}
.btn--ghost-light:hover {
  background: #FFF;
  color: var(--c-primary-dark);
}

.btn--lg { padding: 18px 30px; font-size: 16px; }
.btn--sm {
  padding: 11px 22px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .015em;
}
.btn--sm .arrow { font-size: 14px; opacity: .9; }

.btn .arrow {
  transition: transform var(--t-quick) var(--ease-out);
  display: inline-block;
}
.btn:hover .arrow { transform: translateX(3px); }

.text-link {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  color: var(--c-primary-dark);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1.5px solid var(--c-primary-dark);
  padding-bottom: 1px;
}
.text-link:hover { color: var(--c-accent-dark); border-color: var(--c-accent-dark); }

/* ===============================
   Top bar + Header
   =============================== */
.site-top {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  transition: box-shadow var(--t-base) var(--ease-out);
}
.site-top.is-scrolled .site-header {
  box-shadow: 0 14px 28px -22px rgba(14, 73, 36, .45);
}

.topbar {
  background: var(--c-primary-dark);
  color: #E8F1EA;
  font-size: 13px;
  letter-spacing: .02em;
}
.topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
  padding-block: 8px;
  flex-wrap: wrap;
}
.topbar a { color: inherit; text-decoration: none; opacity: .9; }
.topbar a:hover { opacity: 1; color: var(--c-accent-light); }
.topbar__sep {
  display: inline-block;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--c-accent);
  margin-inline: var(--s-2);
  vertical-align: middle;
}

.site-header {
  background: rgba(247, 242, 231, 0.94);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--c-line);
  box-shadow: 0 6px 20px -16px rgba(14, 73, 36, .35);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
  padding-block: var(--s-3);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  text-decoration: none;
  color: var(--c-primary-dark);
}
.brand__logo {
  height: 44px;
  width: auto;
  border-radius: var(--r-sm);
  background: #FFF;
  padding: 4px 6px;
  box-shadow: var(--sh-sm);
}
.brand__name {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.01em;
  line-height: 1;
  font-variation-settings: "opsz" 60;
}
.brand__name em {
  font-style: italic;
  color: var(--c-accent-dark);
  font-weight: 500;
}

.nav {
  display: flex;
  align-items: center;
  gap: var(--s-5);
}
.nav a {
  font-size: 15px;
  font-weight: 500;
  text-decoration: none;
  color: var(--c-ink);
  position: relative;
  padding: 6px 2px;
}
.nav a:hover { color: var(--c-primary-dark); }
.nav a.is-active::after {
  content: "";
  position: absolute;
  left: 2px; right: 2px; bottom: 0;
  height: 2px;
  background: var(--c-accent);
}
.nav .btn--primary {
  margin-left: var(--s-2);
  padding: 11px 22px;
  box-shadow:
    inset 0 1px 0 rgba(255, 220, 170, .55),
    inset 0 -1.5px 0 rgba(120, 50, 5, .25),
    0 1px 2px rgba(20, 25, 15, .08),
    0 4px 10px -4px rgba(184, 91, 20, .45);
}
.nav .btn--primary:hover {
  box-shadow:
    inset 0 1px 0 rgba(255, 220, 170, .55),
    inset 0 -1.5px 0 rgba(120, 50, 5, .3),
    0 2px 4px rgba(20, 25, 15, .1),
    0 10px 20px -8px rgba(184, 91, 20, .6);
}

.nav-toggle {
  display: none;
  width: 40px; height: 40px;
  border-radius: var(--r-sm);
  background: transparent;
  align-items: center;
  justify-content: center;
}
.nav-toggle svg { width: 22px; height: 22px; stroke: var(--c-ink); }

@media (max-width: 940px) {
  .nav-toggle { display: inline-flex; }
  .nav {
    position: fixed;
    top: 0; right: 0;
    height: 100vh;
    width: min(360px, 84vw);
    background: var(--c-cream);
    flex-direction: column;
    align-items: stretch;
    padding: 80px var(--s-6) var(--s-6);
    gap: var(--s-2);
    transform: translateX(100%);
    transition: transform var(--t-base) var(--ease-out);
    box-shadow: var(--sh-lg);
    z-index: 60;
    overflow-y: auto;
  }
  .nav a {
    padding: 14px 12px;
    border-bottom: 1px solid var(--c-line);
    font-size: 18px;
  }
  .nav .btn { margin-top: var(--s-3); }
  body.nav-open .nav { transform: translateX(0); }
  body.nav-open::before {
    content: "";
    position: fixed; inset: 0;
    background: rgba(14, 73, 36, .35);
    backdrop-filter: blur(2px);
    z-index: 55;
  }
}

/* ===============================
   Hero
   =============================== */
.hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding-block: clamp(72px, 10vw, 130px);
  color: #FFF;
  background: var(--c-primary-dark);
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 60%;
  filter: saturate(105%) brightness(.92);
}
.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(120% 80% at 0% 100%, rgba(14, 73, 36, .85) 0%, rgba(14, 73, 36, .35) 35%, transparent 60%),
    linear-gradient(180deg, rgba(14, 73, 36, .25) 0%, rgba(14, 73, 36, .55) 100%);
  z-index: 1;
}
.hero__inner {
  position: relative;
  z-index: 2;
  display: grid;
  gap: var(--s-6);
  max-width: 720px;
}
.hero__eyebrow {
  color: var(--c-accent-light);
}
.hero__eyebrow::before { background: var(--c-accent-light); }

.hero__title {
  color: #FFF;
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 6.2vw, 5rem);
  line-height: .98;
  letter-spacing: -0.03em;
  font-weight: 400;
  font-variation-settings: "opsz" 144, "SOFT" 50;
}
.hero__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--c-accent-light);
}
.hero__subtitle {
  color: rgba(255, 253, 248, .92);
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  max-width: 56ch;
  line-height: 1.55;
}
.hero__ctas {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
  margin-top: var(--s-2);
}
.hero__stats {
  display: flex;
  gap: var(--s-6);
  flex-wrap: wrap;
  margin-top: var(--s-6);
  padding-top: var(--s-5);
  border-top: 1px solid rgba(255,255,255,.18);
}
.hero__stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.hero__stat-num {
  font-family: var(--ff-display);
  font-size: 1.6rem;
  line-height: 1;
  color: #FFF;
  font-weight: 500;
}
.hero__stat-label {
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255, 253, 248, .7);
  font-weight: 600;
}

/* ===============================
   Locatiekeuze section
   =============================== */
.locations {
  background: var(--c-cream);
}
.locations__head {
  display: grid;
  gap: var(--s-3);
  margin-bottom: var(--s-8);
  max-width: 720px;
}
.location-grid {
  display: grid;
  gap: var(--s-5);
}
@media (min-width: 880px) {
  .location-grid { grid-template-columns: 1fr 1fr; gap: var(--s-6); }
}

.loc-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: var(--r-xl);
  background: var(--c-paper);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  box-shadow: var(--sh-sm);
  transition: transform var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out);
}
.loc-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-lg);
}
.loc-card__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  position: relative;
}
.loc-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--t-slow) var(--ease-out);
}
.loc-card:hover .loc-card__media img { transform: scale(1.04); }
.loc-card__badge {
  position: absolute;
  top: var(--s-4); left: var(--s-4);
  background: rgba(255, 253, 248, .94);
  color: var(--c-primary-dark);
  padding: 6px 12px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.loc-card__body {
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  flex: 1;
}
.loc-card__title {
  font-family: var(--ff-display);
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--c-primary-dark);
  line-height: 1.15;
  letter-spacing: -0.015em;
}
.loc-card__addr {
  color: var(--c-ink-soft);
  font-size: 14px;
  line-height: 1.5;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.loc-card__desc {
  color: var(--c-ink-soft);
  font-size: 15px;
  line-height: 1.55;
}
.loc-card__cta {
  margin-top: auto;
  padding-top: var(--s-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  border-top: 1px solid var(--c-line);
}
.loc-card__cta-text {
  font-weight: 600;
  color: var(--c-primary-dark);
}
.loc-card__cta-arrow {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--c-accent);
  color: #1A1305;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-quick) var(--ease-out),
              transform var(--t-quick) var(--ease-out);
}
.loc-card:hover .loc-card__cta-arrow {
  background: var(--c-accent-dark);
  color: #FFF;
  transform: translateX(4px);
}

/* ===============================
   Bike type cards
   =============================== */
.bikes {
  background: var(--c-cream-deep);
  position: relative;
}
.bike-grid {
  display: grid;
  gap: var(--s-5);
}
@media (min-width: 880px) {
  .bike-grid { grid-template-columns: 1fr 1fr; }
}

.bike-card {
  position: relative;
  background: var(--c-paper);
  border-radius: var(--r-xl);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  box-shadow: var(--sh-sm);
  border: 1px solid var(--c-line);
}
.bike-card--ebike {
  background:
    radial-gradient(120% 100% at 100% 0%, var(--c-ebike-tint) 0%, transparent 60%),
    var(--c-paper);
  border-color: rgba(109, 67, 192, .25);
}
.bike-card__media {
  aspect-ratio: 5 / 3;
  background: var(--c-cream);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--c-line);
}
.bike-card__media img { width: 90%; height: auto; object-fit: contain; }
.bike-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--s-4);
}
.bike-card__name {
  font-family: var(--ff-display);
  font-size: 1.5rem;
  color: var(--c-primary-dark);
  font-weight: 500;
  line-height: 1.15;
}
.bike-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--c-ebike);
  color: #FFF;
  padding: 5px 10px;
  border-radius: var(--r-pill);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 700;
  white-space: nowrap;
}
.bike-card__badge--standard {
  background: var(--c-primary-tint);
  color: var(--c-primary-dark);
}
.bike-card__price-block {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--s-3) var(--s-4);
  padding: var(--s-3) 0;
  border-top: 1px dashed var(--c-line);
  border-bottom: 1px dashed var(--c-line);
}
.bike-card__price-main {
  font-family: var(--ff-display);
  font-size: 2rem;
  font-weight: 500;
  color: var(--c-primary-dark);
  line-height: 1;
}
.bike-card__price-unit {
  font-size: 14px;
  color: var(--c-ink-soft);
}
.bike-card__price-borg {
  font-size: 13px;
  color: var(--c-ebike);
  font-weight: 600;
}
.bike-card__features {
  list-style: none;
  padding: 0;
  display: grid;
  gap: 8px;
  font-size: 14px;
  color: var(--c-ink-soft);
}
.bike-card__features li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.bike-card__features svg { flex: 0 0 auto; margin-top: 3px; color: var(--c-primary); }

/* ===============================
   How it works
   =============================== */
.how {
  background: var(--c-cream);
}
.how__head {
  text-align: center;
  margin-inline: auto;
  margin-bottom: var(--s-7);
  max-width: 640px;
  display: grid;
  gap: var(--s-3);
  justify-items: center;
}
.how__tabs {
  display: inline-flex;
  background: var(--c-paper);
  padding: 4px;
  border-radius: var(--r-pill);
  border: 1px solid var(--c-line);
  margin-bottom: var(--s-7);
  margin-inline: auto;
}
.how__tab {
  padding: 10px 20px;
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: 14px;
  color: var(--c-ink-soft);
  background: transparent;
  transition: background var(--t-quick), color var(--t-quick);
}
.how__tab[aria-selected="true"] {
  background: var(--c-primary-dark);
  color: #FFF;
}

.how-tabs-wrap {
  display: flex;
  justify-content: center;
}

.steps {
  display: grid;
  gap: var(--s-5);
  counter-reset: stp;
}
@media (min-width: 720px) { .steps--4 { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 720px) { .steps--5 { grid-template-columns: repeat(5, 1fr); } }

.steps[hidden] { display: none; }

.step {
  background: var(--c-paper);
  border-radius: var(--r-lg);
  padding: var(--s-6) var(--s-5);
  border: 1px solid var(--c-line);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  counter-increment: stp;
  min-height: 200px;
}
.step--ebike-final {
  background: linear-gradient(180deg, var(--c-ebike-tint), var(--c-paper) 70%);
  border-color: rgba(109, 67, 192, .3);
}
.step__num {
  font-family: var(--ff-display);
  font-size: 2.5rem;
  font-style: italic;
  font-weight: 400;
  color: var(--c-accent-dark);
  line-height: 1;
}
.step--ebike-final .step__num { color: var(--c-ebike); }
.step__title {
  font-family: var(--ff-display);
  font-weight: 500;
  font-size: 1.15rem;
  color: var(--c-primary-dark);
  line-height: 1.2;
}
.step__body {
  font-size: 14px;
  line-height: 1.55;
  color: var(--c-ink-soft);
}

/* ===============================
   Borg block
   =============================== */
.borg {
  background: var(--c-primary-dark);
  color: #F1EAD3;
  position: relative;
  overflow: hidden;
}
.borg::before {
  content: "";
  position: absolute;
  inset: -10% -10% auto auto;
  width: 60%;
  height: 80%;
  background: radial-gradient(circle at 70% 30%, rgba(252, 211, 77, .12), transparent 60%);
  pointer-events: none;
}
.borg .container { position: relative; }
.borg__head {
  display: grid;
  gap: var(--s-3);
  margin-bottom: var(--s-7);
  max-width: 760px;
}
.borg .eyebrow { color: var(--c-accent-light); }
.borg .eyebrow::before { background: var(--c-accent-light); }
.borg__title {
  color: #FFFDF8;
  font-family: var(--ff-display);
  font-size: clamp(2rem, 3.6vw, 3rem);
  line-height: 1.05;
  font-weight: 500;
  letter-spacing: -0.02em;
}
.borg__title em { color: var(--c-accent-light); font-style: italic; }
.borg__lede {
  color: rgba(241, 234, 211, .85);
  font-size: 1.1rem;
  max-width: 60ch;
  line-height: 1.6;
}

.borg-grid {
  display: grid;
  gap: var(--s-5);
}
@media (min-width: 880px) { .borg-grid { grid-template-columns: repeat(3, 1fr); } }

.borg-card {
  background: rgba(255, 253, 248, .06);
  border: 1px solid rgba(255, 253, 248, .12);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.borg-card__icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--c-accent);
  color: #1A1305;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.borg-card h3 {
  color: #FFFDF8;
  font-size: 1.25rem;
  font-weight: 500;
}
.borg-card p {
  color: rgba(241, 234, 211, .8);
  font-size: 15px;
  line-height: 1.6;
}

.borg__placeholder {
  display: inline-block;
  background: rgba(252, 211, 77, .14);
  color: var(--c-accent-light);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: var(--ff-mono);
  font-size: 0.85em;
  border: 1px dashed rgba(252, 211, 77, .35);
}

/* ===============================
   Routes / omgeving
   =============================== */
.routes {
  background: var(--c-cream);
}
.routes-grid {
  display: grid;
  gap: var(--s-5);
}
@media (min-width: 880px) { .routes-grid { grid-template-columns: repeat(3, 1fr); } }

.route-card {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  display: flex;
  align-items: flex-end;
  padding: var(--s-5);
  color: #FFF;
  text-decoration: none;
  background: var(--c-primary-dark);
}
.route-card__img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
  transition: transform var(--t-slow) var(--ease-out);
}
.route-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(14, 73, 36, .85) 100%);
  z-index: 1;
}
.route-card:hover .route-card__img { transform: scale(1.06); }
.route-card__body {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 6px;
}
.route-card__kicker {
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-accent-light);
  font-weight: 600;
}
.route-card__title {
  font-family: var(--ff-display);
  font-size: 1.5rem;
  font-weight: 500;
  color: #FFF;
}
.route-card__meta {
  font-size: 13px;
  color: rgba(255,253,248,.85);
}

/* ===============================
   FAQ
   =============================== */
.faq { background: var(--c-cream); }
.faq__head {
  display: grid;
  gap: var(--s-3);
  margin-bottom: var(--s-7);
  max-width: 720px;
}
.faq-list {
  display: grid;
  gap: var(--s-3);
}
.faq-item {
  background: var(--c-paper);
  border: 1px solid var(--c-line);
  border-radius: var(--r-md);
  padding: var(--s-4) var(--s-5);
  transition: box-shadow var(--t-quick) var(--ease-out),
              border-color var(--t-quick) var(--ease-out);
}
.faq-item[open] {
  box-shadow: var(--sh-sm);
  border-color: var(--c-primary-light);
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
  font-family: var(--ff-display);
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--c-primary-dark);
  padding-block: 6px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item__icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--c-primary-tint);
  color: var(--c-primary-dark);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  transition: transform var(--t-quick) var(--ease-out),
              background var(--t-quick);
}
.faq-item[open] .faq-item__icon {
  transform: rotate(45deg);
  background: var(--c-accent);
  color: #1A1305;
}
.faq-item p {
  margin-top: var(--s-3);
  color: var(--c-ink-soft);
  font-size: 15px;
  line-height: 1.6;
}

/* ===============================
   Help / call-out
   =============================== */
.help-band {
  background: var(--c-accent-tint);
  border-top: 1px solid var(--c-cream-deep);
  border-bottom: 1px solid var(--c-cream-deep);
}
.help-band__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
  flex-wrap: wrap;
}
.help-band__msg {
  display: flex;
  align-items: center;
  gap: var(--s-4);
}
.help-band__icon {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--c-accent);
  color: #1A1305;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.help-band__title {
  font-family: var(--ff-display);
  font-size: 1.3rem;
  font-weight: 500;
  color: var(--c-primary-dark);
  line-height: 1.2;
}
.help-band__sub {
  color: var(--c-ink-soft);
  font-size: 14px;
  margin-top: 2px;
}

/* ===============================
   Footer
   =============================== */
.site-footer {
  background: var(--c-primary-dark);
  color: #DDE7DD;
  padding-block: var(--s-9) var(--s-6);
}
.footer-grid {
  display: grid;
  gap: var(--s-7);
  grid-template-columns: 1fr;
  margin-bottom: var(--s-8);
}
@media (min-width: 720px) {
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; }
}
.footer-brand .brand__logo { background: #FFF; }
.footer-brand .brand__name { color: #FFFDF8; }
.footer-brand p {
  margin-top: var(--s-4);
  color: rgba(221, 231, 221, .7);
  max-width: 36ch;
  font-size: 14px;
  line-height: 1.6;
}
.footer-col h4 {
  font-family: var(--ff-body);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-accent-light);
  margin-bottom: var(--s-4);
  font-weight: 700;
}
.footer-col ul { list-style: none; padding: 0; display: grid; gap: 10px; }
.footer-col a {
  color: rgba(221, 231, 221, .85);
  text-decoration: none;
  font-size: 15px;
}
.footer-col a:hover { color: var(--c-accent-light); }
.footer-col address {
  font-style: normal;
  color: rgba(221, 231, 221, .85);
  font-size: 14px;
  line-height: 1.6;
}
.footer-meta {
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: var(--s-4);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--s-3);
  font-size: 13px;
  color: rgba(221, 231, 221, .55);
}

/* ===============================
   Page header (sub-pages)
   =============================== */
.page-head {
  background: var(--c-primary-dark);
  color: #FFF;
  padding-block: var(--s-9) var(--s-7);
  position: relative;
}
.page-head__crumbs {
  font-size: 13px;
  color: rgba(241, 234, 211, .7);
  margin-bottom: var(--s-3);
  letter-spacing: .04em;
}
.page-head__crumbs a { color: inherit; text-decoration: none; }
.page-head__crumbs a:hover { color: var(--c-accent-light); }
.page-head__title {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: #FFF;
  max-width: 18ch;
  line-height: 1.05;
}
.page-head__title em { color: var(--c-accent-light); font-style: italic; }
.page-head__sub {
  margin-top: var(--s-4);
  max-width: 60ch;
  color: rgba(241, 234, 211, .85);
  line-height: 1.6;
}

/* ===============================
   Location detail
   =============================== */
.loc-hero {
  display: grid;
  gap: var(--s-6);
}
@media (min-width: 880px) {
  .loc-hero { grid-template-columns: 1.1fr .9fr; align-items: center; }
}
.loc-hero__media {
  border-radius: var(--r-xl);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.loc-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.loc-info {
  background: var(--c-paper);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  border: 1px solid var(--c-line);
  display: grid;
  gap: var(--s-4);
}
.loc-info dt {
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-ink-muted);
  font-weight: 600;
  margin-bottom: 4px;
}
.loc-info dd {
  font-size: 16px;
  color: var(--c-ink);
  margin-bottom: var(--s-3);
}

/* ===============================
   Misc
   =============================== */
.divider {
  height: 1px;
  background: var(--c-line);
  margin-block: var(--s-8);
}

.text-center { text-align: center; }
.muted { color: var(--c-ink-muted); }

/* ===============================
   Skip link / a11y helpers
   =============================== */
.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;
  top: 8px; left: 8px;
  z-index: 100;
  background: var(--c-accent);
  color: #1A1305;
  padding: 10px 16px;
  border-radius: var(--r-sm);
  font-weight: 600;
  text-decoration: none;
  transform: translateY(-200%);
  transition: transform var(--t-quick) var(--ease-out);
}
.skip-link:focus { transform: translateY(0); }

/* ===============================
   Reveal on scroll (subtle)
   =============================== */
@media (prefers-reduced-motion: no-preference) {
  .reveal {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity var(--t-slow) var(--ease-out),
                transform var(--t-slow) var(--ease-out);
  }
  .reveal.is-visible { opacity: 1; transform: none; }
}

/* ===============================
   Booking flow (reserveer.php)
   =============================== */
.booking-grid {
  display: grid;
  gap: var(--s-7);
  align-items: start;
}
@media (min-width: 960px) {
  .booking-grid {
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: var(--s-8);
  }
}

.booking-form {
  background: var(--c-paper);
  border: 1px solid var(--c-line);
  border-radius: var(--r-xl);
  padding: clamp(var(--s-5), 4vw, var(--s-8));
  box-shadow: var(--sh-md);
}
.booking-form__group {
  border: 0;
  padding: 0;
  margin: 0 0 var(--s-7) 0;
}
.booking-form__group:last-of-type { margin-bottom: var(--s-5); }
.booking-form__group legend {
  font-family: var(--ff-display);
  font-size: 1.25rem;
  color: var(--c-primary-dark);
  font-weight: 500;
  margin-bottom: var(--s-4);
  letter-spacing: -.01em;
}

.booking-radio-grid {
  display: grid;
  gap: var(--s-3);
}
@media (min-width: 560px) {
  .booking-radio-grid { grid-template-columns: 1fr 1fr; }
}
.booking-radio { cursor: pointer; display: block; }
.booking-radio input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.booking-radio__card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--s-4) var(--s-5);
  border-radius: var(--r-lg);
  border: 1.5px solid var(--c-line);
  background: var(--c-cream);
  transition: border-color var(--t-quick) var(--ease-out),
              background var(--t-quick) var(--ease-out),
              box-shadow var(--t-quick) var(--ease-out);
}
.booking-radio__card strong {
  font-family: var(--ff-display);
  font-size: 1.1rem;
  color: var(--c-primary-dark);
  font-weight: 500;
}
.booking-radio__card span { color: var(--c-ink-soft); font-size: 14px; }
.booking-radio:hover .booking-radio__card {
  border-color: var(--c-primary-light);
  background: var(--c-primary-tint);
}
.booking-radio input:checked + .booking-radio__card {
  border-color: var(--c-primary-dark);
  background: var(--c-primary-tint);
  box-shadow: 0 0 0 3px rgba(27, 107, 58, .12);
}
.booking-radio input:focus-visible + .booking-radio__card {
  outline: 2px solid var(--c-primary);
  outline-offset: 3px;
}

.booking-field-row {
  display: grid;
  gap: var(--s-4);
}
@media (min-width: 560px) {
  .booking-field-row { grid-template-columns: 1fr 1fr; }
}
.booking-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: var(--s-4);
}
.booking-field-row .booking-field { margin-bottom: 0; }
.booking-field > span {
  font-size: 14px;
  font-weight: 600;
  color: var(--c-ink-soft);
  letter-spacing: .01em;
}
.booking-field input,
.booking-field select {
  font: inherit;
  padding: 12px 14px;
  border-radius: var(--r-md);
  border: 1.5px solid var(--c-line);
  background: var(--c-cream);
  color: var(--c-ink);
  transition: border-color var(--t-quick) var(--ease-out),
              box-shadow var(--t-quick) var(--ease-out),
              background var(--t-quick) var(--ease-out);
}
.booking-field input:focus,
.booking-field select:focus {
  outline: none;
  border-color: var(--c-primary-dark);
  background: #FFF;
  box-shadow: 0 0 0 3px rgba(27, 107, 58, .15);
}

.booking-form__error {
  display: block;
  margin-top: 6px;
  color: var(--c-error);
  font-size: 13px;
  font-style: normal;
}

.booking-form__submit {
  width: 100%;
  margin-top: var(--s-3);
}
@media (min-width: 560px) {
  .booking-form__submit { width: auto; }
}
.booking-form__finetext {
  margin-top: var(--s-3);
  font-size: 13px;
  color: var(--c-ink-muted);
}

.booking-aside {
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
}
@media (min-width: 960px) {
  .booking-aside {
    position: sticky;
    top: calc(var(--site-top-h, 110px) + var(--s-4));
  }
}
.booking-aside__card,
.booking-aside__steps {
  background: var(--c-paper);
  border: 1px solid var(--c-line);
  border-radius: var(--r-xl);
  padding: var(--s-6);
  box-shadow: var(--sh-sm);
}
.booking-aside__card h3 {
  margin-top: var(--s-2);
  font-size: 1.4rem;
}
.booking-aside__list {
  margin-top: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  border-top: 1px solid var(--c-line);
  padding-top: var(--s-4);
}
.booking-aside__list > div {
  display: flex;
  justify-content: space-between;
  gap: var(--s-3);
  font-size: 15px;
}
.booking-aside__list dt { color: var(--c-ink-soft); }
.booking-aside__list dd { font-weight: 600; }
.booking-aside__total {
  border-top: 1px dashed var(--c-line);
  padding-top: var(--s-3);
  margin-top: var(--s-2);
}
.booking-aside__total dd {
  font-family: var(--ff-display);
  font-size: 1.4rem;
  color: var(--c-primary-dark);
}
.booking-aside__borg {
  margin-top: var(--s-4);
  padding: var(--s-4);
  background: var(--c-ebike-tint);
  border-radius: var(--r-md);
  font-size: 14px;
  color: var(--c-ink-soft);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.booking-aside__steps h4 {
  margin-bottom: var(--s-3);
  color: var(--c-primary-dark);
}
.booking-aside__steps ol {
  margin: 0;
  padding-left: 1.2em;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  color: var(--c-ink-soft);
  font-size: 15px;
}

/* Confirmation state */
.booking-confirm {
  max-width: 720px;
  margin: 0 auto;
  background: var(--c-paper);
  border: 1px solid var(--c-line);
  border-radius: var(--r-xl);
  padding: clamp(var(--s-6), 5vw, var(--s-9));
  box-shadow: var(--sh-md);
  text-align: center;
}
.booking-confirm__check {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  margin: 0 auto var(--s-5);
  display: grid;
  place-items: center;
  background: var(--c-primary-tint);
  color: var(--c-primary-dark);
  box-shadow: 0 0 0 6px rgba(27, 107, 58, .08);
}
.booking-confirm__check svg { width: 38px; height: 38px; }
.booking-confirm h2 {
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
}

.booking-summary {
  margin-top: var(--s-7);
  text-align: left;
  background: var(--c-cream);
  border-radius: var(--r-lg);
  padding: var(--s-5) var(--s-6);
  border: 1px solid var(--c-line);
}
.booking-summary dl {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.booking-summary > dl > div {
  display: flex;
  justify-content: space-between;
  gap: var(--s-3);
  font-size: 15px;
}
.booking-summary dt { color: var(--c-ink-soft); }
.booking-summary dd { font-weight: 600; text-align: right; }
.booking-summary__total {
  border-top: 1px dashed var(--c-line);
  padding-top: var(--s-3);
  margin-top: var(--s-2);
}
.booking-summary__total dd {
  font-family: var(--ff-display);
  font-size: 1.3rem;
  color: var(--c-primary-dark);
}

.booking-code {
  margin-top: var(--s-7);
  padding: var(--s-7) var(--s-5);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, var(--c-primary-tint) 0%, #FFFDF8 100%);
  border: 1.5px dashed var(--c-primary-light);
}
.booking-code .small-caps { color: var(--c-primary-dark); }
.booking-code__digits {
  font-family: var(--ff-mono), 'Manrope', monospace;
  font-size: clamp(2.6rem, 6vw, 3.6rem);
  font-weight: 700;
  letter-spacing: .35em;
  color: var(--c-primary-dark);
  margin: var(--s-3) 0;
}
.booking-code p {
  font-size: 15px;
  color: var(--c-ink-soft);
  max-width: 42ch;
  margin: 0 auto;
}

.booking-note {
  margin-top: var(--s-5);
  padding: var(--s-4) var(--s-5);
  border-radius: var(--r-md);
  background: var(--c-cream);
  border: 1px solid var(--c-line);
  font-size: 15px;
  color: var(--c-ink-soft);
  text-align: left;
}
.booking-note strong { color: var(--c-primary-dark); display: block; margin-bottom: 2px; }
.booking-note--ebike {
  background: var(--c-ebike-tint);
  border-color: rgba(109, 67, 192, .25);
}
.booking-note--ebike strong { color: var(--c-ebike); }

.booking-confirm__actions {
  margin-top: var(--s-7);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  justify-content: center;
}

