  :root{
    --orange: #f08020;
    --orange-2: #d9631a;
    --purple: #5a1f78;
    --purple-2: #3b1254;
    --dark: #2d242a;
    --card: #2e272b;
    --cream: #ffffff;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{background:#2a1238;color:var(--cream);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  /* Browser automatic hyphenation uit voor alle body tekst */
  html,body,p,li,span{-webkit-hyphens:manual;hyphens:manual}
  html{scroll-behavior:smooth;scroll-padding-top:80px}
  @media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
  body{overflow-x:hidden}
  button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
  a{color:inherit;text-decoration:none}
  img,svg{display:block;max-width:100%}

  .wrap{max-width:1600px;margin:0 auto;padding:0 40px;position:relative}

  /* ======================================== */
  /* NAV (on hero photo) */
  /* ======================================== */
  .nav{
    position:fixed;top:0;left:0;right:0;z-index:50;
    display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:48px;
    padding:40px 48px 24px;
    transition:background .25s ease, backdrop-filter .25s ease, padding .25s ease, box-shadow .25s ease;
  }
  .nav .nav-left{display:flex;gap:40px;align-items:center;justify-content:flex-end}
  .nav .nav-right{display:flex;gap:40px;align-items:center;justify-content:flex-start}
  .nav.scrolled{
    background:linear-gradient(95deg, rgba(90,26,138,.92) 0%, rgba(125,34,144,.92) 20%, rgba(180,61,122,.92) 48%, rgba(226,90,42,.92) 78%, rgba(240,128,32,.92) 100%);
    backdrop-filter:blur(14px) saturate(1.2);
    -webkit-backdrop-filter:blur(14px) saturate(1.2);
    padding:40px 48px 32px;
    box-shadow:0 1px 0 rgba(255,255,255,.12) inset, 0 10px 32px rgba(0,0,0,.28);
    -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 120'><path d='M 0 0 L 1200 0 L 1200 90 Q 600 130 0 90 Z' fill='black'/></svg>");
    mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1200 120'><path d='M 0 0 L 1200 0 L 1200 90 Q 600 130 0 90 Z' fill='black'/></svg>");
    -webkit-mask-size:100% 100%;mask-size:100% 100%;
    -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  }
  .nav.scrolled .logo-mark{transform:scale(.82);transform-origin:center}

  /* hamburger + mobile drawer */
  .hamburger{
    display:none;background:transparent;border:0;padding:8px;cursor:pointer;
    position:absolute;right:20px;top:50%;transform:translateY(-50%);
    width:40px;height:40px;flex-direction:column;justify-content:center;align-items:center;gap:5px;z-index:55;
  }
  .hamburger span{
    display:block;width:22px;height:2px;background:#fff;border-radius:2px;
    transition:transform .25s ease, opacity .2s ease;
  }
  .nav.menu-open .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.menu-open .hamburger span:nth-child(2){opacity:0}
  .nav.menu-open .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  @media (max-width: 750px){
    .nav.menu-open{background:transparent!important;backdrop-filter:none!important;box-shadow:none!important}
  }

  .mobile-drawer{
    position:fixed;inset:0;z-index:49;opacity:0;pointer-events:none;
    background:rgba(10,5,20,.6);backdrop-filter:blur(6px);
    transition:opacity .3s ease;
    overflow:hidden;
  }
  .mobile-drawer.open{opacity:1;pointer-events:auto}
  .mobile-drawer-inner{
    position:absolute;top:0;right:0;bottom:0;width:100%;
    background:linear-gradient(170deg, #5a1a8a 0%, #7d2290 35%, #b43d7a 68%, #e25a2a 100%);
    padding:108px 28px 28px;display:flex;flex-direction:column;gap:2px;align-items:center;justify-content:flex-start;
    transform:translateX(100%);transition:transform .36s cubic-bezier(.2,.8,.2,1);
    box-shadow:none;
  }
  .mobile-drawer.open .mobile-drawer-inner{transform:translateX(0)}
  .mobile-drawer a{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;
    font-size:30px;letter-spacing:.01em;text-transform:uppercase;color:#fff;
    padding:10px 0;border-bottom:1px solid rgba(255,255,255,.14);
    text-decoration:none;transition:transform .2s ease, color .2s ease;
    width:100%;max-width:440px;text-align:center;
  }
  .mobile-drawer a:hover{transform:scale(1.04);color:#ffd8a0}
  .mobile-drawer-socials{
    display:flex;gap:22px;margin-top:22px;align-items:center;justify-content:center;
    border:0;padding-top:0;
  }
  .mobile-drawer-socials a{
    border:none;padding:0;width:36px;height:36px;display:grid;place-items:center;
    background:transparent;border-radius:0;
    transition:transform .2s ease, color .2s ease;
  }
  .mobile-drawer-socials a:hover{background:transparent;transform:scale(1.12)}
  .mobile-drawer-socials a svg{width:22px;height:22px;fill:#fff}
  .nav-left,.nav-right{display:flex;gap:40px;align-items:center}
  .nav a.link{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;
    font-size:22px;letter-spacing:.02em;text-transform:uppercase;color:#fff;
    transition:color .2s;
  }
  .nav a.link:hover{color:var(--orange)}
  .nav .logo{
    display:block;
    width:180px;height:auto;flex-shrink:0;
  }
  .nav .logo img{display:block;width:100%;height:auto}

  /* ======================================== */
  /* HERO - photo with curved bottom */
  /* ======================================== */
  .hero{
    position:relative;
    height:84vh; min-height:560px; max-height:780px;
    overflow:hidden;
    background:#2a1238;
  }
  .hero-slides{position:absolute;inset:0;z-index:0}
  .hero-slide{
    position:absolute;inset:0;
    background-position:center center;
    background-size:cover;
    background-repeat:no-repeat;
    opacity:0;
    transition:opacity 1.6s ease;
    will-change:opacity;
  }
  .hero-slide.active{opacity:1}
  .hero-slide::after{
    content:"";position:absolute;inset:0;
    background:
      linear-gradient(95deg, rgba(90,26,138,.35) 0%, rgba(125,34,144,.3) 22%, rgba(180,61,122,.25) 50%, rgba(226,90,42,.3) 80%, rgba(240,128,32,.35) 100%),
      linear-gradient(180deg, rgba(10,5,20,.15) 0%, rgba(10,5,20,0) 30%, rgba(10,5,20,.1) 70%, rgba(60,20,80,.35) 100%);
  }
  /* Hero slide backgrounds are injected inline by the React app from Customizer settings. */
  /* slide dots */
  .hero-dots{
    position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:5;
    display:flex;gap:10px;
  }
  .hero-dot{
    width:28px;height:3px;border-radius:2px;background:rgba(255,255,255,.35);
    cursor:pointer;transition:background .25s, width .25s;
  }
  .hero-dot.active{background:#fff;width:44px}
  .hero-dot:hover{background:rgba(255,255,255,.7)}
  /* social strip on right side */
  .hero-socials{
    position:fixed;right:32px;top:50%;transform:translateY(-50%);z-index:40;
    display:flex;flex-direction:column;gap:14px;
  }
  @media (max-width:750px){
    .hero-socials{display:none}
  }
  .hero-socials a{
    width:28px;height:28px;display:grid;place-items:center;color:#fff;
    opacity:.92;transition:transform .15s, color .15s;
  }
  .hero-socials a:hover{color:var(--orange);transform:translateX(-2px)}
  .hero-socials svg{width:20px;height:20px}

  /* curved section mask - hero bottom dips down toward center (upper boog: links hoog, rechts lager) */
  .hero-curve{
    position:absolute;left:0;right:0;bottom:-2px;width:100%;height:180px;
    z-index:4;display:block;pointer-events:none;
  }

  /* Mobile-only hero overlay: groot logo + datum/locatie + ronde CTA */
  .hero-mobile-content{display:none}
  @keyframes hero-fade-up{
    from{opacity:0;transform:translateY(24px)}
    to{opacity:1;transform:translateY(0)}
  }
  @keyframes hero-logo-in{
    from{opacity:0;transform:translateY(28px) scale(.94)}
    to{opacity:1;transform:translateY(0) scale(1)}
  }
  @keyframes hero-cta-pulse{
    0%,100%{box-shadow:0 6px 18px rgba(0,0,0,.3),0 0 0 0 rgba(240,128,32,.55)}
    50%{box-shadow:0 6px 18px rgba(0,0,0,.3),0 0 0 14px rgba(240,128,32,0)}
  }
  @media (max-width:750px){
    .hero-mobile-content{
      position:absolute;inset:0;z-index:3;
      display:flex;flex-direction:column;align-items:center;justify-content:center;
      gap:18px;padding:60px 24px 120px;text-align:center;pointer-events:none;
    }
    .hero-mobile-content > *{pointer-events:auto}
    .hero-mobile-logo{
      width:min(78vw,360px);height:auto;display:block;
      filter:drop-shadow(0 6px 20px rgba(0,0,0,.45));
      opacity:0;transform:translateY(28px) scale(.94);
      animation:hero-logo-in .9s cubic-bezier(.2,.7,.2,1) .15s forwards;
    }
    .hero-mobile-meta{
      display:flex;flex-direction:column;gap:4px;
      color:#fff;font-family:'Conduit ITC','Archivo Black',sans-serif;
      font-weight:900;text-transform:uppercase;letter-spacing:.04em;
      font-size:clamp(15px,4.2vw,20px);line-height:1.15;
      text-shadow:0 2px 12px rgba(0,0,0,.55);
      opacity:0;transform:translateY(24px);
      animation:hero-fade-up .7s cubic-bezier(.2,.7,.2,1) .55s forwards;
    }
    .hero-mobile-cta{
      display:inline-flex;align-items:center;gap:10px;
      background:var(--orange,#f08020);color:#0a0212;text-decoration:none;
      font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;
      text-transform:uppercase;letter-spacing:.04em;
      font-size:18px;padding:14px 28px;border-radius:999px;
      box-shadow:0 6px 18px rgba(0,0,0,.3);
      opacity:0;transform:translateY(24px);
      animation:
        hero-fade-up .7s cubic-bezier(.2,.7,.2,1) .85s forwards,
        hero-cta-pulse 2.4s ease-out 1.8s infinite;
      transition:transform .15s ease, background .15s ease;
    }
    .hero-mobile-cta:hover,.hero-mobile-cta:focus{background:#ff9433;transform:translateY(-1px)}
    .hero-mobile-cta .arrow{display:inline-flex}
    .hero-mobile-cta svg{width:18px;height:18px;fill:#0a0212}
    /* Respect reduced motion */
    @media (prefers-reduced-motion:reduce){
      .hero-mobile-logo,.hero-mobile-meta,.hero-mobile-cta{
        opacity:1;transform:none;animation:none;
      }
    }
    /* Verberg het kleine nav-logo zodat we niet 2 logo's zien op mobiel */
    .nav .logo{visibility:hidden}
    .nav.scrolled .logo{visibility:visible}
  }

  /* ======================================== */
  /* PURPLE BAND with from-a-z list + play btn */
  /* ======================================== */
  /* horizontal purple -> orange sweep, used across A-Z, lineup, tickets */
  .az-band{
    position:relative;
    background:linear-gradient(95deg, #5a1a8a 0%, #7d2290 22%, #b43d7a 50%, #e25a2a 80%, #f08020 100%);
    padding:70px 0 40px;
  }
  .az-inner{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:40px}
  .az-play{
    display:flex;align-items:center;justify-content:center;
    width:68px;height:68px;border-radius:0;
  }
  .az-play svg{width:40px;height:40px;fill:#fff;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}
  .az-play:hover svg{fill:var(--orange)}
  .az-hex{
    position:absolute;left:50%;top:-250px;transform:translateX(-50%);
    width:110px;height:121px;z-index:50;
  }
  .az-hex svg{width:100%;height:100%}
  .az-center{text-align:center;padding-top:0;margin-top:-70px}
  @media (max-width:750px){ .az-center{margin-top:-30px} }
  .az-datum{
    text-align:center;margin-bottom:20px;
    font-family:'Archivo',sans-serif;font-weight:700;font-size:12px;
    letter-spacing:.22em;text-transform:uppercase;color:#fff;opacity:.95;
  }
  .az-datum .part{display:inline-block;white-space:nowrap}
  .az-datum .part::before{
    content:"";display:inline-block;width:4px;height:4px;background:#fff;
    border-radius:50%;margin:0 14px;vertical-align:middle;opacity:.6;
  }
  /* Row-start: dot onzichtbaar maar behoudt ghost-ruimte voor stabiele layout.
     translateX schuift het item visueel naar links (optische centrering)
     zonder de layout-flow te verstoren — anders zouden volgende items de
     vrijgemaakte ruimte opvullen en tegen elkaar plakken. */
  .az-datum .part.row-start::before{visibility:hidden}
  .az-datum .part:first-child::before{display:none}
  /* Compenseer HELFT van de ghost-ruimte (32px): text-align:center centreert
     de flow-content INCL ghost, dus visueel staat de regel 16px te ver naar
     rechts. translateX(-16px) op alle items van de rij brengt de regel exact
     in het midden. -32px zou 16px doorschieten naar links. */
  .az-datum .part.on-shifted-row{transform:translateX(-16px)}
  .lineup-intro{
    max-width:1040px;margin:0 auto 36px;text-align:center;
    font-family:'Inter',sans-serif;font-weight:400;font-size:15px;line-height:1.65;
    color:#fff;
  }
  .lineup-intro p{margin:0 0 14px}
  .lineup-intro p:last-child{margin-bottom:0}
  .az-label{
    font-family:'Archivo',sans-serif;font-weight:800;font-size:11px;
    letter-spacing:.35em;text-transform:uppercase;margin-bottom:16px;opacity:.95;
  }
  .az-list{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;font-size:clamp(22px,2.2vw,34px);
    letter-spacing:.01em;line-height:1.25;text-transform:uppercase;
  }
  .az-list .artist{display:inline-block;white-space:nowrap}
  .az-list .artist::before{
    content:"";display:inline-block;width:8px;height:8px;background:#fff;border-radius:50%;
    margin:0 14px;vertical-align:middle;opacity:.7;
  }
  /* Row-start: dot onzichtbaar maar behoudt ghost-ruimte voor stabiele layout.
     translateX schuift het item visueel naar links voor optische centrering
     zonder de layout-flow te verstoren — anders zouden volgende items door
     de vrijgemaakte ruimte mee naar voren schuiven en tegen elkaar plakken
     (bug: "ALEX RANZINOAMI" probleem). Transform beïnvloedt alleen painting,
     niet de box-model positie, dus naburige items blijven waar ze horen. */
  .az-list .artist.row-start::before{visibility:hidden}
  .az-list .artist:first-child::before{display:none}
  /* Compenseer HELFT van de ghost-ruimte (36px): text-align:center centreert
     de flow-content INCL ghost, dus visueel staat de regel 18px te ver naar
     rechts. translateX(-18px) op alle items van de rij brengt de regel exact
     in het midden. -36px zou 18px doorschieten naar links. */
  .az-list .artist.on-shifted-row{transform:translateX(-18px)}

  /* ======================================== */
  /* LINE-UP */
  /* ======================================== */
  .lineup{
    background:linear-gradient(90deg, #5a1a8a 0%, #7d2290 22%, #b43d7a 50%, #e25a2a 80%, #f08020 100%);
    padding:40px 0 0;position:relative;z-index:20;
  }
  .lineup-bottom-curve{display:block;width:100%;height:180px;margin-top:60px;position:relative;z-index:2}
  .tickets-top-curve{display:block;width:100%;height:140px;position:relative;z-index:2;margin-top:-1px}
  .dj-top-curve{display:block;width:100vw;margin-left:calc(50% - 50vw);height:120px;position:relative;z-index:3;margin-top:20px}
  .lineup .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
  .lineup h2{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;font-size:clamp(64px,8.5vw,112px);
    line-height:.85;letter-spacing:-.01em;text-transform:uppercase;color:#fff;
  }
  .lineup-btn{
    display:inline-flex;align-items:center;gap:14px;
    padding:14px 26px;border:2px solid #fff;border-radius:999px;
    font-family:'Archivo',sans-serif;font-weight:800;font-size:13px;
    letter-spacing:.14em;text-transform:uppercase;color:#fff;
    transition:all .2s;
  }
  .lineup-btn:hover{background:#fff;color:var(--orange)}
  .lineup-btn .arrow{
    width:24px;height:24px;border-radius:50%;background:#fff;color:var(--orange);
    display:grid;place-items:center;
  }
  .lineup-btn .arrow svg{width:10px;height:10px}
  .lineup-btn:hover .arrow{background:var(--orange);color:#fff}

  /* staggered 4x2 grid - equal squares, every other card shifted up */
  .lineup-grid{
    display:grid;
    grid-template-columns:repeat(4, 1fr);
    gap:20px;
    position:relative;
    padding-top:30px;
  }
  .card{
    background:var(--card);border-radius:14px;
    cursor:pointer;transition:transform .3s;
    position:relative;overflow:hidden;
    aspect-ratio:1/1;
  }
  .card:hover{transform:translateY(-3px)}
  .card-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0}
  .card.has-img::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.2) 28%,rgba(0,0,0,.05) 55%,rgba(0,0,0,.75) 100%);pointer-events:none}
  .card .card-top{position:absolute;top:14px;left:16px;right:16px;z-index:2;display:flex;flex-direction:column;gap:2px;color:#fff}
  .card .tag{font-family:'Inter',sans-serif;font-weight:600;font-size:9px;letter-spacing:.22em;text-transform:uppercase;opacity:.55}
  .card.has-img .tag{opacity:.95;text-shadow:0 1px 4px rgba(0,0,0,.5)}
  .card .time{font-family:'Inter',sans-serif;font-weight:600;font-size:11px;letter-spacing:.08em;color:rgba(255,255,255,.9);text-shadow:0 1px 4px rgba(0,0,0,.45)}
  .card.has-img .time{color:#fff}
  .card .nm{position:absolute;left:16px;right:16px;bottom:14px;z-index:2;font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;font-size:clamp(13px,1.15vw,18px);letter-spacing:.01em;text-transform:uppercase;line-height:1.05}
  .card.has-img .nm{text-shadow:0 1px 6px rgba(0,0,0,.55)}
  /* hover: preserve offset */
  .c1:hover,.c3:hover,.c5:hover,.c7:hover{transform:translateY(-33px)}
  .c2:hover,.c4:hover,.c6:hover,.c8:hover{transform:translateY(-3px)}

  .lineup-chevron{
    position:absolute;top:50%;transform:translateY(-50%);z-index:5;
    width:52px;height:52px;border-radius:50%;border:2px solid rgba(255,255,255,.85);
    display:grid;place-items:center;color:#fff;opacity:1;
    background:rgba(0,0,0,.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
    transition:background .2s ease, transform .2s ease;cursor:pointer;
    box-shadow:0 4px 14px rgba(0,0,0,.25);
  }
  .lineup-chevron:hover{background:rgba(0,0,0,.65);transform:translateY(-50%) scale(1.05)}
  .lineup-chevron.left{left:12px}
  .lineup-chevron.right{right:12px}
  .lineup-chevron svg{width:16px;height:16px;stroke-width:2}

  /* static stagger - odd cards up, even cards baseline */
  .c1,.c3,.c5,.c7{transform:translateY(-30px)}
  .c2,.c4,.c6,.c8{transform:translateY(0)}
  .lineup-grid .card{animation:cardfade .55s cubic-bezier(.2,.7,.2,1) both}
  @keyframes cardfade{from{opacity:0}to{opacity:1}}
  .lineup-dots{display:flex;justify-content:center;gap:10px;margin-top:40px}
  .lineup-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.25);border:0;padding:0;cursor:pointer;transition:all .2s}
  .lineup-dot.active{background:#fff;width:28px;border-radius:4px}

  /* ======================================== */
  /* SCROLL REVEALS (framer-like) */
  /* ======================================== */
  .reveal{opacity:0;will-change:transform,opacity;transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);transition-delay:var(--rd, 0ms)}
  .reveal.up{transform:translateY(40px)}
  .reveal.down{transform:translateY(-30px)}
  .reveal.left{transform:translateX(-50px)}
  .reveal.right{transform:translateX(50px)}
  .reveal.scale{transform:scale(.9)}
  .reveal.blur{filter:blur(10px)}
  .reveal.in{opacity:1;transform:translate(0,0) scale(1);filter:blur(0)}
  /* subtle word-by-word heading reveal */
  .reveal-words .word{display:inline-block;opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);transition-delay:calc(var(--wi, 0) * 60ms)}
  .reveal-words.in .word{opacity:1;transform:translateY(0)}
  @media (prefers-reduced-motion: reduce){
    .reveal,.reveal-words .word{transition:none;opacity:1;transform:none;filter:none}
  }

  /* ======================================== */
  /* TICKETS */
  /* ======================================== */
  .tickets{
    background:#f08020;
    padding:30px 0 0;position:relative;margin-top:-1px;
  }
  .tickets-inner{display:grid;grid-template-columns:1.35fr 1fr;gap:60px;align-items:start;padding-bottom:0;position:relative;z-index:3}
  .tickets-inner .left{padding-top:40px;margin-bottom:-160px}
  .ticket-card{
    background:var(--orange-2);border:0;border-radius:10px;
    width:100%;min-height:950px;
    /* ghost outline card: same orange tone as bg, slightly darker */
  }
  .tickets h2{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;font-size:clamp(72px,9.5vw,128px);
    line-height:.85;letter-spacing:-.01em;text-transform:uppercase;color:#fff;
    text-align:right;margin-bottom:20px;
  }
  .tickets .copy{
    font-family:'Inter',sans-serif;font-weight:400;font-size:15px;line-height:1.65;color:#fff;
    text-align:right;max-width:440px;margin-left:auto;
  }
  .tickets .copy p{margin-bottom:14px}
  .tickets-hex{
    position:absolute;right:32px;bottom:80px;width:48px;height:53px;z-index:10;
  }

  /* DJ photo with hump-shaped top - rises in center, drops on sides */
  .dj-wrap{position:relative;margin:0 calc(50% - 50vw) 0;width:100vw;overflow:visible;background:transparent;z-index:1}
  .dj-photo{
    height:600px;width:100%;position:relative;overflow:hidden;
    background:#1a0820;
    /* Upper boog zonder clipping: grotere viewBox zodat hele curve binnen blijft (geen horizontale lijnen aan randen) */
    -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 100 130'><path d='M 0 10 Q 50 -20 100 55 L 100 130 L 0 130 Z' fill='black'/></svg>");
    mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 100 130'><path d='M 0 10 Q 50 -20 100 55 L 100 130 L 0 130 Z' fill='black'/></svg>");
    -webkit-mask-size: 100% 100%;mask-size:100% 100%;
    -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  }
  .dj-photo .photo-slide{background-position:center 45%}
  /* curved divider sitting at the bottom of the DJ image - absolute-positioned over the image */
  .dj-bottom-curve{
    position:absolute;left:0;bottom:-1px;
    display:block;width:100%;
    height:180px;z-index:2;pointer-events:none;
  }
  .dj-photo::after{
    content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:
      linear-gradient(95deg, rgba(90,26,138,.35) 0%, rgba(125,34,144,.3) 22%, rgba(180,61,122,.25) 50%, rgba(226,90,42,.3) 80%, rgba(240,128,32,.35) 100%),
      linear-gradient(180deg, rgba(10,5,20,.15) 0%, rgba(10,5,20,0) 30%, rgba(10,5,20,.1) 70%, rgba(60,20,80,.35) 100%);
  }

  /* ======================================== */
  /* IMPRESSIE */
  /* ======================================== */
  .impressie{
    background:#f08020;
    padding:0;position:relative;margin-top:-80px;
  }
  .impressie > .wrap{position:relative;z-index:15}
  .impressie-row{
    display:grid;grid-template-columns:1fr 1fr;gap:24px;
    margin-top:-300px;position:relative;z-index:10;align-items:start;
  }
  .impressie-row .ph{
    background:var(--card);border-radius:14px;aspect-ratio:16/10;position:relative;overflow:hidden;
  }
  .photo-slider{position:absolute;inset:0}
  .photo-slide{
    position:absolute;inset:0;
    background-size:cover;background-position:center center;background-repeat:no-repeat;
    opacity:0;transition:opacity 2.4s ease;
  }
  .photo-slide.active{opacity:1}
  .impressie-row > *:nth-child(1){transform:translateY(0)}
  .impressie-row > *:nth-child(2){transform:translateY(40px)}
  .impressie h2{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;font-size:clamp(64px,8.5vw,120px);
    line-height:.85;letter-spacing:-.01em;text-transform:uppercase;color:#fff;
    margin:0 0 0;padding-top:100px;padding-bottom:60px;
  }
  .impressie-video-row{
    display:grid;grid-template-columns:1fr 0.9fr;gap:40px;align-items:center;
    margin-top:60px;
  }
  .impressie-video-full{margin-top:30px;margin-bottom:-140px;aspect-ratio:16/7.2;position:relative;z-index:30}
  .video-caption{color:#fff}
  .video-caption .vc-eyebrow{
    font-family:'Archivo',sans-serif;font-weight:800;font-size:11px;letter-spacing:.28em;
    text-transform:uppercase;opacity:.8;margin-bottom:10px;
  }
  .video-caption .vc-title{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;
    font-size:clamp(36px,4.2vw,56px);line-height:.9;letter-spacing:-.01em;
    text-transform:uppercase;margin-bottom:14px;
  }
  .video-caption .vc-meta{
    font-family:'Inter',sans-serif;font-size:14px;opacity:.75;
  }
  .video-big{
    background:var(--card);border-radius:14px;aspect-ratio:16/7.2;
    position:relative;display:grid;place-items:center;cursor:pointer;overflow:hidden;
  }
  .video-big-sm{aspect-ratio:16/10;border-radius:14px}
  /* caption onder de video uitgezet op verzoek */
  .play-circle{
    width:78px;height:78px;border-radius:50%;border:2px solid var(--orange);
    display:grid;place-items:center;color:var(--orange);transition:all .2s;
  }
  .play-circle svg{width:26px;height:26px;margin-left:3px}
  .video-big:hover .play-circle{background:var(--orange);color:#fff}

  /* Mute/unmute toggle on the auto-playing vibe video */
  .video-mute-toggle{
    position:absolute;right:16px;bottom:16px;z-index:10;
    display:inline-flex;align-items:center;gap:8px;
    padding:8px 14px 8px 12px;border:1.5px solid rgba(255,255,255,.85);
    border-radius:999px;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);
    -webkit-backdrop-filter:blur(6px);color:#fff;cursor:pointer;
    font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;
    text-transform:uppercase;
    transition:background .2s ease, transform .2s ease;
  }
  .video-mute-toggle:hover{background:rgba(0,0,0,.7);transform:translateY(-1px)}
  .video-mute-toggle svg{flex:0 0 auto}
  .video-mute-toggle .label{white-space:nowrap}

  /* Anchor element net boven de VIBES titel zodat #impressie direct bij de video land */
  .impressie-anchor{position:relative;top:-40px;height:0;width:0}
  /* Anchor vlak boven de line-up cards zodat scroll niet op de heading maar direct op de cards land */
  .lineup-anchor{position:relative;top:-10px;height:0;width:0}

  /* ======================================== */
  /* FAQ */
  /* ======================================== */
  .faq{
    background:linear-gradient(90deg, #f08020 0%, #e25a2a 22%, #b43d7a 52%, #7d2290 80%, #5a1a8a 100%);
    padding:0 0 0;position:relative;
  }
  .impressie-bottom-curve{display:block;width:100%;height:220px;position:relative;z-index:5;margin-top:0;margin-bottom:-1px}
  .faq-bottom-curve{display:block;width:100%;height:140px;position:relative;z-index:2;margin-top:60px;margin-bottom:-1px}
  .faq h2{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;font-size:clamp(64px,8.5vw,120px);
    line-height:.85;letter-spacing:-.01em;text-transform:uppercase;color:#fff;
    text-align:right;margin-bottom:32px;
  }
  .faq-list{}
  .faq-item{border-top:1px solid rgba(255,255,255,.4)}
  .faq-item:last-child{border-bottom:1px solid rgba(255,255,255,.4)}
  .faq-q{
    width:100%;display:flex;justify-content:space-between;align-items:center;
    padding:26px 0;text-align:left;
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;font-size:clamp(20px,1.7vw,26px);letter-spacing:.02em;text-transform:uppercase;
    color:#fff;transition:opacity .15s;
  }
  .faq-q:hover{opacity:.75}
  .faq-q .plus{
    width:32px;height:32px;border-radius:50%;border:1.5px solid #fff;
    display:grid;place-items:center;color:#fff;flex-shrink:0;transition:all .25s;
  }
  .faq-q .plus svg{width:14px;height:14px;transition:transform .25s}
  .faq-item.open .plus{background:#fff;color:var(--orange)}
  .faq-item.open .plus .minus{display:block}
  .faq-item.open .plus .plus-icon{display:none}
  .faq-item .plus .minus{display:none}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
  .faq-a-inner{
    padding:0 0 26px 0;max-width:860px;
    font-family:'Inter',sans-serif;font-weight:400;font-size:15px;line-height:1.65;color:#fff;
  }

  /* ======================================== */
  /* CONTACT */
  /* ======================================== */
  /* ======================================== */
  /* NEWSLETTER */
  /* ======================================== */
  .newsletter{
    background:linear-gradient(95deg, #5a1a8a 0%, #7d2290 30%, #b43d7a 65%, #e25a2a 100%);
    padding:60px 0;position:relative;
  }
  .newsletter-box{
    display:grid;grid-template-columns:1fr 1.3fr;gap:56px;align-items:center;
    padding:56px 48px;border-radius:20px;
    background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
    backdrop-filter:blur(8px);
  }
  .newsletter-text .sub{
    font-family:'Archivo',sans-serif;font-weight:800;font-size:11px;letter-spacing:.28em;
    text-transform:uppercase;color:#fff;margin-bottom:14px;opacity:.85;
  }
  .newsletter-text h2{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;
    font-size:clamp(44px,5.5vw,76px);line-height:.9;letter-spacing:-.01em;
    text-transform:uppercase;color:#fff;margin-bottom:16px;
  }
  .newsletter-text p{
    font-family:'Inter',sans-serif;font-weight:400;font-size:15px;line-height:1.65;
    color:#fff;
  }
  .newsletter-form{position:relative}
  .nl-row{display:grid;grid-template-columns:1fr 1.2fr auto;gap:18px;align-items:end}
  .nl-field{border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:6px}
  .nl-field label{
    display:block;
    font-family:'Archivo',sans-serif;font-weight:800;font-size:10px;letter-spacing:.24em;
    text-transform:uppercase;color:#fff;margin-bottom:2px;opacity:.85;
  }
  .nl-field input{
    width:100%;background:transparent;border:0;padding:6px 0;outline:none;
    font-family:'Inter',sans-serif;font-size:14px;color:#fff;
  }
  .newsletter-form .verstuur{margin-top:0;flex-shrink:0;white-space:nowrap}
  .nl-msg{margin-top:16px;font-family:'Inter',sans-serif;font-size:13px;opacity:.95}
  @media (max-width:750px){
    .newsletter-box{grid-template-columns:1fr;gap:28px;padding:36px 24px}
    .nl-row{grid-template-columns:1fr;gap:22px}
    .newsletter-form .verstuur{align-self:start}
  }

  /* ======================================== */
  /* CONTACT */
  /* ======================================== */
  .contact{
    /* Moet exact matchen met faq-bottom-curve gradient (90° horizontal, dezelfde stops) */
    background:linear-gradient(90deg, #5a1a8a 0%, #7d2290 20%, #b43d7a 48%, #e25a2a 78%, #f08020 100%);
    padding:0 0 40px;
    margin-top:-1px;
  }
  .contact-grid{display:grid;grid-template-columns:0.6fr 1.2fr;gap:56px;align-items:start}
  .contact-photo{
    background:var(--card);border-radius:14px;aspect-ratio:2/3;min-height:440px;
    position:relative;overflow:hidden;
  }
  .contact-photo::after{
    content:none;
  }
  .contact-form h3{
    font-family:'Conduit ITC','Archivo Black',sans-serif;font-weight:900;font-size:clamp(56px,8vw,104px);
    line-height:.85;letter-spacing:-.01em;text-transform:uppercase;color:#fff;
    margin-bottom:14px;
  }
  .contact-form .sub{
    font-family:'Archivo',sans-serif;font-weight:800;font-size:11px;letter-spacing:.28em;
    text-transform:uppercase;color:#fff;margin-bottom:26px;
  }
  .field{margin-bottom:14px;border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:6px}
  .field label{
    display:block;
    font-family:'Archivo',sans-serif;font-weight:800;font-size:10px;letter-spacing:.24em;
    text-transform:uppercase;color:#fff;margin-bottom:2px;
  }
  .field input,.field textarea{
    width:100%;background:transparent;border:0;padding:6px 0;
    font-family:'Inter',sans-serif;font-size:14px;color:#fff;
  }
  .field input:focus,.field textarea:focus{outline:none}
  .field textarea{resize:vertical;min-height:50px}
  .verstuur{
    display:inline-flex;align-items:center;gap:10px;margin-top:14px;
    padding:10px 22px;border:1.5px solid #fff;border-radius:999px;
    font-family:'Archivo',sans-serif;font-weight:800;font-size:11px;letter-spacing:.22em;
    text-transform:uppercase;color:#fff;transition:all .2s;
  }
  .verstuur:hover{background:#fff;color:var(--orange)}
  .verstuur .arrow{width:22px;height:22px;border-radius:50%;background:#fff;color:var(--orange);display:grid;place-items:center}
  .verstuur:hover .arrow{background:var(--orange);color:#fff}
  .verstuur .arrow svg{width:9px;height:9px}
  .contact-note{
    margin-top:22px;padding:16px 0;
    font-family:'Inter',sans-serif;font-weight:400;font-size:15px;line-height:1.65;
    color:#fff;
    border-top:1px solid rgba(255,255,255,.3);
  }
  .contact-bottom{
    display:flex;justify-content:space-between;align-items:center;
    margin-top:10px;padding-top:22px;border-top:1px solid rgba(255,255,255,.5);
  }
  .contact-bottom .vo{
    font-family:'Archivo',sans-serif;font-weight:800;font-size:11px;letter-spacing:.28em;
    text-transform:uppercase;color:#fff;
  }
  .contact-bottom .socials{display:flex;gap:14px}
  .contact-bottom .socials a{
    width:30px;height:30px;display:grid;place-items:center;color:#fff;
    transition:color .18s ease, transform .18s ease;
  }
  .contact-bottom .socials a:hover{color:var(--orange);transform:translateY(-2px)}
  .contact-bottom .socials svg{width:22px;height:22px}

  /* Gestapelde variant: label boven, grotere iconen eronder */
  .contact-bottom-stacked{
    flex-direction:column;align-items:flex-start;gap:14px;
  }
  .contact-bottom-stacked .socials{gap:18px}
  .contact-bottom-stacked .socials a{width:44px;height:44px}
  .contact-bottom-stacked .socials svg{width:32px;height:32px}

  /* ======================================== */
  /* ======================================== */
  /* scroll-to-top button */
  /* ======================================== */
  .scroll-top{
    position:fixed;bottom:24px;right:24px;z-index:90;
    width:48px;height:48px;border-radius:50%;
    background:var(--orange);color:#fff;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 8px 24px rgba(0,0,0,.35), 0 2px 6px rgba(240,128,32,.4);
    opacity:0;pointer-events:none;transform:translateY(12px) scale(.9);
    transition:opacity .3s ease, transform .3s cubic-bezier(.4,1.4,.6,1), background .2s;
  }
  .scroll-top.visible{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
  .scroll-top:hover{background:var(--orange-2);transform:translateY(-2px) scale(1.05)}
  .scroll-top:active{transform:translateY(0) scale(.96)}

  /* ======================================== */
  /* site footer */
  /* ======================================== */
  .site-footer{background:#1a0820;border-top:1px solid rgba(255,255,255,.06);padding:40px 0 30px;color:rgba(255,255,255,.55);position:relative;z-index:2}
  .foot-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
  .foot-logo img{width:90px;height:auto;opacity:.8;display:block}
  .foot-links{display:flex;gap:28px;flex-wrap:wrap;font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase}
  .foot-links a{color:rgba(255,255,255,.7);transition:color .2s}
  .foot-links a:hover{color:var(--orange)}
  /* WCAG AA contrast: tekst min 4.5:1 op #1a0820 → witte tekst >=70% opacity, links onderstreept */
  .foot-copy{font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.78)}
  .foot-copy a{color:#fff;text-decoration:underline;text-underline-offset:3px;transition:color .2s}
  .foot-copy a:hover,.foot-copy a:focus{color:var(--orange)}
  @media (max-width:720px){
    .foot-inner{justify-content:center;text-align:center;gap:20px}
  }

  /* ======================================== */
  /* tweak panel */
  /* ======================================== */
  .tweak-panel{position:fixed;bottom:20px;right:20px;z-index:100;background:#1a0a20;border:1px solid rgba(240,128,32,.4);border-radius:12px;padding:18px;width:250px;font-family:'Inter',sans-serif;font-size:11px;color:#fff;box-shadow:0 20px 60px rgba(0,0,0,.6);display:none}
  .tweak-panel.on{display:block}
  .tweak-panel h4{font-family:'Archivo Black',sans-serif;font-size:12px;letter-spacing:.15em;text-transform:uppercase;margin-bottom:14px;color:var(--orange)}
  .tweak-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
  .tweak-row label{font-weight:600;letter-spacing:.2em;text-transform:uppercase;opacity:.7;font-size:10px}
  .segmented{display:flex;gap:3px;background:#120418;padding:3px;border-radius:999px}
  .segmented button{flex:1;padding:6px 4px;border-radius:999px;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.65);transition:all .15s}
  .segmented button.active{background:var(--orange);color:#1a0a20}

  @media (max-width: 750px){
    /* Logo exact in het midden - 1fr aan beide kanten */
    .nav{grid-template-columns:1fr auto 1fr;padding:8px 14px;gap:0}
    .nav.scrolled{padding:6px 14px}
    .nav .logo{width:108px;grid-column:2;justify-self:center}
    .nav.scrolled .logo{width:92px}
    .hamburger{right:10px;padding:6px;width:32px;height:32px;gap:4px}
    .hamburger span{width:18px}
    /* Double-selector for higher specificity than `.nav .nav-left{display:flex}` above */
    .nav .nav-left,
    .nav .nav-right{display:none !important}
    .hamburger{display:flex}
    .hero-curve{height:90px}
    .impressie-bottom-curve{height:120px}
    .lineup-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto;padding-top:20px;padding-bottom:70px}
    .c1,.c3,.c5,.c7{transform:translateY(-20px)}
    .c2,.c4,.c6,.c8{transform:translateY(0)}
    .tickets-inner{grid-template-columns:1fr;gap:30px}
    .tickets-inner .left{display:block;padding-top:0;margin-bottom:0;order:2}
    .tickets-inner > div:nth-child(2){order:1}
    .ticket-card{min-height:420px}
    .tickets h2, .tickets .copy{text-align:center;margin-left:auto;margin-right:auto}
    .tickets-hex{display:none}
    .impressie-row{grid-template-columns:1fr;margin-top:-200px;gap:16px}
    .impressie-row > *:nth-child(2){transform:none}
    .impressie-row .ph:nth-child(2){margin-top:0}
    .impressie-video-row{grid-template-columns:1fr;gap:20px}
    /* mobile: minder ruimte boven + onder VIBES titel en de video strakker tegen de titel */
    .impressie h2{padding-top:30px;padding-bottom:18px}
    .impressie-video-full{margin-top:0;margin-bottom:20px}
    .lineup-dots{display:none}
    /* on mobile, reposition prev/next so they don't overflow the viewport */
    .lineup-chevron{top:auto;bottom:10px;transform:none;width:46px;height:46px}
    .lineup-chevron:hover{transform:scale(1.05)}
    .lineup-chevron.left{left:calc(50% - 56px);right:auto}
    .lineup-chevron.right{right:calc(50% - 56px);left:auto}
    .contact-grid{grid-template-columns:minmax(0,1fr)}
    .contact-grid > *{min-width:0}
    .contact-photo{min-height:240px;aspect-ratio:3/2;width:100%;max-width:100%}
    .az-inner{grid-template-columns:1fr;text-align:center;gap:20px}
    .az-hex{top:-150px;width:72px;height:79px}

    /* smaller section headings on mobile */
    .lineup h2{font-size:clamp(42px,12vw,64px)}
    .tickets h2{font-size:clamp(48px,13vw,72px);text-align:center}
    .impressie h2{font-size:clamp(42px,12vw,64px)}
    .faq h2{font-size:clamp(42px,12vw,64px);text-align:center}
    .contact-form h3{font-size:clamp(40px,11vw,60px)}
    .az-list{font-size:clamp(16px,4.2vw,22px)}
    .wrap{padding:0 20px}
  }
