/* ============================================================
   GOODLAND 2026 — Oldies festival pre celú rodinu
   Warm sunset + wine anchor. Bricolage Grotesque / Hanken Grotesk / Instrument Serif
   ============================================================ */

:root{
  /* Surfaces */
  --cream:      #FBF4E9;
  --cream-2:    #F5E7D5;
  --surface:    #FFFCF6;
  --surface-2:  #FBF2E4;

  /* Ink */
  --ink:        #2A1712;
  --ink-soft:   #6E564A;
  --ink-faint:  #9C8475;
  --line:       #E7D8C3;

  /* Sunset spectrum */
  --plum:       #3A1530;
  --wine:       #7A1228;
  --wine-deep:  #500C1C;
  --coral:      #E15B36;
  --amber:      #F0993A;
  --gold:       #F6BC54;
  --sun:        #FFD27A;

  /* Roles */
  --accent:     var(--wine);
  --accent-2:   var(--coral);

  /* Pixmark brand gradient (cyan → purple → coral) */
  --grad-pixmark: linear-gradient(90deg, #12c2e9, #c471ed, #f64f59);

  /* Radii */
  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;
  --r-xl: 34px;
  --pill: 999px;

  /* Shadows (warm tinted) */
  --sh-1: 0 1px 2px rgba(74,20,20,.06), 0 2px 8px rgba(74,20,20,.05);
  --sh-2: 0 4px 14px rgba(74,20,20,.08), 0 14px 34px rgba(74,20,20,.10);
  --sh-3: 0 10px 30px rgba(74,20,20,.14), 0 30px 70px rgba(58,12,22,.18);
  --sh-glow: 0 10px 40px rgba(225,91,54,.30);

  /* Layout */
  --maxw: 1140px;
  --gut: clamp(20px, 5vw, 56px);

  --ff-display: "Bricolage Grotesque", system-ui, sans-serif;
  --ff-body: "Hanken Grotesk", system-ui, sans-serif;
  --ff-serif: "Instrument Serif", Georgia, serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--ff-body);
  background:var(--cream);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; border:none; background:none; }
h1,h2,h3,h4{ margin:0; font-family:var(--ff-display); font-weight:800; line-height:1.02; letter-spacing:-.02em; }
p{ margin:0; }
::selection{ background:var(--coral); color:#fff; }

/* ---------- Helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px, 10vw, 128px); position:relative; }
.eyebrow{
  font-family:var(--ff-serif);
  font-style:italic;
  font-size:clamp(20px,2.4vw,28px);
  color:var(--coral);
  line-height:1;
  margin:0 0 14px;
}
.kicker{
  display:inline-flex; align-items:center; gap:9px;
  font-size:12.5px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--wine);
}
.kicker::before{ content:""; width:26px; height:2px; background:var(--coral); border-radius:2px; }
.h-sec{ font-size:clamp(34px, 6vw, 64px); }
.lead{ font-size:clamp(17px,2.1vw,20px); color:var(--ink-soft); max-width:54ch; }
.center{ text-align:center; }
.center .lead{ margin-inline:auto; }
.center .kicker{ justify-content:center; }

/* reveal */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }
.reveal.d4{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-weight:700; font-size:16px; letter-spacing:.01em;
  padding:15px 26px; border-radius:var(--pill);
  transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s, background .25s, color .2s;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--wine); color:#fff; box-shadow:0 8px 22px rgba(122,18,40,.30); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(122,18,40,.42); background:#8c1730; }
.btn-sun{ background:linear-gradient(180deg,var(--gold),var(--amber)); color:var(--wine-deep); box-shadow:var(--sh-glow); }
.btn-sun:hover{ transform:translateY(-2px); box-shadow:0 14px 44px rgba(225,91,54,.42); }
.btn-ghost{ background:rgba(255,255,255,.14); color:#fff; backdrop-filter:blur(8px); border:1.5px solid rgba(255,255,255,.5); }
.btn-ghost:hover{ background:rgba(255,255,255,.24); transform:translateY(-2px); }
.btn-outline{ background:transparent; color:var(--wine); border:1.5px solid var(--line); }
.btn-outline:hover{ border-color:var(--wine); transform:translateY(-2px); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .35s, box-shadow .35s, backdrop-filter .35s, padding .35s;
  padding-block:18px;
}
.site-header.scrolled{
  background:rgba(251,244,233,.82);
  backdrop-filter:saturate(1.4) blur(14px);
  box-shadow:0 1px 0 var(--line), 0 8px 24px rgba(74,20,20,.06);
  padding-block:11px;
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--ff-display); font-weight:800; font-size:21px; letter-spacing:-.02em; color:#fff; transition:color .35s; }
.scrolled .brand{ color:var(--wine); }
.brand .mark{
  width:34px; height:34px; border-radius:50%; flex:none;
  background:radial-gradient(circle at 50% 120%, var(--sun), var(--coral) 55%, var(--wine) 100%);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.35);
}
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ font-size:15px; font-weight:600; color:rgba(255,255,255,.92); transition:color .2s, opacity .2s; }
.nav-links a:hover{ opacity:.7; }
.scrolled .nav-links a{ color:var(--ink-soft); }
.scrolled .nav-links a:hover{ color:var(--wine); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav .btn{ padding:11px 20px; font-size:14.5px; }
.scrolled .nav .btn-ghost{ background:var(--wine); color:#fff; border-color:transparent; }
@media (max-width: 860px){ .nav-links{ display:none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; flex-direction:column;
  justify-content:flex-end; overflow:hidden; isolation:isolate;
  padding-top:120px;
}
.hero-sky{
  position:absolute; inset:0; z-index:-3;
  background:
    radial-gradient(120% 80% at 78% 8%, rgba(255,210,122,.0) 40%, transparent 70%),
    linear-gradient(178deg,
      var(--plum) 0%,
      var(--wine) 26%,
      #b23320 52%,
      var(--coral) 68%,
      var(--amber) 84%,
      var(--gold) 100%);
}
/* sun */
.hero-sun{
  position:absolute; z-index:-2; right:8%; top:14%;
  width:min(46vw,440px); aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, #FFE9B8 0%, var(--sun) 38%, rgba(246,188,84,.5) 60%, transparent 72%);
  filter:blur(2px);
  animation:sun-rise 14s ease-in-out infinite alternate;
}
@keyframes sun-rise{ from{ transform:translateY(0); } to{ transform:translateY(-22px); } }
.hero-haze{
  position:absolute; z-index:-2; inset:auto 0 0 0; height:42%;
  background:linear-gradient(180deg, transparent, rgba(252,200,101,.55));
}
/* film grain + soft vignette for premium depth */
.hero-grain{
  position:absolute; inset:0; z-index:-1; pointer-events:none; opacity:.5; mix-blend-mode:overlay;
  background:radial-gradient(140% 100% at 50% 100%, transparent 55%, rgba(58,12,22,.55) 100%);
}
/* DJ Kukoo cutout — stands at the right edge of the hero */
.hero-figure{
  position:absolute; z-index:3; right:clamp(-40px, 1vw, 40px); bottom:clamp(80px, 12vh, 160px);
  height:min(72vh, 680px); width:auto; pointer-events:none;
  filter:drop-shadow(0 24px 40px rgba(58,12,22,.45));
  animation:kuko-in 1.1s cubic-bezier(.22,1,.36,1) .15s both;
}
@keyframes kuko-in{ from{ opacity:0; transform:translateY(40px) rotate(-2deg); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .hero-figure{ animation:none; } }
/* The cutout is a wide-desktop flourish — it needs horizontal room beside the
   text, so it only shows above 1024px. Tablets/phones get a clean text hero. */
@media (max-width: 1024px){ .hero-figure{ display:none; } }
.hero-inner{ position:relative; z-index:2; padding-bottom:clamp(40px,7vw,84px); color:#fff; }
.hero-tag{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-serif); font-style:italic; font-size:clamp(19px,2.6vw,26px);
  color:#FFE3B0; margin-bottom:18px;
}
.hero-tag::before,.hero-tag::after{ content:""; width:28px; height:1.5px; background:rgba(255,227,176,.6); }
.hero-title{
  font-size:clamp(68px, 14vw, 188px);
  line-height:.84; letter-spacing:-.04em; color:#fff;
  text-shadow:0 4px 40px rgba(58,12,22,.4);
  margin-bottom:4px;
}
.hero-title .yr{
  display:block;
  font-family:var(--ff-serif); font-style:italic; font-weight:400;
  font-size:clamp(30px,7vw,86px); letter-spacing:-.01em; color:#FFE3B0;
  line-height:1; margin-top:6px;
}
.hero-feeling{
  font-family:var(--ff-serif); font-style:italic;
  font-size:clamp(26px,4.5vw,52px); line-height:1.05; color:#FFE8C4;
  margin-top:16px; text-wrap:balance;
}
.hero-when{ margin-top:30px; }
.hero-date{
  font-family:var(--ff-display); font-weight:800; letter-spacing:-.02em;
  font-size:clamp(40px,7vw,76px); line-height:.95; color:#fff;
  text-shadow:0 4px 30px rgba(58,12,22,.35);
}
.hero-sub-row{
  display:flex; flex-wrap:wrap; align-items:center; gap:12px 16px; margin-top:18px;
}
.hero-free{
  display:inline-flex; align-items:center; gap:8px;
  background:#FFFCF6; color:var(--wine);
  font-weight:800; letter-spacing:.02em; font-size:15px;
  padding:8px 16px; border-radius:var(--pill);
  box-shadow:0 8px 22px rgba(58,12,22,.25);
}
.hero-free::before{ content:""; width:9px; height:9px; border-radius:50%; background:var(--coral); }
.hero-place{ font-size:clamp(15px,1.9vw,18px); font-weight:600; color:rgba(255,255,255,.9); }
.hero-cd{
  display:flex; align-items:flex-end; gap:18px; margin-top:26px;
}
.hero-cd .u{ display:flex; flex-direction:column; align-items:flex-start; line-height:1; }
.hero-cd .u b{
  font-family:var(--ff-display); font-weight:800; font-size:clamp(24px,3.4vw,32px);
  color:#fff; font-variant-numeric:tabular-nums; letter-spacing:-.01em;
}
.hero-cd .u span{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.62); margin-top:6px; }
.hero-cd .u + .u{ position:relative; padding-left:18px; }
.hero-cd .u + .u::before{ content:":"; position:absolute; left:-2px; top:0; font-family:var(--ff-display); font-weight:800; font-size:clamp(24px,3.4vw,32px); color:rgba(255,255,255,.3); }
.hero-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin-top:30px; }

/* countdown */
.countdown{
  display:flex; gap:10px; margin-top:34px; flex-wrap:wrap;
}
.cd-unit{
  background:rgba(255,255,255,.12); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.28); border-radius:var(--r);
  padding:14px 6px 10px; min-width:78px; text-align:center;
}
.cd-num{ font-family:var(--ff-display); font-weight:800; font-size:clamp(28px,4.4vw,40px); line-height:1; color:#fff; font-variant-numeric:tabular-nums; }
.cd-lbl{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.75); margin-top:7px; }
.hero-scroll{
  position:absolute; left:50%; bottom:20px; transform:translateX(-50%); z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:7px;
  font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.7);
}
.hero-scroll .line{ width:1.5px; height:34px; background:linear-gradient(rgba(255,255,255,.7),transparent); animation:scrolldn 1.8s ease-in-out infinite; }
@keyframes scrolldn{ 0%,100%{ transform:scaleY(.5); transform-origin:top; opacity:.4;} 50%{ transform:scaleY(1); opacity:1; } }

/* hero — tablet & down: drop the forced full height so there's no empty sky,
   and remove the scroll hint that would collide with the bottom content */
@media (max-width: 1024px){
  .hero{ min-height:auto; padding-top:clamp(96px,13vw,128px); padding-bottom:clamp(44px,7vw,68px); }
  .hero-scroll{ display:none; }
}
/* phones: full-width stacked CTAs */
@media (max-width: 720px){
  .hero{ padding-top:96px; }
  .hero-actions{ width:100%; gap:12px; }
  .hero-actions .btn{ flex:1 1 100%; }
}

/* ============================================================
   HIGHLIGHTS
   ============================================================ */
.highlights{ background:var(--surface); position:relative; z-index:2; border-radius:var(--r-xl) var(--r-xl) 0 0; margin-top:-32px; padding-top:clamp(56px,8vw,96px); }
.hl-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:46px; }
.hl-card{
  background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:26px 20px; transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s, background .3s;
}
.hl-card:hover{ transform:translateY(-6px); box-shadow:var(--sh-2); background:var(--surface); }
.hl-ic{
  width:50px; height:50px; border-radius:14px; display:grid; place-items:center; margin-bottom:18px;
  background:linear-gradient(150deg, var(--cream), #fff); border:1px solid var(--line);
  color:var(--wine);
}
.hl-ic svg{ width:25px; height:25px; }
.hl-card h3{ font-size:18px; letter-spacing:-.01em; margin-bottom:6px; }
.hl-card p{ font-size:14px; color:var(--ink-soft); line-height:1.5; }
@media (max-width: 900px){ .hl-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width: 460px){ .hl-grid{ grid-template-columns:1fr 1fr; gap:11px; } .hl-card{ padding:20px 16px; } }

/* ============================================================
   PROGRAM TIMELINE
   ============================================================ */
.program{ background:var(--surface); }
.tl{ margin-top:50px; position:relative; max-width:680px; margin-inline:auto; padding-left:38px; }
.tl::before{
  content:""; position:absolute; left:7px; top:16px; bottom:16px; width:2px;
  background:linear-gradient(var(--coral),var(--gold)); border-radius:2px;
}
.tl-item{ position:relative; padding-block:9px; }
.tl-card{
  position:relative; background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:20px 24px; transition:transform .3s, box-shadow .3s;
}
.tl-card:hover{ transform:translateX(5px); box-shadow:var(--sh-2); }
.tl-card::before{
  content:""; position:absolute; left:-38px; top:25px; width:14px; height:14px; border-radius:50%;
  background:var(--surface); border:3px solid var(--coral); box-shadow:0 0 0 4px var(--surface);
}
.tl-card.headliner{ background:linear-gradient(150deg,var(--wine),var(--wine-deep)); border-color:transparent; color:#fff; }
.tl-card.headliner::before{ border-color:var(--gold); background:var(--gold); }
.tl-card.headliner .tl-sub{ color:rgba(255,255,255,.78); }
.tl-card.headliner .tag{ background:rgba(255,255,255,.16); color:#FFE3B0; }
.tl-top{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:9px; }
.tl-when{
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--ff-display); font-weight:800; font-size:18px; letter-spacing:-.01em;
  color:var(--wine); font-variant-numeric:tabular-nums; line-height:1;
}
.tl-when .sep{ width:14px; height:2px; background:var(--coral); border-radius:2px; opacity:.7; }
.tl-card.headliner .tl-when{ color:var(--gold); }
.tl-card.headliner .tl-when .sep{ background:var(--sun); }
.tl-card h3{ font-size:21px; letter-spacing:-.01em; }
.tl-sub{ font-size:14.5px; color:var(--ink-soft); margin-top:5px; }
.tag{
  font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 10px; border-radius:var(--pill); background:var(--cream-2); color:var(--wine);
}
@media (max-width: 560px){
  .tl{ padding-left:30px; }
  .tl::before{ left:5px; }
  .tl-card::before{ left:-30px; top:23px; }
  .tl-card{ padding:18px 18px; }
  .tl-when{ font-size:16px; }
}

/* ============================================================
   PERFORMERS
   ============================================================ */
.performers{ background:var(--cream); }
.pf-grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:20px; margin-top:50px; }
.pf-card{
  position:relative; border-radius:var(--r-xl); overflow:hidden; background:var(--surface);
  border:1px solid var(--line); box-shadow:var(--sh-1);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
  display:flex; flex-direction:column;
}
.pf-card:hover{ transform:translateY(-6px); box-shadow:var(--sh-3); }
.pf-photo{ position:relative; width:100%; aspect-ratio:16/11; background:var(--cream-2); }
.pf-card.headliner{ grid-row:span 2; }
.pf-card.headliner .pf-photo{ aspect-ratio:auto; flex:1; min-height:300px; }
image-slot{ width:100%; height:100%; }
.pf-photo .badge{
  position:absolute; top:16px; left:16px; z-index:3;
  display:inline-flex; align-items:center; gap:7px;
  background:linear-gradient(180deg,var(--gold),var(--amber)); color:var(--wine-deep);
  font-weight:800; font-size:12px; letter-spacing:.06em; text-transform:uppercase;
  padding:7px 13px; border-radius:var(--pill); box-shadow:0 6px 16px rgba(225,91,54,.3);
}
.pf-body{ padding:22px 24px 26px; }
.pf-time{ font-size:13px; font-weight:700; color:var(--coral); letter-spacing:.04em; }
.pf-card h3{ font-size:clamp(22px,3vw,32px); margin:7px 0 4px; }
.pf-role{ font-family:var(--ff-serif); font-style:italic; font-size:17px; color:var(--ink-soft); }
.pf-note{ font-size:15px; color:var(--ink-soft); line-height:1.55; margin-top:14px; }
.pf-card.headliner .pf-body{ padding:28px 30px 32px; }
.pf-card.headliner .pf-note{ font-size:16.5px; }
@media (max-width: 820px){
  .pf-grid{ grid-template-columns:1fr; }
  .pf-card.headliner{ grid-row:auto; }
  /* portrait photos (Eva, Kukoo) open tall so faces aren't cropped */
  .pf-photo{ aspect-ratio:4/5; min-height:0; }
  .pf-card.headliner .pf-photo{ aspect-ratio:4/5; flex:none; }
  /* band photo is landscape — keep it wide */
  .pf-card--landscape .pf-photo{ aspect-ratio:16/11; }
}

/* ============================================================
   SPLIT (Family + Food share the band)
   ============================================================ */
.split{ background:var(--surface); }
.split-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:50px; }
.feature{
  border-radius:var(--r-xl); padding:40px; position:relative; overflow:hidden;
  border:1px solid var(--line); min-height:380px; display:flex; flex-direction:column;
}
.feature.family{ background:linear-gradient(160deg,#FFF3DE,#FBE3C3); }
.feature.food{ background:linear-gradient(160deg,#F7E5D9,#F2D2C1); }
.feature .f-ic{
  width:56px; height:56px; border-radius:16px; display:grid; place-items:center;
  background:var(--surface); color:var(--wine); box-shadow:var(--sh-1); margin-bottom:20px;
}
.feature .f-ic svg{ width:28px; height:28px; }
.feature h3{ font-size:clamp(26px,3.4vw,36px); margin-bottom:12px; }
.feature > p{ font-size:16px; color:var(--ink-soft); max-width:42ch; }
.chips{ display:flex; flex-wrap:wrap; gap:9px; margin-top:auto; padding-top:26px; }
.chip{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.7); border:1px solid rgba(122,18,40,.12); color:var(--ink);
  font-size:14px; font-weight:600; padding:9px 15px; border-radius:var(--pill);
}
.chip svg{ width:15px; height:15px; color:var(--coral); }
.feature .deco{ position:absolute; right:-40px; top:-40px; width:200px; height:200px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.5),transparent 70%); pointer-events:none; }
@media (max-width: 820px){ .split-grid{ grid-template-columns:1fr; } .feature{ min-height:0; padding:32px 28px; } }

/* ============================================================
   CHARITY
   ============================================================ */
.charity{ background:linear-gradient(165deg,var(--wine),var(--wine-deep)); color:#fff; position:relative; overflow:hidden; }
.charity::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(70% 60% at 85% 0%, rgba(246,188,84,.22), transparent 60%);
}
.charity .wrap{ position:relative; z-index:2; max-width:920px; text-align:center; }
.charity .heart{
  width:64px; height:64px; margin:0 auto 26px; border-radius:50%;
  background:linear-gradient(180deg,var(--gold),var(--coral)); display:grid; place-items:center;
  box-shadow:0 10px 30px rgba(225,91,54,.4);
}
.charity .heart svg{ width:32px; height:32px; color:#fff; }
.charity .kicker{ color:var(--gold); justify-content:center; }
.charity .kicker::before{ background:var(--gold); }
.charity h2{ font-size:clamp(30px,5vw,54px); margin:14px 0 22px; }
.charity h2 em{ font-family:var(--ff-serif); font-weight:400; font-style:italic; color:var(--sun); }
.charity p{ font-size:clamp(17px,2.2vw,21px); color:rgba(255,255,255,.86); max-width:60ch; margin:0 auto 14px; }
.charity .thanks{ font-family:var(--ff-serif); font-style:italic; font-size:clamp(20px,2.6vw,28px); color:var(--sun); margin-top:26px; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ background:var(--cream); }
.faq-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:start; margin-top:14px; }
.faq-list{ display:flex; flex-direction:column; gap:12px; }
.faq-item{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:box-shadow .3s, border-color .3s; }
.faq-item[open]{ box-shadow:var(--sh-2); border-color:#e3c9a8; }
.faq-q{
  list-style:none; cursor:pointer; padding:20px 24px; display:flex; align-items:center; justify-content:space-between; gap:16px;
  font-family:var(--ff-display); font-weight:700; font-size:17.5px; letter-spacing:-.01em;
}
.faq-q::-webkit-details-marker{ display:none; }
.faq-q .pm{ flex:none; width:26px; height:26px; border-radius:50%; background:var(--cream-2); display:grid; place-items:center; color:var(--wine); transition:transform .3s, background .3s; }
.faq-item[open] .faq-q .pm{ transform:rotate(45deg); background:var(--wine); color:#fff; }
.faq-a{ padding:0 24px 22px; color:var(--ink-soft); font-size:15.5px; line-height:1.6; }
.faq-aside{ position:sticky; top:100px; }
@media (max-width: 820px){ .faq-grid{ grid-template-columns:1fr; gap:32px; } .faq-aside{ position:static; } }

/* ============================================================
   EVENT INFO
   ============================================================ */
.info{ background:var(--surface); }
.info-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:24px; margin-top:50px; }
.info-cards{ display:grid; grid-template-columns:1fr 1fr; gap:14px; align-content:start; }
.info-card{ background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; }
.info-card.wide{ grid-column:1/-1; }
.info-card .ic{ width:42px; height:42px; border-radius:12px; background:var(--cream); border:1px solid var(--line); display:grid; place-items:center; color:var(--wine); margin-bottom:14px; }
.info-card .ic svg{ width:21px; height:21px; }
.info-card h4{ font-size:13px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:7px; font-family:var(--ff-body); font-weight:700; }
.info-card .big{ font-family:var(--ff-display); font-weight:800; font-size:19px; letter-spacing:-.01em; color:var(--ink); line-height:1.2; }
.info-card p{ font-size:14px; color:var(--ink-soft); margin-top:5px; line-height:1.5; }
.map{
  position:relative; border-radius:var(--r-xl); overflow:hidden; min-height:340px; border:1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(122,18,40,.04), rgba(225,91,54,.06)),
    repeating-linear-gradient(45deg, var(--surface-2) 0 16px, var(--surface) 16px 32px);
  display:flex; flex-direction:column; justify-content:flex-end;
}
.map .map-grid{ position:absolute; inset:0; background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px); background-size:46px 46px; opacity:.5; }
.map .pin{
  position:absolute; left:50%; top:42%; transform:translate(-50%,-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.map .pin .dot{ width:22px; height:22px; border-radius:50% 50% 50% 0; transform:rotate(-45deg); background:var(--wine); box-shadow:0 6px 16px rgba(122,18,40,.4), 0 0 0 6px rgba(122,18,40,.14); }
.map .pin .lbl{ background:#fff; box-shadow:var(--sh-1); font-weight:700; font-size:13px; padding:6px 12px; border-radius:var(--pill); color:var(--wine); }
.map .map-foot{ position:relative; z-index:2; margin:0 16px 16px; background:rgba(255,255,255,.86); backdrop-filter:blur(8px); border-radius:var(--r); padding:16px 18px; display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.map .map-foot .a{ font-weight:700; font-size:15px; }
.map .map-foot .b{ font-size:13px; color:var(--ink-soft); }
@media (max-width: 820px){ .info-grid{ grid-template-columns:1fr; } }
@media (max-width: 440px){ .info-cards{ grid-template-columns:1fr; } }

/* ============================================================
   PARTNERS
   ============================================================ */
.partners{ background:var(--cream); }
.partner-row{
  margin-top:44px; display:flex; flex-wrap:wrap; align-items:center; justify-content:center;
  gap:22px;
}
.partner{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:30px 40px; display:flex; align-items:center; justify-content:center;
  min-width:240px; min-height:118px; box-shadow:var(--sh-1);
  transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s;
}
.partner:hover{ transform:translateY(-5px); box-shadow:var(--sh-2); }
.partner img{
  width:200px; height:50px; object-fit:contain; object-position:center;
  transition:transform .3s;
}
/* Pixmark logo is single-colour white — fill it with the brand gradient via
   a mask so it reads on the light card and matches pixmark.sk's look. */
.partner-logo--pixmark{
  display:block; width:200px; height:50px;
  background:var(--grad-pixmark);
  -webkit-mask:url(assets/partner-pixmark.svg) center / contain no-repeat;
  mask:url(assets/partner-pixmark.svg) center / contain no-repeat;
  transition:transform .3s;
}
.partner:hover img,
.partner:hover .partner-logo--pixmark{ transform:scale(1.04); }
.partner-note{
  margin-top:30px; font-family:var(--ff-serif); font-style:italic;
  font-size:clamp(17px,2.2vw,21px); color:var(--ink-soft);
}
@media (max-width: 520px){
  .partner{ min-width:0; width:100%; padding:26px; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--plum); color:rgba(255,255,255,.7); padding-block:clamp(56px,8vw,90px) 40px; position:relative; overflow:hidden; }
.footer::before{ content:""; position:absolute; inset:auto 0 0 0; height:60%; background:radial-gradient(80% 120% at 50% 120%, rgba(225,91,54,.28), transparent 70%); pointer-events:none; }
.footer .wrap{ position:relative; z-index:2; }
.foot-top{ text-align:center; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.12); }
.foot-top .eyebrow{ color:var(--sun); }
.foot-title{ font-size:clamp(48px,12vw,150px); color:#fff; line-height:.85; letter-spacing:-.04em; margin:6px 0 8px; }
.foot-title .yr{ font-family:var(--ff-serif); font-style:italic; font-weight:400; color:var(--sun); }
.foot-line{ font-size:17px; color:rgba(255,255,255,.78); margin-top:18px; }
.foot-cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:30px; }
.foot-grid{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:30px; padding-top:40px; }
.foot-col h5{ font-family:var(--ff-body); font-weight:700; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:14px; }
.foot-col a, .foot-col p{ display:block; font-size:15px; color:rgba(255,255,255,.78); margin-bottom:9px; transition:color .2s; }
.foot-col a:hover{ color:#fff; }
.socials{ display:flex; gap:10px; }
.socials a{ width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.08); display:grid; place-items:center; transition:background .25s, transform .25s; }
.socials a:hover{ background:var(--coral); transform:translateY(-3px); }
.socials svg{ width:19px; height:19px; color:#fff; }
.foot-bottom{ margin-top:44px; padding-top:22px; border-top:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:13px; color:rgba(255,255,255,.5); }

/* ============================================================
   STICKY MOBILE CTA
   ============================================================ */
.sticky-cta{
  position:fixed; left:12px; right:12px; bottom:12px; z-index:55;
  background:rgba(42,23,18,.9); backdrop-filter:blur(16px); border:1px solid rgba(255,255,255,.12);
  border-radius:var(--pill); padding:9px 9px 9px 20px; display:none;
  align-items:center; justify-content:space-between; gap:12px;
  box-shadow:0 14px 40px rgba(58,12,22,.4);
  transform:translateY(140%); transition:transform .45s cubic-bezier(.2,.7,.2,1);
}
.sticky-cta.show{ transform:none; }
.sticky-cta .sc-info{ color:#fff; line-height:1.1; }
.sticky-cta .sc-info b{ font-family:var(--ff-display); font-size:15px; }
.sticky-cta .sc-info span{ display:block; font-size:12px; color:rgba(255,255,255,.6); margin-top:2px; }
.sticky-cta .btn{ padding:13px 20px; font-size:14.5px; }
@media (max-width: 860px){ .sticky-cta{ display:flex; } }

/* toast */
.toast{
  position:fixed; left:50%; bottom:84px; translate:-50% 0; z-index:80;
  background:var(--ink); color:#fff; padding:13px 22px; border-radius:var(--pill);
  font-size:14.5px; font-weight:600; box-shadow:var(--sh-3); opacity:0; pointer-events:none;
  transition:opacity .3s, transform .3s; transform:translateY(16px);
}
.toast.show{ opacity:1; transform:translateY(0); }
@media (max-width:860px){ .toast{ bottom:96px; } }
