/* ──────────────────────────────────────────────────────────────────
   Wiebeltenen — redesign stylesheet
   System: dark theme + bold brand colors. Roboto Condensed display, DM Sans body.
   ────────────────────────────────────────────────────────────────── */

:root{
  /* Dark theme — matching original site */
  --paper:        #12111a;
  --paper-2:      #1c1a28;
  --paper-3:      #211f30;
  --ink:          #ffffff;
  --ink-2:        #e0e0e0;
  --ink-3:        #a0a0a0;
  --line:         #2e2a42;

  /* Brand */
  --pink:   #e8198b;
  --green:  #7ec225;
  --blue:   #00b4d8;
  --yellow: #f5c800;

  --pink-soft:   #1a0a14;
  --green-soft:  #1a2a0a;
  --blue-soft:   #051520;
  --yellow-soft: #1a1500;

  /* Accent (theme dependent — overridden via JS) */
  --accent:        var(--pink);
  --accent-soft:   var(--pink-soft);
  --accent-ink:    #fff;

  /* Type */
  --f-display: 'Roboto Condensed', system-ui, sans-serif;
  --f-body:    'DM Sans', system-ui, -apple-system, sans-serif;
  --f-mono:    'DM Mono', ui-monospace, monospace;

  /* Layout */
  --pad: clamp(20px, 4vw, 56px);
  --maxw: 1320px;
  --r-sm: 10px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-xl: 36px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html,body{ background:var(--paper); color:var(--ink); }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
ul{ list-style:none; }

/* No texture on dark theme */
body::before{
  content:none;
}
body > *{ position:relative; z-index:1; }

/* ─── helpers ─── */
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }

.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#888;
  display:inline-flex; align-items:center; gap:8px;
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 22px;
  border-radius:999px;
  font-weight:600;
  font-size:15px;
  border:1.5px solid var(--ink);
  transition:transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
  white-space:nowrap;
  line-height:1;
}
.btn:hover{ transform:translateY(-2px); box-shadow:4px 4px 0 0 var(--ink); }
.btn--primary{ background:var(--ink); color:var(--paper); }
.btn--primary:hover{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); box-shadow:4px 4px 0 0 var(--ink); }
.btn--accent{ background:var(--accent); color:var(--accent-ink); border-color:var(--ink); }
.btn--ghost{ background:transparent; }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); }
.btn .arrow{ transition:transform .18s ease; display:inline-block; }
.btn:hover .arrow{ transform:translateX(3px); }

/* ─── nav ─── */
.nav{
  position:sticky; top:0; z-index:50;
  background:var(--paper-3);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1.5px solid var(--line);
}
.nav__inner{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:14px 0;
}
.nav__brand{
  display:flex; align-items:center; gap:10px; font-family:var(--f-display); font-size:22px;
  margin-left: clamp(20px, 6vw, 80px);
  transition: margin-left 0.3s ease, flex 0.3s ease;
}
.nav__brand img{ height:54px; width:auto; }
.nav__brand-text{ display:flex; flex-direction:column; line-height:.95; }
.nav__brand-text small{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-3); margin-top:2px;
}

.nav__links{ display:flex; align-items:center; gap:6px; }
.nav__link{
  font-size:15px; font-weight:600; padding:10px 18px; border-radius:999px;
  position:relative; transition:background .15s ease, color .15s ease;
  border: 1.5px solid transparent;
}
.nav__link:hover{ background:var(--link-color, var(--accent)); color:#fff; }
.nav__link.is-active{ background:var(--link-color, var(--accent)); color:#fff; }
.nav__cta{ margin-left:6px; }

.nav__hamburger{ display:none; width:42px; height:42px; border-radius:999px; border:1.5px solid var(--ink); align-items:center; justify-content:center; }
.nav__hamburger span{ width:18px; height:2px; background:var(--ink); border-radius:1px; position:relative; display:block; }
.nav__hamburger span::before, .nav__hamburger span::after{
  content:""; position:absolute; left:0; right:0; height:2px; background:var(--ink); border-radius:1px;
}
.nav__hamburger span::before{ top:-6px; }
.nav__hamburger span::after{ top:6px; }

@media (max-width: 980px){
  .nav__links{ display:none; }
  .nav__hamburger{ display:inline-flex; }
  .nav__inner{ justify-content: center; }
  .nav__brand{ margin-left: 0; flex: 1; justify-content: center; }
  .nav__brand-text{ display: none; }
}

.nav__drawer{
  position:fixed; inset:0; z-index:60;
  background:var(--paper-2);
  padding:24px var(--pad);
  display:flex; flex-direction:column; gap:8px;
  transform:translateY(-100%);
  transition:transform .3s ease;
  overflow:hidden auto;
}
.nav__drawer.is-open{ transform:translateY(0); }
.nav__drawer-top{ display:flex; align-items:center; justify-content:space-between; padding-bottom:18px; border-bottom:1.5px solid var(--ink); margin-bottom:18px; }
.nav__drawer-top .nav__brand span{ display: none; }
.nav__drawer a{
  font-family:var(--f-display); font-size:34px; padding:10px 0;
  border-bottom:1px dashed rgba(26,24,20,.25);
}

/* ─── HERO ─── */
.hero{ padding: clamp(40px, 7vw, 80px) 0 clamp(40px, 6vw, 70px); }
.hero__grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 60px);
  align-items: flex-start;
}
.hero__title{
  font-family:var(--f-display);
  font-size: clamp(54px, 9.2vw, 148px);
  font-weight:900;
  line-height:.92;
  letter-spacing:-0.02em;
  margin-bottom:24px;
}
.hero__title em{
  font-style:italic; color:var(--accent);
  display:inline-block; transform-origin:50% 100%;
  animation: wibble 3.2s ease-in-out infinite;
}
@keyframes wibble{
  0%,100%{ transform:rotate(-3deg); }
  50%{ transform:rotate(3deg); }
}
.hero__subtitle{
  font-size: clamp(17px, 1.5vw, 21px);
  color:#fff;
  max-width:48ch;
  margin-bottom:30px;
}
.hero__actions{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero__meta{
  display:flex; gap:28px; flex-wrap:wrap;
  margin-top:36px; padding-top:24px;
  border-top:1px dashed rgba(26,24,20,.25);
}
.hero__meta dt{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#888; margin-bottom:4px; }
.hero__meta dd{ font-family:var(--f-display); font-size:22px; font-weight:700; line-height:1; }

/* Hero photo composition */
.hero__visual{
  position: relative;
  aspect-ratio: 1/1.05;
  max-height: 479px;
}
.hero__photo{
  position:absolute; inset:0;
  border-radius:var(--r-xl);
  overflow:hidden;
  border:3px solid #fff;
  box-shadow: 8px 8px 0 0 rgba(255,255,255,.3);
  background:var(--paper-2);
}
.hero__photo img{ width:100%; height:100%; object-fit:cover; user-select:none; -webkit-user-select:none; -moz-user-select:none; -ms-user-select:none; pointer-events:auto; }
.hero__sticker{
  position:absolute;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-display);
  border-radius:50%;
  border:2px solid var(--ink);
  box-shadow: 4px 4px 0 0 var(--ink);
  text-align:center;
}
.hero__sticker--top{
  top:-22px; right:-10px;
  width:130px; height:130px;
  background:var(--yellow);
  font-size:18px;
  font-weight:700;
  transform: rotate(-12deg);
  padding:14px;
  line-height:1.05;
}
.hero__sticker--bottom{
  bottom:-26px; left:-22px;
  width:140px; height:140px;
  background:var(--pink);
  border-color:var(--pink);
  color:#fff;
  font-size:17px; padding:14px;
  transform: rotate(8deg);
  line-height:1.1;
  text-decoration:none;
  cursor:pointer;
  font-weight:700;
  transition: transform .25s ease, box-shadow .25s ease;
}
.hero__sticker--bottom:hover{ transform: rotate(8deg) scale(1.06); box-shadow: 6px 6px 0 0 rgba(0,0,0,.35); }
.hero__sticker--top{
  text-decoration:none;
  cursor:pointer;
  transition: transform .25s ease, box-shadow .25s ease;
}
.hero__sticker--top:hover{ transform: rotate(-12deg) scale(1.06); box-shadow: 6px 6px 0 0 rgba(0,0,0,.35); }
.hero__notes{
  position:absolute; pointer-events:none;
  font-family:var(--f-display);
  color:var(--ink);
  opacity:.85;
}
.hero__notes--a{ top:14%; left:-30px; font-size:42px; transform:rotate(-14deg); animation: float 4s ease-in-out infinite; }
.hero__notes--b{ bottom:18%; right:-24px; font-size:34px; transform:rotate(12deg); color:var(--blue); animation: float 5s ease-in-out -1s infinite; }
@keyframes float{
  0%,100%{ transform: translateY(0) rotate(var(--r,0deg)); }
  50%{ transform: translateY(-10px) rotate(var(--r,0deg)); }
}

@media (max-width: 880px){
  .hero__grid{
    grid-template-columns: 1fr;
  }
  .hero__visual{
    aspect-ratio: 1/1;
    order: -1;
  }
}

/* ─── marquee ─── */
.marquee{
  background:var(--paper-2);
  border-top:2px solid var(--line);
  border-bottom:2px solid var(--line);
  overflow:hidden; padding:18px 0;
  font-family:var(--f-display);
  font-size:34px;
  white-space:nowrap;
}
.marquee__track{
  display:inline-flex; gap:48px; padding-left:48px;
  animation: marquee 50s linear infinite;
  will-change: transform;
  animation-play-state: running !important;
  transform: translateZ(0);
  backface-visibility: hidden;
  perspective: 1000px;
}
.marquee__track span{ display:inline-flex; align-items:center; gap:48px; }
.marquee__track .dot{ width:14px; height:14px; border-radius:999px; background:var(--accent); }
@keyframes marquee{ to{ transform:translateX(-50%); } }

@keyframes float-up{
  0%{ opacity:1; transform: translateY(0) rotate(0deg); }
  100%{ opacity:0; transform: translateY(-200px) rotate(360deg); }
}

@keyframes bombastic-entrance{
  0%{ opacity:0; transform: scale(0) rotate(-180deg); }
  60%{ transform: scale(1.2) rotate(20deg); }
  100%{ opacity:1; transform: scale(1) rotate(0deg); }
}

/* ─── show cards ─── */
.section{ padding: clamp(56px, 8vw, 110px) 0; }
.section__head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap;
  margin-bottom: clamp(28px, 4vw, 56px);
}
.section__title{
  font-family:var(--f-display);
  font-size: clamp(40px, 5.5vw, 78px);
  font-weight:900;
  line-height:.95;
  letter-spacing:-0.015em;
  max-width:18ch;
  padding-bottom:14px;
}
.section__title em{ font-style:italic; color:var(--accent); }
.section__lede{ max-width:46ch; color:#ccc; font-size:17px; }

.shows{
  display:grid; grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2.4vw, 36px);
}
@media (max-width: 880px){ .shows{ grid-template-columns:1fr; } }

.shows .show:nth-child(1){ border-left:5px solid var(--pink); }
.shows .show:nth-child(2){ border-left:5px solid var(--blue); }

.show{
  position:relative;
  border-radius:var(--r-lg);
  border:3px solid;
  overflow:hidden;
  background:rgba(255,255,255,.04);
  display:flex; flex-direction:column;
  min-height:520px;
  transition: transform .25s ease, box-shadow .25s ease;
}
.show.show--pink{ border-color:var(--pink); }
.show.show--blue{ border-color:var(--blue); }
.show.show--green{ border-color:var(--green); }
.show__media{ aspect-ratio: 16/10; overflow:hidden; border-bottom:none; position:relative; }
.show__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.show__tag{
  position:absolute; top:14px; left:14px;
  padding:6px 12px; border-radius:999px;
  background:rgba(0,0,0,.7); color:#fff;
  border:1px solid rgba(255,255,255,.4);
  font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
}
.show__body{ padding: clamp(20px, 2.5vw, 32px); display:flex; flex-direction:column; gap:14px; flex:1; }
.show__title{ font-family:var(--f-mono); font-size: clamp(20px, 2.2vw, 36px); font-weight:900; line-height:.95; white-space:nowrap; }
.show__desc{ color:#ddd; }
.show__meta{
  display:flex; gap:14px; flex-wrap:wrap;
  padding-top:0;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:#999;
}
.show__cta{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:600;
  margin-top:auto; padding-top:18px;
  border-top:1px dashed rgba(255,255,255,.15);
  width:100%;
}
.show__cta .arrow{ transition:transform .18s ease; }

@media (hover: hover) {
  .show:hover{ transform: translateY(-4px); box-shadow: 8px 10px 0 0 var(--ink); }
  .show:hover .show__media img{ transform:scale(1.04); }
  .show:hover .show__cta .arrow{ transform:translateX(4px); }
}

.show--pink{ background:rgba(232, 25, 139, .15); border-color:var(--pink); }
.show--blue{ background:rgba(0, 180, 216, .15); border-color:var(--blue); }
.show--green{ background:rgba(126, 194, 37, .15); border-color:var(--green); }

/* ─── listen / tracks ─── */
.listen{
  background:var(--paper);
  border-top:1.5px solid var(--line);
  border-bottom:1.5px solid var(--line);
}
.listen .section__lede{ color:var(--ink-3); }

.tracks{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 880px){ .tracks{ grid-template-columns:1fr 1fr; } }
@media (max-width: 560px){ .tracks{ grid-template-columns:1fr; } }

.track{
  position:relative;
  background:rgba(246,239,225,.06);
  border:1.5px solid rgba(246,239,225,.15);
  border-radius:var(--r-md);
  padding:22px;
  display:flex; flex-direction:column; gap:10px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.track--wiggling {
  animation: wiggle-track 0.5s ease-in-out infinite;
}
.track:hover{ transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.3); }
.track--pink{ background:var(--pink); border-color:var(--pink); }
.track--green{ background:var(--green); border-color:var(--green); }
.track--blue{ background:var(--blue); border-color:var(--blue); }
.track--yellow{ background:var(--yellow); border-color:var(--yellow); }
.track__num{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em;
  color:rgba(255,255,255,.7);
}
.track--yellow .track__num{ color:rgba(0,0,0,.5); }
.track__title{ font-family:var(--f-mono); font-size:24px; font-weight:700; line-height:1; color:#fff; }
.track--yellow .track__title{ color:var(--paper); }
.track__desc{ font-size:14px; color:rgba(255,255,255,.8); }
.track--yellow .track__desc{ color:rgba(0,0,0,.6); }
.track__row{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  margin-top:auto; padding-top:14px;
}
.play-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 18px; border-radius:999px;
  background:rgba(0,0,0,.25); color:#fff;
  font-weight:700; font-size:13px;
  border:1.5px solid rgba(255,255,255,.4);
}
.track--yellow .play-btn{ background:rgba(0,0,0,.15); color:var(--paper); border-color:rgba(0,0,0,.2); }
.play-btn:hover{ background:rgba(0,0,0,.4); }
.play-btn .triangle{
  width:0; height:0;
  border-left:7px solid currentColor;
  border-top:5px solid transparent;
  border-bottom:5px solid transparent;
  margin-right:1px;
}
.track__time{
  font-family:var(--f-mono); font-size:12px; color:#999;
}

/* ─── feature stripe ─── */
.feature{
  border-top:1.5px solid var(--ink);
  border-bottom:1.5px solid var(--ink);
  padding: clamp(60px, 7vw, 96px) 0;
}
.feature__grid{
  display:grid; grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 64px);
  align-items:center;
}
@media (max-width: 880px){ .feature__grid{ grid-template-columns:1fr; } }
.feature__photo{
  border:2px solid var(--ink);
  border-radius:var(--r-lg);
  overflow:hidden;
  aspect-ratio: 4/5;
  box-shadow:8px 8px 0 0 var(--ink);
}
.feature__photo img{ width:100%; height:100%; object-fit:cover; }

.feature__list{
  margin:24px 0;
  display:grid; gap:8px;
}
.feature__list li{
  display:flex; gap:14px; padding:12px 0;
  border-bottom:1px dashed rgba(255,255,255,.12);
  font-size:16px;
  color:#ddd;
}
.feature__list li:last-child{ border-bottom:none; }
.feature__list .check{
  flex:0 0 24px; width:24px; height:24px; border-radius:999px;
  background:var(--accent); color:var(--accent-ink);
  display:inline-flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:700;
  margin-top:2px;
}

/* ─── team ─── */
.team{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap: clamp(14px, 1.6vw, 24px);
  grid-auto-rows: 1fr;
}

.team .member:nth-child(1){ border-top:4px solid var(--pink); padding-top:14px; }
.team .member:nth-child(2){ border-top:4px solid var(--green); padding-top:14px; }
.team .member:nth-child(3){ border-top:4px solid var(--blue); padding-top:14px; }
.team .member:nth-child(4){ border-top:4px solid var(--yellow); padding-top:14px; }

.member{
  display:flex; flex-direction:column; gap:10px;
  height: 100%;
  align-items: stretch;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.member__photo{
  aspect-ratio: 4/5;
  border-radius:var(--r-md);
  overflow:hidden;
  border:2px solid #555;
  background:var(--paper-2);
  position:relative;
  transition: transform .25s ease;
  flex: 1;
  width: 100%;
}
.member:hover .member__photo{ transform:rotate(-2deg); }
.member__photo img{ width:100%; height:100%; object-fit:cover; object-position: top center; }
.member__photo::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 60%, rgba(26,24,20,.5));
  opacity:0; transition:opacity .25s ease;
}
.member:hover .member__photo::after{ opacity:1; }
.member__photo .badge{
  position:absolute; top:10px; left:10px;
  padding:4px 10px; border-radius:999px;
  background:rgba(0,0,0,.8); color:#fff;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  border:1px solid rgba(255,255,255,.3);
}
.member__name{ font-family:var(--f-display); font-size:24px; line-height:1; margin-top:4px; }
.member__role{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#888; height:calc(1.2em * 3); overflow:hidden; display:flex; align-items:center; }

@media (max-width: 1000px) {
  .member__role { white-space: normal; }
}

@media (min-width: 1001px) {
  .member__role { white-space: nowrap; text-overflow: ellipsis; }
}
.member__toggle{ background:none; border:none; color:inherit; text-align:left; cursor:pointer; display:flex; flex-direction:column; gap:10px; width:100%; height:100%; padding:0; }
.member__toggle:hover .member__photo{ transform:rotate(-2deg); }
.member__chevron{ font-size:11px; color:var(--accent); margin-top:2px; }
.member__bio{ padding:16px 0 4px; border-top:1px dashed var(--line); display:flex; flex-direction:column; gap:10px; }
.member__bio p{ font-size:14px; color:var(--ink-2); line-height:1.65; margin:0; }
.team__bio-panel{ margin-top: 32px; margin-left: auto; margin-right: auto; padding: 24px; background: var(--paper-2); border-radius: var(--r-lg); border-top: 3px solid var(--accent); max-width: 600px; }
.team__bio-close{ padding: 8px 16px; margin-top: 16px; border: 1.5px solid var(--ink); border-radius: 999px; background: transparent; color: var(--ink); cursor: pointer; font-weight: 600; transition: all .2s ease; }
.team__bio-close:hover{ background: var(--member-color); color: #fff; }

/* ─── quote band ─── */
.quotes{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(14px, 1.6vw, 22px);
  margin-top: 30px;
}
@media (max-width: 880px){ .quotes{ grid-template-columns:1fr; } }
.quote{
  position:relative;
  padding:28px 24px 24px;
  border-radius:var(--r-md);
  border:2px solid;
  background:rgba(255,255,255,.04);
  font-family:var(--f-body);
  font-size:19px; font-weight:600; line-height:1.45;
  color:#fff;
}
.quote--pink{ border-color:var(--pink); }
.quote--blue{ border-color:var(--blue); }
.quote--green{ border-color:var(--green); }
.quote--yellow{ border-color:var(--yellow); }
.quote::before{
  content:"“"; position:absolute; top:-26px; left:14px;
  font-family:var(--f-display); font-size:80px; line-height:1; color:var(--ink);
}
.quote__author{
  display:block; margin-top:14px;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:#999;
}

/* ─── cta band ─── */
.cta{
  background:var(--paper-2);
  color:var(--ink);
  border-top:1.5px solid var(--line); border-bottom:1.5px solid var(--line);
  padding: clamp(60px, 8vw, 120px) 0;
  position:relative; overflow:hidden;
}
.cta__title{
  font-family:var(--f-display);
  font-size: clamp(46px, 7vw, 110px);
  font-weight:900;
  line-height:.92; letter-spacing:-0.015em;
  max-width:18ch;
  color:var(--ink);
}
.cta__lede{ max-width:48ch; margin-top:18px; font-size:18px; color:var(--ink-2); }
.cta__actions{ margin-top:32px; display:flex; gap:14px; flex-wrap:wrap; }

/* ─── contact form ─── */
.contact-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px, 6vw, 80px); margin-top:48px; }
@media (max-width: 880px){ .contact-wrap{ grid-template-columns:1fr; } }
.contact-form{ display:flex; flex-direction:column; gap:18px; }
.form-group{ display:flex; flex-direction:column; gap:8px; }
.form-group label{ font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3, #a0a0a0); }
.form-group input, .form-group select, .form-group textarea{
  font:500 15px/1.4 var(--f-body); color:var(--ink, #ffffff);
  background:var(--paper, #12111a); border:1.5px solid var(--ink, #ffffff); border-radius:var(--r-md, 18px); padding:12px 14px; outline:none;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{ border-color:var(--accent, #e8198b); box-shadow: 0 0 0 3px var(--accent-soft, #1a0a14); }
.form-group textarea{ min-height:120px; resize:vertical; }
#contactSuccess{ background:var(--green-soft); border:1.5px solid var(--green); border-radius:var(--r-md); padding:24px; text-align:center; color:#3a6010; }
#contactSuccess p:first-child{ font-size:18px; font-weight:700; margin-bottom:6px; }
.contact-info{ display:flex; flex-direction:column; gap:24px; }
.contact-info__item{ display:flex; gap:16px; align-items:flex-start; }
.contact-info__icon{ font-size:32px; flex-shrink:0; }
.contact-info__label{ font-weight:700; margin-bottom:4px; }
.contact-info__value{ color:var(--ink-2, #e0e0e0); font-size:14px; line-height:1.5; }

/* ─── volg ons buttons ─── */
.volgons-btn {
  transition: transform .2s ease, box-shadow .2s ease;
}
.volgons-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

/* ─── footer ─── */
.footer{
  background: linear-gradient(135deg, #1a0d1f 0%, #0a1a2e 50%, #0d1a0d 100%);
  color:var(--ink);
  padding: clamp(56px, 6vw, 90px) 0 30px;
  border-top: 3px solid var(--yellow);
}
.footer__grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: clamp(24px, 3vw, 48px);
}
@media (max-width: 880px){ .footer__grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px){ .footer__grid{ grid-template-columns: 1fr; } }

.footer__brand-mark{
  font-family:var(--f-display); font-size:48px; font-weight:900; line-height:1; margin-bottom:12px;
  background:linear-gradient(90deg, var(--pink), var(--blue));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.footer__about{ color:#999; max-width:32ch; }
.footer__head{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:#888; margin-bottom:14px;
}
.footer__list a{ display:block; padding:5px 0; color:#bbb; }
.footer__list a:hover{ color:var(--accent); }
.footer__bottom{
  margin-top:48px; padding-top:20px;
  border-top:1px solid rgba(255,255,255,.1);
  display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:#777;
}

/* ─── Mobile (≤ 560px) ─── */
@media (max-width: 560px) {
  /* Nav */
  .nav__brand { margin-left: 0; }

  /* Hero */
  .hero { padding: 28px 0 20px; }
  .hero__visual { aspect-ratio: 4/3; }
  .hero__sticker--top  { width:88px; height:88px; font-size:13px; top:-8px;  right:-4px;  padding:10px; }
  .hero__sticker--bottom { width:96px; height:96px; font-size:12px; bottom:-10px; left:-8px; padding:10px; }
  .hero__notes--a, .hero__notes--b { display:none; }

  /* Show cards */
  .show__title { white-space:normal; font-size: clamp(18px, 5.5vw, 28px); }
  .show { min-height:360px; }

  /* Section titles */
  .section__title { font-size: clamp(34px, 9vw, 56px); }
  .section__head { flex-direction:column; align-items:flex-start; }

  /* CTA */
  .cta__title { font-size: clamp(34px, 9vw, 78px); }

  /* Quotes */
  .quote { font-size:16px; }

  /* Team */
  .team { grid-template-columns: repeat(4, 1fr) !important; }
  .member__role { white-space: normal; min-height: auto; }
  .member__name { font-size: 22px; }
  .member__role { font-size: 10px; }

  /* Feature */
  .feature__grid { gap: 32px; }

  /* Footer */
  .footer__bottom { flex-direction:column; gap:8px; }
}

/* ─── Very small screens (≤ 440px) ─── */
@media (max-width: 440px) {
  .member__name { font-size: 19px; }
}

/* ─── animations ─── */
@keyframes wiggle-track {
  0%, 100% { transform: rotate(-0.5deg); }
  50% { transform: rotate(0.5deg); }
}

@keyframes font-picker-entrance {
  from {
    transform: scale(0) translate(0, 0);
    opacity: 0;
  }
  50% {
    transform: scale(1.15) translate(-60px, -120px);
    opacity: 1;
  }
  to {
    transform: scale(1) translate(0, 0);
    opacity: 1;
  }
}

@keyframes font-picker-slide {
  from {
    transform: translate(0, 0);
    opacity: 0;
  }
  to {
    transform: translate(0, 0);
    opacity: 1;
  }
}

@keyframes bombastic-entrance {
  from {
    transform: scale(0.3) translate(-50%, -50%);
    opacity: 0;
  }
  to {
    transform: scale(1) translate(0, 0);
    opacity: 1;
  }
}

@keyframes float-up {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-80px);
  }
}

/* ─── decorative scattered dots/notes ─── */
.confetti{
  position:absolute; pointer-events:none;
  font-family:var(--f-display);
  opacity:.95;
}
