/* ============================================================
   MAINSTAGE PRIDE AMSTERDAM 2026
   Luxury fashion-campaign aesthetic · mobile first
   ============================================================ */
:root{
  --purple:  #8B3DFF;
  --lavender:#EDE6FF;
  --pink:    #FF4FA3;
  --white:   #FFFFFF;
  --surface: #F8F5FF;
  --ink:     #111111;
  --ink2:    #555060;
  --ease:    cubic-bezier(.16,1,.3,1);
  --font-sans: "Roboto", "Helvetica Neue", sans-serif;
  --font-serif: "Roboto", "Helvetica Neue", sans-serif; /* serif accents removed */
  --pad: clamp(20px, 5vw, 64px);
}
*{ box-sizing:border-box; margin:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-sans);
  background:var(--white);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
em{
  font-family:inherit;
  font-style:normal;
  font-weight:300;
  letter-spacing:inherit;
}

.container{ width:100%; max-width:1240px; margin:0 auto; padding-inline:var(--pad); }
.container--narrow{ max-width:860px; }

/* ---- shared type ---- */
.overline{
  font-size:12px; font-weight:600;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--purple);
  margin-bottom:20px;
}
.overline--center{ text-align:center; }
.overline--light{ color:var(--lavender); }
.section-title{
  font-size:clamp(40px, 7vw, 84px);
  font-weight:700;
  letter-spacing:-.035em;
  line-height:1.0;
  margin-bottom:clamp(40px, 6vw, 80px);
  text-wrap:balance;
}
section{ padding-block:clamp(80px, 12vw, 170px); }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:16px 32px;
  border-radius:999px;
  font-weight:600; font-size:15px;
  letter-spacing:.01em;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s, color .3s;
  will-change:transform;
}
.btn--primary{
  background:var(--purple); color:#fff;
  box-shadow:0 8px 30px rgba(139,61,255,.35);
}
.btn--primary:hover{ transform:translateY(-2px); box-shadow:0 14px 40px rgba(139,61,255,.45); }
.btn--ghost{
  border:1px solid rgba(255,255,255,.5); color:#fff;
  backdrop-filter:blur(8px);
}
.btn--ghost:hover{ background:rgba(255,255,255,.12); transform:translateY(-2px); }
.btn--outline{
  border:1px solid rgba(17,17,17,.18); color:var(--ink2);
  pointer-events:none; opacity:.6;
}
.btn--light{ background:#fff; color:var(--purple); }
.btn--light:hover{ transform:translateY(-2px); box-shadow:0 14px 40px rgba(0,0,0,.25); }
.btn--nav{ background:var(--ink); color:#fff; padding:11px 22px; font-size:13px; }
.btn--nav:hover{ background:var(--purple); }

/* ---- hot CTA: animated, bright, impossible to miss ---- */
.btn--hot{
  position:relative; overflow:hidden;
  background:linear-gradient(115deg, #FF4FA3 0%, #8B3DFF 40%, #FF4FA3 80%, #8B3DFF 100%);
  background-size:250% 100%;
  color:#fff;
  box-shadow:0 8px 30px rgba(255,79,163,.45);
}
@media (prefers-reduced-motion: no-preference){
  .btn--hot{
    animation:
      hotShift 5s linear infinite,
      hotGlow 2.6s ease-in-out infinite;
  }
  .btn--hot::after{
    content:"";
    position:absolute; top:0; bottom:0; left:-80%;
    width:55%;
    background:linear-gradient(105deg, transparent 0%, rgba(255,255,255,.55) 50%, transparent 100%);
    transform:skewX(-18deg);
    animation:hotShine 3.4s var(--ease) infinite;
  }
}
.btn--hot:hover{
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 16px 50px rgba(255,79,163,.65), 0 0 0 4px rgba(255,79,163,.18);
}
@keyframes hotShift{
  from{ background-position:0% 0; }
  to  { background-position:250% 0; }
}
@keyframes hotGlow{
  0%,100%{ box-shadow:0 8px 30px rgba(255,79,163,.45), 0 0 0 0 rgba(255,79,163,.5); }
  50%    { box-shadow:0 10px 38px rgba(255,79,163,.6), 0 0 0 12px rgba(255,79,163,0); }
}
@keyframes hotShine{
  0%      { left:-80%; }
  46%,100%{ left:160%; }
}
.btn--massive{
  background:#fff; color:var(--purple);
  font-size:clamp(17px, 2vw, 22px);
  padding:clamp(20px,2.6vw,28px) clamp(44px,6vw,72px);
  animation:ctaPulse 3.2s var(--ease) infinite;
}
.btn--massive:hover{ transform:translateY(-3px) scale(1.02); }
@keyframes ctaPulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(255,255,255,.45), 0 18px 50px rgba(0,0,0,.25); }
  50%    { box-shadow:0 0 0 18px rgba(255,255,255,0), 0 18px 50px rgba(0,0,0,.25); }
}

/* ---- scroll reveals ---- */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
  .reveal.in{ opacity:1; transform:none; }
}

/* ============================================================
   SPLASH OPENING
   ============================================================ */
.splash{
  position:fixed; inset:0; z-index:300;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(90% 90% at 50% 42%, #2a1455 0%, #160b2e 55%, #0d0a14 100%);
}
.splash img{
  width:clamp(180px, 46vw, 320px);
  height:auto;
  filter:drop-shadow(0 20px 60px rgba(139,61,255,.5));
}
@media (prefers-reduced-motion: reduce){
  .splash{ display:none; }
}
@media (prefers-reduced-motion: no-preference){
  .splash{ animation:splashFade .7s ease forwards 2s; }
  .splash img{
    animation:
      splashLogoIn 1s var(--ease) both,
      splashLogoOpen .85s cubic-bezier(.5,0,.75,.5) forwards 1.7s;
  }
}
@keyframes splashLogoIn{
  from{ transform:scale(.4) rotate(-8deg); opacity:0; }
  to  { transform:scale(1) rotate(0deg); opacity:1; }
}
@keyframes splashLogoOpen{
  to{ transform:scale(9); opacity:0; }
}
@keyframes splashFade{
  to{ opacity:0; visibility:hidden; }
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; gap:24px;
  padding:14px var(--pad);
  transition:background .4s, box-shadow .4s, padding .4s;
}
.nav.scrolled{
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(16px);
  box-shadow:0 1px 0 rgba(17,17,17,.06);
  padding-block:10px;
}
.nav__logo{
  display:flex; align-items:center; gap:10px;
  font-weight:700; font-size:15px; letter-spacing:.06em; color:#fff;
  transition:color .4s;
}
.nav__logo img{
  width:56px; height:56px;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.25));
}
.nav__logo span{ font-weight:300; margin-left:6px; }
.nav.scrolled .nav__logo{ color:var(--ink); }
.nav__links{ display:none; gap:28px; margin-left:auto; }
.nav__links a{
  font-size:13.5px; font-weight:500; color:#fff; opacity:.85;
  transition:opacity .2s, color .4s;
}
.nav__links a:hover{ opacity:1; }
.nav.scrolled .nav__links a{ color:var(--ink); }
.nav .btn--nav{ margin-left:auto; }
@media (min-width:760px){
  .nav__links{ display:flex; }
  .nav .btn--nav{ margin-left:0; }
}

/* ============================================================
   1 · HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex; flex-direction:column;
  justify-content:center;
  padding:0;
  overflow:hidden;
  color:#fff;
}
.hero__media{ position:absolute; inset:-12% 0; z-index:0; }
.hero__media img{
  width:100%; height:100%; object-fit:cover;
  animation:heroZoom 22s var(--ease) both;
}
@keyframes heroZoom{ from{ transform:scale(1.14); } to{ transform:scale(1); } }
.hero__veil{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(17,8,38,.45) 0%, rgba(17,8,38,.18) 40%, rgba(17,8,38,.62) 100%),
    linear-gradient(135deg, rgba(139,61,255,.42) 0%, rgba(255,79,163,.18) 55%, rgba(139,61,255,.30) 100%);
}
.hero__inner{
  position:relative; z-index:2;
  width:100%; max-width:1240px;
  margin:0 auto; padding:120px var(--pad) 40px;
  text-align:center;
}
.hero__presented{
  display:inline-flex; align-items:center; gap:14px;
  font-size:11.5px; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase;
  padding:10px 22px 10px 12px;
  border:1px solid rgba(255,255,255,.35);
  border-radius:999px;
  backdrop-filter:blur(10px);
  background:rgba(255,255,255,.08);
  margin-bottom:clamp(28px,4vw,44px);
}
.hero__presented .flag{
  width:36px; height:24px; flex-shrink:0;
  border-radius:4px;
  background:url(../assets/progress-flag.svg) center/cover no-repeat;
  box-shadow:0 0 0 1px rgba(255,255,255,.45), 0 2px 10px rgba(0,0,0,.28);
}
.hero__presented .amp{ font-weight:300; }
.hero__title{
  font-size:clamp(48px, 10.5vw, 148px);
  font-weight:900;
  letter-spacing:-.03em;
  line-height:.96;
  text-transform:uppercase;
}
.hero__title em{ font-weight:300; }
.hero__line{ display:block; }
.hero__sub{
  margin:clamp(22px,3vw,34px) auto 0;
  max-width:480px;
  font-size:clamp(16px,1.6vw,19px);
  font-weight:400;
  color:rgba(255,255,255,.88);
  text-wrap:pretty;
}
.hero__cta{
  display:flex; gap:14px; justify-content:center; flex-wrap:wrap;
  margin-top:clamp(30px,4vw,46px);
}
.hero__date{
  position:relative; z-index:2;
  display:flex; align-items:center; gap:12px;
  justify-content:center;
  padding:0 var(--pad) 42px;
  font-size:12.5px; font-weight:600;
  letter-spacing:.26em;
  color:rgba(255,255,255,.9);
}
.hero__date .dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--pink);
  box-shadow:0 0 12px var(--pink);
}
.hero__date .sep{ opacity:.5; }

/* staggered hero entrance */
.hero .reveal{ transition-delay:.1s; }
.hero .hero__title.reveal{ transition-delay:.22s; }
.hero .hero__sub.reveal{ transition-delay:.36s; }
.hero .hero__cta.reveal{ transition-delay:.5s; }
.hero .hero__date.reveal{ transition-delay:.64s; }

/* ============================================================
   2 · INTRO — editorial
   ============================================================ */
.intro__title{
  font-size:clamp(48px, 9vw, 120px);
  font-weight:700; letter-spacing:-.04em; line-height:.98;
  margin-bottom:clamp(48px,7vw,96px);
}
.intro__grid{ display:grid; gap:48px; }
.intro__copy .lead{
  font-weight:300;
  font-size:clamp(22px,2.6vw,30px);
  line-height:1.4;
  letter-spacing:-.01em;
  margin-bottom:24px;
  text-wrap:pretty;
}
.intro__copy p:not(.lead){
  color:var(--ink2);
  max-width:52ch;
  margin-bottom:18px;
  text-wrap:pretty;
}
.intro__photo{ position:relative; }
.intro__photo image-slot{ width:100%; height:auto; aspect-ratio:16/10; display:block; }
.intro__photo img{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:18px; }
.intro__photo figcaption{
  margin-top:14px;
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink2);
}
@media (min-width:900px){
  .intro__grid{
    grid-template-columns:5fr 7fr;
    grid-template-rows:auto auto;
    column-gap:72px;
  }
  .intro__copy{ grid-column:1; grid-row:1; }
  .intro__photo--main{ grid-column:2; grid-row:1 / span 2; }
  .intro__photo--main image-slot{ aspect-ratio:4/5; height:auto; }
  .intro__photo--offset{ grid-column:1; grid-row:2; width:78%; margin-top:24px; }
}


/* ============================================================
   3 · AFTERMOVIE — backstage wall: reel + floating prints
   ============================================================ */
.aftermovie{ padding-top:0; }
.aftermovie__stage{
  position:relative;
  border-radius:12px;
  background:
    radial-gradient(120% 140% at 18% 0%, #2b1252 0%, transparent 55%),
    radial-gradient(120% 140% at 85% 100%, #3d1040 0%, transparent 55%),
    #160a2c;
  overflow:hidden;
  padding:clamp(48px, 6vw, 90px) clamp(20px, 4vw, 64px);
  display:flex; flex-direction:column; align-items:center;
}

/* ambient glows */
.am-glow{
  position:absolute; border-radius:50%;
  pointer-events:none;
  filter:blur(10px);
}
.am-glow--pink{
  width:520px; height:520px; top:-180px; right:-120px;
  background:radial-gradient(circle, rgba(255,79,163,.28) 0%, transparent 65%);
}
.am-glow--purple{
  width:620px; height:620px; bottom:-240px; left:-160px;
  background:radial-gradient(circle, rgba(139,61,255,.30) 0%, transparent 65%);
}

/* giant outline watermark */
.am-ghost{
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  font-size:clamp(120px, 19vw, 280px);
  font-weight:900; letter-spacing:-.02em;
  white-space:nowrap;
  color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,.10);
  pointer-events:none;
  user-select:none;
}

/* floating photo prints */
.am-float{
  position:absolute;
  display:none;
  z-index:1;
  will-change:transform;
}
.am-card{
  background:#fff;
  padding:9px 9px 12px;
  border-radius:3px;
  box-shadow:0 24px 60px rgba(8,2,22,.55), 0 4px 14px rgba(8,2,22,.35);
  transform:rotate(var(--r, 0deg));
  transition:transform .6s var(--ease), box-shadow .6s var(--ease);
}
.am-card img{
  width:100%; aspect-ratio:4/3.1; object-fit:cover;
  border-radius:1px;
}
.am-card figcaption{
  padding-top:9px;
  font-size:11px; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  color:#8d86a0;
  text-align:center;
}
.am-card--mini img{ aspect-ratio:1/1.15; }
.am-float:hover{ z-index:3; }
.am-float:hover .am-card{
  transform:rotate(0deg) scale(1.06);
  box-shadow:0 34px 80px rgba(8,2,22,.65), 0 0 0 6px rgba(255,79,163,.25);
}
@media (prefers-reduced-motion: no-preference){
  .am-card{ animation:amDrift var(--dur, 8s) ease-in-out var(--dly, 0s) infinite; }
  .am-float:hover .am-card{ animation-play-state:paused; }
  @keyframes amDrift{
    0%, 100%{ transform:rotate(var(--r, 0deg)) translateY(0); }
    50%     { transform:rotate(var(--r, 0deg)) translateY(-13px); }
  }
}

/* the reel stays the hero */
.aftermovie__reel{ width:min(320px, 86vw); margin:0 auto; position:relative; z-index:2; }
.aftermovie__reelframe{
  position:relative;
  aspect-ratio:267/476;
  border-radius:28px;
  overflow:hidden;
  background:#0d0a14;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:
    0 30px 80px rgba(139,61,255,.40),
    0 10px 30px rgba(255,79,163,.25),
    inset 0 0 0 1px rgba(255,255,255,.06);
}
.aftermovie__reelframe::before{
  content:""; position:absolute; inset:-40px; z-index:-1;
  background:radial-gradient(circle at 30% 20%, rgba(255,79,163,.35), transparent 60%),
             radial-gradient(circle at 75% 85%, rgba(139,61,255,.4), transparent 60%);
  filter:blur(30px);
}
.aftermovie__reelframe iframe{
  position:absolute; inset:0;
  width:100%; height:100%;
  border:0; display:block;
}
.aftermovie__cap{
  margin-top:18px;
  text-align:center;
  font-size:12px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:rgba(255,255,255,.85);
}

/* mobile: two prints peek out behind the reel */
.am-float--1, .am-float--4{ display:block; }
.am-float--1{ width:130px; top:6%; left:-26px; }
.am-float--4{ width:140px; bottom:7%; right:-30px; }

@media (min-width:900px){
  .aftermovie__stage{ min-height:680px; justify-content:center; }
  .am-float{ display:block; }
  .am-float--1{ width:250px; top:9%;  left:5%;  bottom:auto; }
  .am-float--2{ width:205px; bottom:8%; left:13%; }
  .am-float--3{ width:220px; top:7%;  right:8%; }
  .am-float--4{ width:250px; bottom:10%; right:4.5%; }
  .am-float--5{ width:130px; top:38%; left:26%; }
  .aftermovie__reel{
    width:300px;
    transform:rotate(-3deg);
    transition:transform .7s var(--ease);
  }
  .aftermovie__reel:hover{ transform:rotate(0deg) scale(1.02); }
}

/* ============================================================
   4 · LINEUP
   ============================================================ */
.lineup{ background:var(--surface); }
.lineup__cat{
  font-size:12px; font-weight:600;
  letter-spacing:.3em; text-transform:uppercase;
  color:var(--ink2);
  margin:clamp(44px,6vw,72px) 0 22px;
  display:flex; align-items:center; gap:16px;
}
.lineup__cat::after{ content:""; flex:1; height:1px; background:rgba(17,17,17,.1); }
.lineup__row{ display:grid; gap:20px; }
@media (min-width:700px){
  .lineup__row--head{ grid-template-columns:1fr 1fr; gap:28px; }
  .lineup__row--djs{ grid-template-columns:repeat(3,1fr); }
}
.artist{ display:block; }
.artist__media{
  display:block; overflow:hidden; border-radius:16px;
  aspect-ratio:4/5;
  background:var(--lavender);
}
.artist--xl .artist__media{ aspect-ratio:4/3.4; }
.artist__media img{
  width:100%; height:100%; object-fit:cover; object-position:center 28%;
  filter:saturate(.92);
  transition:transform 1s var(--ease), filter .6s;
}
.artist:hover .artist__media img{ transform:scale(1.05); filter:saturate(1.1); }
.artist__meta{
  display:flex; align-items:baseline; gap:14px;
  padding:16px 2px 0;
}
.artist__meta strong{
  font-size:clamp(18px,2vw,24px);
  font-weight:700; letter-spacing:-.02em;
  transition:color .25s;
}
.artist--xl .artist__meta strong{ font-size:clamp(24px,3vw,38px); }
.artist:hover .artist__meta strong{ color:var(--purple); }
.artist__meta span{
  margin-left:auto;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink2);
  white-space:nowrap;
}

.lineup__split{ display:grid; gap:48px; }
@media (min-width:900px){ .lineup__split{ grid-template-columns:7fr 5fr; gap:72px; align-items:start; } }
/* the drag column has no heading anymore — match the live column's heading
   offset so the card lines up with "Live Acts" (and spaces it on mobile). */
.lineup__drag{ margin-top:clamp(44px,6vw,72px); }
.dragcard{
  display:grid; grid-template-columns:minmax(120px,200px) 1fr;
  align-items:end; gap:24px;
  background:var(--lavender);
  border-radius:16px;
  padding:28px 28px 0 0;
  overflow:hidden;
}
.dragcard img{ width:100%; transform:translateY(2px); }
.dragcard__meta{ padding-bottom:28px; }
.dragcard__meta strong{
  display:block;
  font-weight:700; letter-spacing:-.02em;
  font-size:clamp(24px,2.8vw,34px);
  line-height:1.08;
  margin-bottom:12px;
}
.dragcard__meta span{ color:var(--ink2); font-size:15px; text-wrap:pretty; }

.livelist{ list-style:none; padding:0; }
.livelist li{
  display:flex; align-items:baseline; gap:16px;
  padding:18px 2px;
  border-bottom:1px solid rgba(17,17,17,.1);
}
.livelist li:first-child{ border-top:1px solid rgba(17,17,17,.1); }
.livelist strong{ font-size:clamp(17px,1.8vw,21px); font-weight:700; letter-spacing:-.01em; }
.livelist span{
  margin-left:auto;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink2); white-space:nowrap;
}

/* ============================================================
   5 · GALLERY
   ============================================================ */
.gallery{ padding-bottom:clamp(60px,8vw,120px); }
.gallery__grid{
  display:grid;
  gap:clamp(10px,1.4vw,16px);
  grid-template-columns:repeat(2,1fr);
  margin-top:clamp(28px,4vw,48px);
}
.gallery__grid figure{
  margin:0; overflow:hidden;
  border-radius:clamp(14px,1.6vw,20px);
  aspect-ratio:1;
  background:var(--lavender);
}
.gallery__grid figure img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform 1.1s var(--ease);
}
.gallery__grid figure:hover img{ transform:scale(1.06); }
/* playful staggered entrance */
.gallery__grid figure:nth-child(2){ transition-delay:.05s; }
.gallery__grid figure:nth-child(3){ transition-delay:.10s; }
.gallery__grid figure:nth-child(4){ transition-delay:.15s; }
.gallery__grid figure:nth-child(5){ transition-delay:.20s; }
.gallery__grid figure:nth-child(6){ transition-delay:.25s; }
.gallery__grid figure:nth-child(7){ transition-delay:.30s; }
.gallery__grid figure:nth-child(8){ transition-delay:.35s; }

/* desktop bento: contained 4×3 with square cells, one big feature + one wide tile */
@media (min-width:680px){
  .gallery__grid{
    grid-template-columns:repeat(4,1fr);
    grid-template-rows:repeat(3,1fr);
    aspect-ratio:4 / 3;
  }
  .gallery__grid figure{ aspect-ratio:auto; }
  .gallery__grid .g-big{ grid-column:1 / span 2; grid-row:1 / span 2; }
  .gallery__grid .g-wide{ grid-column:1 / span 2; grid-row:3; }
}

/* ============================================================
   6 · TICKETS — Pride Deck (playful ticket stubs)
   ============================================================ */
.tickets{ background:var(--white); }
.tickets__intro{
  max-width:46ch;
  font-size:clamp(17px,1.8vw,20px);
  color:var(--ink2);
  margin:-24px 0 28px;
  text-wrap:pretty;
}
.tickets__perks{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-bottom:clamp(36px,5vw,56px);
}
.tickets__perks span{
  padding:9px 16px;
  border-radius:999px;
  background:var(--surface);
  border:1px solid rgba(139,61,255,.18);
  color:var(--purple);
  font-size:13px; font-weight:500;
}
.tickets__grid{ display:grid; gap:22px; margin-bottom:22px; }
@media (min-width:760px){ .tickets__grid{ grid-template-columns:repeat(3,1fr); gap:26px; } }

/* — day ticket stub — */
.deck{
  position:relative;
  border-radius:16px;
  padding:30px 28px 28px;
  background:var(--lavender);
  display:flex; flex-direction:column; align-items:flex-start; gap:6px;
  transform:rotate(-1.2deg);
  transition:transform .45s var(--ease), box-shadow .45s var(--ease);
}
.deck--sat{ background:#FFE4F1; transform:rotate(1deg); }
.deck--sun{ background:#F3EDFF; transform:rotate(-.6deg); }
.deck:hover{
  transform:rotate(0deg) translateY(-6px);
  box-shadow:0 26px 60px rgba(40,16,80,.16);
}
/* pride band on top */
.deck::before{
  content:"";
  position:absolute; top:0; left:0; right:0; height:7px;
  border-radius:16px 16px 0 0;
  background:linear-gradient(90deg,
    #E40303 0 16.6%, #FF8C00 16.6% 33.3%, #FFED00 33.3% 50%,
    #008026 50% 66.6%, #24408E 66.6% 83.3%, #732982 83.3% 100%);
}
/* perforation notches */
.deck::after{
  content:"";
  position:absolute; left:18px; right:18px; bottom:96px;
  border-top:2px dashed rgba(17,17,17,.16);
}
.deck .notch{ display:none; }
.deck h3{
  font-size:clamp(24px,2.4vw,30px);
  font-weight:900; letter-spacing:-.02em; line-height:1.05;
  margin-top:8px;
}
.deck__tag{
  position:absolute; top:18px; right:16px;
  transform:rotate(7deg);
  background:var(--ink); color:#fff;
  font-size:11px; font-weight:700; letter-spacing:.2em;
  padding:7px 13px;
  border-radius:999px;
  box-shadow:0 6px 16px rgba(0,0,0,.18);
}
.deck__time{
  font-size:13px; font-weight:600;
  letter-spacing:.14em;
  color:var(--ink2);
}
.deck__price{
  font-size:clamp(40px,3.8vw,52px);
  font-weight:900; letter-spacing:-.03em;
  margin:auto 0 14px;
  padding-top:26px;
}
.deck__price span{
  font-size:12.5px; font-weight:500; letter-spacing:.04em;
  color:var(--ink2); margin-left:8px;
}
.deck .btn{ width:100%; }

/* — weekend banner — */
.deck--weekend{
  background:linear-gradient(120deg, #8B3DFF 0%, #B14BFF 45%, #FF4FA3 100%);
  color:#fff;
  transform:rotate(.4deg);
  flex-direction:column; gap:14px;
  padding:clamp(32px,4vw,48px);
  overflow:visible;
}
.deck--weekend::after{ display:none; }
.deck--weekend:hover{ transform:rotate(0deg) translateY(-6px); box-shadow:0 30px 70px rgba(139,61,255,.35); }
.deck--weekend h3{ font-size:clamp(30px,3.6vw,46px); }
.deck--weekend .deck__time{ color:rgba(255,255,255,.85); }
.deck--weekend .deck__price{ margin:6px 0 10px; padding-top:0; }
.deck--weekend .deck__price span{ color:rgba(255,255,255,.8); }
.deck--weekend .btn{ width:auto; align-self:flex-start; }
.deck__sticker{
  position:absolute; top:-16px; right:clamp(16px,4vw,40px);
  transform:rotate(4deg);
  background:#FFED00; color:var(--ink);
  font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  padding:10px 18px;
  border-radius:999px;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}
@media (min-width:900px){
  .deck--weekend{
    display:grid;
    grid-template-columns:1fr auto auto;
    align-items:center;
    column-gap:clamp(24px,4vw,56px);
  }
  .deck--weekend .deck__price{ margin:0; }
  .deck--weekend .btn{ align-self:center; }
}
.tickets__fine{
  margin-top:26px;
  font-size:13px; color:var(--ink2);
  max-width:62ch; text-wrap:pretty;
}

/* ============================================================
   7 · SCHEDULE — timeline
   ============================================================ */
.schedule{ background:var(--surface); }
.timeline{ position:relative; padding-left:34px; }
.timeline::before{
  content:""; position:absolute; left:8px; top:8px; bottom:8px;
  width:1px;
  background:linear-gradient(180deg, var(--purple), var(--pink));
}
.timeline__day{ position:relative; padding-bottom:clamp(40px,5vw,64px); }
.timeline__day:last-child{ padding-bottom:0; }
.timeline__day::before{
  content:""; position:absolute; left:-30px; top:10px;
  width:9px; height:9px; border-radius:50%;
  background:var(--purple);
  box-shadow:0 0 0 5px var(--surface), 0 0 0 6px rgba(139,61,255,.3);
}
.timeline__head{ display:flex; align-items:baseline; gap:16px; margin-bottom:18px; flex-wrap:wrap; }
.timeline__num{
  font-size:12px; font-weight:700; letter-spacing:.3em;
  color:var(--purple);
}
.timeline__head h3{
  font-size:clamp(22px,2.6vw,32px);
  font-weight:700; letter-spacing:-.02em;
}
.timeline__day ul{ list-style:none; padding:0; }
.timeline__day li{
  display:flex; gap:20px; align-items:baseline;
  padding:12px 0;
  border-bottom:1px solid rgba(17,17,17,.07);
  font-size:15.5px; color:var(--ink2);
}
.timeline__day time{
  font-weight:700; color:var(--ink);
  font-variant-numeric:tabular-nums;
  flex-shrink:0; width:52px;
}

/* ============================================================
   8 · LOCATION
   ============================================================ */
.location__grid{ display:grid; gap:24px; }
@media (min-width:900px){ .location__grid{ grid-template-columns:7fr 5fr; gap:28px; } }
.location__map{
  border-radius:16px; overflow:hidden;
  min-height:380px;
  border:1px solid rgba(17,17,17,.08);
}
.location__map iframe{ width:100%; height:100%; min-height:380px; border:0; display:block; }
.location__side{ display:flex; flex-direction:column; gap:24px; }
.location__photo image-slot{ width:100%; height:auto; aspect-ratio:16/10; display:block; }
.location__info{
  background:var(--surface);
  border-radius:8px;
  padding:28px;
  flex:1;
}
.location__info p{ margin-bottom:14px; color:var(--ink2); text-wrap:pretty; }
.location__info p strong{ color:var(--ink); font-size:17px; }
.location__info p:last-child{ margin-bottom:0; }

/* ============================================================
   9 · SPONSORS
   ============================================================ */
.sponsors{ padding-block:clamp(70px,9vw,130px); }
.sponsors__wall{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(36px,6vw,72px) clamp(24px,4vw,56px);
  justify-items:center; align-items:center;
  margin-top:clamp(36px,5vw,60px);
}
@media (min-width:760px){ .sponsors__wall{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1100px){ .sponsors__wall{ grid-template-columns:repeat(6,1fr); } }
.wordmark{
  font-size:15px; font-weight:700; letter-spacing:.22em;
  color:rgba(17,17,17,.34);
  transition:color .3s;
  white-space:nowrap;
}
.wordmark--serif{
  font-weight:300;
  font-size:19px; letter-spacing:.12em;
}
.wordmark:hover{ color:var(--purple); }

/* ============================================================
   10 · FAQ
   ============================================================ */
.faq{ background:var(--surface); }
.faq__list{ border-top:1px solid rgba(17,17,17,.1); }
.faq__item{ border-bottom:1px solid rgba(17,17,17,.1); }
.faq__item summary{
  display:flex; align-items:center; gap:20px;
  list-style:none; cursor:pointer;
  padding:24px 2px;
  font-size:clamp(16px,1.8vw,19px); font-weight:600; letter-spacing:-.01em;
  transition:color .25s;
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary:hover{ color:var(--purple); }
.faq__icon{
  margin-left:auto; flex-shrink:0;
  width:30px; height:30px; border-radius:50%;
  border:1px solid rgba(17,17,17,.18);
  position:relative;
  transition:transform .4s var(--ease), background .3s, border-color .3s;
}
.faq__icon::before, .faq__icon::after{
  content:""; position:absolute; top:50%; left:50%;
  background:currentColor;
  transform:translate(-50%,-50%);
}
.faq__icon::before{ width:11px; height:1.5px; }
.faq__icon::after{ width:1.5px; height:11px; transition:opacity .25s; }
.faq__item[open] .faq__icon{ transform:rotate(45deg); background:var(--lavender); border-color:transparent; }
.faq__body{ overflow:hidden; }
.faq__body p{
  padding:0 2px 26px;
  color:var(--ink2); max-width:62ch; text-wrap:pretty;
}

/* ============================================================
   11 · FINAL CTA
   ============================================================ */
.final{
  position:relative; overflow:hidden;
  background:linear-gradient(170deg, #1b0f33 0%, #3a1670 50%, #8B3DFF 130%);
  color:#fff;
  padding-block:clamp(120px,16vw,220px);
  text-align:center;
}
.final__blobs i{
  position:absolute; border-radius:50%;
  filter:blur(70px); opacity:.5;
  animation:blob 14s ease-in-out infinite alternate;
}
.final__blobs i:nth-child(1){ width:48vw; height:48vw; left:-12vw; top:-10vw; background:var(--pink); animation-delay:0s; }
.final__blobs i:nth-child(2){ width:40vw; height:40vw; right:-10vw; bottom:-14vw; background:var(--purple); animation-delay:-5s; }
.final__blobs i:nth-child(3){ width:26vw; height:26vw; right:18vw; top:6vw; background:#5B8CFF; opacity:.3; animation-delay:-9s; }
@keyframes blob{
  from{ transform:translate(0,0) scale(1); }
  to  { transform:translate(6vw,4vw) scale(1.15); }
}
@media (prefers-reduced-motion: reduce){ .final__blobs i{ animation:none; } }
.final__inner{ position:relative; z-index:1; }
.final__title{
  font-size:clamp(40px,7.5vw,104px);
  font-weight:900; letter-spacing:-.03em; line-height:1.0;
  max-width:14ch; margin:0 auto clamp(40px,6vw,64px);
  text-wrap:balance;
}
.final__title em{ font-weight:300; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:#0d0a14; color:rgba(255,255,255,.65);
  padding-block:clamp(48px,6vw,72px);
  text-align:center; font-size:14px;
}
.footer__mark{
  width:96px; height:96px;
  margin:0 auto 20px;
}
.footer__logo{
  display:inline-block;
  font-weight:700; letter-spacing:.06em; color:#fff;
  margin-bottom:16px;
}
.footer__logo span{ font-weight:300; margin-left:6px; }
.footer__inner p{ margin-bottom:6px; }
.footer__fine{ font-size:12px; color:rgba(255,255,255,.4); margin-top:10px; }

/* ============================================================
   LANGUAGE TOGGLE (EN / NL)
   ============================================================ */
.nav__lang{
  margin-left:auto;
  display:inline-flex; align-items:center; gap:2px;
  padding:3px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.45);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  transition:background .35s var(--ease), border-color .35s var(--ease);
}
.nav.scrolled .nav__lang{ background:var(--surface); border-color:rgba(139,61,255,.22); }
.nav__lang button{
  appearance:none; -webkit-appearance:none; border:0; cursor:pointer;
  font:inherit; font-size:12px; font-weight:700; letter-spacing:.08em; line-height:1;
  padding:7px 13px; border-radius:999px;
  color:#fff; background:transparent;
  transition:background .3s var(--ease), color .3s var(--ease), box-shadow .3s var(--ease);
}
.nav.scrolled .nav__lang button{ color:var(--ink); }
.nav__lang button:hover{ color:var(--pink); }
.nav__lang button[aria-pressed="true"],
.nav.scrolled .nav__lang button[aria-pressed="true"]{
  color:#fff;
  background:linear-gradient(90deg, var(--purple), var(--pink));
  box-shadow:0 4px 14px rgba(255,79,163,.45);
}
.nav .btn--nav{ margin-left:12px; }
@media (min-width:760px){ .nav__lang{ margin-left:28px; } }

/* ============================================================
   HIDE SCROLLBAR (scrolling stays fully functional)
   ============================================================ */
html{ scrollbar-width:none; -ms-overflow-style:none; }
html::-webkit-scrollbar,
body::-webkit-scrollbar{ width:0; height:0; display:none; }
/* keep section headings clear of the fixed nav when jumped to via anchors */
section[id]{ scroll-margin-top:88px; }

/* ============================================================
   LOCATION — Dam Square video (replaces the photo placeholder)
   ============================================================ */
.location__photo video{
  width:100%; aspect-ratio:16/10;
  object-fit:cover; border-radius:16px;
  display:block; background:var(--ink);
}

/* ============================================================
   TRAVEL ASSISTANT (in de Locatie-sectie)
   ============================================================ */
.travel{
  margin-top:clamp(40px,5vw,64px);
  background:var(--surface);
  border:1px solid rgba(139,61,255,.14);
  border-radius:16px;
  padding:clamp(24px,3.5vw,44px);
}
.travel__head{ margin-bottom:22px; }
.travel__head .overline{ margin-bottom:10px; }
.travel__head h3{
  font-size:clamp(26px,3.4vw,40px);
  font-weight:900; letter-spacing:-.025em;
}
.travel__chat{
  display:flex; flex-direction:column; gap:12px;
  max-height:340px;
  overflow-y:auto;
  padding:4px 2px;
  margin-bottom:18px;
}
.travel__msg{
  max-width:88%;
  padding:13px 16px;
  border-radius:14px;
  font-size:15px; line-height:1.55;
  text-wrap:pretty;
  white-space:pre-wrap;
}
.travel__msg--bot{
  align-self:flex-start;
  background:#fff;
  border:1px solid rgba(139,61,255,.16);
  border-bottom-left-radius:4px;
}
.travel__msg--bot strong{ color:var(--purple); }
.travel__msg--user{
  align-self:flex-end;
  background:linear-gradient(135deg, var(--purple), #B14BFF);
  color:#fff;
  border-bottom-right-radius:4px;
}
.travel__typing{
  align-self:flex-start;
  display:flex; gap:5px;
  padding:15px 18px;
  background:#fff;
  border:1px solid rgba(139,61,255,.16);
  border-radius:14px; border-bottom-left-radius:4px;
}
.travel__typing span{
  width:6px; height:6px; border-radius:50%;
  background:var(--purple);
  animation:travelDot 1.1s infinite ease-in-out;
}
.travel__typing span:nth-child(2){ animation-delay:.18s; }
.travel__typing span:nth-child(3){ animation-delay:.36s; }
@keyframes travelDot{
  0%,100%{ transform:translateY(0); opacity:.4; }
  50%    { transform:translateY(-4px); opacity:1; }
}
.travel__chips{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-bottom:16px;
}
.travel__chips button{
  font-family:inherit;
  font-size:13.5px; font-weight:500;
  color:var(--purple);
  background:#fff;
  border:1px solid rgba(139,61,255,.3);
  border-radius:999px;
  padding:10px 16px;
  cursor:pointer;
  transition:background .2s, color .2s, transform .25s var(--ease);
}
.travel__chips button:hover{
  background:var(--purple); color:#fff;
  transform:translateY(-2px);
}
.travel__input{ display:flex; gap:10px; }
.travel__input input{
  flex:1; min-width:0;
  font-family:inherit; font-size:15px;
  color:var(--ink);
  background:#fff;
  border:1px solid rgba(17,17,17,.14);
  border-radius:999px;
  padding:14px 20px;
  outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.travel__input input:focus{
  border-color:var(--purple);
  box-shadow:0 0 0 4px rgba(139,61,255,.12);
}
.travel__input input::placeholder{ color:#9a93ab; }
.travel__input button{
  font-family:inherit; font-size:15px; font-weight:600;
  color:#fff; background:var(--purple);
  border:0; border-radius:999px;
  padding:0 28px;
  cursor:pointer;
  transition:transform .25s var(--ease), background .2s;
}
.travel__input button:hover{ transform:translateY(-2px); background:#7a2ef0; }
.travel__input button:disabled{ opacity:.5; cursor:wait; transform:none; }

/* ============================================================
   FACEBOOK — playful follow section
   ============================================================ */
.social{ padding-block:clamp(80px,11vw,150px); }
.social__inner{
  display:flex; flex-direction:column; align-items:center;
  gap:clamp(40px,5vw,72px);
  text-align:center;
}
@media (min-width:860px){
  .social__inner{ flex-direction:row; text-align:left; justify-content:center; }
}
.social__badge{
  position:relative;
  display:flex; align-items:center; justify-content:center;
  width:clamp(170px,22vw,230px);
  aspect-ratio:1;
  flex-shrink:0;
  border-radius:26%;
  background:linear-gradient(145deg, #2E8BFF 0%, #1877F2 45%, #0E5FCB 100%);
  box-shadow:0 30px 70px rgba(24,119,242,.35);
  transform:rotate(-7deg);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
@media (prefers-reduced-motion: no-preference){
  .social__badge{ animation:fbBob 4.5s ease-in-out infinite; }
}
@keyframes fbBob{
  0%,100%{ transform:rotate(-7deg) translateY(0); }
  50%    { transform:rotate(-4.5deg) translateY(-10px); }
}
.social__badge:hover{
  animation-play-state:paused;
  transform:rotate(0deg) scale(1.06);
  box-shadow:0 40px 90px rgba(24,119,242,.5);
}
.social__f{
  font-weight:900;
  font-size:clamp(110px,14vw,150px);
  line-height:1;
  color:#fff;
  transform:translateY(6%);
  user-select:none;
}
.social__confetti{ position:absolute; inset:-26px; pointer-events:none; }
.social__confetti i{
  position:absolute;
  width:12px; height:12px;
  border-radius:3px;
  background:var(--cf, #FF4FA3);
  opacity:0;
}
@media (prefers-reduced-motion: no-preference){
  .social__confetti i{ animation:cfPop 3.2s ease-in-out infinite; }
}
.social__confetti i:nth-child(1){ top:-4px;  left:18%;  --cf:#E40303; animation-delay:0s;   }
.social__confetti i:nth-child(2){ top:12%;   right:-8px; --cf:#FF8C00; animation-delay:.5s; width:9px; height:9px; }
.social__confetti i:nth-child(3){ bottom:8%; right:-16px; --cf:#FFED00; animation-delay:1.1s; }
.social__confetti i:nth-child(4){ bottom:-10px; left:30%; --cf:#008026; animation-delay:1.6s; width:9px; height:9px; }
.social__confetti i:nth-child(5){ top:38%;  left:-18px; --cf:#24408E; animation-delay:2.2s; }
.social__confetti i:nth-child(6){ top:-14px; right:24%; --cf:#732982; animation-delay:2.7s; width:10px; height:10px; }
@keyframes cfPop{
  0%,100%{ opacity:0; transform:translateY(6px) rotate(0deg) scale(.5); }
  50%    { opacity:1; transform:translateY(-8px) rotate(140deg) scale(1); }
}
.social__copy{ max-width:480px; }
.social__title{
  font-size:clamp(38px,5.5vw,68px);
  font-weight:900; letter-spacing:-.03em; line-height:1.0;
  margin-bottom:18px;
}
.social__sub{
  color:var(--ink2);
  margin-bottom:30px;
  text-wrap:pretty;
}

/* ============================================================
   NAV — mobile hamburger menu + desktop bar
   ============================================================ */
/* keep logo + hamburger above the overlay so they stay usable */
.nav__logo{ position:relative; z-index:2; }

.nav__toggle{
  display:flex; flex-direction:column; justify-content:center; gap:5px;
  margin-left:auto;
  width:44px; height:44px; padding:11px;
  border:0; background:transparent; cursor:pointer;
  position:relative; z-index:2;
}
.nav__toggle-bar{
  display:block; width:100%; height:2px; border-radius:2px;
  background:#fff;
  transition:transform .3s var(--ease), opacity .2s var(--ease), background .3s var(--ease);
}
.nav.scrolled .nav__toggle-bar{ background:var(--ink); }
.nav--open .nav__toggle-bar{ background:#fff; }
.nav--open .nav__toggle-bar:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav--open .nav__toggle-bar:nth-child(2){ opacity:0; }
.nav--open .nav__toggle-bar:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* full-screen overlay menu (mobile) */
.nav__menu{
  position:fixed; inset:0; z-index:1;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:clamp(22px,5vh,40px);
  padding:96px 24px max(40px, env(safe-area-inset-bottom));
  background:linear-gradient(160deg, #1b0f33 0%, #2c1455 55%, #4a1d8f 100%);
  opacity:0; visibility:hidden;
  transition:opacity .32s var(--ease), visibility .32s;
}
.nav--open .nav__menu{ opacity:1; visibility:visible; }
.nav__menu .nav__links{
  display:flex; flex-direction:column; align-items:center; gap:6px;
  margin:0;
}
.nav__menu .nav__links a{
  color:#fff; opacity:.85;
  font-size:clamp(28px,8vw,40px); font-weight:700; letter-spacing:-.02em;
  padding:10px 18px;
}
.nav__menu .nav__links a.is-active{ color:var(--pink); opacity:1; }
.nav__menu .nav__lang{ margin:0; background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.4); }
.nav__menu .nav__lang button{ padding:11px 22px; font-size:14px; color:#fff; }
.nav__menu .btn--nav{ margin:0; font-size:16px; padding:16px 34px; }

/* desktop: inline bar, no hamburger */
@media (min-width:760px){
  .nav__toggle{ display:none; }
  .nav__menu{
    position:static; inset:auto; z-index:auto;
    flex-direction:row; align-items:center; justify-content:flex-end;
    margin-left:auto; gap:26px;
    padding:0; background:none;
    opacity:1; visibility:visible;
  }
  .nav__menu .nav__links{ flex-direction:row; gap:28px; }
  .nav__menu .nav__links a{
    color:#fff; opacity:.92;
    font-size:14px; font-weight:400; letter-spacing:0; padding:0;
  }
  .nav__menu .nav__links a:hover{ opacity:1; }
  .nav.scrolled .nav__menu .nav__links a{ color:var(--ink); }
  .nav__menu .nav__links a.is-active,
  .nav.scrolled .nav__menu .nav__links a.is-active{ color:var(--purple); opacity:1; }
  .nav__menu .nav__lang{ background:rgba(255,255,255,.14); }
  .nav__menu .nav__lang button{ padding:7px 13px; font-size:12px; color:#fff; }
  .nav.scrolled .nav__menu .nav__lang button{ color:var(--ink); }
  .nav__menu .nav__lang button[aria-pressed="true"],
  .nav.scrolled .nav__menu .nav__lang button[aria-pressed="true"]{ color:#fff; }
  .nav__menu .btn--nav{ font-size:13px; padding:11px 22px; }
}

/* ============================================================
   BACK TO TOP — pride scroll-progress ring
   ============================================================ */
.totop{
  position:fixed;
  right:clamp(16px,4vw,28px);
  bottom:calc(clamp(16px,4vw,28px) + env(safe-area-inset-bottom, 0px));
  z-index:50;
  width:54px; height:54px;
  display:grid; place-items:center;
  border:0; padding:0; cursor:pointer;
  border-radius:50%;
  background:#fff;
  box-shadow:0 10px 30px rgba(40,16,80,.22), 0 2px 8px rgba(0,0,0,.08);
  opacity:0; visibility:hidden;
  transform:translateY(14px) scale(.85);
  transition:opacity .35s var(--ease), transform .35s var(--ease),
             visibility .35s, box-shadow .3s var(--ease);
}
.totop.is-visible{ opacity:1; visibility:visible; transform:translateY(0) scale(1); }
.totop:hover{
  transform:translateY(-3px) scale(1.06);
  box-shadow:0 18px 44px rgba(255,79,163,.4), 0 0 0 4px rgba(255,79,163,.12);
}
.totop:active{ transform:translateY(-1px) scale(.98); }
.totop:focus-visible{ outline:3px solid var(--purple); outline-offset:3px; }
.totop__progress{
  position:absolute; inset:0; width:100%; height:100%;
  transform:rotate(-90deg);
}
.totop__track{ fill:none; stroke:rgba(17,17,17,.1); stroke-width:3; }
.totop__ring{
  fill:none; stroke:url(#prideRing); stroke-width:3; stroke-linecap:round;
  transition:stroke-dashoffset .12s linear;
}
.totop__arrow{
  position:relative; width:22px; height:22px;
  fill:none; stroke:var(--purple); stroke-width:2.4;
  stroke-linecap:round; stroke-linejoin:round;
  transition:transform .3s var(--ease);
}
.totop:hover .totop__arrow{ transform:translateY(-2px); }
@media (prefers-reduced-motion: reduce){
  .totop, .totop__arrow, .totop__ring{ transition:none; }
  .totop:hover{ transform:none; }
  .totop:hover .totop__arrow{ transform:none; }
}

/* ============================================================
   NAV LEGIBILITY — top scrim so the menu reads over the hero
   ============================================================ */
.nav::before{
  content:"";
  position:absolute; left:0; right:0; top:0;
  height:188px;
  background:linear-gradient(180deg, rgba(8,3,18,.74) 0%, rgba(8,3,18,.42) 40%, transparent 100%);
  pointer-events:none;
  z-index:-1;
  transition:opacity .4s var(--ease);
}
.nav.scrolled::before{ opacity:0; }
/* full-strength + shadowed nav text at the top, cleared once scrolled */
.nav__menu .nav__links a{ opacity:1; text-shadow:0 1px 16px rgba(0,0,0,.7); }
.nav.scrolled .nav__menu .nav__links a{ text-shadow:none; }
.nav__logo{ text-shadow:0 1px 16px rgba(0,0,0,.6); }
.nav.scrolled .nav__logo{ text-shadow:none; }

/* ============================================================
   LOCATION + DAM-MAP (3D Amsterdam, uit zip-design)
   ============================================================ */
@media (min-width:900px){ .location__grid{ grid-template-columns:7fr 5fr; gap:28px; } }

/* ---- map card ---- */
.dam-map{
  --tilt:50deg;
  --turn:-10deg;
  --mapscale:1.08;
  position:relative;
  border-radius:16px;
  overflow:hidden;
  min-height:440px;
  background:
    radial-gradient(46% 40% at 44% 44%, rgba(139,61,255,.13), transparent 70%),
    linear-gradient(180deg, #FCFBF8 0%, #F2F0EA 100%);
  border:1px solid rgba(17,17,17,.07);
  box-shadow:0 36px 80px -36px rgba(60,40,16,.28);
}
.dam-map__scene{
  position:absolute; inset:0;
  perspective:1100px;
  perspective-origin:50% 30%;
}
.dam-map__plane{
  position:absolute; left:51%; top:74%;
  width:780px; height:780px;
  margin:-390px 0 0 -390px;
  border-radius:28px;
  transform:rotateX(var(--tilt)) rotateZ(var(--turn)) scale(var(--mapscale));
  transform-style:preserve-3d;
  background:linear-gradient(180deg, #F1EEE7 0%, #E9E5DC 100%);
  box-shadow:
    0 60px 90px -40px rgba(60,40,16,.30),
    inset 0 0 0 1px rgba(255,255,255,.7);
  transition:transform 1.1s var(--ease);
}
@media (hover:hover) and (prefers-reduced-motion: no-preference){
  .dam-map:hover{ --tilt:45deg; --turn:-6deg; }
}

/* the IJ */
.dm-ij{
  position:absolute; left:-6%; right:-6%; top:-14%;
  height:24%;
  z-index:2;
  background:linear-gradient(180deg, #BFD8EF 0%, #CFE3F4 100%);
  border-radius:0 0 46% 38%;
  box-shadow:inset 0 -3px 0 rgba(255,255,255,.85), inset 0 -14px 24px rgba(120,160,205,.18);
}

/* canal belt: water rings, ending at the IJ */
.dm-canal{
  position:absolute;
  z-index:1;
  border-radius:50%;
  border-style:solid;
  border-color:#C7DDF1;
}

/* radial streets */
.dm-street{
  position:absolute; left:388px; top:190px;
  width:4px; height:290px;
  z-index:1;
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.35));
  transform:rotate(var(--a, 0deg));
  transform-origin:top center;
}

/* Damrak: the axis from Centraal to the Dam */
.dm-damrak{
  position:absolute; left:381px; top:70px;
  width:14px; height:94px;
  z-index:2;
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.6));
  border-radius:3px;
}

/* city blocks: the canal fan */
.dm-b{
  position:absolute;
  z-index:3;
  border-radius:2.5px;
  background:linear-gradient(165deg, #FFFFFF 0%, #F1EDE4 100%);
  box-shadow:
    0 12px 16px -9px rgba(70,50,20,.32),
    inset 0 0 0 1px rgba(255,255,255,.85);
  transform:translateZ(var(--z, 6px)) rotateZ(var(--rz, 0deg));
}
.dm-b--old{ background:linear-gradient(165deg, #FDFBF6 0%, #EFE9DD 100%); }

/* bridges over the canals */
.dm-bridge{
  position:absolute;
  width:16px; height:7px;
  z-index:2;
  border-radius:2px;
  background:#FFFFFF;
  box-shadow:0 4px 8px -3px rgba(70,50,20,.30);
  transform:translateZ(3px) rotateZ(var(--rz, 0deg));
}

/* parks */
.dm-park{
  position:absolute;
  z-index:1;
  border-radius:14px;
  background:linear-gradient(165deg, #E2EAD6 0%, #D5E0C6 100%);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.6);
  transform:rotate(var(--rz, 0deg));
}

/* Centraal Station on its island */
.dm-cs-isle{
  position:absolute; left:306px; top:30px;
  width:168px; height:46px;
  z-index:3;
  border-radius:8px;
  background:linear-gradient(180deg, #F3F0E9, #EAE6DD);
  box-shadow:0 8px 14px -6px rgba(70,90,120,.35);
  transform:translateZ(2px);
}
.dm-cs{
  position:absolute; left:324px; top:38px;
  width:132px; height:30px;
  z-index:4;
  border-radius:3px;
  background:linear-gradient(165deg, #FFFFFF 0%, #EFEAE0 100%);
  box-shadow:0 14px 18px -9px rgba(70,50,20,.36), inset 0 0 0 1px rgba(255,255,255,.85);
  transform:translateZ(14px);
}
.dm-cs__tower{
  position:absolute; top:36px;
  width:15px; height:15px;
  z-index:5;
  border-radius:2px;
  background:linear-gradient(165deg, #FFFFFF, #EAE4D8);
  box-shadow:0 16px 18px -9px rgba(70,50,20,.38), inset 0 0 0 1px rgba(255,255,255,.9);
  transform:translateZ(24px);
}

/* Royal Palace at the Dam */
.dm-palace{
  position:absolute; left:300px; top:172px;
  width:46px; height:30px;
  z-index:4;
  border-radius:3px;
  background:linear-gradient(165deg, #FFFFFF 0%, #EFEAE0 100%);
  box-shadow:0 14px 18px -9px rgba(70,50,20,.36), inset 0 0 0 1px rgba(255,255,255,.85);
  transform:translateZ(13px);
}
.dm-palace__dome{
  position:absolute; left:318px; top:168px;
  width:10px; height:10px;
  z-index:5;
  border-radius:50%;
  background:linear-gradient(165deg, #FFFFFF, #E6E0D3);
  box-shadow:0 14px 16px -8px rgba(70,50,20,.38);
  transform:translateZ(21px);
}

/* church towers */
.dm-tower{
  position:absolute;
  width:13px; height:13px;
  z-index:4;
  border-radius:2px;
  background:linear-gradient(165deg, #FFFFFF, #EAE4D8);
  box-shadow:0 18px 18px -9px rgba(70,50,20,.40), inset 0 0 0 1px rgba(255,255,255,.9);
  transform:translateZ(var(--z, 22px));
}
.dm-tower--s{ width:10px; height:10px; }

/* De Dam: the glowing heart */
.dm-dam{
  position:absolute; left:355px; top:163px;
  width:70px; height:54px;
  z-index:3;
  border-radius:8px;
  background:linear-gradient(165deg, #A86BFF 0%, #8B3DFF 100%);
  box-shadow:
    0 0 0 6px rgba(139,61,255,.15),
    0 0 46px 16px rgba(139,61,255,.40),
    inset 0 0 0 1px rgba(255,255,255,.35);
  transform:translateZ(3px);
}
.dm-dam::after{
  content:"";
  position:absolute; inset:-6px;
  border-radius:12px;
  border:2px solid rgba(139,61,255,.55);
  opacity:0;
}
@media (prefers-reduced-motion: no-preference){
  .dm-dam::after{ animation:damPulse 2.8s var(--ease) infinite; }
  @keyframes damPulse{
    0%  { transform:scale(.7); opacity:.9; }
    70% { transform:scale(1.7); opacity:0; }
    100%{ transform:scale(1.7); opacity:0; }
  }
}

/* upright labels, billboarded against the tilt */
.dm-pinwrap{
  position:absolute;
  z-index:6;
  transform-style:preserve-3d;
  transform:rotateZ(calc(-1 * var(--turn, -14deg))) rotateX(calc(-1 * var(--tilt, 55deg)));
  transition:transform 1.1s var(--ease);
}
.dm-pin{
  position:absolute; bottom:0; left:0;
  transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center;
}
.dm-pin__label{
  background:rgba(17,12,30,.92);
  color:#fff;
  font-size:13px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  padding:8px 16px;
  border-radius:999px;
  white-space:nowrap;
  box-shadow:0 14px 30px rgba(20,8,50,.4), inset 0 0 0 1px rgba(255,255,255,.14);
}
.dm-pin__label--soft{
  background:rgba(255,255,255,.92);
  color:var(--ink2);
  font-size:10px; font-weight:700;
  padding:6px 12px;
  box-shadow:0 10px 22px rgba(60,40,16,.22), inset 0 0 0 1px rgba(17,17,17,.06);
}
.dm-pin__stem{
  width:2px; height:34px;
  background:linear-gradient(180deg, rgba(17,12,30,.9), rgba(139,61,255,.0));
}
.dm-pin__stem--s{
  height:16px;
  background:linear-gradient(180deg, rgba(120,110,140,.7), rgba(120,110,140,0));
}

/* glass chip in the card corner */
.dam-map__chip{
  position:absolute; left:18px; top:16px;
  display:inline-flex; align-items:center; gap:9px;
  padding:9px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.62);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.85);
  box-shadow:0 8px 24px rgba(60,40,16,.12);
  font-size:11px; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink2);
}
.dam-map__chipdot{
  width:8px; height:8px; border-radius:50%;
  background:var(--purple);
  box-shadow:0 0 10px 2px rgba(139,61,255,.5);
}

@media (max-width:640px){
  .dam-map{ min-height:360px; }
  .dam-map{ --mapscale:.78; }
}

/* ---- side column ---- */
.location__side{ display:flex; flex-direction:column; gap:24px; }
.location__photo image-slot{ width:100%; height:auto; aspect-ratio:16/10; display:block; }
.location__info{
  background:var(--surface);
  border-radius:8px;
  padding:28px;
  flex:1;
}
.location__info p{ margin-bottom:14px; color:var(--ink2); text-wrap:pretty; }
.location__info p strong{ color:var(--ink); font-size:17px; }
.location__info p:last-child{ margin-bottom:0; }
.location__cta{ margin-top:6px; }


/* foto in het locatie-slot (img i.p.v. image-slot) */
.location__photo img{
  width:100%; aspect-ratio:16/10; object-fit:cover;
  border-radius:16px; display:block; background:var(--lavender);
}

/* ============================================================
   CONTACT FORM (boven de footer)
   ============================================================ */
.contact{ padding-block:clamp(60px,8vw,110px); background:var(--surface); }
.contact__intro{
  max-width:54ch; margin:clamp(14px,2vw,22px) 0 clamp(28px,4vw,44px);
  font-size:clamp(16px,1.8vw,19px); color:var(--ink2); text-wrap:pretty;
}
.contact__form{ display:flex; flex-direction:column; gap:18px; }
.contact__row{ display:grid; gap:18px; }
@media (min-width:640px){ .contact__row{ grid-template-columns:1fr 1fr; } }
.field{ display:flex; flex-direction:column; gap:8px; }
.field__label{
  font-size:13px; font-weight:600; letter-spacing:.04em;
  text-transform:uppercase; color:var(--ink2);
}
.contact__form input,
.contact__form textarea{
  width:100%; font-family:inherit; font-size:16px; color:var(--ink);
  background:#fff; border:1px solid rgba(17,17,17,.14);
  border-radius:14px; padding:14px 16px; outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.contact__form textarea{ resize:vertical; min-height:130px; }
.contact__form input::placeholder,
.contact__form textarea::placeholder{ color:#9a93ab; }
.contact__form input:focus,
.contact__form textarea:focus{
  border-color:var(--purple);
  box-shadow:0 0 0 4px rgba(139,61,255,.12);
}
.contact__form input:user-invalid,
.contact__form textarea:user-invalid{
  border-color:#e0245e; box-shadow:0 0 0 4px rgba(224,36,94,.12);
}
.contact__submit{ align-self:flex-start; margin-top:6px; }
.contact__submit:disabled{ opacity:.6; cursor:progress; }
.contact__hint{ font-size:13px; color:var(--ink2); margin-top:2px; }
/* spam honeypot — hidden from people, reachable by bots */
.contact__hp{
  position:absolute; left:-9999px; width:1px; height:1px;
  overflow:hidden; opacity:0;
}
/* submit feedback */
.contact__status{
  margin:2px 0 0; font-size:14px; font-weight:500; line-height:1.5;
  padding:12px 16px; border-radius:12px;
}
.contact__status--ok{
  color:#1f7a4d; background:rgba(34,160,90,.1);
  border:1px solid rgba(34,160,90,.28);
}
.contact__status--error{
  color:#b22d4f; background:rgba(255,79,143,.08);
  border:1px solid rgba(255,79,143,.3);
}
.contact__status--error a{ color:var(--purple); font-weight:600; }

/* ============================================================
   LEGAL PAGES (privacy / cookies / terms)
   ============================================================ */
.legal{ background:var(--white); }
/* solid nav from the top on light legal pages */
.legal .nav,
.legal .nav.scrolled{
  background:rgba(255,255,255,.9);
  -webkit-backdrop-filter:blur(16px); backdrop-filter:blur(16px);
  box-shadow:0 1px 0 rgba(17,17,17,.06);
}
.legal .nav::before{ display:none; }
.legal .nav__logo{ color:var(--ink); text-shadow:none; }
.legal .nav__toggle-bar{ background:var(--ink); }
.legal .nav__menu .nav__links a{ color:var(--ink); text-shadow:none; opacity:.78; }
.legal .nav__menu .nav__links a:hover{ opacity:1; }
.legal .nav__menu .nav__lang{ background:var(--surface); border-color:rgba(139,61,255,.22); }
.legal .nav__menu .nav__lang button{ color:var(--ink); }
.legal .nav__menu .nav__lang button[aria-pressed="true"]{ color:#fff; }

.legal-hero{
  padding-top:clamp(124px,16vw,184px);
  padding-bottom:clamp(30px,4vw,52px);
  background:
    radial-gradient(120% 130% at 100% -20%, rgba(255,79,163,.10), transparent 55%),
    radial-gradient(120% 130% at -15% 0%, rgba(139,61,255,.13), transparent 52%),
    var(--surface);
  border-bottom:1px solid rgba(17,17,17,.06);
}
.legal-hero__flag{
  height:5px; width:74px; border-radius:999px; margin-bottom:22px;
  background:linear-gradient(90deg,
    #E40303 0 16.6%, #FF8C00 16.6% 33.3%, #FFED00 33.3% 50%,
    #008026 50% 66.6%, #24408E 66.6% 83.3%, #732982 83.3% 100%);
}
.legal__title{
  font-size:clamp(38px,6.2vw,72px); font-weight:700;
  letter-spacing:-.035em; line-height:1.02; text-wrap:balance;
}
.legal__lead{
  margin-top:18px; max-width:60ch;
  font-size:clamp(17px,1.9vw,20px); font-weight:300;
  color:var(--ink2); line-height:1.6; text-wrap:pretty;
}
.legal__updated{
  display:inline-flex; align-items:center; gap:9px; margin-top:24px;
  padding:8px 16px; border-radius:999px;
  background:#fff; border:1px solid rgba(139,61,255,.18);
  font-size:12.5px; font-weight:600; letter-spacing:.04em;
  color:var(--ink2); text-transform:uppercase;
}
.legal__updated::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--purple); }

.legal-body{ padding-block:clamp(48px,7vw,88px); }
.prose > :first-child{ margin-top:0; }
.prose h2{
  font-size:clamp(22px,2.7vw,30px); font-weight:700;
  letter-spacing:-.02em; line-height:1.2; color:var(--ink);
  margin:clamp(44px,5.5vw,68px) 0 16px;
  scroll-margin-top:96px;
}
.prose h3{
  font-size:clamp(16px,1.7vw,19px); font-weight:600;
  color:var(--ink); margin:30px 0 8px;
}
.prose p{
  font-size:17px; line-height:1.75; color:var(--ink2);
  margin-bottom:16px; max-width:68ch; text-wrap:pretty;
}
.prose strong{ color:var(--ink); font-weight:600; }
.prose a{ color:var(--purple); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; }
.prose a:hover{ color:var(--pink); }
.prose ul{ list-style:none; padding:0; margin:6px 0 20px; max-width:68ch; }
.prose li{
  position:relative; padding-left:26px; margin-bottom:11px;
  font-size:17px; line-height:1.65; color:var(--ink2); text-wrap:pretty;
}
.prose li::before{
  content:""; position:absolute; left:3px; top:10px;
  width:7px; height:7px; border-radius:50%;
  background:linear-gradient(150deg, var(--pink), var(--purple));
}
.prose__card{
  background:var(--surface); border:1px solid rgba(139,61,255,.16);
  border-radius:18px; padding:clamp(20px,3vw,30px);
  margin:26px 0; max-width:68ch;
}
.prose__card p{ margin-bottom:6px; }
.prose__card p:last-child{ margin-bottom:0; }

/* ============================================================
   COOKIE CONSENT BANNER (glass, purple accent)
   ============================================================ */
.cookie{
  position:fixed; left:0; right:0; bottom:0; z-index:200;
  display:flex; justify-content:center;
  padding:clamp(12px,2vw,20px);
  padding-bottom:calc(clamp(12px,2vw,20px) + env(safe-area-inset-bottom,0px));
  pointer-events:none;
  opacity:0; transform:translateY(130%);
  transition:opacity .45s var(--ease), transform .5s var(--ease);
}
.cookie.is-shown{ opacity:1; transform:none; }
.cookie__panel{
  pointer-events:auto;
  width:min(740px,100%);
  display:flex; align-items:center; gap:clamp(12px,2.2vw,26px);
  flex-wrap:wrap;
  padding:clamp(15px,2.2vw,20px) clamp(18px,2.6vw,26px);
  border-radius:20px;
  background:var(--white);
  border:1px solid var(--lavender);
  box-shadow:0 20px 60px rgba(40,16,80,.16), 0 2px 6px rgba(40,16,80,.05);
  position:relative; overflow:hidden;
}
.cookie__panel::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:4px;
  background:linear-gradient(180deg, var(--pink), var(--purple));
}
.cookie__text{
  flex:1 1 240px; margin:0;
  font-size:14.5px; line-height:1.55; color:var(--ink2);
}
.cookie__text strong{ color:var(--ink); font-weight:600; }
.cookie__actions{ display:flex; gap:10px; flex:0 0 auto; }
.cookie__btn{
  appearance:none; border:0; cursor:pointer; font:inherit;
  font-size:14px; font-weight:600;
  padding:11px 22px; border-radius:999px; min-height:44px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s;
}
.cookie__btn--accept{
  color:#fff; background:linear-gradient(115deg, var(--pink), var(--purple));
  box-shadow:0 8px 24px rgba(139,61,255,.4);
}
.cookie__btn--accept:hover{ transform:translateY(-2px); box-shadow:0 12px 32px rgba(139,61,255,.5); }
.cookie__btn--decline{
  color:var(--ink2); background:transparent; border:1px solid rgba(17,17,17,.16);
}
.cookie__btn--decline:hover{ color:var(--ink); border-color:rgba(17,17,17,.32); }
.cookie__btn:focus-visible{ outline:3px solid var(--purple); outline-offset:2px; }
.cookie__more{
  flex:0 0 auto; font-size:13px; font-weight:500; color:var(--purple);
  text-decoration:underline; text-underline-offset:3px;
}
.cookie__more:hover{ color:var(--pink); }
@media (max-width:560px){
  .cookie__actions{ width:100%; }
  .cookie__btn{ flex:1; }
  .cookie__more{ width:100%; text-align:center; }
}
@media (prefers-reduced-motion: reduce){
  .cookie{ transition:opacity .3s; transform:none; }
}

/* ============================================================
   FOOTER — legal links
   ============================================================ */
.footer__legal{
  display:flex; flex-direction:column; align-items:center; gap:10px;
  margin-top:18px;
}
.footer__legal a{
  color:rgba(255,255,255,.66); font-size:13px; font-weight:500;
  letter-spacing:.02em; transition:color .25s;
}
.footer__legal a:hover{ color:#fff; }
@media (min-width:560px){
  .footer__legal{ flex-direction:row; gap:14px; }
  .footer__legal a{ position:relative; padding:0 4px; }
  .footer__legal a + a::before{
    content:"·"; position:absolute; left:-9px; color:rgba(255,255,255,.3);
  }
}

/* ============================================================
   FOOTER — "made with magic by TheCreativityLab.nl" credit
   ============================================================ */
.footer__tcl{
  display:inline-flex; align-items:center; gap:7px;
  margin-top:22px; padding:7px 16px;
  border-radius:999px; text-decoration:none;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  font-size:12px; letter-spacing:.015em; white-space:nowrap;
  color:rgba(255,255,255,.55);
  transition:transform .3s var(--ease), border-color .3s, background .3s;
}
.footer__tcl:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.07);
  border-color:rgba(139,61,255,.45);
}
.footer__tcl-star{
  color:#FFD45A; font-size:13px; line-height:1;
  filter:drop-shadow(0 0 6px rgba(255,180,60,.55));
}
.footer__tcl-name{
  font-weight:700;
  background:linear-gradient(90deg, var(--pink), var(--purple) 55%, #5BCEFA);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
@media (prefers-reduced-motion: no-preference){
  .footer__tcl-star{ animation:tclTwinkle 2.8s ease-in-out infinite; }
}
@keyframes tclTwinkle{
  0%,100%{ opacity:.7; transform:scale(1) rotate(0deg); }
  50%    { opacity:1;  transform:scale(1.25) rotate(18deg); }
}
.prose code{
  font-family:ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size:.88em; background:var(--surface);
  border:1px solid rgba(139,61,255,.16); border-radius:6px;
  padding:2px 7px; color:var(--purple);
}
