/* ============================================================
   AKKORDEONIE NEBIKON — Festival
   Aesthetic: Plakat-Energie, schwarzes Grundsetting, Festival-Gelb,
   Inter Display als Stimme, grosse gelbe Track-Nummern als Anker.
   ============================================================ */

:root {
  /* Background system — deep, theatrical */
  --bg: #0a0d12;
  --bg-soft: #14181f;
  --bg-deep: #060810;
  --bg-card: #11151c;

  /* Ink */
  --ink: #fafaf6;
  --ink-soft: #c5c8cd;
  --mute: #6b7280;
  --line: rgba(255, 255, 255, 0.08);
  --line-strong: rgba(255, 255, 255, 0.18);

  /* Festival accents */
  --yellow: #ffd23f;
  --yellow-deep: #e0b423;
  --coral: #ff5e3a;

  /* Type */
  --sans: "Inter", "Helvetica Neue", system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "Courier New", monospace;

  /* Rhythm */
  --gutter: clamp(20px, 4vw, 72px);
  --section-y: clamp(72px, 12vh, 160px);
  --max: 1480px;

  /* Motion */
  --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
*, *::before, *::after { -webkit-font-smoothing: antialiased; }

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.55;
  font-weight: 400;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

::selection { background: var(--yellow); color: var(--bg); }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; background: none; border: none; color: inherit; }

/* ------------------------------------------------------------
   Layout primitives
   ------------------------------------------------------------ */

.wrap {
  width: 100%;
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  position: relative;
}
.wrap--narrow { max-width: 880px; }

.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mute);
}
.eyebrow--yellow { color: var(--yellow); }
.eyebrow--coral { color: var(--coral); }

.divider {
  height: 1px;
  background: var(--line);
  margin: 0;
}

.arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: gap 240ms var(--ease);
}
.arrow::after {
  content: "→";
  display: inline-block;
  transition: transform 240ms var(--ease);
}
a:hover .arrow, .arrow:hover { gap: 14px; }

/* ------------------------------------------------------------
   Masthead — sticky, dark, blurred
   ------------------------------------------------------------ */

.masthead {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(10, 13, 18, 0.78);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--line);
}

.masthead__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 0;
  gap: 24px;
}

.masthead__brand {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.masthead__brand .ak {
  color: var(--ink);
}
.masthead__brand .accent {
  color: var(--yellow);
  font-weight: 800;
}
.masthead__brand .arrow-mark {
  color: var(--yellow);
  margin-left: 2px;
  font-weight: 500;
}

.masthead__nav {
  display: flex;
  align-items: center;
  gap: 28px;
  font-size: 14px;
  font-weight: 500;
}
.masthead__nav a {
  color: var(--ink-soft);
  transition: color 200ms var(--ease);
}
.masthead__nav a:hover { color: var(--ink); }
.masthead__nav a.is-active { color: var(--yellow); }

.cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 999px;
  background: var(--yellow);
  color: var(--bg);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: -0.005em;
  transition: transform 200ms var(--ease), background 200ms var(--ease);
}
.cta:hover { background: #ffe070; transform: translateY(-1px); }
.cta--ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--line-strong);
}
.cta--ghost:hover { background: rgba(255,255,255,0.05); border-color: var(--ink-soft); }

/* ------------------------------------------------------------
   Hero — Statement
   ------------------------------------------------------------ */

.hero {
  padding: clamp(70px, 10vh, 130px) 0 clamp(60px, 9vh, 110px);
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background:
    radial-gradient(1200px 600px at 90% -10%, rgba(255, 210, 63, 0.10), transparent 60%),
    radial-gradient(800px 500px at -10% 110%, rgba(255, 94, 58, 0.06), transparent 60%);
  pointer-events: none;
}

.hero__eyebrow {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 18px;
  margin-bottom: 36px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mute);
}
.hero__eyebrow span { display: inline-flex; align-items: center; gap: 8px; }
.hero__eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--yellow); }

.hero__title {
  font-size: clamp(64px, 12vw, 184px);
  line-height: 0.86;
  letter-spacing: -0.045em;
  font-weight: 900;
  margin-bottom: 36px;
  font-feature-settings: "ss01", "cv11";
}
.hero__title .accent { color: var(--yellow); }
.hero__title em { font-style: normal; color: var(--yellow); }

.hero__layout {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  align-items: end;
  margin-top: 48px;
}
@media (max-width: 860px) {
  .hero__layout { grid-template-columns: 1fr; gap: 36px; }
}

.hero__lede {
  font-size: clamp(17px, 1.5vw, 21px);
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 56ch;
}
.hero__lede strong { color: var(--ink); font-weight: 600; }

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

.hero__concert {
  border: 1px solid var(--line-strong);
  border-radius: 14px;
  padding: 24px 26px;
  background: rgba(255, 255, 255, 0.02);
}
.hero__concert .label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-bottom: 14px;
}
.hero__concert .date {
  font-size: clamp(34px, 4.5vw, 56px);
  line-height: 1;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 10px;
}
.hero__concert .where {
  font-size: 14px;
  color: var(--ink-soft);
  margin-bottom: 6px;
}
.hero__concert .reservation {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--mute);
  letter-spacing: 0.04em;
  padding-top: 14px;
  margin-top: 14px;
  border-top: 1px solid var(--line);
}
.hero__concert .reservation strong {
  color: var(--ink);
  font-weight: 600;
}

/* ------------------------------------------------------------
   Marquee — running concert strip
   ------------------------------------------------------------ */

.marquee {
  background: var(--yellow);
  color: var(--bg);
  padding: 18px 0;
  overflow: hidden;
  position: relative;
}
.marquee__track {
  display: flex;
  gap: 60px;
  white-space: nowrap;
  animation: marqueeRun 32s linear infinite;
  font-weight: 800;
  font-size: clamp(20px, 2.4vw, 30px);
  letter-spacing: -0.02em;
}
.marquee__track span { display: inline-flex; align-items: center; gap: 60px; }
.marquee__track .sep { color: var(--bg); opacity: 0.35; font-weight: 500; }
@keyframes marqueeRun {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ------------------------------------------------------------
   Tracks — the design anchor: massive yellow numerals
   ------------------------------------------------------------ */

.tracks {
  padding: var(--section-y) 0;
}

.tracks__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: clamp(40px, 6vh, 80px);
}
.tracks__title {
  font-size: clamp(40px, 5.5vw, 76px);
  line-height: 0.95;
  letter-spacing: -0.04em;
  font-weight: 800;
  max-width: 14ch;
}
.tracks__title .accent { color: var(--yellow); }
.tracks__intro {
  max-width: 38ch;
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1.55;
}

.track {
  display: grid;
  grid-template-columns: minmax(180px, 320px) 1fr auto;
  gap: 32px;
  align-items: start;
  padding: 36px 0;
  border-top: 1px solid var(--line);
  position: relative;
  transition: padding 240ms var(--ease);
}
.track:last-child { border-bottom: 1px solid var(--line); }
.track:hover { padding: 36px 0 36px 12px; }

.track__num {
  font-size: clamp(80px, 13vw, 200px);
  line-height: 0.82;
  letter-spacing: -0.05em;
  font-weight: 900;
  color: var(--yellow);
  font-feature-settings: "tnum", "ss01";
}

.track__body { padding-top: clamp(8px, 1.5vw, 18px); }
.track__body h3 {
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  font-weight: 800;
  margin-bottom: 14px;
}
.track__lede {
  font-size: 16px;
  color: var(--ink-soft);
  line-height: 1.55;
  max-width: 56ch;
  margin-bottom: 18px;
}
.track__points {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
}
.track__points li::before { content: "·"; margin-right: 8px; color: var(--yellow); }

.track__cta {
  align-self: end;
  padding-top: clamp(8px, 1.5vw, 18px);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--yellow);
}

@media (max-width: 760px) {
  .track { grid-template-columns: 1fr; gap: 12px; }
  .track__cta { align-self: start; }
  .track__num { font-size: 80px; }
}

/* ------------------------------------------------------------
   Audio strip — feature: konzert 2025 to listen to
   ------------------------------------------------------------ */

.audio {
  background: var(--bg-soft);
  padding: var(--section-y) 0;
  position: relative;
  overflow: hidden;
}
.audio::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(800px 400px at 100% 0%, rgba(255, 210, 63, 0.06), transparent 60%);
  pointer-events: none;
}

.audio__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  margin-bottom: 56px;
  align-items: end;
}
@media (max-width: 860px) { .audio__head { grid-template-columns: 1fr; gap: 24px; } }

.audio__title {
  font-size: clamp(36px, 4.6vw, 64px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  font-weight: 800;
}
.audio__title .accent { color: var(--coral); font-style: italic; font-weight: 800; }
.audio__intro {
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1.55;
  max-width: 48ch;
}

.audio__list {
  display: grid;
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.audio-row {
  display: grid;
  grid-template-columns: 60px 1.4fr 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 22px 4px;
  background: var(--bg-soft);
  transition: background 200ms var(--ease);
}
.audio-row:hover { background: var(--bg-card); }

.audio-row .num {
  font-family: var(--mono);
  font-size: 14px;
  color: var(--mute);
  font-feature-settings: "tnum";
}
.audio-row .title {
  font-size: 19px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.audio-row .meta {
  font-size: 13px;
  color: var(--ink-soft);
}
.audio-row .meta em { color: var(--mute); font-style: normal; }

.audio-row .play {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--yellow);
  color: var(--bg);
  font-size: 14px;
  font-weight: 700;
  transition: transform 200ms var(--ease), background 200ms var(--ease);
}
.audio-row .play:hover { background: #ffe070; transform: scale(1.06); }
.audio-row .play::before { content: "▶"; transform: translateX(1px); }

@media (max-width: 700px) {
  .audio-row { grid-template-columns: 32px 1fr auto; gap: 14px; }
  .audio-row .meta { display: none; }
}

.audio__more {
  margin-top: 28px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--coral);
}

/* ------------------------------------------------------------
   Posts — recent blog entries
   ------------------------------------------------------------ */

.posts {
  padding: var(--section-y) 0;
}
.posts__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: 56px;
}
.posts__title {
  font-size: clamp(36px, 4.6vw, 64px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  font-weight: 800;
}
.posts__title .accent { color: var(--yellow); }

.posts__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 32px;
}
@media (max-width: 1100px) { .posts__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 720px)  { .posts__grid { grid-template-columns: 1fr; } }

.post-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-soft);
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--line);
  transition: transform 200ms var(--ease), border-color 200ms var(--ease);
}
.post-card:hover { transform: translateY(-3px); border-color: var(--line-strong); }

.post-card__img {
  aspect-ratio: 16 / 10;
  background: #1a1f29 center/cover no-repeat;
}
.post-card__body {
  padding: 24px 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
}
.post-card__meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mute);
}
.post-card__meta .author { color: var(--yellow); }
.post-card__title {
  font-size: clamp(20px, 1.8vw, 26px);
  line-height: 1.18;
  font-weight: 700;
  letter-spacing: -0.015em;
}
.post-card__excerpt {
  color: var(--ink-soft);
  font-size: 14.5px;
  line-height: 1.5;
}
.post-card__more {
  margin-top: auto;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--yellow);
}

.post-card--feature .post-card__img { aspect-ratio: 16 / 11; }
.post-card--feature .post-card__title { font-size: clamp(26px, 2.4vw, 34px); }

/* ------------------------------------------------------------
   Sponsors strip
   ------------------------------------------------------------ */

.sponsors {
  padding: 64px 0;
  border-top: 1px solid var(--line);
}
.sponsors__head {
  display: grid;
  grid-template-columns: 1fr 2.5fr;
  gap: 36px;
  align-items: center;
}
@media (max-width: 760px) { .sponsors__head { grid-template-columns: 1fr; } }

.sponsors__label {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mute);
}
.sponsors__label strong { display: block; color: var(--ink); font-size: 18px; font-weight: 600; letter-spacing: -0.005em; text-transform: none; margin-top: 6px; }

.sponsors__row {
  display: flex;
  flex-wrap: wrap;
  gap: 36px;
  align-items: center;
}
.sponsors__row a {
  display: inline-flex;
  align-items: center;
  height: 48px;
  filter: grayscale(1) brightness(2.4) contrast(0.95);
  opacity: 0.85;
  transition: opacity 200ms var(--ease), filter 200ms var(--ease);
}
.sponsors__row a:hover { filter: grayscale(0) brightness(1); opacity: 1; }
.sponsors__row img { max-height: 48px; width: auto; }

/* ------------------------------------------------------------
   Footer
   ------------------------------------------------------------ */

.footer {
  background: var(--bg-deep);
  padding: 80px 0 40px;
  border-top: 1px solid var(--line);
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 36px;
  margin-bottom: 56px;
}
@media (max-width: 900px) { .footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .footer__grid { grid-template-columns: 1fr; } }

.footer h4 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-bottom: 16px;
  font-weight: 500;
}
.footer__brand {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.025em;
  margin-bottom: 14px;
}
.footer__brand .accent { color: var(--yellow); }
.footer__tagline { color: var(--ink-soft); font-size: 14.5px; line-height: 1.5; max-width: 30ch; }

.footer ul { list-style: none; display: flex; flex-direction: column; gap: 10px; font-size: 14.5px; }
.footer ul a { color: var(--ink-soft); transition: color 200ms var(--ease); }
.footer ul a:hover { color: var(--yellow); }

.footer__bottom {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--mute);
}
.footer__bottom a { color: var(--mute); transition: color 200ms var(--ease); }
.footer__bottom a:hover { color: var(--ink-soft); }

/* ============================================================
   PAGE-HERO — used on all sub pages
   ============================================================ */

.page-hero {
  padding: clamp(60px, 9vh, 110px) 0 clamp(48px, 7vh, 90px);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(900px 500px at 92% -10%, rgba(255, 210, 63, 0.10), transparent 60%);
  pointer-events: none;
}

.page-hero__crumb {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  margin-bottom: 28px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mute);
}
.page-hero__crumb a { color: var(--mute); transition: color 200ms var(--ease); }
.page-hero__crumb a:hover { color: var(--yellow); }
.page-hero__crumb .here { color: var(--yellow); }
.page-hero__crumb .sep { opacity: 0.4; }

.page-hero__title {
  font-size: clamp(48px, 9vw, 132px);
  line-height: 0.9;
  letter-spacing: -0.04em;
  font-weight: 900;
  margin-bottom: 28px;
}
.page-hero__title .accent { color: var(--yellow); }
.page-hero__title em { font-style: normal; color: var(--yellow); }

.page-hero__lede {
  font-size: clamp(17px, 1.5vw, 21px);
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 60ch;
}
.page-hero__lede strong { color: var(--ink); font-weight: 600; }

/* ============================================================
   SECTION-HEAD — reusable
   ============================================================ */

.section {
  padding: var(--section-y) 0;
}
.section--soft { background: var(--bg-soft); }

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: clamp(40px, 6vh, 72px);
}
.section-head__title {
  font-size: clamp(36px, 4.6vw, 64px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  font-weight: 800;
  max-width: 14ch;
}
.section-head__title .accent { color: var(--yellow); }
.section-head__title em { color: var(--yellow); font-style: normal; }
.section-head__intro {
  max-width: 46ch;
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1.55;
}

/* ============================================================
   PROSE — long text
   ============================================================ */

.prose {
  max-width: 64ch;
  font-size: clamp(17px, 1.4vw, 19px);
  line-height: 1.6;
  color: var(--ink-soft);
}
.prose p + p { margin-top: 1em; }
.prose strong { color: var(--ink); font-weight: 600; }

/* ============================================================
   PEOPLE GRID — Mitglieder
   ============================================================ */

.voice-block { padding: 56px 0; border-top: 1px solid var(--line); }
.voice-block:first-of-type { border-top: 0; padding-top: 0; }

.voice-head {
  display: grid;
  grid-template-columns: minmax(120px, 200px) 1fr;
  gap: 28px;
  align-items: baseline;
  margin-bottom: 36px;
}
@media (max-width: 720px) { .voice-head { grid-template-columns: 1fr; gap: 8px; } }

.voice-num {
  font-size: clamp(56px, 8vw, 100px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -0.04em;
  color: var(--yellow);
  font-feature-settings: "tnum";
}
.voice-name {
  font-size: clamp(24px, 2.5vw, 36px);
  line-height: 1.05;
  font-weight: 700;
  letter-spacing: -0.025em;
}
.voice-name .label {
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mute);
  font-weight: 500;
  margin-bottom: 10px;
}

.people-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 18px;
}

.person {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  transition: border-color 200ms var(--ease), transform 200ms var(--ease);
}
.person:hover { border-color: var(--line-strong); transform: translateY(-2px); }
.person__img {
  aspect-ratio: 1 / 1;
  background: #1a1f29 center/cover no-repeat;
  filter: grayscale(0.15) contrast(1.05);
}
.person__body { padding: 14px 16px 18px; }
.person__name {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.person__role {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  margin-top: 4px;
}
.person__since { color: var(--yellow); }

/* ============================================================
   ALBUM GRID — Galerie
   ============================================================ */

.year-block { padding: 64px 0; border-top: 1px solid var(--line); }
.year-block:first-of-type { border-top: 0; padding-top: 0; }
.year-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 32px;
}
.year-num {
  font-size: clamp(56px, 7vw, 88px);
  font-weight: 900;
  letter-spacing: -0.04em;
  color: var(--yellow);
  line-height: 0.9;
  font-feature-settings: "tnum";
}
.year-meta { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mute); }

.album-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
}

.album {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  cursor: pointer;
  background: #1a1f29 center/cover no-repeat;
  isolation: isolate;
  transition: transform 200ms var(--ease);
}
.album:hover { transform: translateY(-2px); }
.album::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,13,18,0) 30%, rgba(10,13,18,0.85) 100%);
  z-index: 1;
}
.album__body {
  position: absolute;
  z-index: 2;
  bottom: 16px; left: 18px; right: 18px;
}
.album__title {
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.015em;
  margin-bottom: 4px;
}
.album__meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  opacity: 0.85;
}
.album--feature { aspect-ratio: 16 / 9; grid-column: span 2; }
@media (max-width: 720px) { .album--feature { grid-column: auto; aspect-ratio: 4 / 3; } }

/* ============================================================
   TIMELINE — Chronik
   ============================================================ */

.timeline {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 0;
}
@media (max-width: 720px) { .timeline { grid-template-columns: 80px 1fr; } }

.timeline__year {
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--yellow);
  font-feature-settings: "tnum";
  padding: 28px 0 28px 0;
  border-top: 1px solid var(--line);
}
.timeline__entry {
  padding: 28px 0;
  border-top: 1px solid var(--line);
  font-size: 16.5px;
  line-height: 1.55;
  color: var(--ink-soft);
}
.timeline__entry strong { color: var(--ink); font-weight: 600; }
.timeline__year:first-of-type, .timeline__entry:first-of-type { border-top: 0; padding-top: 8px; }

/* ============================================================
   AGENDA — featured event card
   ============================================================ */

.event {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
}
@media (max-width: 860px) { .event { grid-template-columns: 1fr; } }

.event__body { padding: clamp(36px, 4vw, 56px); }
.event__label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-bottom: 24px;
}
.event__title {
  font-size: clamp(40px, 5vw, 72px);
  line-height: 0.92;
  letter-spacing: -0.035em;
  font-weight: 900;
  margin-bottom: 18px;
}
.event__title .accent { color: var(--yellow); }
.event__lede {
  color: var(--ink-soft);
  font-size: 17px;
  line-height: 1.55;
  margin-bottom: 24px;
}
.event__meta {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 28px;
  margin-bottom: 28px;
  font-size: 14.5px;
}
.event__meta dt {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 4px;
}
.event__meta dd { color: var(--ink); font-weight: 600; }

.event__poster {
  background: #1a1f29 center/cover no-repeat;
  min-height: 360px;
  border-left: 1px solid var(--line);
}
@media (max-width: 860px) { .event__poster { border-left: 0; border-top: 1px solid var(--line); } }

.upcoming {
  margin-top: 56px;
  display: grid;
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.upcoming__row {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  gap: 24px;
  align-items: center;
  background: var(--bg);
  padding: 22px 4px;
  font-size: 16px;
}
.upcoming__date {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--yellow);
  font-feature-settings: "tnum";
}
.upcoming__title { font-weight: 600; }
.upcoming__meta { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--mute); }

/* ============================================================
   MUSIC — year accordion
   ============================================================ */

.year-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 40px;
}
.year-tab {
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  cursor: pointer;
  transition: background 200ms var(--ease), color 200ms var(--ease), border-color 200ms var(--ease);
}
.year-tab.is-active { background: var(--yellow); color: var(--bg); border-color: var(--yellow); }

/* ============================================================
   KONTAKT — info grid
   ============================================================ */

.kontakt-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px;
  align-items: start;
}
@media (max-width: 860px) { .kontakt-grid { grid-template-columns: 1fr; } }

.info-card {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 32px 30px;
}
.info-card h3 {
  font-size: clamp(22px, 2vw, 28px);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 18px;
}
.info-card h3 .accent { color: var(--yellow); }
.info-card dl { display: grid; grid-template-columns: 1fr; gap: 14px; }
.info-card dt {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 4px;
}
.info-card dd { font-size: 16.5px; color: var(--ink); }
.info-card dd a { color: var(--yellow); }
.info-card dd a:hover { text-decoration: underline; }

.map-placeholder {
  aspect-ratio: 4 / 3;
  background:
    radial-gradient(600px 300px at 30% 30%, rgba(255, 210, 63, 0.08), transparent 60%),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.03) 0, rgba(255,255,255,0.03) 1px, transparent 1px, transparent 40px),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.03) 0, rgba(255,255,255,0.03) 1px, transparent 1px, transparent 40px),
    var(--bg-soft);
  border-radius: 14px;
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.map-placeholder::after {
  content: "📍 Pfarrsaal · Nebikon";
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--yellow);
  background: var(--bg);
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--yellow);
}
