/* ============================================================
   WIRRAL BLUES FESTIVAL — design system
   Direction: dark electric + paint splash
   Palette:  near-black canvas · electric blue "blues" anchor
             multicolour paint-splash pop (pink / amber / teal / purple)
   Bridges the user's loves: slick + professional, bright tasteless
   colour, paint splashes, a "logo field" line-up, light Mersey nods.
   ============================================================ */

/* ---------- 1. Tokens ---------------------------------------- */
:root {
  /* surfaces */
  --bg:        #0B0E14;
  --bg-2:      #0E1219;
  --surface:   #141A24;
  --surface-2: #1B2330;
  --line:      #28303f;
  --line-soft: #1d242f;

  /* ink */
  --ink:   #F4F7FB;
  --ink-2: #AEB8C7;
  --ink-3: #748196;

  /* electric blue — the "blues" */
  --blue:      #1FA2FF;
  --blue-hi:   #58BFFF;
  --blue-deep: #0A6CD6;

  /* paint-splash pop */
  --pink:   #FF3D7F;
  --amber:  #FFD23F;
  --teal:   #18E0C8;
  --purple: #A24BFF;

  /* glows */
  --glow-blue:  rgba(31,162,255,.55);
  --glow-pink:  rgba(255,61,127,.50);
  --glow-teal:  rgba(24,224,200,.45);

  /* type */
  --f-display: "Anton", "Arial Narrow", sans-serif;
  --f-label:   "Bebas Neue", "Anton", sans-serif;
  --f-body:    "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* scale (fluid) */
  --step--1: clamp(.82rem, .79rem + .15vw, .92rem);
  --step-0:  clamp(1rem, .96rem + .2vw, 1.12rem);
  --step-1:  clamp(1.2rem, 1.1rem + .5vw, 1.5rem);
  --step-2:  clamp(1.6rem, 1.35rem + 1.2vw, 2.4rem);
  --step-3:  clamp(2.2rem, 1.7rem + 2.5vw, 3.6rem);
  --step-4:  clamp(3rem, 2rem + 5vw, 6rem);
  --step-5:  clamp(3.6rem, 1.6rem + 9vw, 9.5rem);

  /* space */
  --gap: clamp(1rem, .6rem + 1.6vw, 1.6rem);
  --section-y: clamp(3.5rem, 2rem + 6vw, 7rem);
  --wrap: 1200px;

  /* shape */
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --r-pill: 999px;

  /* shadow */
  --sh:    0 10px 30px -12px rgba(0,0,0,.7);
  --sh-lg: 0 30px 70px -30px rgba(0,0,0,.85);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- 2. Reset / base --------------------------------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){ html { scroll-behavior: auto; } }

body {
  font-family: var(--f-body);
  font-size: var(--step-0);
  line-height: 1.6;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* grain + ambient field that sits behind everything */
body::before {
  content: "";
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E");
  opacity: .035;
  pointer-events: none;
  z-index: 0;
  mix-blend-mode: screen;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; }

:focus-visible {
  outline: 3px solid var(--blue);
  outline-offset: 3px;
  border-radius: 4px;
}

::selection { background: var(--pink); color: #fff; }

/* ---------- 3. Layout --------------------------------------- */
.wrap { width: min(100% - 2.2rem, var(--wrap)); margin-inline: auto; position: relative; z-index: 1; }
.wrap--narrow { width: min(100% - 2.2rem, 820px); }
.section { padding-block: var(--section-y); position: relative; }
main { position: relative; z-index: 1; }

.eyebrow {
  font-family: var(--f-label);
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: var(--step-0);
  color: var(--blue);
  display: inline-flex; align-items: center; gap: .6rem;
}
.eyebrow::before { content:""; width: 26px; height: 2px; background: var(--blue); display:inline-block; }

.h-sec {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: var(--step-4);
  line-height: .92;
  letter-spacing: .01em;
  text-transform: uppercase;
}
.lead { color: var(--ink-2); font-size: var(--step-1); max-width: 56ch; }

/* ---------- 4. Buttons -------------------------------------- */
.btn {
  --bw: 1px;
  display: inline-flex; align-items: center; justify-content:center; gap: .55rem;
  font-family: var(--f-label); letter-spacing: .12em; text-transform: uppercase;
  font-size: 1.05rem; line-height: 1;
  padding: 1.05em 1.6em;
  border-radius: var(--r-pill);
  border: var(--bw) solid transparent;
  transition: transform .18s var(--ease), box-shadow .25s var(--ease), background .2s, color .2s, border-color .2s;
  will-change: transform;
}
.btn svg { width: 1.1em; height: 1.1em; }
.btn-primary {
  background: var(--blue); color: #06121f;
  box-shadow: 0 0 0 0 var(--glow-blue), 0 14px 30px -12px var(--glow-blue);
}
.btn-primary:hover { background: var(--blue-hi); transform: translateY(-2px); box-shadow: 0 0 36px -2px var(--glow-blue), 0 18px 36px -14px var(--glow-blue); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--blue); color: var(--blue-hi); transform: translateY(-2px); }
.btn-splash { background: var(--pink); color:#fff; box-shadow: 0 14px 30px -12px var(--glow-pink); }
.btn-splash:hover { transform: translateY(-2px); box-shadow: 0 0 34px -4px var(--glow-pink); }
.btn-lg { font-size: 1.2rem; padding: 1.15em 2em; }
.btn:active { transform: translateY(0); }

/* ---------- 5. Ambient splash blobs ------------------------- */
.field { position: relative; isolation: isolate; }
.blob {
  position: absolute; border-radius: 50%;
  filter: blur(60px); opacity: .5; mix-blend-mode: screen;
  pointer-events: none; z-index: 0;
  animation: float 18s ease-in-out infinite;
}
.blob--blue  { background: var(--blue);  }
.blob--pink  { background: var(--pink);  }
.blob--teal  { background: var(--teal);  }
.blob--amber { background: var(--amber); }
.blob--purple{ background: var(--purple);}
@keyframes float {
  0%,100% { transform: translate(0,0) scale(1); }
  33%     { transform: translate(3%, -4%) scale(1.08); }
  66%     { transform: translate(-3%, 3%) scale(.95); }
}
@media (prefers-reduced-motion: reduce){ .blob { animation: none; } }

/* ---------- 6. Header / nav --------------------------------- */
.site-head {
  position: fixed; inset: 0 0 auto 0; z-index: 50;
  display: flex; align-items: center;
  transition: background .3s, box-shadow .3s, padding .3s;
  padding-block: 1.1rem;
}
.site-head.scrolled {
  background: rgba(11,14,20,.82);
  backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 var(--line-soft), 0 20px 40px -30px #000;
  padding-block: .7rem;
}
.nav { display:flex; align-items:center; justify-content: space-between; gap: 1rem; width: min(100% - 2.2rem, var(--wrap)); margin-inline:auto; }
.brand { display:flex; align-items:center; gap:.6rem; font-family: var(--f-display); text-transform: uppercase; letter-spacing:.02em; font-size: 1.5rem; line-height: 1; }
.brand .spark { width: 16px; height: 16px; flex: none; }
.nav-links { display:flex; align-items:center; gap: clamp(1rem,2.2vw,2rem); }
.nav-links a { font-family: var(--f-label); letter-spacing:.12em; text-transform: uppercase; font-size: 1.06rem; color: var(--ink-2); transition: color .2s; position: relative; padding-block: .2rem; }
.nav-links a::after { content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px; background: var(--blue); transition: right .25s var(--ease); }
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--ink); }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after { right: 0; }
.nav-cta { display:flex; align-items:center; gap:.8rem; }
.nav-cta .btn { padding: .8em 1.3em; font-size: .98rem; }

.brand { min-width: 0; }
.nav-toggle { display:none; flex:none; width:46px; height:46px; border:1px solid #3c4a5e; border-radius: var(--r-sm); background: rgba(31,162,255,.10); align-items:center; justify-content:center; }
.nav-toggle:hover { border-color: var(--blue); background: rgba(31,162,255,.18); }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after { content:""; display:block; width:20px; height:2px; background: var(--ink); transition: transform .25s, opacity .2s; }
.nav-toggle span::before { transform: translateY(-6px); } .nav-toggle span::after { transform: translateY(4px); }
.nav-toggle[aria-expanded="true"] span { background: transparent; }
.nav-toggle[aria-expanded="true"] span::before { transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] span::after { transform: rotate(-45deg) translateY(-1px); }

@media (max-width: 880px){
  .nav-toggle { display:inline-flex; }
  .nav-links {
    position: fixed; inset: 0 0 0 auto; width: min(82vw, 340px);
    flex-direction: column; align-items: flex-start; gap: 1.4rem;
    background: var(--bg-2); border-left: 1px solid var(--line);
    padding: 6rem 2rem 2rem; transform: translateX(100%); transition: transform .3s var(--ease);
    box-shadow: var(--sh-lg);
  }
  .nav-links.open { transform: translateX(0); }
  .nav-links a { font-size: 1.5rem; }
  .nav-cta { gap: .6rem; }
  .nav-cta .btn span.long { display:none; }
}
/* On phones the header is just brand + menu; tickets live in the menu + hero. */
.nav-tickets { display: none; }
@media (max-width: 880px){
  .nav-tickets { display: inline-flex; color: var(--blue); }
}
@media (max-width: 640px){
  .brand { font-size: 1.2rem; }
  .site-head { padding-block: .8rem; }
  .nav-cta > a.btn { display: none; }   /* hide header ticket pill, use menu/hero */
}

/* ---------- 7. Hero ----------------------------------------- */
.hero { position: relative; min-height: 100svh; display:flex; align-items:center; padding-top: 6rem; padding-bottom: 3rem; overflow: hidden; }
.hero .blob--blue  { width: 60vw; height: 60vw; top: -18%; left: -10%; opacity:.42; }
.hero .blob--pink  { width: 34vw; height: 34vw; bottom: -10%; right: -6%; opacity:.4; animation-delay: -5s; }
.hero .blob--teal  { width: 26vw; height: 26vw; top: 30%; right: 18%; opacity:.3; animation-delay: -9s; }
.hero-splash { position:absolute; inset:0; z-index:0; opacity:.5; background: center/cover no-repeat; pointer-events:none; mix-blend-mode: screen; }
.hero-grid { position:absolute; inset:0; z-index:0; opacity:.5; pointer-events:none;
  background:
    linear-gradient(transparent 0, var(--bg) 78%),
    repeating-linear-gradient(0deg, transparent 0 38px, rgba(255,255,255,.025) 38px 39px),
    repeating-linear-gradient(90deg, transparent 0 38px, rgba(255,255,255,.025) 38px 39px);
}
.hero-inner { position: relative; z-index: 2; }
.hero .tag-row { display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom: 1.4rem; }
.chip {
  font-family: var(--f-label); letter-spacing:.16em; text-transform: uppercase; font-size: 1rem;
  padding:.5em 1em; border-radius: var(--r-pill); border:1px solid var(--line);
  background: rgba(255,255,255,.03); color: var(--ink-2);
  display:inline-flex; align-items:center; gap:.5rem;
}
.chip b { color: var(--ink); font-weight: 600; }
.chip .dot { width:8px; height:8px; border-radius:50%; background: var(--teal); box-shadow:0 0 12px var(--teal); }

.wordmark { font-family: var(--f-display); text-transform: uppercase; line-height: .92; letter-spacing: .005em; }
.wordmark .l2 { margin-top: .02em; }
.wordmark .l1 { display:block; font-size: var(--step-5); color: var(--ink);
  text-shadow: 0 0 36px var(--glow-blue), 0 0 8px rgba(31,162,255,.35); }
.wordmark .l2 { display:block; font-size: var(--step-5);
  color: transparent; -webkit-text-stroke: 2px var(--blue); text-stroke: 2px var(--blue);
  filter: drop-shadow(0 0 22px var(--glow-blue)); }
.wordmark .fest { display:inline-block; margin-top:.5rem; font-family: var(--f-label); letter-spacing:.55em;
  font-size: clamp(1rem,3.5vw,1.9rem); color: var(--amber); padding-left:.55em; }

.hero-when { margin-top: 1.6rem; font-family: var(--f-label); letter-spacing:.06em; text-transform:uppercase;
  font-size: clamp(1.2rem, 3.4vw, 2rem); color: var(--ink); }
.hero-when .sep { color: var(--blue); padding: 0 .4em; }
.hero-why { margin-top: .8rem; color: var(--ink-2); font-size: var(--step-1); max-width: 44ch; }

.hero-cta { margin-top: 2rem; display:flex; flex-wrap:wrap; gap: .9rem; }
.scroll-cue { position:absolute; bottom: 1.6rem; left:50%; transform: translateX(-50%); z-index:2;
  font-family: var(--f-label); letter-spacing:.2em; text-transform:uppercase; font-size:.8rem; color: var(--ink-3);
  display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.scroll-cue .bar { width:2px; height:34px; background: linear-gradient(var(--blue), transparent); animation: cue 1.8s ease-in-out infinite; }
@keyframes cue { 0%,100%{ transform: scaleY(.4); opacity:.4; transform-origin: top; } 50%{ transform: scaleY(1); opacity:1; } }
@media (prefers-reduced-motion: reduce){ .scroll-cue .bar { animation: none; } }

/* ---------- 8. Countdown ------------------------------------ */
.countdown { display:flex; gap: clamp(.6rem,2vw,1.4rem); margin-top: 2rem; flex-wrap:wrap; }
.cd-cell { text-align:center; min-width: 78px; }
.cd-num { font-family: var(--f-display); font-size: clamp(2.2rem,6vw,3.4rem); line-height:1; color: var(--ink);
  background: linear-gradient(180deg, #fff, var(--blue-hi)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color: transparent; }
.cd-lab { display:block; font-family: var(--f-label); letter-spacing:.2em; text-transform:uppercase; font-size:.82rem; color: var(--ink-3); margin-top:.35rem; }
.cd-sep { font-family: var(--f-display); font-size: clamp(1.6rem,4vw,2.6rem); color: var(--line); align-self:flex-start; }
.cd-live { font-family: var(--f-label); letter-spacing:.2em; text-transform:uppercase; color: var(--pink); }

/* ---------- 9. When / Where / Why trio ---------------------- */
.trio { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--gap); }
.trio-card { background: linear-gradient(180deg, var(--surface), var(--bg-2)); border:1px solid var(--line); border-radius: var(--r);
  padding: clamp(1.4rem,3vw,2rem); position:relative; overflow:hidden; transition: border-color .25s, transform .25s; }
.trio-card:hover { border-color: var(--blue); transform: translateY(-3px); }
.trio-card .ic { width:44px; height:44px; border-radius: var(--r-sm); display:grid; place-items:center; margin-bottom:1rem;
  background: rgba(31,162,255,.12); color: var(--blue); }
.trio-card .ic svg { width:24px; height:24px; }
.trio-card.k--pink .ic { background: rgba(255,61,127,.14); color: var(--pink); }
.trio-card.k--amber .ic { background: rgba(255,210,63,.14); color: var(--amber); }
.trio-card h3 { font-family: var(--f-label); letter-spacing:.14em; text-transform:uppercase; font-size:1.4rem; color: var(--ink-3); margin-bottom:.4rem; }
.trio-card p.big { font-size: var(--step-1); font-weight:600; color: var(--ink); }
.trio-card p.sub { color: var(--ink-2); margin-top:.3rem; font-size: var(--step--1); }
@media (max-width: 760px){ .trio { grid-template-columns: 1fr; } }

/* ---------- 10. Line-up (logo field) ------------------------ */
.lineup-head { display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom: 2.4rem; }
.tap-hint { font-family: var(--f-label); letter-spacing:.14em; text-transform:uppercase; font-size:1rem; color: var(--ink-3);
  display:inline-flex; align-items:center; gap:.55rem; }
.tap-hint svg { width:1.2em; height:1.2em; color: var(--blue); }

.logo-field { display:flex; flex-wrap:wrap; gap: clamp(1rem,2.5vw,2.4rem); align-items:center; justify-content:center; text-align:center; }
.band {
  position: relative; display:inline-flex; flex-direction:column; align-items:center; gap:.5rem;
  padding: .8rem 1rem; border-radius: var(--r);
  transition: transform .2s var(--ease);
  color: var(--ink);
}
.band .logo {
  line-height: .95; transition: filter .25s, transform .2s, color .2s;
  filter: drop-shadow(0 2px 0 rgba(0,0,0,.4));
}
/* headliner + tiers via size */
.band--xl .logo { font-size: clamp(2.6rem, 8vw, 6rem); }
.band--l  .logo { font-size: clamp(2rem, 6vw, 4.2rem); }
.band--m  .logo { font-size: clamp(1.6rem, 4.6vw, 3rem); }

.band .meta { font-family: var(--f-label); letter-spacing:.14em; text-transform:uppercase; font-size:.92rem;
  color: var(--ink-3); display:flex; align-items:center; gap:.5rem; opacity:.8; transition: color .2s, opacity .2s; }
.band .bio-cue { font-family: var(--f-label); letter-spacing:.14em; text-transform:uppercase; font-size:.92rem;
  color: var(--blue); opacity:0; transform: translateY(4px); transition: opacity .2s, transform .2s; display:inline-flex; align-items:center; gap:.35rem; }
.band:hover { transform: translateY(-4px); }
.band:hover .logo { transform: scale(1.03); }
.band:hover .meta { opacity:0; }
.band:hover .bio-cue { opacity:1; transform: translateY(0); }
.band::after { /* splash glow behind on hover */
  content:""; position:absolute; inset:-10% -6%; z-index:-1; border-radius:50%;
  background: radial-gradient(closest-side, var(--c, var(--blue)), transparent 72%);
  opacity:0; filter: blur(26px); transition: opacity .3s; transform: scale(.7);
}
.band:hover::after { opacity:.55; transform: scale(1); }
.band:focus-visible { outline-offset: 6px; }

/* band logo fonts + accent colour (the "varied logos" trick) */
.lg--hounds   { font-family:"Anton", sans-serif; color:#fff; letter-spacing:.01em; }
.lg--mojo     { font-family:"Rye", serif; color: var(--amber); }
.lg--slide    { font-family:"Special Elite", monospace; color: var(--teal); letter-spacing:-.01em; }
.lg--boogie   { font-family:"Righteous", cursive; color: var(--blue-hi); }
.lg--ruby     { font-family:"Abril Fatface", serif; color: var(--pink); }
.lg--cormorant{ font-family:"Monoton", cursive; color: var(--purple); }
.lg--ramblers { font-family:"Permanent Marker", cursive; color:#fff; }

/* ---------- 11. Ferry strapline / pull quote ---------------- */
.strap { position:relative; overflow:hidden; border-block:1px solid var(--line-soft); }
.strap .blob--teal { width:40vw; height:40vw; left:-8%; bottom:-30%; opacity:.22; }
.strap .blob--blue { width:36vw; height:36vw; right:-8%; top:-30%; opacity:.26; }
.strap-quote { font-family: var(--f-display); text-transform:uppercase; line-height: .96; font-size: var(--step-3);
  text-align:center; max-width: 18ch; margin-inline:auto; }
.strap-quote .hl { color: var(--blue); text-shadow: 0 0 28px var(--glow-blue); }
.strap-sub { text-align:center; color: var(--ink-2); margin-top:1rem; font-family: var(--f-label); letter-spacing:.2em; text-transform:uppercase; }

/* ---------- 12. CTA band ------------------------------------ */
.cta-band { position:relative; overflow:hidden; text-align:center;
  background: radial-gradient(120% 140% at 50% -20%, rgba(31,162,255,.22), transparent 60%), var(--bg-2);
  border-top:1px solid var(--line-soft); }
.cta-band .blob--pink { width:34vw; height:34vw; right:4%; bottom:-40%; opacity:.3; }
.cta-band .blob--amber{ width:24vw; height:24vw; left:6%; top:-30%; opacity:.22; }
.cta-band h2 { font-family: var(--f-display); text-transform:uppercase; font-size: var(--step-4); line-height:.9; }
.cta-band p { color: var(--ink-2); font-size: var(--step-1); margin-top:.8rem; }
.cta-band .hero-cta { justify-content:center; margin-top:1.8rem; }

/* ---------- 13. Footer -------------------------------------- */
.site-foot { background: var(--bg-2); border-top:1px solid var(--line); padding-block: 3.2rem 2rem; position:relative; z-index:1; }
.foot-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; }
.foot-brand .brand { font-size: 2rem; margin-bottom:.8rem; }
.foot-brand p { color: var(--ink-2); max-width: 36ch; }
.foot-strap { color: var(--blue); font-family: var(--f-label); letter-spacing:.14em; text-transform:uppercase; margin-top:1rem; }
.foot-col h4 { font-family: var(--f-label); letter-spacing:.18em; text-transform:uppercase; color: var(--ink-3); font-size:1rem; margin-bottom:1rem; }
.foot-col a, .foot-col p { display:block; color: var(--ink-2); padding-block:.32rem; transition: color .2s; }
.foot-col a:hover { color: var(--blue); }
.socials { display:flex; gap:.6rem; margin-top: .4rem; }
.socials a { width:42px; height:42px; border:1px solid var(--line); border-radius: var(--r-sm); display:grid; place-items:center; color: var(--ink-2); transition: all .2s; }
.socials a:hover { color: var(--blue); border-color: var(--blue); transform: translateY(-2px); }
.socials svg { width:20px; height:20px; }
.foot-base { display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; justify-content:space-between; align-items:center;
  margin-top: 2.4rem; padding-top: 1.4rem; border-top:1px solid var(--line-soft); color: var(--ink-3); font-size: var(--step--1); }
.foot-base .mock { color: var(--amber); }
@media (max-width: 760px){ .foot-grid { grid-template-columns: 1fr; gap:1.6rem; } }

/* ---------- 14. Sub-page hero (locations / artist / std) ----- */
.subhero { position:relative; overflow:hidden; padding-top: 8rem; padding-bottom: var(--section-y); }
.subhero .blob--blue { width:48vw; height:48vw; top:-26%; right:-10%; opacity:.3; }
.subhero .blob--pink { width:30vw; height:30vw; bottom:-30%; left:-8%; opacity:.26; }
.crumb { font-family: var(--f-label); letter-spacing:.16em; text-transform:uppercase; color: var(--ink-3); font-size:1rem; display:inline-flex; gap:.5rem; align-items:center; margin-bottom:1rem; }
.crumb a { color: var(--ink-2); } .crumb a:hover { color: var(--blue); }
.subhero h1 { font-family: var(--f-display); text-transform:uppercase; font-size: var(--step-5); line-height:.86; }
.subhero .lead { margin-top:1.1rem; }

/* ---------- 15. Locations ----------------------------------- */
.loc-grid { display:grid; grid-template-columns: 1.05fr .95fr; gap: var(--gap); align-items:stretch; }
@media (max-width: 900px){ .loc-grid { grid-template-columns: 1fr; } }
.venue-card { background: linear-gradient(180deg,var(--surface),var(--bg-2)); border:1px solid var(--line); border-radius: var(--r-lg); padding: clamp(1.6rem,3vw,2.4rem); }
.venue-card .eyebrow { margin-bottom:1rem; }
.venue-card h2 { font-family: var(--f-display); text-transform:uppercase; font-size: var(--step-3); line-height:.92; }
.venue-card address { font-style:normal; color: var(--ink-2); margin-top:.8rem; font-size: var(--step-1); line-height:1.5; }
.venue-meta { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.2rem; }
.venue-meta .chip { background: rgba(255,255,255,.03); }
.venue-card .btn { margin-top: 1.6rem; }
.map-wrap { border:1px solid var(--line); border-radius: var(--r-lg); overflow:hidden; min-height: 340px; position:relative; background: var(--surface); }
.map-wrap iframe { width:100%; height:100%; min-height:340px; border:0; filter: grayscale(.3) invert(.9) hue-rotate(170deg) contrast(.9); }
.map-fallback { position:absolute; inset:0; display:grid; place-items:center; text-align:center; color: var(--ink-3); padding:2rem; }

.travel { display:grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: var(--gap); margin-top: 2.4rem; }
.travel-card { background: var(--surface); border:1px solid var(--line); border-radius: var(--r); padding: 1.4rem; transition: border-color .25s, transform .25s; }
.travel-card:hover { border-color: var(--blue); transform: translateY(-3px); }
.travel-card .ic { width:42px; height:42px; border-radius: var(--r-sm); display:grid; place-items:center; margin-bottom:.9rem; background: rgba(31,162,255,.12); color: var(--blue); }
.travel-card .ic svg { width:22px; height:22px; }
.travel-card h3 { font-family: var(--f-label); letter-spacing:.1em; text-transform:uppercase; font-size:1.3rem; margin-bottom:.3rem; }
.travel-card p { color: var(--ink-2); font-size: var(--step--1); }
.travel-card .ferry { color: var(--teal); }

.nearby { margin-top:2.4rem; display:grid; grid-template-columns: repeat(auto-fit,minmax(240px,1fr)); gap: var(--gap); }
.near-card { border:1px dashed var(--line); border-radius: var(--r); padding:1.2rem 1.4rem; }
.near-card h4 { font-family: var(--f-label); letter-spacing:.1em; text-transform:uppercase; font-size:1.2rem; color: var(--ink); }
.near-card p { color: var(--ink-2); font-size: var(--step--1); margin-top:.2rem; }

/* ---------- 16. Artist page --------------------------------- */
.artist-hero { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(1.4rem,4vw,3rem); align-items:center; }
@media (max-width: 860px){ .artist-hero { grid-template-columns: 1fr; } }
.artist-photo { position:relative; border-radius: var(--r-lg); overflow:hidden; border:1px solid var(--line); aspect-ratio: 4/5; background: var(--surface); }
.artist-photo svg { width:100%; height:100%; }
.artist-photo .tier { position:absolute; top:1rem; left:1rem; z-index:2; font-family: var(--f-label); letter-spacing:.16em; text-transform:uppercase; font-size:.92rem;
  padding:.45em 1em; border-radius: var(--r-pill); background: rgba(11,14,20,.7); border:1px solid var(--line); color: var(--ink); backdrop-filter: blur(6px); }
.artist-photo .tier b { color: var(--amber); }
.artist-info .role { font-family: var(--f-label); letter-spacing:.18em; text-transform:uppercase; color: var(--blue); font-size:1.1rem; }
.artist-info .name { line-height:.9; margin: .6rem 0; }
.artist-info .name .logo { display:inline-block; }
.band-name--xl { font-size: clamp(2.8rem, 9vw, 5.4rem); }
.artist-tags { display:flex; flex-wrap:wrap; gap:.6rem; margin:1.2rem 0; }
.artist-bio p { color: var(--ink-2); font-size: var(--step-1); margin-top:1rem; max-width: 60ch; }

.onstage { display:flex; flex-wrap:wrap; gap: var(--gap); margin-top: 2rem; }
.onstage .slot { background: var(--surface); border:1px solid var(--line); border-radius: var(--r); padding:1.1rem 1.4rem; min-width: 150px; }
.onstage .slot .k { font-family: var(--f-label); letter-spacing:.16em; text-transform:uppercase; color: var(--ink-3); font-size:.85rem; }
.onstage .slot .v { font-family: var(--f-display); font-size: var(--step-1); color: var(--ink); margin-top:.2rem; }
.onstage .slot .v.blue { color: var(--blue); }

.listen { display:flex; flex-wrap:wrap; gap:.7rem; margin-top: 1.6rem; }
.listen a { display:inline-flex; align-items:center; gap:.5rem; border:1px solid var(--line); border-radius: var(--r-pill); padding:.7em 1.2em; color: var(--ink-2); font-family: var(--f-label); letter-spacing:.08em; text-transform:uppercase; font-size:.95rem; transition: all .2s; }
.listen a:hover { color: var(--ink); border-color: var(--blue); transform: translateY(-2px); }
.listen svg { width:1.1em; height:1.1em; }

.prevnext { display:flex; justify-content:space-between; gap:1rem; margin-top: var(--section-y); border-top:1px solid var(--line-soft); padding-top: 2rem; }
.prevnext a { display:flex; flex-direction:column; gap:.2rem; color: var(--ink-2); transition: color .2s; max-width: 45%; }
.prevnext a:hover { color: var(--blue); }
.prevnext .k { font-family: var(--f-label); letter-spacing:.16em; text-transform:uppercase; font-size:.82rem; color: var(--ink-3); }
.prevnext .v { font-family: var(--f-display); text-transform:uppercase; font-size: var(--step-1); line-height:1; }
.prevnext a.next { text-align:right; align-items:flex-end; }

/* ---------- 17. Save the date (poster) ---------------------- */
.poster { min-height: 100svh; display:grid; place-items:center; text-align:center; position:relative; overflow:hidden; padding: 6rem 1.2rem 3rem; }
.poster .blob--blue { width:60vw; height:60vw; top:-20%; left:-12%; opacity:.4; }
.poster .blob--pink { width:40vw; height:40vw; bottom:-16%; right:-10%; opacity:.36; }
.poster .blob--amber{ width:24vw; height:24vw; top:12%; right:14%; opacity:.24; }
.poster-inner { position:relative; z-index:2; }
.poster .save { font-family: var(--f-label); letter-spacing:.42em; text-transform:uppercase; color: var(--amber); font-size: clamp(1.1rem,4vw,1.8rem); padding-left:.42em; }
.poster .date { font-family: var(--f-display); text-transform:uppercase; line-height:.82; margin:.6rem 0 .4rem;
  font-size: clamp(3.6rem, 16vw, 11rem); }
.poster .date .d { color: var(--ink); text-shadow: 0 0 40px var(--glow-blue); }
.poster .date .mo { color: transparent; -webkit-text-stroke: 2px var(--blue); filter: drop-shadow(0 0 22px var(--glow-blue)); }
.poster .name { font-family: var(--f-display); text-transform:uppercase; font-size: var(--step-3); line-height:.9; margin-top:.4rem; }
.poster .where { margin-top:1.2rem; font-family: var(--f-label); letter-spacing:.16em; text-transform:uppercase; color: var(--ink-2); font-size: clamp(1rem,3.4vw,1.5rem); }
.poster .where .sep { color: var(--blue); padding:0 .4em; }
.poster .ferry { margin-top:.6rem; color: var(--teal); font-family: var(--f-label); letter-spacing:.16em; text-transform:uppercase; }
.poster .hero-cta { justify-content:center; margin-top: 2.2rem; }
.poster .mini-foot { position:absolute; bottom:1.2rem; left:0; right:0; z-index:2; color: var(--ink-3); font-size: var(--step--1); }
.poster-back { position:absolute; top:1.4rem; left:1.4rem; z-index:3; }

/* ---------- 18. Reveal on scroll ---------------------------- */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity:1; transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity:1; transform:none; transition:none; } }

/* ---------- 19. Misc helpers -------------------------------- */
.center { text-align:center; }
.mt-1 { margin-top: .6rem; } .mt-2 { margin-top: 1.2rem; } .mt-3 { margin-top: 2rem; }
.divider { height:1px; background: var(--line-soft); border:0; }
.skip { position:absolute; left:-999px; top:0; z-index:200; background: var(--blue); color:#06121f; padding:.7em 1.2em; border-radius: var(--r-sm); font-family:var(--f-label); letter-spacing:.1em; text-transform:uppercase; }
.skip:focus { left:1rem; top:1rem; }
