/* =========================================================================
   Bouw een Robot — Enso huisstijl
   Versie: 0.1 (initiele opzet)
   Tokens en regels volgen design.md v2.22.
   ========================================================================= */

/* ── Fonts (embedded, geen Google CDN — design.md §scope v2.21) ─────────── */
@font-face {
  font-family: "Barlow Condensed";
  src: url("../fonts/BarlowCondensed-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans";
  src: url("../fonts/NotoSans-Variable.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans";
  src: url("../fonts/NotoSans-Italic-Variable.woff2") format("woff2-variations");
  font-weight: 100 600;
  font-style: italic;
  font-display: swap;
}

/* ── Tokens ─────────────────────────────────────────────────────────────── */
:root {
  /* Kleur — 60/30/10 (wit/zwart/rood) */
  --c-white:           #FAFAFA;
  --c-black:           #121212;
  --c-samurai-red:     #9D0A0E;
  --c-samurai-hover:   #7A0709;
  --c-samurai-active:  #5C0406;
  --c-samurai-subtle:  #F2E5E0;
  --c-gray-50:         #F4F4F4;
  --c-gray-100:        #E6E6E6;
  --c-gray-200:        #CFCFCF;
  --c-gray-300:        #A8A8A8;
  --c-gray-400:        #7A7A7A;
  --c-gray-500:        #555555;
  --c-gray-700:        #2C2C2C;

  --c-text:            var(--c-black);
  --c-text-muted:      var(--c-gray-500);
  --c-bg:              var(--c-white);
  --c-link:            var(--c-black);
  --c-link-hover:      var(--c-samurai-red);
  --c-accent:          var(--c-samurai-red);
  --c-focus-ring:      var(--c-samurai-red);

  /* Typografie */
  --ff-display: "Barlow Condensed", "Arial Narrow", "Helvetica Condensed", sans-serif;
  --ff-body:    "Noto Sans", Arial, Helvetica, sans-serif;
  --ff-mono:    "JetBrains Mono", Consolas, "Courier New", monospace;

  /* Spacing — 4-punts schaal, 8-punts voorkeur */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 24px;
  --s-6: 32px;
  --s-7: 40px;
  --s-8: 48px;
  --s-9: 64px;
  --s-10: 96px;
  --s-11: 128px;

  /* Layout */
  --container-max: 1200px;
  --container-narrow: 760px;
  --radius-base: 4px;
  --radius-pill: 9999px;
  --border: 1px solid var(--c-black);
  --border-hair: 1px solid var(--c-gray-200);

  /* Motion */
  --dur: 180ms;
  --ease: cubic-bezier(.2, 0, 0, 1);
}

/* ── Reset / basis ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--c-bg);
  color: var(--c-text);
  font-family: var(--ff-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  font-feature-settings: "ss01", "tnum";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { max-width: 100%; display: block; }
a {
  color: var(--c-link);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color var(--dur) var(--ease);
}
a:hover { color: var(--c-link-hover); }
:focus-visible {
  outline: 2px solid var(--c-focus-ring);
  outline-offset: 2px;
}

/* Skip-link — accessibility */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--c-black);
  color: var(--c-white);
  padding: var(--s-3) var(--s-4);
  z-index: 100;
  text-decoration: none;
}
.skip-link:focus { left: var(--s-4); top: var(--s-4); }

/* ── Typografische schaal ───────────────────────────────────────────────── */
.h1, h1 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(40px, 6vw, 72px);
  line-height: 1.05;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin: 0 0 var(--s-5);
}
.h2, h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1.1;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  margin: 0 0 var(--s-5);
}
.h3, h3 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.2;
  letter-spacing: 0.2px;
  text-transform: uppercase;
  margin: 0 0 var(--s-4);
}
.h4, h4 {
  font-family: var(--ff-body);
  font-weight: 600;
  font-size: 18px;
  line-height: 1.4;
  margin: 0 0 var(--s-3);
}
p { margin: 0 0 var(--s-4); }
.lead {
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.5;
  color: var(--c-gray-700);
}
.eyebrow {
  font-family: var(--ff-mono);
  font-size: 12px;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--c-gray-500);
  margin: 0 0 var(--s-3);
  font-feature-settings: "calt" 0;
}
.muted { color: var(--c-text-muted); }
em, i { font-style: italic; } /* Noto Sans Regular Italic — max één per pagina (zie design.md) */

ul, ol { padding-left: var(--s-5); margin: 0 0 var(--s-4); }
li { margin-bottom: var(--s-2); }

blockquote {
  margin: 0;
  font-family: var(--ff-body);
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.4;
  font-style: italic;
  color: var(--c-gray-700);
  padding-left: var(--s-4);
  border-left: 3px solid var(--c-black);
}
blockquote cite {
  display: block;
  margin-top: var(--s-3);
  font-size: 14px;
  font-style: normal;
  color: var(--c-gray-500);
}

/* ── Layout-helpers ─────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--s-5);
}
.container.narrow { max-width: var(--container-narrow); }

.section { padding: var(--s-10) 0; }
.section.tight { padding: var(--s-8) 0; }
.section.dark {
  background: var(--c-black);
  color: var(--c-white);
}
.section.dark a { color: var(--c-white); }
.section.dark a:hover { color: var(--c-samurai-red); }
.section.dark blockquote { color: var(--c-gray-200); border-left-color: var(--c-white); }
.section.dark .muted { color: var(--c-gray-300); }
.section.dark .eyebrow { color: var(--c-gray-300); }

.grid { display: grid; gap: var(--s-6); }
.grid.cols-2 { grid-template-columns: 1fr; }
.grid.cols-3 { grid-template-columns: 1fr; }
.grid.cols-4 { grid-template-columns: 1fr; }
@media (min-width: 720px) {
  .grid.cols-2 { grid-template-columns: 1fr 1fr; }
  .grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
  .grid.cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
}

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

.divider {
  height: 1px;
  background: var(--c-gray-200);
  border: 0;
  margin: var(--s-8) 0;
}

/* ── Header / navigatie ────────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  background: rgba(250, 250, 250, 0.96);
  backdrop-filter: saturate(140%) blur(6px);
  border-bottom: var(--border-hair);
  z-index: 50;
}
.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--s-3);
  padding-bottom: var(--s-3);
  gap: var(--s-5);
}
/* Rakkan-zone web = linksboven (signature-zone v2.19) */
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  text-decoration: none;
  color: var(--c-black);
}
.brand img { height: 32px; width: auto; }
.brand-text { display: inline-flex; flex-direction: column; line-height: 1; }
.brand-name {
  font-family: var(--ff-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 18px;
}
.brand-sub {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--c-gray-400);
  margin-top: 3px;
  font-feature-settings: "calt" 0;
}
.nav {
  display: none;
  align-items: center;
  gap: var(--s-6);
}
@media (min-width: 800px) { .nav { display: inline-flex; } }
.nav a {
  text-decoration: none;
  font-size: 15px;
  color: var(--c-black);
  position: relative;
}
.nav a[aria-current="page"] {
  color: var(--c-samurai-red); /* nav-link-active — single-accent uitzondering */
}
.nav a[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -6px;
  height: 2px;
  background: var(--c-samurai-red);
}

/* Mobiele hamburger — minimaal */
.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  background: transparent;
  border: 1px solid var(--c-black);
  border-radius: var(--radius-base);
  cursor: pointer;
}
@media (min-width: 800px) { .nav-toggle { display: none; } }
.nav-toggle svg { width: 18px; height: 18px; }
.nav-mobile {
  display: none;
  border-top: var(--border-hair);
  background: var(--c-white);
  padding: var(--s-4) var(--s-5);
}
.nav-mobile.open { display: block; }
.nav-mobile a {
  display: block;
  padding: var(--s-3) 0;
  text-decoration: none;
  border-bottom: var(--border-hair);
}
.nav-mobile a:last-child { border-bottom: 0; }

/* ── Buttons (line-or-fill regel — v2.19) ─────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  min-height: 44px;
  padding: var(--s-3) var(--s-5);
  font-family: var(--ff-body);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.2px;
  text-decoration: none;
  border-radius: var(--radius-base);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
  cursor: pointer;
}
.btn-primary {
  background: var(--c-samurai-red);
  color: var(--c-white);
  border: 0; /* vulling, geen border */
}
.btn-primary:hover { background: var(--c-samurai-hover); color: var(--c-white); }
.btn-primary:active { background: var(--c-samurai-active); }

.btn-secondary {
  background: transparent; /* contour, geen vulling */
  color: var(--c-black);
  border: 1px solid var(--c-black);
}
.btn-secondary:hover { color: var(--c-samurai-red); border-color: var(--c-samurai-red); }

.btn-tertiary {
  background: transparent;
  color: var(--c-black);
  border: 0;
  padding-left: 0;
  padding-right: 0;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.btn-tertiary:hover { color: var(--c-samurai-red); }

.btn .arrow { transition: transform var(--dur) var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }

.section.dark .btn-secondary {
  color: var(--c-white);
  border-color: var(--c-white);
}
.section.dark .btn-secondary:hover { color: var(--c-samurai-red); border-color: var(--c-samurai-red); }

/* ── Hero ──────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  padding: var(--s-11) 0 var(--s-10);
  overflow: hidden;
}
.hero-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-8);
  align-items: center;
}
@media (min-width: 960px) {
  .hero-inner { grid-template-columns: 1.3fr 1fr; }
}
.hero h1 { max-width: 14ch; }
.hero .lead { max-width: 52ch; }
.hero-cta { margin-top: var(--s-6); display: inline-flex; gap: var(--s-4); flex-wrap: wrap; }
.hero-mark {
  justify-self: center;
  max-width: 380px;
  opacity: 0.92;
}
.hero-mark img { width: 100%; height: auto; }

/* ── Cards (1px border + transparante bg — line-or-fill) ──────────────── */
.card {
  border: 1px solid var(--c-gray-200);
  background: transparent;
  padding: var(--s-6);
  border-radius: var(--radius-base);
}
.card .h4 { margin-bottom: var(--s-3); }
.card .step {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 48px;
  line-height: 1;
  color: var(--c-gray-200);
  margin-bottom: var(--s-3);
}

/* Feature row — 3 tiles als bullet-substituut (v2.10) */
.tiles { display: grid; gap: var(--s-6); grid-template-columns: 1fr; }
@media (min-width: 720px) { .tiles { grid-template-columns: repeat(3, 1fr); } }
.tile h4 { font-family: var(--ff-display); text-transform: uppercase; letter-spacing: 0.2px; font-weight: 700; font-size: 18px; }

/* Quote-blok */
.quote-grid { display: grid; gap: var(--s-6); }
@media (min-width: 820px) { .quote-grid { grid-template-columns: 1fr 1fr; } }

/* FAQ */
.faq details {
  border-bottom: var(--border-hair);
  padding: var(--s-4) 0;
}
.faq details:first-of-type { border-top: var(--border-hair); }
.faq summary {
  cursor: pointer;
  font-family: var(--ff-body);
  font-weight: 600;
  font-size: 17px;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-4);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  color: var(--c-gray-400);
  transition: transform var(--dur) var(--ease), color var(--dur) var(--ease);
}
.faq details[open] summary::after {
  transform: rotate(45deg);
  color: var(--c-samurai-red); /* single-accent uitzondering: active state */
}
.faq details > p, .faq details > div { padding-top: var(--s-3); color: var(--c-gray-700); }

/* Praktisch-lijstje */
.kv {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3) var(--s-5);
  padding: 0;
  list-style: none;
  margin: 0;
}
@media (min-width: 720px) {
  .kv { grid-template-columns: 180px 1fr; }
}
.kv dt { font-weight: 600; color: var(--c-black); }
.kv dd { margin: 0; color: var(--c-gray-700); }
@media (min-width: 720px) {
  .kv dt { padding-top: 2px; }
}

/* CTA-strip (donker, sluit een pagina af) */
.cta-strip {
  background: var(--c-black);
  color: var(--c-white);
  padding: var(--s-10) 0;
}
.cta-strip h2, .cta-strip .h2 { color: var(--c-white); }
.cta-strip .lead { color: var(--c-gray-200); }

/* ── Sumi-e als sfeer-element ──────────────────────────────────────────── */
.sumi {
  display: block;
  max-width: 100%;
  height: auto;
  opacity: 0.95;
}
.sumi.compact { max-width: 280px; }

/* Section-divider met Ensō-comment (v2.15) — gebruik in lange pagina's */
.section-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--s-8) 0;
}
.section-divider img { width: 88px; height: auto; opacity: 0.5; }

/* Full-bleed photo-band — gebruik tussen secties voor sfeer/realiteit (v0.8) */
.photo-band {
  width: 100%;
  background: var(--c-black);
  overflow: hidden;
}
.photo-band img {
  width: 100%;
  height: auto;
  display: block;
}
.photo-band figcaption {
  display: block;
  text-align: center;
  font-family: var(--ff-mono);
  font-size: 12px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--c-gray-400);
  padding: var(--s-3) var(--s-5);
  font-feature-settings: "calt" 0;
}

/* ── Footer ────────────────────────────────────────────────────────────── */
.site-footer {
  background: var(--c-black);
  color: var(--c-gray-200);
  padding: var(--s-9) 0 var(--s-6);
  font-size: 14px;
}
.site-footer a { color: var(--c-white); }
.site-footer a:hover { color: var(--c-samurai-red); }
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid var(--c-gray-700);
}
@media (min-width: 720px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr; } }
.footer-tagline {
  font-family: var(--ff-display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 22px;
  letter-spacing: 0.3px;
  color: var(--c-white);
  margin-bottom: var(--s-3);
  max-width: 28ch;
}
.footer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
  justify-content: space-between;
  padding-top: var(--s-4);
  color: var(--c-gray-300);
}

/* ── Utility ───────────────────────────────────────────────────────────── */
.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;
}
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }

/* ── Play-laag (v0.2) — binnen Enso, geen extra kleuren ──────────────── */

/* Warmere washi-tint voor 'play'-secties (gebruik samurai-subtle) */
.section.washi { background: var(--c-samurai-subtle); }
.section.washi .eyebrow { color: var(--c-gray-700); }

/* Card-hover-lift voor speelse interactie */
.card.play, .tile.play {
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow 320ms var(--ease);
}
.card.play:hover, .tile.play:hover {
  transform: translateY(-3px);
  border-color: var(--c-black);
  box-shadow: 0 12px 28px rgba(18, 18, 18, 0.06);
}

/* Instrument-grid — abstract close-ups (sensoren), klein en speels */
.instruments {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-5);
  margin-top: var(--s-7);
}
@media (min-width: 720px) { .instruments { grid-template-columns: repeat(4, 1fr); } }
.instrument {
  border: 1px solid var(--c-gray-200);
  background: var(--c-white);
  border-radius: var(--radius-base);
  padding: var(--s-5);
  text-align: center;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.instrument:hover { transform: translateY(-3px) rotate(-1.5deg); border-color: var(--c-black); }
.instrument img {
  height: 88px;
  width: auto;
  margin: 0 auto var(--s-3);
  display: block;
  object-fit: contain;
}
.instrument span {
  display: block;
  font-family: var(--ff-mono);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--c-gray-500);
  font-feature-settings: "calt" 0;
}

/* Robot-in-de-ensō — home-hero merkbeeld (v0.3) */
.robot-hero {
  position: relative;
  width: 100%;
  max-width: 420px;
  aspect-ratio: 1 / 1;
  justify-self: center;
}
.robot-hero .hero-ring {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0.92;
  transform: rotate(-3deg);
  transition: transform 480ms var(--ease);
  animation: enso-in 700ms var(--ease) both;
}
.robot-hero .hero-bot {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}
.robot-hero .hero-bot svg {
  width: 41%;
  height: auto;
  /* Geen drop-shadow — conform Enso no-shadows-discipline (design.md v2.11). */
  transform: translateY(2%);
  animation: bot-in 760ms var(--ease) both;
  animation-delay: 160ms;
}
.robot-hero:hover .hero-ring { transform: rotate(0deg); }
@keyframes bot-in {
  from { opacity: 0; transform: translateY(14%) scale(0.92); }
  to   { opacity: 1; transform: translateY(2%) scale(1); }
}
@media (prefers-reduced-motion: reduce) {
  .robot-hero .hero-ring { transform: rotate(-3deg); animation: none; }
  .robot-hero .hero-bot svg { transform: translateY(2%); animation: none; }
}

/* Speelse hero-ensō: licht hellen, subtle entrance */
.hero-mark.play img {
  transform: rotate(-4deg);
  transition: transform 480ms var(--ease);
  animation: enso-in 700ms var(--ease) both;
}
.hero-mark.play:hover img { transform: rotate(0deg); }
@keyframes enso-in {
  from { opacity: 0; transform: rotate(-8deg) scale(0.96); }
  to   { opacity: 0.92; transform: rotate(-4deg) scale(1); }
}

/* Phase-cards: nummers worden rood op hover (single-accent uitzondering: hover-state) */
.card.phase .step { transition: color var(--dur) var(--ease); }
.card.phase:hover .step { color: var(--c-samurai-red); }

/* Stippellijn tussen fases (verbinding suggereren) */
@media (min-width: 720px) {
  .phases-row { position: relative; }
  .phases-row::before {
    content: "";
    position: absolute;
    left: 4%; right: 4%;
    top: 70px;
    height: 1px;
    background-image: linear-gradient(to right, var(--c-gray-300) 50%, transparent 50%);
    background-size: 8px 1px;
    z-index: -1;
  }
}

/* Verba-grid — drie display-font werkwoorden i.p.v. icoon-tiles (v0.8) */
.verba-grid {
  display: grid;
  gap: var(--s-6);
  grid-template-columns: 1fr;
  margin-top: var(--s-8);
}
@media (min-width: 720px) {
  .verba-grid { grid-template-columns: repeat(3, 1fr); }
}
.verbum {
  text-align: center;
  padding: var(--s-5) var(--s-3);
  border: 0;
}
.verbum h3 {
  font-family: var(--ff-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: clamp(44px, 6vw, 72px);
  line-height: 0.95;
  color: var(--c-black);
  margin: 0 0 var(--s-3);
  display: inline-block;
  position: relative;
  transition: transform var(--dur) var(--ease);
}
/* Subtle hover-accent: rode onderlijn verschijnt, sluit aan op single-accent op interaction-state */
.verbum h3::after {
  content: "";
  position: absolute;
  left: 10%; right: 10%;
  bottom: -4px;
  height: 3px;
  background: var(--c-samurai-red);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 320ms var(--ease);
}
.verbum:hover h3::after { transform: scaleX(1); }
.verbum:hover h3 { transform: translateY(-2px); }
.verbum p {
  font-family: var(--ff-mono);
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--c-gray-500);
  margin: 0;
  font-feature-settings: "calt" 0;
}

/* Coda onder de verba — fluistert de vierde actie ('zie') */
.verba-coda {
  text-align: center;
  margin: var(--s-8) auto 0;
  max-width: 48ch;
  font-family: var(--ff-body);
  font-style: italic;
  font-size: 17px;
  color: var(--c-gray-700);
  line-height: 1.5;
}
.verba-coda strong {
  font-family: var(--ff-display);
  font-style: normal;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--c-black);
  margin-right: var(--s-2);
}

/* Speelse pull-quote bubble (gebruik in 'play'-sectie) */
.pull-quote {
  font-family: var(--ff-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.15;
  max-width: 22ch;
  position: relative;
  padding-left: var(--s-5);
  border-left: 3px solid var(--c-samurai-red);
}

/* Knop met arrow al subtly bouncen op rust (alleen primary CTA's, niet alle) */
.btn-primary .arrow { transition: transform 220ms var(--ease); }
.btn-primary:hover .arrow { transform: translateX(4px); }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .hero-mark.play img { transform: none; }
  .instrument:hover { transform: none; }
  .card.play:hover, .tile.play:hover { transform: none; }
}
