/* %%GOA-STYLES-START%% */
/* Galder Open Air — Visueel design systeem v2 */

/* =====================================================
   FONT: BlowBrush
   Primaire brush-font voor hero H1 en sectie H2.
   Fontbestanden plaatsen in: templates/luxyort/fonts/
   - BlowBrush.woff2
   - BlowBrush.woff
   Bron: commercieel font (Genesislab) — licentie vereist.
   Tot die tijd valt de browser terug op 'Permanent Marker'.
   ===================================================== */

@font-face {
  font-family: 'BlowBrush';
  src: url('../fonts/BlowBrush.woff2') format('woff2'),
       url('../fonts/BlowBrush.woff')  format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* =====================================================
   0. RESET LUXYORT TEMPLATE OVERRIDES
   ===================================================== */

/* body.site (0,1,1) beats Luxyort injected <style> body{} (0,0,1) and preset1.css body{} (0,0,1) */
body.site {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: #10100f;
  color: #f1ead9;
}

/* Preloader pseudo-elements: template explicitly sets these, !important needed */
body.helix-ultimate-preloader::before,
body.helix-ultimate-preloader::after { display: none !important; }

/* body.site h2 (0,1,2) beats Luxyort injected h2{font-family} (0,0,1) and template h2{} */
body.site h1, body.site h2, body.site h3,
body.site h4, body.site h5, body.site h6 {
  font-family: 'BlowBrush', 'Permanent Marker', cursive;
}

body.site a { transition: color .15s, background-color .15s; }

/* =====================================================
   1. DESIGN TOKENS
   ===================================================== */

:root {
  --goa-black:   #10100f;
  --goa-dark:    #141414;
  --goa-paper:   #f1ead9;
  --goa-ink:     #141414;
  --goa-yellow:  #f4cf32;
  --goa-pink:    #f13a91;
  --goa-teal:    #54c7bd;
  --goa-green:   #93b95c;
  --goa-muted:   #d5c7aa;
  --goa-max:     1180px;
  --goa-pad:     4vw;

  --goa-font-brush:      'BlowBrush', 'Permanent Marker', 'Rock Salt', cursive;
  --goa-font-hand:       'Rock Salt', 'Permanent Marker', cursive;
  --goa-font-poster:     'Bangers', 'Staatliches', 'Arial Narrow', Impact, sans-serif;
  --goa-font-condensed:  'Staatliches', 'Arial Narrow', Impact, sans-serif;
  --goa-font-typewriter: 'Special Elite', 'Courier New', monospace;
  --goa-font-body:       'Inter', system-ui, -apple-system, sans-serif;
}

/* =====================================================
   2. LUXYORT TEMPLATE SHELL — restyle to GOA nav
   ===================================================== */

/* body.site prefix (1,1,1) beats template's #sp-page-builder (1,0,0) */
body.site #sp-page-builder,
body.site .sp-page-builder,
body.site .body-wrapper,
body.site .body-innerwrapper,
body.site #sp-main-body { background: transparent; position: relative; }

/* SPPB section default: dark — but NO !important so PB inline styles can override */
.sppb-section { background: var(--goa-black); }

/* body.site #sp-header (1,1,1) beats template's #sp-header (1,0,0) */
body.site #sp-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 200;
  background: transparent;
  padding: 14px var(--goa-pad);
  border-bottom: none;
  box-shadow: none;
}

body.site #sp-header .container {
  max-width: var(--goa-max);
  padding: 0;
}

body.site #sp-header .row {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  width: 100%;
  margin: 0;
  padding: 0;
}

/* Logo */
#sp-logo { flex: 0 0 auto; }
body.site #sp-logo a { text-decoration: none; }
body.site #sp-logo img { max-height: 124px; width: auto; }

/* Menu area */
body.site #sp-menu {
  display: flex;
  align-items: center;
}

body.site #sp-menu .sp-column {
  width: 100%;
}

body.site #sp-menu .sp-megamenu-wrapper {
  flex: 1 1 auto;
  min-width: 0;
}

body.site #sp-menu nav,
body.site #sp-menu ul {
  display: flex;
  width: 100%;
  justify-content: space-evenly;
  list-style: none;
  margin: 0; padding: 0;
  align-items: center;
  flex-wrap: nowrap;
}

body.site #sp-menu .sp-menu-item {
  display: flex;
  align-items: center;
}

/* All nav links — (1,2,1) already beats any template nav rule */
#sp-menu .sp-menu-item a {
  font-family: var(--goa-font-poster);
  font-size: 1.3rem;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: rgba(255,255,255,.9);
  text-decoration: none;
  padding: 4px 0;
  background: transparent;
  border: none;
  border-radius: 0;
  transition: color .15s;
  white-space: nowrap;
  text-shadow: 0 1px 8px rgba(0,0,0,.9), 0 0 20px rgba(0,0,0,.8);
}

#sp-menu .sp-menu-item a:hover { color: var(--goa-yellow); }

/* Verberg Luxyort decoratieve ::before lijn op nav links */
#sp-menu .sp-menu-item a::before { display: none; }

/* Active / current menu item */
#sp-menu .sp-menu-item.active a,
#sp-menu .sp-menu-item.current-item a {
  color: var(--goa-yellow);
  border-bottom: 2px solid var(--goa-yellow);
}

/* Tickets link — yellow box */
#sp-menu .sp-menu-item a[href="/tickets"],
#sp-menu .sp-menu-item a[href*="tickets"] {
  background: var(--goa-yellow);
  color: #111;
  padding: 3px 16px;
  transform: rotate(-1.5deg);
  display: inline-block;
  border-bottom: none;
  text-shadow: none;
}

/* Main content area spacing (accounts for fixed header) */
#sp-main-body { padding-top: 80px; }

/* Footer restyle — body.site prefix (1,1,1) beats template's #sp-footer (1,0,0) */
body.site #sp-footer,
body.site footer,
body.site .sp-footer {
  background: #070707;
  color: #aaa;
  padding: 40px var(--goa-pad);
  font-family: var(--goa-font-body);
  font-size: .875rem;
}

/* SPPB structural resets — geen !important zodat PB inline padding/margin doorkomt */
.sppb-addon-wrapper { margin: 0; padding: 0; }
.sppb-row-container { padding: 0; }
.sppb-section > .sppb-row-container > .sppb-row { margin: 0; }
.sppb-addon-content { margin: 0; }

/* =====================================================
   3. GOA CONTAINERS & SECTIONS
   ===================================================== */

.goa-section {
  padding: 80px var(--goa-pad);
  position: relative;
}

.goa-container {
  max-width: var(--goa-max);
  margin: 0 auto;
}

.goa-paper-section {
  background: var(--goa-paper);
  color: var(--goa-ink);
}

.goa-paper-section * { color: var(--goa-ink); }
.goa-paper-section a { color: var(--goa-ink); }

.goa-dark-section { background: #0f0f0f; }

/* =====================================================
   3b. SPPB GLOBAL OVERRIDES (native addon rendering)
   ===================================================== */

/* body.site .sppb-btn (0,2,1) beats template's .sppb-btn (0,1,0) — no !important needed */
body.site .sppb-btn,
body.site .sppb-btn-rounded,
body.site .sppb-btn-custom {
  border-radius: 0;
}

/* SPPB heading addon — (0,2,2) beats Luxyort h1{} (0,0,1) and template h2{} */
.sppb-addon-header h1.sppb-addon-title,
.sppb-addon-header.goa-title-hero h1,
.sppb-addon-header.goa-title-hero .sppb-addon-title {
  font-family: var(--goa-font-brush);
  font-size: clamp(3rem, 8vw, 6.5rem);
  line-height: .82;
  text-transform: uppercase;
  text-shadow: 5px 5px 0 rgba(0,0,0,.6);
  color: #fff;
  margin: 16px 0;
}

/* Donker glas IN de letters — geen backdrop-filter (bloedt rectangle) */
.sppb-addon-header.goa-title-hero h1,
.sppb-addon-header.goa-title-hero .sppb-addon-title {
  /* Donkere, licht doorzichtige gradient = gelaagd donker glas.
     De foto schijnt subtiel door (~10-20%) zonder de rectangle te raken. */
  background: linear-gradient(
    148deg,
    rgba(90,  130, 170, 0.55) 0%,
    rgba(8,   18,   38, 0.92) 8%,
    rgba(12,  25,   52, 0.90) 25%,
    rgba(32,  60,   95, 0.76) 38%,
    rgba(5,   14,   30, 0.94) 52%,
    rgba(8,   18,   38, 0.91) 68%,
    rgba(28,  55,   88, 0.79) 80%,
    rgba(85, 125,  165, 0.52) 90%,
    rgba(6,   15,   32, 0.90) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-shadow: none;
  /* Witte stroke = letterrand, geeft contrast op de donkere fill */
  -webkit-text-stroke: 1.8px rgba(255, 255, 255, 0.88);
  filter: drop-shadow(3px 4px 0 rgba(0, 5, 20, 0.80));
}

.sppb-addon-header h2.sppb-addon-title,
.sppb-addon-header.goa-title-section .sppb-addon-title {
  font-family: var(--goa-font-brush);
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: .88;
  text-transform: uppercase;
  margin: 0 0 1.5rem;
}

.sppb-addon-header.goa-marker-wrap .sppb-addon-title {
  font-size: inherit;
  font-family: inherit;
  text-shadow: none;
  line-height: normal;
}

.sppb-addon-text-block .goa-hero-sub {
  font-family: var(--goa-font-typewriter);
  font-size: 1.25rem;
  color: rgba(241,234,217,.9);
  text-shadow: 1px 1px 12px rgba(0,0,0,1), 0 0 60px rgba(0,0,0,.95), 0 0 100px rgba(0,0,0,.7);
  max-width: 560px;
  margin: 0 0 28px;
}

/* Lineup card title in yellow */
.goa-lineup-card .sppb-addon-header .sppb-addon-title {
  color: var(--goa-yellow);
  font-family: var(--goa-font-poster);
  font-size: 1.6rem;
}

.goa-paper-section .sppb-addon-header .sppb-addon-title { color: var(--goa-ink); }

#section-id-1667266846 .sppb-addon-title { color: var(--goa-paper); text-align: center; }
#section-id-1667266849 h2.sppb-addon-title { text-align: center; }

.goa-timetable-row .sppb-addon-header.goa-slot-time .sppb-addon-title {
  font-family: var(--goa-font-poster);
  font-size: 1.3rem;
  letter-spacing: .04em;
  color: var(--goa-yellow);
  margin: 0;
  padding: 14px 16px;
}

.goa-timetable-row .sppb-row-container { padding: 0; }
.goa-timetable-row .sppb-column { padding: 0; }
.goa-timetable-row { margin-bottom: 6px; }

.goa-info-balk-row .goa-info-item .sppb-addon-feature .sppb-addon-content {
  padding: 28px 16px;
  text-align: center;
}

.goa-info-balk-row .goa-info-item .sppb-img-container {
  background: transparent;
  transform: none;
  box-shadow: none;
}

.goa-info-balk-row .goa-info-item .sppb-img-container img {
  filter: invert(1) opacity(.8);
  width: 48px; height: 48px;
}

.goa-info-balk-row .goa-info-item .sppb-feature-box-title {
  color: var(--goa-yellow);
  font-family: var(--goa-font-poster);
  text-transform: uppercase;
}

/* SPPB section row overlay support */
.sppb-row-overlay { position: absolute; inset: 0; z-index: 0; pointer-events: none; }

/* =====================================================
   4. TYPOGRAPHY
   ===================================================== */

/* Hero title */
.goa-title-hero,
.goa-hero-row h1 {
  font-family: var(--goa-font-brush);
  font-size: clamp(3rem, 8vw, 6.5rem);
  line-height: .82;
  margin: 16px 0;
  text-transform: uppercase;
  letter-spacing: .01em;
  text-shadow: 5px 5px 0 rgba(0,0,0,.6), 0 0 60px rgba(0,0,0,.4);
  color: #fff;
}

/* Section titles */
.goa-title-section,
.goa-section h2 {
  font-family: var(--goa-font-brush);
  font-size: clamp(2.5rem, 6vw, 5.5rem);
  line-height: .88;
  margin: 0 0 1.5rem;
  text-transform: uppercase;
  letter-spacing: .01em;
}

.goa-paper-section .goa-title-section,
.goa-paper-section h2 {
  color: var(--goa-ink);
}

/* Card titles */
.goa-card-title,
.goa-section h3 {
  font-family: var(--goa-font-poster);
  font-size: 1.4rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  line-height: 1;
  margin: 0 0 .6rem;
}

/* Utility type classes */
.goa-font-brush    { font-family: var(--goa-font-brush); }
.goa-font-poster   { font-family: var(--goa-font-poster); }
.goa-font-hand     { font-family: var(--goa-font-hand); }
.goa-font-typewriter,
.paper-note,
.intro-copy        { font-family: var(--goa-font-typewriter); }
.title-brush       { font-family: var(--goa-font-brush); text-transform: uppercase; }
.title-poster,
.sticker-title     { font-family: var(--goa-font-poster); text-transform: uppercase; }

.scribble-underline { position: relative; display: inline-block; }
.scribble-underline::after {
  content: "";
  position: absolute; left: 0; right: 0;
  bottom: -.1em; height: .1em;
  background: var(--goa-yellow);
  transform: rotate(-1.5deg);
}

/* =====================================================
   5. HERO SECTION
   ===================================================== */

.goa-hero-row {
  /* Foto via PB — background-size/attachment/position need !important to override SPPB per-section <style> injection */
  background-size: cover !important;
  background-attachment: fixed !important;
  background-position: center 30% !important;
  padding: 180px var(--goa-pad) 80px;
  position: relative;
  display: flex;
  align-items: flex-start;
  overflow: hidden;
}

.goa-hero-row::before {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg,
      rgba(0,0,0,.85) 0%,
      rgba(0,0,0,0)   20%,
      rgba(0,0,0,0)   80%,
      rgba(0,0,0,.85) 100%),
    linear-gradient(135deg, rgba(0,0,0,.6) 0%, rgba(0,0,0,.1) 60%, rgba(0,0,0,.4) 100%),
    linear-gradient(0deg, rgba(0,0,0,1) 0%, rgba(0,0,0,.6) 20%, transparent 45%);
  z-index: 1;
  pointer-events: none;
}

.goa-hero-row .sppb-row-container {
  position: relative;
  z-index: 2;
}

/* Grain texture overlay */
.goa-hero-row::after {
  content: "";
  position: absolute; inset: 0;
  background-image:
    url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.07'/%3E%3C/svg%3E");
  z-index: 2; opacity: .5;
  pointer-events: none;
}

.goa-hero-inner {
  position: relative;
  z-index: 3;
  max-width: var(--goa-max);
  width: 100%;
  margin: 0 auto;
}

.goa-hero-sub {
  max-width: 560px;
  font-size: 1.25rem;
  font-family: var(--goa-font-typewriter);
  color: rgba(241,234,217,.9);
  text-shadow: 1px 1px 12px rgba(0,0,0,1), 0 0 60px rgba(0,0,0,.95), 0 0 100px rgba(0,0,0,.7);
  margin: 20px 0 28px;
  line-height: 1.5;
}

/* =====================================================
   6. MARKER / STICKER ELEMENT
   ===================================================== */

.goa-marker {
  display: inline-block;
  background: var(--goa-pink);
  color: #111;
  padding: 6px 20px;
  transform: rotate(-2.5deg);
  font-family: var(--goa-font-poster);
  font-size: 2rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 12px;
  box-shadow: 3px 3px 0 rgba(0,0,0,.3);
}

.goa-marker--yellow { background: var(--goa-yellow); }
.goa-marker--teal   { background: var(--goa-teal); }

/* =====================================================
   7. BUTTONS
   ===================================================== */

.goa-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.goa-hero-row .addon-root-button {
  display: inline-flex;
  margin-right: 12px;
  margin-bottom: 8px;
}

.goa-btn {
  display: inline-block;
  border: 2.5px solid currentColor;
  padding: 14px 24px;
  text-decoration: none;
  color: #f1ead9;
  background: rgba(16,16,15,.7);
  font-family: var(--goa-font-poster);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  cursor: pointer;
  transition: all .2s;
  border-radius: 0;
  backdrop-filter: blur(4px);
}

.goa-btn--primary {
  background: var(--goa-yellow);
  color: #111;
  border-color: var(--goa-yellow);
}

.goa-btn--primary:hover {
  background: #d4b020;
  border-color: #d4b020;
  color: #111;
  transform: translateY(-2px);
}

.goa-btn--secondary {
  background: rgba(16,16,15,.7);
  color: #f1ead9;
  border-color: #f1ead9;
}

.goa-btn--secondary:hover,
.goa-btn:not(.goa-btn--primary):hover {
  background: var(--goa-yellow);
  color: #111;
  border-color: var(--goa-yellow);
  transform: translateY(-2px);
}

.goa-btn--lg { padding: 18px 32px; font-size: 1.15rem; }
.goa-btn--block { display: block; text-align: center; width: 100%; }

/* =====================================================
   8. ICON CARDS — native SPPB feature addon styling
   ===================================================== */

/* SPPB wraps feature addons in: .sppb-addon-wrapper > .sppb-addon > .sppb-addon-content-align-* */
.goa-icon-card,
.addon-root-feature .goa-icon-card,
.sppb-addon-feature.goa-icon-card,
.sppb-addon-feature.goa-icon-card .sppb-addon-content {
  height: 100%;
}

.goa-icon-card:hover,
.sppb-addon-feature.goa-icon-card:hover {
  transform: translateY(-4px) rotate(.3deg);
  box-shadow: 12px 14px 0 rgba(0,0,0,.4);
}

/* Paper section icon cards get light styling */
.goa-paper-section .goa-icon-card,
.goa-paper-section .sppb-addon-feature.goa-icon-card,
.goa-paper-section .sppb-addon-feature.goa-icon-card .sppb-addon-content {
  background: rgba(255,255,255,.75);
  border-color: rgba(20,20,20,.12);
  box-shadow: 6px 6px 0 rgba(0,0,0,.15);
  color: var(--goa-ink);
}

/* Feature icon image */
.goa-icon-card .sppb-img-container,
.sppb-addon-feature.goa-icon-card .sppb-img-container {
  display: inline-block;
  background: var(--goa-yellow);
  padding: 12px;
  transform: rotate(-5deg);
  margin-bottom: 18px;
  box-shadow: 3px 3px 0 rgba(0,0,0,.2);
  width: 64px; height: 64px;
}

.goa-icon-card .sppb-img-container img,
.sppb-addon-feature.goa-icon-card .sppb-img-container img {
  width: 40px;
  height: 40px;
  display: block;
}

/* Feature icon (Font Awesome) */
.goa-icon-card .sppb-icon,
.sppb-addon-feature.goa-icon-card .sppb-icon {
  display: inline-block;
  width: 64px; height: 64px;
  background: var(--goa-yellow);
  display: flex; align-items: center; justify-content: center;
  transform: rotate(-5deg);
  margin-bottom: 18px;
  box-shadow: 3px 3px 0 rgba(0,0,0,.2);
}

.goa-icon-card .sppb-icon i { color: #111; font-size: 1.6rem; }

.goa-icon-card .sppb-feature-box-title,
.sppb-addon-feature.goa-icon-card .sppb-feature-box-title {
  font-family: var(--goa-font-poster);
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: .5rem;
}

/* Ensure icon card spans full column height */
.sppb-col-md-3 .addon-root-feature,
.sppb-col-md-4 .addon-root-feature {
  height: 100%;
}

/* Illustration cards — 3-class specificity beats paper-section rules */
.sppb-addon-feature.goa-icon-card.goa-illus-card {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}
.sppb-addon-feature.goa-icon-card.goa-illus-card .sppb-addon-content {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 16px 12px;
}
.sppb-addon-feature.goa-icon-card.goa-illus-card:hover {
  transform: none;
  box-shadow: none;
}
.sppb-addon-feature.goa-illus-card .sppb-img-container {
  background: transparent;
  padding: 0;
  transform: none;
  box-shadow: none;
  width: auto;
  height: auto;
  display: block;
  margin-bottom: 12px;
}
.sppb-addon-feature.goa-illus-card .sppb-img-container img {
  width: 150px;
  height: 150px;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

/* Old direct class support */
.goa-icon-wrap {
  width: 64px; height: 64px;
  background: var(--goa-yellow);
  padding: 12px;
  transform: rotate(-5deg);
  margin-bottom: 18px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 3px 3px 0 rgba(0,0,0,.2);
}

.goa-icon-wrap img { width: 100%; height: 100%; }

/* =====================================================
   9. GRIDS
   ===================================================== */

.goa-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.goa-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.goa-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.goa-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

/* =====================================================
   10. PHOTO CARDS
   ===================================================== */

.goa-photo-card {
  min-height: 280px;
  background-size: cover;
  background-position: center;
  padding: 16px;
  display: flex;
  align-items: flex-end;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: transform .25s;
}

.goa-photo-card::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(0,0,0,.6) 0%, transparent 60%);
  transition: opacity .25s;
}

.goa-photo-card:hover { transform: scale(1.02); }
.goa-photo-card:hover::after { opacity: .5; }

.goa-label {
  background: var(--goa-pink);
  color: #111;
  padding: 8px 14px;
  display: inline-block;
  font-family: var(--goa-font-poster);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .9rem;
  position: relative; z-index: 1;
  box-shadow: 2px 2px 0 rgba(0,0,0,.3);
}

.goa-label--teal   { background: var(--goa-teal); }
.goa-label--yellow { background: var(--goa-yellow); }
.goa-label--green  { background: var(--goa-green); }

/* =====================================================
   11. POLAROIDS
   ===================================================== */

.goa-polaroids {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.goa-polaroids--large {
  grid-template-columns: repeat(4, 1fr);
}

.goa-polaroids img {
  width: 100%;
  background: white;
  padding: 10px 10px 50px;
  transform: rotate(var(--r, 0deg));
  box-shadow: 0 12px 30px rgba(0,0,0,.4), 0 2px 6px rgba(0,0,0,.2);
  transition: transform .25s, box-shadow .25s;
  display: block;
}

.goa-polaroids img:hover {
  transform: rotate(0deg) scale(1.04);
  box-shadow: 0 20px 50px rgba(0,0,0,.5);
  z-index: 2;
  position: relative;
}

/* =====================================================
   12. LINEUP CARDS
   ===================================================== */

.goa-lineup-card {
  background: rgba(255,255,255,.06);
  border: 1.5px solid rgba(255,255,255,.1);
  overflow: hidden;
  box-shadow: 6px 6px 0 rgba(0,0,0,.3);
  transition: transform .2s, box-shadow .2s;
}

.goa-lineup-card:hover {
  transform: translateY(-4px);
  box-shadow: 10px 12px 0 rgba(0,0,0,.4);
}

.goa-lineup-photo {
  height: 220px;
  background-size: cover;
  background-position: center top;
}

.goa-lineup-info {
  padding: 20px;
}

.goa-lineup-info .goa-card-title {
  font-size: 1.6rem;
  color: var(--goa-yellow);
}

.goa-lineup-card--more {
  background: repeating-linear-gradient(
    -45deg,
    rgba(255,255,255,.03),
    rgba(255,255,255,.03) 10px,
    rgba(255,255,255,.06) 10px,
    rgba(255,255,255,.06) 20px
  );
  display: flex; align-items: center;
}

/* =====================================================
   13. LINEUP TEASER (homepage)
   ===================================================== */

.goa-lineup-teaser {
  background:
    url('/images/goa/backgrounds/dark-stage-wide-no-text.jpg') center/cover;
  position: relative;
}

.goa-lineup-teaser::before {
  content: "";
  position: absolute; inset: 0;
  background: rgba(0,0,0,.75);
}

.goa-lineup-teaser .goa-container { position: relative; z-index: 1; }

.goa-teaser-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 48px;
  align-items: center;
}

.goa-lineup-names {
  margin: 24px 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.goa-lineup-names span {
  font-family: var(--goa-font-brush);
  font-size: clamp(2.2rem, 5vw, 4rem);
  line-height: .9;
  text-transform: uppercase;
  color: #fff;
}

.goa-lineup-small {
  font-family: var(--goa-font-poster);
  font-size: 1rem;
  color: var(--goa-muted);
  margin-top: 8px;
}

.goa-teaser-photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.goa-polaroid-mini {
  height: 160px;
  background-size: cover;
  background-position: center;
  transform: rotate(var(--r, 0deg));
  box-shadow: 0 8px 20px rgba(0,0,0,.5);
  padding: 0;
  background-color: #fff;
  transition: transform .25s;
}

.goa-polaroid-mini:hover { transform: rotate(0deg) scale(1.05); }

/* =====================================================
   14. TIMETABLE
   ===================================================== */

.goa-timetable {
  display: grid;
  grid-template-columns: 90px 1fr 1fr;
  gap: 8px;
  margin-top: 24px;
}

.goa-slot {
  padding: 14px 16px;
  background: rgba(241,234,217,.12);
  font-family: var(--goa-font-body);
  font-size: .95rem;
}

.goa-slot--time {
  font-family: var(--goa-font-poster);
  font-size: 1.2rem;
  background: #1a1a1a;
  color: var(--goa-yellow);
  letter-spacing: .04em;
}

.goa-slot--pink { background: var(--goa-pink); color: #111; font-weight: 600; }
.goa-slot--teal { background: var(--goa-teal); color: #111; }

.goa-timetable-note {
  margin-top: 20px;
  font-size: .9rem;
  color: var(--goa-muted);
  font-family: var(--goa-font-typewriter);
}

/* =====================================================
   15. TERREIN MAP
   ===================================================== */

.goa-terrain-map {
  background: url('/images/goa/textures/paper-texture.jpg') center/cover;
  border: 6px solid #e2d2aa;
  min-height: 380px;
  position: relative;
  border-radius: 4px;
  margin-bottom: 28px;
  box-shadow: 8px 8px 0 rgba(0,0,0,.2);
}

.goa-terrain-pin {
  position: absolute;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--goa-pink);
  display: grid; place-items: center;
  font-family: var(--goa-font-poster);
  font-weight: 900;
  font-size: 1.1rem;
  box-shadow: 0 0 0 6px rgba(0,0,0,.15), 3px 4px 0 rgba(0,0,0,.3);
  color: #111;
  transform: translate(-50%, -50%);
}

.goa-terrain-pin--teal   { background: var(--goa-teal); }
.goa-terrain-pin--yellow { background: var(--goa-yellow); }
.goa-terrain-pin--green  { background: var(--goa-green); }
.goa-terrain-pin--pink   { background: var(--goa-pink); }

.goa-terrain-num {
  width: 42px; height: 42px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--goa-font-poster);
  font-weight: 900;
  font-size: 1.2rem;
  margin-bottom: 14px;
  box-shadow: 3px 3px 0 rgba(0,0,0,.2);
}

.goa-terrain-num--pink   { background: var(--goa-pink); color: #111; }
.goa-terrain-num--teal   { background: var(--goa-teal); color: #111; }
.goa-terrain-num--yellow { background: var(--goa-yellow); color: #111; }
.goa-terrain-num--green  { background: var(--goa-green); color: #111; }

/* =====================================================
   16. TICKET CARDS
   ===================================================== */

.goa-ticket-card {
  background: rgba(255,255,255,.06);
  border: 2px solid rgba(255,255,255,.12);
  padding: 32px 28px;
  box-shadow: 8px 8px 0 rgba(0,0,0,.2);
  position: relative;
}

.goa-paper-section .goa-ticket-card {
  background: rgba(255,255,255,.7);
  border-color: rgba(0,0,0,.12);
  box-shadow: 6px 6px 0 rgba(0,0,0,.15);
}

.goa-ticket-card--featured {
  border-color: var(--goa-yellow);
  background: rgba(244,207,50,.08);
  transform: scale(1.04);
}

.goa-ticket-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.goa-ticket-type {
  font-family: var(--goa-font-poster);
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.goa-ticket-badge {
  background: var(--goa-yellow);
  color: #111;
  padding: 4px 10px;
  font-family: var(--goa-font-poster);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  transform: rotate(-2deg);
  display: inline-block;
}

.goa-price {
  font-family: var(--goa-font-brush);
  font-size: 4rem;
  line-height: 1;
  margin: 12px 0;
  color: var(--goa-yellow);
}

.goa-paper-section .goa-price { color: var(--goa-ink); }

.goa-ticket-list {
  list-style: none;
  padding: 0; margin: 0 0 24px;
}

.goa-ticket-list li {
  padding: 6px 0;
  border-bottom: 1px solid rgba(255,255,255,.1);
  font-size: .9rem;
}

.goa-paper-section .goa-ticket-list li { border-bottom-color: rgba(0,0,0,.1); }

/* =====================================================
   17. INFO BALK (homepage)
   ===================================================== */

.goa-info-balk {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
}

.goa-info-item {
  padding: 28px 20px;
  text-align: center;
  border-right: 1px solid rgba(255,255,255,.08);
}

.goa-info-item:last-child { border-right: none; }

.goa-info-item img {
  width: 40px; height: 40px;
  margin: 0 auto 10px;
  filter: invert(1) opacity(.8);
}

.goa-info-item > span {
  display: block;
  font-family: var(--goa-font-poster);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--goa-yellow);
}

.goa-info-item small {
  display: block;
  margin-top: 4px;
  font-size: .85rem;
  color: var(--goa-muted);
}

.goa-info-item small a { color: var(--goa-teal); text-decoration: none; }
.goa-info-item small a:hover { text-decoration: underline; }

/* =====================================================
   18. CTA SECTION
   ===================================================== */

.goa-cta {
  padding: 120px var(--goa-pad);
  position: relative;
  text-align: center;
}

.goa-cta .goa-container { position: relative; z-index: 1; }
.goa-cta h2, .goa-cta .goa-title-section { color: #fff; }
.goa-cta p { color: rgba(241,234,217,.85); font-size: 1.1rem; margin-bottom: 32px; }

/* =====================================================
   19. FOTOS NOTE
   ===================================================== */

.goa-fotos-note {
  text-align: center;
  margin-top: 32px;
  color: var(--goa-muted);
  font-size: .9rem;
}

/* =====================================================
   20. RESPONSIVE — 850px
   ===================================================== */

@media (max-width: 850px) {
  .goa-hero-row {
    min-height: 75vh;
    padding: 120px var(--goa-pad) 60px;
    background-attachment: scroll !important; /* needs !important: SPPB per-section <style> injection */
  }

  .goa-grid-4,
  .goa-grid-3,
  .goa-split,
  .goa-teaser-grid,
  .goa-info-balk {
    grid-template-columns: 1fr;
  }

  .goa-grid-2 { grid-template-columns: 1fr 1fr; }

  .goa-timetable { grid-template-columns: 80px 1fr; }

  .goa-polaroids,
  .goa-polaroids--large { grid-template-columns: 1fr 1fr; }

  .goa-actions { flex-direction: column; }

  .goa-ticket-card--featured { transform: none; }

  .goa-lineup-teaser .goa-teaser-photos { display: none; }

  .goa-info-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); }

  body.site #sp-menu ul { gap: 0; justify-content: space-evenly; }

  .goa-title-hero,
  .goa-hero-row h1 { font-size: clamp(2.5rem, 10vw, 5rem); }
}

@media (max-width: 560px) {
  .goa-grid-2, .goa-polaroids, .goa-polaroids--large {
    grid-template-columns: 1fr;
  }

  .goa-info-balk { gap: 0; }
}
/* =====================================================
   21. LUXYORT HOTEL CONTENT — VERBERGEN
   ===================================================== */

/* Verberg BOOK NOW knop in nav (Luxyort hotel template artifact) */
a.header-btn,
.addon-root-button .header-btn,
#sppb-addon-1620299499049,
#sppb-addon-wrapper-1620299499049 { display: none !important; }

/* Verberg hotel footer kolommen (sp-bottom1..4) */
#sp-bottom1 .sp-module-content,
#sp-bottom2,
#sp-bottom3,
#sp-bottom4 { display: none !important; }

/* Verberg hotel footer titles */
#sp-bottom .sp-module-title { display: none !important; }

/* Verberg hotel SPPB-module content in footer */
#sp-bottom .mod-sppagebuilder { display: none !important; }

/* Maar bewaar de copyright-regel */
#sp-bottom .sp-copyright {
  display: block !important;
  text-align: center;
  padding: 16px;
  color: #666;
  font-size: .875rem;
}

/* body.site prefix beats template's #sp-bottom (1,0,0) */
body.site #sp-bottom {
  background: #070707;
  padding: 20px var(--goa-pad);
  border-top: 1px solid rgba(255,255,255,.08);
}

/* Verberg hotel SPPB heading addon met "Exclusive Discount" tekst */
#sp-bottom1 .sppb-addon-header { display: none !important; }

/* Verberg de email subscription form */
#sp-bottom1 .sp-module { display: none !important; }

/* Voeg GOA-footer toe boven de copyright */
#sp-bottom::before {
  content: "";
  display: block;
  max-width: var(--goa-max);
  margin: 0 auto;
}

/* Nav: verberg Luxyort mobile hamburger (we stylen het anders) */
#sp-header .sp-offcanvas-toggle { display: none !important; }

/* body.site #sp-header.sticky-header--sticky (1,2,1) beats template's #sp-header (1,0,0) */
body.site #sp-header.sticky-header--sticky {
  background: rgba(16,16,15,.97);
  box-shadow: 0 2px 20px rgba(0,0,0,.5);
}

/* =====================================================
   22. NAV VERFIJNING
   ===================================================== */

/* Verberg Luxyort mega-menu dropdowns die we niet gebruiken */
#sp-menu .nav-child,
#sp-menu ul ul { display: none !important; }

/* Active menu item highlight — handled by .sp-menu-item.active above */

/* Verberg Luxyort presets colorstrip */
.color-switcher-wrapper,
.sppb-color-switcher { display: none !important; }

/* =====================================================
   23. PAPER SECTIE — ICON CARDS FIX
   ===================================================== */

/* Icons in paper sectie zichtbaar op lichte achtergrond */
.goa-paper-section .goa-icon-wrap {
  background: var(--goa-yellow);
}

.goa-paper-section .goa-icon-card {
  background: rgba(255,255,255,.75);
  color: var(--goa-ink);
  border-color: rgba(20,20,20,.12);
}

.goa-paper-section .goa-icon-card h3,
.goa-paper-section .goa-card-title,
.goa-paper-section .goa-icon-card p { color: var(--goa-ink); }

.goa-paper-section .goa-icon-card.goa-illus-card h3,
.goa-paper-section .goa-icon-card.goa-illus-card .sppb-feature-box-title,
.goa-paper-section .goa-icon-card.goa-illus-card p,
.goa-paper-section .goa-icon-card.goa-illus-card .sppb-addon-text { color: var(--goa-paper); }

.goa-paper-section .goa-lineup-card { color: var(--goa-ink); }
.goa-paper-section .goa-lineup-info .goa-card-title { color: var(--goa-ink); }

/* =====================================================
   24. MOBILE NAV — LUXYORT AANPASSEN
   ===================================================== */

@media (max-width: 991px) {
  body.site #sp-menu ul.sp-megamenu-parent { display: none; }
  body.site #sp-menu .sp-module-content {
    background: rgba(16,16,15,.97);
    padding: 10px 0;
  }
  body.site #sp-menu ul { flex-direction: column; gap: 4px; padding: 10px; }
  body.site #sp-menu ul li a { font-size: 1.1rem; padding: 8px 16px; display: block; }
}

/* =====================================================
   25. TERRAIN GRID — afwisselend scheve foto's
   ===================================================== */

.goa-terrain-grid .sppb-row > :nth-child(2) .sppb-column-addons { transform: rotate(-2deg); }
.goa-terrain-grid .sppb-row > :nth-child(3) .sppb-column-addons { transform: rotate(2.5deg); }
.goa-terrain-grid .sppb-row > :nth-child(4) .sppb-column-addons { transform: rotate(-1.5deg); }
.goa-terrain-grid .sppb-row > :nth-child(5) .sppb-column-addons { transform: rotate(1.8deg); }

/* Rauw gekleurde rand via SVG feTurbulence filter — direct om de foto */
.goa-terrain-grid .sppb-addon-single-image-container { position: relative; }

.goa-terrain-grid .sppb-addon-single-image-container::after {
  content: '';
  position: absolute;
  inset: -6px;
  border: 5px solid;
  pointer-events: none;
  filter: url(#goa-rough);
  z-index: 2;
}

.goa-terrain-grid .sppb-row > :nth-child(2) .sppb-addon-single-image-container::after { border-color: var(--goa-pink); }
.goa-terrain-grid .sppb-row > :nth-child(3) .sppb-addon-single-image-container::after { border-color: var(--goa-teal); }
.goa-terrain-grid .sppb-row > :nth-child(4) .sppb-addon-single-image-container::after { border-color: var(--goa-yellow); }
.goa-terrain-grid .sppb-row > :nth-child(5) .sppb-addon-single-image-container::after { border-color: var(--goa-green); }

/* Badge = ticket-stub shape — zigzag zijkanten via clip-path polygon */
.goa-terrain-grid span.goa-label {
  display: inline-block;
  font-size: 1.2rem;
  padding: 8px 28px;
  clip-path: polygon(
    0% 0%, 100% 0%,
    100% 10%, 93% 20%, 100% 30%, 93% 40%, 100% 50%, 93% 60%, 100% 70%, 93% 80%, 100% 90%, 100% 100%,
    0% 100%,
    7% 90%, 0% 80%, 7% 70%, 0% 60%, 7% 50%, 0% 40%, 7% 30%, 0% 20%, 7% 10%
  );
}

.goa-terrain-grid .sppb-row > :nth-child(2) span.goa-label { background: var(--goa-pink); }
.goa-terrain-grid .sppb-row > :nth-child(3) span.goa-label { background: var(--goa-teal); color: #000; }
.goa-terrain-grid .sppb-row > :nth-child(4) span.goa-label { background: var(--goa-yellow); }
.goa-terrain-grid .sppb-row > :nth-child(5) span.goa-label { background: var(--goa-green); }

.goa-terrain-grid .addon-root-heading { text-align: center; }
.goa-terrain-grid .addon-root-heading .sppb-addon-title { margin-top: 0; }
.goa-terrain-grid h2.sppb-addon-title { margin-bottom: 0.4rem; }

/* =====================================================
   26. LINE-UP TEASER — POSTER OVERHAUL
   ===================================================== */

/* #sp-page-builder prefix (1,1,0) beats SPPB's .sppb-section default (0,1,0) via source order */
#sp-page-builder .goa-lineup-teaser {
  background: #0d0c0a;
  position: relative;
  padding: 56px var(--goa-pad);
  overflow: hidden;
}

.goa-lineup-teaser::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 140% 90% at 30% 50%, rgba(45,28,5,.22) 0%, transparent 65%),
    url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.07'/%3E%3C/svg%3E");
  background-size: cover, 256px 256px;
  z-index: 0;
  pointer-events: none;
}

.goa-lineup-teaser::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 520' preserveAspectRatio='xMidYMid slice'%3E%3Ctext x='480' y='38' fill='%23f4cf32' font-size='28' font-family='sans-serif'%3E%E2%98%85%3C/text%3E%3Ctext x='12' y='55' fill='%23f4cf32' font-size='14' font-family='sans-serif'%3E%E2%98%85%3C/text%3E%3Ctext x='455' y='78' fill='%23f13a91' font-size='24' font-family='sans-serif'%3E%E2%9A%A1%3C/text%3E%3Ctext x='490' y='165' fill='%23f13a91' font-size='18' font-family='sans-serif'%3E%E2%9A%A1%3C/text%3E%3Ctext x='18' y='220' fill='%23f4cf32' font-size='20' font-family='sans-serif'%3E%E2%98%85%3C/text%3E%3Ctext x='470' y='280' fill='%23f4cf32' font-size='16' font-family='sans-serif'%3E%E2%98%85%3C/text%3E%3Ctext x='10' y='340' fill='%23f13a91' font-size='16' font-family='sans-serif'%3E%E2%9A%A1%3C/text%3E%3Ctext x='430' y='420' fill='%23f13a91' font-size='20' font-family='sans-serif'%3E%E2%9A%A1%3C/text%3E%3Ctext x='55' y='490' fill='%23f4cf32' font-size='13' font-family='sans-serif'%3E%E2%98%85%3C/text%3E%3Ctext x='310' y='505' fill='%23f4cf32' font-size='11' font-family='sans-serif'%3E%E2%98%85%3C/text%3E%3Ctext x='485' y='490' fill='%23f13a91' font-size='14' font-family='sans-serif'%3E%E2%9A%A1%3C/text%3E%3C/svg%3E");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 3;
}

.goa-lineup-teaser .sppb-row-container { position: relative; z-index: 2; }

.goa-lineup-teaser .sppb-col-md-6:first-child {
  flex: 0 0 42%;
  max-width: 42%;
  width: 42%;
}
.goa-lineup-teaser .sppb-col-md-6:last-child {
  flex: 0 0 55%;
  max-width: 55%;
  width: 55%;
}

/* BANDNAMEN: Staatliches */
.goa-lineup-teaser .sppb-addon-header.goa-title-hero .sppb-addon-title {
  font-family: 'Staatliches', Impact, sans-serif;
  font-size: clamp(3.2rem, 6.5vw, 5.5rem);
  line-height: .88;
  letter-spacing: .06em;
  text-shadow: none;
  color: #fff;
  text-transform: uppercase;
  margin: 0;
}

.goa-lineup-teaser .sppb-addon-text-block p {
  font-family: var(--goa-font-poster);
  font-size: .9rem;
  color: rgba(241,234,217,.5);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin: 10px 0 0;
  line-height: 1.4;
}

/* CTA knop — box-shadow needs !important: template uses box-shadow: none !important on .sppb-btn */
.goa-lineup-teaser .addon-root-button .sppb-btn {
  background: var(--goa-yellow);
  color: #111;
  font-family: 'Staatliches', 'Bangers', sans-serif;
  font-size: 1.55rem;
  letter-spacing: .05em;
  padding: 6px 24px;
  border: 2.5px solid #111;
  border-radius: 0;
  transform: rotate(-1.5deg);
  display: inline-block;
  box-shadow: 3px 3px 0 rgba(0,0,0,.4) !important;
  margin-top: 20px;
  text-decoration: none;
}
.goa-lineup-teaser .addon-root-button .sppb-btn:hover {
  background: #d4b020;
  transform: rotate(-1.5deg) translateY(-2px);
}

@media (max-width: 850px) {
  .goa-lineup-teaser .sppb-addon-header.goa-title-hero h2.sppb-addon-title {
    font-size: clamp(2.5rem, 10vw, 3.5rem);
  }
}

/* =====================================================
   27. LINEUP PAGE — TAB NAV
   ===================================================== */

.goa-lineup-tabs-row { background: #111111; border-bottom: 2px solid rgba(255,255,255,.1); }

.goa-lineup-tabs {
  display: flex;
  justify-content: center;
  gap: 0;
  list-style: none;
  margin: 0; padding: 0;
}

.goa-lineup-tab {
  display: block;
  font-family: var(--goa-font-poster);
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(241,234,217,.6);
  text-decoration: none;
  padding: 18px 36px;
  border-bottom: 3px solid transparent;
  transition: color .2s, border-color .2s;
}

.goa-lineup-tab:hover {
  color: var(--goa-yellow);
  border-bottom-color: var(--goa-yellow);
  text-decoration: none;
}

/* =====================================================
   28. LINEUP PAGE — HEADLINER CARDS
   ===================================================== */

.goa-headliner-card {
  overflow: hidden;
  box-shadow: 8px 8px 0 rgba(0,0,0,.12);
  background: #fffbf0;
}

.goa-headliner-card .sppb-addon-single-image-container img {
  width: 100%;
  height: 440px;
  object-fit: cover;
  object-position: top center;
  display: block;
}

.goa-headliner-card .addon-root-image {
  line-height: 0;
  margin: 0;
}

.goa-headliner-card .addon-root-heading,
.goa-headliner-card .addon-root-text-block,
.goa-headliner-card .addon-root-button {
  padding: 0 24px;
}

.goa-headliner-name .sppb-addon-title {
  font-family: var(--goa-font-brush);
  font-size: clamp(2.2rem, 4.5vw, 3.5rem);
  line-height: .88;
  text-transform: uppercase;
  color: var(--goa-ink);
  margin: 20px 0 8px;
  text-shadow: none;
}

.goa-genre-badge .sppb-addon-title {
  display: inline-block;
  background: var(--goa-pink);
  color: #111;
  padding: 5px 16px;
  font-family: var(--goa-font-poster);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  transform: rotate(-1.5deg);
  margin-bottom: 16px;
  box-shadow: 2px 2px 0 rgba(0,0,0,.2);
  font-style: normal;
}

.goa-band-link, .goa-band-link:visited {
  color: inherit;
  text-decoration: none;
}
.goa-band-link:hover { text-decoration: underline; text-underline-offset: .1em; }

/* SPPB 6.6 does not set inline styles on custom buttons — body.site (0,2,1) beats Luxyort body .sppb-btn (0,1,1) */
body.site .goa-btn--spotify.sppb-btn {
  background: #1DB954;
  color: #fff;
  border-color: #1DB954;
  transition: transform .2s, box-shadow .2s;
}
body.site .goa-btn--spotify.sppb-btn:hover {
  background: #17a849;
  border-color: #17a849;
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(29,185,84,.4);
}

/* =====================================================
   29. LINEUP PAGE — AND MORE...
   ===================================================== */

.goa-and-more { text-align: center; }

.goa-and-more .sppb-addon-title {
  font-family: var(--goa-font-hand);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  color: var(--goa-ink);
  text-transform: none;
  letter-spacing: .04em;
  font-style: italic;
  text-shadow: none;
}

/* =====================================================
   30. LINEUP PAGE — BAND CARDS
   ===================================================== */

.goa-band-card {
  overflow: hidden;
  transition: transform .2s;
  background: #1a1a1a;
}

.goa-band-card:hover { transform: translateY(-4px); }

.goa-band-card .sppb-addon-single-image-container img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform .3s;
}

.goa-band-card:hover .sppb-addon-single-image-container img { transform: scale(1.04); }

.goa-band-name .sppb-addon-title {
  font-family: var(--goa-font-poster);
  font-size: 1.3rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--goa-yellow);
  margin: 10px 8px 8px;
  text-shadow: none;
  line-height: 1.1;
}

.goa-band-genre .sppb-addon-title {
  font-family: var(--goa-font-body);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--goa-muted);
  margin: 0 8px 12px;
  text-shadow: none;
}

/* =====================================================
   31. LINEUP PAGE — PINK / SPOTIFY BUTTONS
   ===================================================== */

body.site .goa-btn--pink.sppb-btn {
  background: var(--goa-pink);
  color: #fff;
  border-color: var(--goa-pink);
  transition: transform .2s, box-shadow .2s;
}
body.site .goa-btn--pink.sppb-btn:hover {
  background: #d42a7e;
  border-color: #d42a7e;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(241,58,145,.35);
}

/* =====================================================
   32. LINEUP PAGE — SPOTIFY PLAYER MOCKUP
   ===================================================== */

.goa-spotify-col { padding-left: 32px; }

.goa-spotify-player {
  background: #fffbf0;
  border: 2px solid rgba(0,0,0,.1);
  padding: 24px;
  box-shadow: 4px 4px 0 rgba(0,0,0,.1);
  margin-top: 8px;
}

.goa-spotify-title {
  display: block;
  font-family: var(--goa-font-poster);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #1DB954;
  margin-bottom: 16px;
}

.goa-spotify-tracks {
  list-style: none;
  padding: 0; margin: 0;
}

.goa-spotify-track {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
  font-family: var(--goa-font-body);
  font-size: .88rem;
}

.goa-spotify-track:last-child { border-bottom: none; }

.goa-track-name { color: var(--goa-ink); }
.goa-track-dur  { color: rgba(20,20,20,.45); font-variant-numeric: tabular-nums; white-space: nowrap; margin-left: 16px; }

/* paper-section * { color: goa-ink } overrides .goa-track-dur — restore muted tone */
.goa-paper-section .goa-track-dur { color: rgba(20,20,20,.45); }

/* =====================================================
   33. LINEUP PAGE — USP CARDS
   ===================================================== */

.goa-usp-card { text-align: center; padding: 0 8px; }

.goa-usp-card .sppb-addon-single-image-container {
  display: inline-block;
  background: var(--goa-yellow);
  padding: 12px;
  transform: rotate(-4deg);
  margin-bottom: 18px;
  box-shadow: 3px 3px 0 rgba(0,0,0,.2);
  width: 64px; height: 64px;
}

.goa-usp-card .sppb-addon-single-image-container img {
  width: 40px; height: 40px;
  display: block;
  filter: invert(1);
}

.goa-usp-title .sppb-addon-title,
.goa-usp-card .sppb-addon-header .sppb-addon-title {
  font-family: var(--goa-font-poster);
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--goa-yellow);
  margin: 0 0 8px;
  text-shadow: none;
}

.goa-usp-card .sppb-addon-text-block p { color: rgba(241,234,217,.7); font-size: .9rem; margin: 0; }

/* =====================================================
   34. LINEUP PAGE — INFO STRIP
   ===================================================== */

.goa-lineup-info-strip { border-top: 1px solid rgba(255,255,255,.08); }

.goa-lineup-info-item { text-align: center; }

.goa-lineup-info-item .sppb-addon-single-image-container {
  display: inline-block;
  margin-bottom: 8px;
}

.goa-lineup-info-item .sppb-addon-single-image-container img {
  width: 36px; height: 36px;
  filter: invert(1) opacity(.7);
  display: block;
}

.goa-info-label .sppb-addon-title,
.goa-lineup-info-item .sppb-addon-header .sppb-addon-title {
  font-family: var(--goa-font-poster);
  font-size: 1rem;
  text-transform: uppercase;
  color: var(--goa-yellow);
  margin: 0 0 4px;
  letter-spacing: .04em;
  text-shadow: none;
}

.goa-lineup-info-item .sppb-addon-text-block p { font-size: .85rem; color: var(--goa-muted); margin: 0; }

/* Yellow primary button (CTA "Tickets Kopen") */
body.site .goa-btn--yellow.sppb-btn {
  background: var(--goa-yellow);
  color: #111;
  border-color: var(--goa-yellow);
  transition: transform .15s, box-shadow .15s;
}
body.site .goa-btn--yellow.sppb-btn:hover {
  background: #d4b020;
  border-color: #d4b020;
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(244,207,50,.35);
}

/* Hero kleine link ("Luister alvast") */
.goa-hero-link-small { display: inline-block; }
.goa-hero-link-small a,
.goa-hero-link-small {
  color: rgba(255,255,255,.75);
  font-family: var(--goa-font-poster);
  font-size: 1.1rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  text-decoration: none;
}
.goa-hero-link-small a:hover { color: var(--goa-yellow); }

/* Spotify logo image addon */
.goa-spotify-logo .sppb-addon-single-image-container { display: inline-block; }
.goa-spotify-logo img { height: 30px; width: auto; display: block; margin: 0 0 16px; }

/* CTA subtitle */
.goa-cta-sub { color: rgba(241,234,217,.85); font-size: 1.1rem; margin-bottom: 0; }

/* =====================================================
   35. LINEUP PAGE — RESPONSIVE
   ===================================================== */

@media (max-width: 850px) {
  .goa-lineup-tabs-row { position: static; }
  .goa-lineup-tab { padding: 14px 16px; font-size: 1rem; }

  .goa-headliner-card .sppb-addon-single-image-container img { height: 280px; }

  .goa-band-card .sppb-addon-single-image-container img { height: 160px; }

  .goa-spotify-col { padding-left: 0; margin-top: 32px; }
}

/* =====================================================
   36. LINEUP PAGE — HERO BLIKSEM + PAINT STREEP
   ===================================================== */

/* Bliksem-kolom — bolt gecentreerd binnen eigen 3-col rechterkolom */
body.site .goa-hero-bolt-col {
  display: flex;
  align-items: center;
  justify-content: center;
}
body.site .goa-hero-bolt-img .sppb-addon-single-image-container { display: block; }
body.site .goa-hero-bolt-img img {
  width: 90px !important;
  height: auto !important;
  max-width: none !important;
  display: block;
  transform: rotate(-14deg);
  filter: drop-shadow(4px 6px 5px rgba(0,0,0,.75));
}
@media (max-width: 767px) {
  body.site .goa-hero-bolt-col { display: none; }
}

/* Verf-streep — SVG 400×36 viewBox; breder en zichtbaarder */
body.site .goa-hero-paint-stroke { display: block; margin: -2px 0 18px; }
body.site .goa-hero-paint-stroke .sppb-addon-single-image-container { display: block; }
body.site .goa-hero-paint-stroke img {
  width: 100% !important;
  max-width: 420px !important;
  height: auto !important;
  display: block;
}

/* =====================================================
   37. PROGRAMMA PAGE
   ===================================================== */

/* ── Hero ── */
.goa-prog-hero .sppb-col-md-12 { text-align: center; }

.goa-prog-crown .sppb-addon-single-image-container { display: inline-block; }
body.site .goa-prog-crown img {
  width: 80px;
  height: auto;
  display: block;
  margin: 0 auto 8px;
}

.goa-prog-title h1,
.goa-prog-title .sppb-addon-title {
  font-family: var(--goa-font-brush);
  font-size: clamp(3rem, 8vw, 6.4rem);
  font-weight: 500;
  letter-spacing: .01em;
  line-height: 1;
  margin: 0;
  text-transform: uppercase;
  /* Glassmorphism: donker glas in de letters — identiek aan homepage hero */
  background: linear-gradient(
    148deg,
    rgba(90,  130, 170, 0.55) 0%,
    rgba(8,   18,   38, 0.92) 8%,
    rgba(12,  25,   52, 0.90) 25%,
    rgba(32,  60,   95, 0.76) 38%,
    rgba(5,   14,   30, 0.94) 52%,
    rgba(8,   18,   38, 0.91) 68%,
    rgba(28,  55,   88, 0.79) 80%,
    rgba(85, 125,  165, 0.52) 90%,
    rgba(6,   15,   32, 0.90) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  -webkit-text-stroke: 1.8px rgba(255, 255, 255, 0.88);
  filter: drop-shadow(3px 4px 0 rgba(0, 5, 20, 0.80));
}

.goa-prog-underline .sppb-addon-single-image-container { display: inline-block; }
body.site .goa-prog-underline img {
  width: 340px;
  height: auto;
  display: block;
  margin: 8px auto 0;
}

/* ── Datum badge ── */
.goa-program-date-badge div,
.goa-program-date-badge h1,
.goa-program-date-badge h2 {
  display: inline-block;
  background: url('/images/goa/programma/goa-tab-active-pink.png') center center / 100% 100% no-repeat;
  padding: 10px 32px;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.goa-prog-date-row .sppb-col-md-12 { text-align: center; }

/* ── Timetable — structuur ── */
.goa-timetable-header-row .sppb-row,
.goa-slot-row .sppb-row { display: flex; align-items: stretch; flex-wrap: nowrap; }

/* Tijdkolom */
.goa-time-col { display: flex; flex-direction: column; align-items: center; justify-content: flex-start; min-width: 0; }
.goa-time-label { margin: 0; text-align: center; }
/* Tijdlabel addon — zelfde hoogte als band slot voor uitlijning */
.sppb-addon.goa-time-label {
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
/* SPPB empty_space rendert met height:0 — forceer via CSS de spacer hoogte gelijk aan stage header */
.goa-time-col .sppb-column-addons > .sppb-addon-wrapper.addon-root-empty-space {
  min-height: 86px;
}

/* Podium kolommen — centreer de addons-container horizontaal */
.goa-stage-col { min-width: 0; }
.goa-stage-col--main,
.goa-stage-col--second {
  background: none;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
/* Addons-container krimpt naar de breedste inhoud; alle addons worden even breed */
.goa-stage-col--main .sppb-column-addons,
.goa-stage-col--second .sppb-column-addons {
  width: max-content;
}

/* Stage headers — PNG op addon-niveau, min-height = PNG hoogte (86px) */
.sppb-addon.goa-stage-label--main {
  background: url('/images/goa/programma/goa-stage-header-pink.png') center center / 100% 100% no-repeat;
  min-height: 86px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sppb-addon.goa-stage-label--second {
  background: url('/images/goa/programma/goa-stage-header-teal.png') center center / 100% 100% no-repeat;
  min-height: 86px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.goa-stage-label div,
.goa-stage-label h2,
.goa-stage-label h3,
.goa-stage-label h4,
.goa-stage-label h5,
.goa-stage-label h6,
.goa-stage-label .sppb-addon-title {
  font-family: Bangers, Staatliches, "Arial Narrow", Impact, sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-align: center;
  margin: 0;
  padding: 8px 20px;
}

/* Stage header kleur-overrides */
.goa-stage-label--main div,
.goa-stage-label--main h2 { color: #111111; }
.goa-stage-label--second div,
.goa-stage-label--second h2 { color: #ffffff; }

/* ── Slot cellen — backgrounds op addon-niveau ── */
.sppb-addon.goa-slot-beige,
.sppb-addon.goa-slot-yellow,
.sppb-addon.goa-slot-pink,
.sppb-addon.goa-slot-green,
.sppb-addon.goa-slot-teal {
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center center;
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sppb-addon.goa-slot-beige  { background-image: url('/images/goa/programma/goa-slot-paper-beige.png'); }
.sppb-addon.goa-slot-yellow { background-image: url('/images/goa/programma/goa-slot-paper-yellow.png'); }
.sppb-addon.goa-slot-pink   { background-image: url('/images/goa/programma/goa-slot-paper-pink.png'); }
.sppb-addon.goa-slot-green  { background-image: url('/images/goa/programma/goa-slot-paper-green.png'); }
.sppb-addon.goa-slot-teal   { background-image: url('/images/goa/programma/goa-slot-paper-teal.png'); }

/* Tekst in slotcel — Bangers font, zelfde als menu */
.sppb-addon.goa-slot-band div {
  font-family: Bangers, Staatliches, "Arial Narrow", Impact, sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #111111;
  margin: 0;
  padding: 8px 20px;
  text-align: center;
  line-height: 1;
}
/* Teal slots hebben lichte tekst */
.sppb-addon.goa-slot-teal div { color: #ffffff; }

/* Tijdlabel — Bangers font, zelfde stijl als bandnamen */
.goa-time-label div,
.goa-time-label .sppb-addon-title {
  font-family: Bangers, Staatliches, "Arial Narrow", Impact, sans-serif;
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #111111;
  margin: 0;
  text-align: center;
  padding: 4px 12px;
}

/* Linker tijdkolom (bij Hoofdpodium): geel/roze afwisselend */
.goa-time-col:not(.goa-time-col--right) .sppb-column-addons > .sppb-addon-wrapper:nth-child(even) .sppb-addon.goa-time-label {
  background: url('/images/goa/programma/goa-slot-paper-yellow.png') center / 100% 100% no-repeat;
}
.goa-time-col:not(.goa-time-col--right) .sppb-column-addons > .sppb-addon-wrapper:nth-child(odd) .sppb-addon.goa-time-label {
  background: url('/images/goa/programma/goa-slot-paper-pink.png') center / 100% 100% no-repeat;
}

/* Rechter tijdkolom (bij Tweede Podium): teal/groen afwisselend */
.goa-time-col--right .sppb-column-addons > .sppb-addon-wrapper:nth-child(even) .sppb-addon.goa-time-label {
  background: url('/images/goa/programma/goa-slot-paper-teal.png') center / 100% 100% no-repeat;
}
.goa-time-col--right .sppb-column-addons > .sppb-addon-wrapper:nth-child(odd) .sppb-addon.goa-time-label {
  background: url('/images/goa/programma/goa-slot-paper-green.png') center / 100% 100% no-repeat;
}
/* Teal achtergrond vereist witte tekst */
.goa-time-col--right .sppb-column-addons > .sppb-addon-wrapper:nth-child(even) .sppb-addon.goa-time-label div,
.goa-time-col--right .sppb-column-addons > .sppb-addon-wrapper:nth-child(even) .sppb-addon.goa-time-label .sppb-addon-title {
  color: #ffffff;
}

/* Alternerende rijen minimale scheiding */
.goa-slot-row { border-top: 2px solid #222; }

/* ── Notitie — note paper PNG als background achter de tekst ── */
.goa-prog-note-row .sppb-col-md-12 { text-align: left; }
.goa-note-paper span {
  display: inline-block;
  background: url('/images/goa/programma/goa-note-paper-small.png') center center / 100% 100% no-repeat;
  padding: 12px 12px;
  font-size: .85rem;
  font-weight: 700;
  color: #3a2a1a;
  letter-spacing: .06em;
  text-transform: uppercase;
  line-height: 1;
}

/* ── Decoratie ── */
body.site .goa-program-collage img { width: 100%; height: auto; display: block; border-radius: 4px; }
body.site .goa-program-sticker img {
  width: 100px;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* ── Tickets button ── */
body.site .goa-btn--tickets.sppb-btn {
  background: var(--goa-yellow);
  color: #111;
  border-color: var(--goa-yellow);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: transform .15s, box-shadow .15s;
}
body.site .goa-btn--tickets.sppb-btn:hover {
  background: #d4b020;
  border-color: #d4b020;
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}

/* ── CTA ── */
.goa-prog-cta-title h2 {
  font-family: var(--goa-font-display, 'Permanent Marker', cursive);
  font-size: clamp(1.8rem, 4vw, 3rem);
  text-align: center;
  letter-spacing: .02em;
  margin: 0 0 12px;
}
.goa-prog-cta-sub p {
  color: #cccccc;
  text-align: center;
  font-size: 1rem;
  margin: 0;
}
.goa-program-cta .sppb-col-md-12 { text-align: center; }

/* ── Footer info strip ── */
.goa-footer-info-item { text-align: center; }
.goa-footer-info-icon img { width: 40px; height: 40px; margin-bottom: 8px; }
.goa-footer-info-label h4 {
  font-size: .75rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #ffffff;
  opacity: .65;
  margin: 0 0 4px;
}
.goa-footer-info-val p {
  font-size: .95rem;
  font-weight: 600;
  color: #ffffff;
  margin: 0;
}

/* ── Responsive ── */
@media (max-width: 767px) {
  .goa-prog-title h1,
  .goa-prog-title .sppb-addon-title { font-size: 2.6rem; }

  /* Op mobiel: timetable kolommen stack — tijd boven slot */
  .goa-timetable-header-row .sppb-row,
  .goa-slot-row .sppb-row { flex-wrap: wrap; }

  /* Tijdkolom volledig breed op mobiel */
  .goa-time-col { width: 100%; min-width: 100%; }
  .goa-time-label { text-align: left; padding: 4px 8px; }

  /* Podiumkolommen naast elkaar op mobiel (elk 50%) */
  .goa-stage-col { width: 50%; min-width: 50%; }

  .goa-program-sticker { display: none; }
}

/* %%GOA-STYLES-END%% */
