/* ============================================================
   Monschau Festival — Website
   "Ein Sommerabend an der Rur." — hell, farbig, einladend,
   emotional. Das Rur-Blau (#1F4E9E) ist die FÜHRENDE Akzentfarbe:
   Headlines, Buttons, Navigation, Wellen-Übergänge. Die sieben
   Dörferfarben erscheinen dezent als Signatur. Keine Schatten,
   keine dunkle Business-Optik.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

:root {
  --ink-soft: #2A2D34;
  --cream:   #FAF6EE;  /* warm paper — replaces pure white surfaces */
  --cream-2: #F4EEE2;  /* slightly deeper warm tone for alt sections   */
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 104px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  font-family: var(--font-text);
  font-weight: 400;
  color: var(--ink-soft);
  background: var(--cream);
  font-size: clamp(1rem, 0.96rem + 0.25vw, 1.1875rem);
  line-height: 1.62;
}

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

/* ---- layout primitives -------------------------------------------------- */
.container { width: 100%; max-width: 1240px; margin: 0 auto; padding-inline: clamp(20px, 5vw, 56px); }

.section { padding-block: clamp(72px, 9vw, 140px); position: relative; }
.section--sky { background: var(--mf-blue-tint); }
.section--warm { background: #FBFAF6; }
/* seven-colour signature bars (from the logo) */
.color-bars { display: flex; gap: 4px; }
.color-bars span { width: 26px; height: 7px; border-radius: 2px; }
.color-bars span:nth-child(1){ background: var(--mf-green); }
.color-bars span:nth-child(2){ background: var(--mf-yellow); }
.color-bars span:nth-child(3){ background: var(--mf-blue); }
.color-bars span:nth-child(4){ background: var(--mf-red); }
.color-bars span:nth-child(5){ background: var(--mf-petrol); }
.color-bars span:nth-child(6){ background: var(--mf-lilac); }
.color-bars span:nth-child(7){ background: var(--mf-grey); }

.kicker {
  font-family: var(--font-text);
  font-weight: 700;
  font-size: clamp(0.8125rem, 0.78rem + 0.2vw, 0.9375rem);
  letter-spacing: var(--ls-kicker);
  text-transform: uppercase;
  color: var(--mf-blue);
  margin: 0 0 18px;
}

.section-title {
  font-family: var(--font-display);
  font-weight: 900;
  line-height: 1.0;
  letter-spacing: -0.015em;
  font-size: clamp(2rem, 1.3rem + 3.4vw, 3.85rem);
  margin: 0;
  color: var(--mf-blue);
  text-wrap: balance;
}
.section-intro {
  margin: 22px 0 0;
  max-width: 56ch;
  color: var(--mf-muted);
  font-size: clamp(1.0625rem, 1rem + 0.4vw, 1.3125rem);
  line-height: 1.55;
}

/* ---- buttons ------------------------------------------------------------ */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.0625rem;
  line-height: 1;
  padding: 18px 30px;
  border-radius: var(--radius-cta);
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .25s ease, background-color .25s ease, color .25s ease, border-color .25s ease;
  text-decoration: none;
}
.btn .arrow { transition: transform .25s ease; }
.btn:hover .arrow { transform: translateX(4px); }
.btn--primary { background: var(--mf-blue); color: #fff; }
.btn--primary:hover { background: #18407f; transform: translateY(-2px); }
.btn--ghost { background: #fff; color: var(--mf-blue); border-color: var(--mf-blue); }
.btn--ghost:hover { background: var(--mf-blue); color: #fff; }

/* ============================================================
   Header / Navigation — hell, Logo prominent
   ============================================================ */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  padding: 16px clamp(20px, 5vw, 56px);
  background: rgba(250,246,238,0.85);
  backdrop-filter: saturate(150%) blur(12px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s ease, padding .3s ease, background-color .3s ease;
}
.nav.scrolled {
  background: rgba(250,246,238,0.96);
  border-bottom-color: var(--mf-line);
  padding-block: 12px;
}
.nav__brand { display: flex; align-items: center; gap: 14px; }
.nav__brand img { height: 54px; width: 54px; object-fit: contain; transition: height .3s ease; display: block; }
.nav.scrolled .nav__brand img { height: 46px; width: 46px; }
.nav__brand .wordmark {
  font-family: var(--font-display); font-weight: 900; font-size: 1.3rem;
  letter-spacing: -0.01em; line-height: 1; color: var(--mf-blue);
}
.nav__brand .wordmark small { display: block; font-family: var(--font-text); font-weight: 600; font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--mf-muted); margin-top: 4px; }
.nav__links { display: flex; align-items: center; gap: clamp(18px, 2vw, 34px); }
.nav__links a {
  font-family: var(--font-text); font-weight: 600;
  font-size: 0.9375rem; letter-spacing: 0.01em;
  color: var(--ink-soft); position: relative; padding-block: 6px;
}
.nav__links a:not(.btn)::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 2px; width: 0;
  background: var(--mf-blue); transition: width .25s ease;
}
.nav__links a:not(.btn):hover { color: var(--mf-blue); }
.nav__links a:not(.btn):hover::after { width: 100%; }
.nav__cta { padding: 12px 22px; font-size: 0.9375rem; color: #fff; }

.nav__toggle { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 8px; z-index: 110; }
.nav__toggle span { width: 26px; height: 2px; background: var(--mf-blue); transition: transform .3s, opacity .3s; }
.nav.menu-open .nav__toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav.menu-open .nav__toggle span:nth-child(2) { opacity: 0; }
.nav.menu-open .nav__toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   Hero — Original-Logo auf warmem Verlauf, kompakter
   ============================================================ */
.hero {
  position: relative; min-height: 72svh;
  display: flex; align-items: center; justify-content: center;
  text-align: center; isolation: isolate; overflow: hidden;
}
.hero__sky {
  position: absolute; inset: 0; z-index: -2;
  background:
    linear-gradient(180deg,
      #EFF3FA 0%,
      #F1F2EC 38%,
      #F6F2E8 70%,
      var(--cream) 100%);
}
/* warme Sonnen-Aura, organisch */
.hero__glow {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(58% 48% at 50% 32%, rgba(244,198,59,0.14), transparent 70%),
    radial-gradient(70% 60% at 80% 82%, rgba(59,169,166,0.10), transparent 72%),
    radial-gradient(60% 55% at 16% 78%, rgba(139,191,77,0.10), transparent 72%);
}
.hero__inner {
  display: flex; flex-direction: column; align-items: center;
  padding: 116px 0 56px;
}
.hero__eyebrow {
  font-family: var(--font-text); font-weight: 700; text-transform: uppercase;
  letter-spacing: var(--ls-kicker); font-size: clamp(0.8125rem, 0.78rem + 0.2vw, 0.9375rem);
  color: var(--mf-blue); margin: 0 0 clamp(22px, 3vw, 36px);
}
.hero__sub {
  margin: clamp(22px, 3vw, 34px) auto 0; max-width: 30ch;
  font-size: clamp(1.125rem, 1rem + 0.7vw, 1.5rem); line-height: 1.45;
  color: var(--ink-soft); font-weight: 400; text-wrap: balance;
}
.hero__actions { margin-top: 30px; display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }

/* ---- Hero logo (original asset, static) -------------------------------- */
.hero__logo { width: min(560px, 84vw); height: auto; display: block; }

/* ---- Hero entrance: gentle fade of the original logo ------------------- */
@media (prefers-reduced-motion: no-preference) {
  .hero__eyebrow { opacity: 0; animation: heroFade .7s ease forwards .15s; }
  .hero__logo    { opacity: 0; animation: heroFade 1s cubic-bezier(.2,.8,.25,1) forwards .45s; }
  .hero__sub     { opacity: 0; animation: heroFade .8s ease forwards 1.0s; }
  .hero__actions { opacity: 0; animation: heroFade .8s ease forwards 1.2s; }
}
@keyframes heroFade { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }

/* ---- Rur-Welle divider -------------------------------------------------- */
.wave { position: relative; line-height: 0; }
.wave svg { display: block; width: 100%; height: clamp(60px, 7.5vw, 116px); }
.wave--overlap { margin-top: clamp(-116px, -7.5vw, -60px); position: relative; z-index: 1; pointer-events: none; }

/* ============================================================
   Upcoming dates strip
   ============================================================ */
.upcoming { border-bottom: 1px solid var(--mf-line); }
.upcoming__head { display: flex; align-items: baseline; justify-content: space-between; gap: 20px; margin-bottom: 8px; }
.upcoming__head h2 { font-family: var(--font-display); font-weight: 900; font-size: 1.5rem; margin: 0; color: var(--mf-blue); }
.upcoming__head a { font-weight: 600; color: var(--mf-blue); font-size: 0.95rem; }
.upcoming__head a:hover { text-decoration: underline; }
.upcoming__list { display: grid; grid-template-columns: repeat(3, 1fr); }
.date-row { display: flex; align-items: baseline; gap: 22px; padding: 28px 28px 28px 0; border-top: 1px solid var(--mf-line); transition: padding-left .25s ease; }
.upcoming__list .date-row:not(:last-child) { border-right: 1px solid var(--mf-line); padding-right: 32px; }
.upcoming__list .date-row + .date-row { padding-left: 32px; }
.upcoming__list .date-row:hover { padding-left: 40px; }
.date-row__day { font-family: var(--font-display); font-weight: 900; font-size: 1.75rem; line-height: 1; white-space: nowrap; min-width: 88px; color: var(--mf-blue); }
.date-row__day small { display: block; font-size: 0.8125rem; font-weight: 600; color: var(--mf-muted); letter-spacing: 0.04em; margin-top: 6px; text-transform: uppercase; }
.date-row__body h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.125rem; margin: 0 0 4px; line-height: 1.15; color: var(--ink-soft); }
.date-row__body p { margin: 0; color: var(--mf-muted); font-size: 0.9375rem; }

/* ============================================================
   Veranstaltungen — horizontale Filmstrip-Bühne
   ============================================================ */
.section--events { background: linear-gradient(180deg, var(--cream) 0%, #EFEFE6 100%); overflow: hidden; }
.events__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; }
.film-nav { display: flex; gap: 10px; flex-shrink: 0; }
.film-nav__btn {
  width: 52px; height: 52px; border-radius: var(--radius-pill);
  border: 2px solid var(--mf-blue); background: #fff; color: var(--mf-blue);
  font-size: 1.25rem; cursor: pointer; display: grid; place-items: center;
  transition: background-color .2s, color .2s, transform .2s, opacity .2s;
}
.film-nav__btn:hover { background: var(--mf-blue); color: #fff; }
.film-nav__btn:active { transform: scale(0.94); }
.film-nav__btn:disabled { opacity: 0.32; cursor: default; }
.film-nav__btn:disabled:hover { background: #fff; color: var(--mf-blue); }

.filmstrip-wrap { position: relative; margin-top: clamp(36px, 4.5vw, 64px); }
.filmstrip-wrap::before, .filmstrip-wrap::after {
  content: ""; position: absolute; top: 0; bottom: 18px; width: clamp(24px, 5vw, 72px); z-index: 2; pointer-events: none;
}
.filmstrip-wrap::before { left: 0; background: linear-gradient(90deg, #F4F4EB, rgba(244,244,235,0)); }
.filmstrip-wrap::after { right: 0; background: linear-gradient(270deg, #F4F4EB, rgba(244,244,235,0)); }
.filmstrip {
  display: flex; gap: clamp(20px, 2.6vw, 40px);
  overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 8px clamp(20px, 5vw, 56px) 18px;
  scroll-padding-left: clamp(20px, 5vw, 56px);
  -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.filmstrip::-webkit-scrollbar { display: none; }
.filmstrip .poster {
  flex: 0 0 clamp(248px, 27vw, 340px); scroll-snap-align: start; margin: 0;
}

.poster { margin: 0; }
.poster__frame {
  position: relative; aspect-ratio: 1 / 1.414; overflow: hidden;
  background: #ECEAE2;
  border: 1px solid rgba(0,0,0,0.05); border-radius: var(--radius-sm);
  box-shadow: 0 18px 40px -28px rgba(20,40,80,0.45);
  transition: transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease;
}
.poster__frame image-slot { width: 100%; height: 100%; background: transparent; }
.poster:hover .poster__frame { transform: translateY(-8px) scale(1.012); box-shadow: 0 28px 56px -26px rgba(20,40,80,0.5); }
.poster__caption { padding-top: 18px; display: flex; flex-direction: column; gap: 4px; }
.poster__caption .ev-date { font-family: var(--font-text); font-weight: 700; font-size: 0.8125rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--accent, var(--mf-muted)); }
.poster__caption h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.375rem; margin: 2px 0 0; line-height: 1.1; color: var(--ink-soft); }
.poster__caption .ev-place { color: var(--mf-muted); font-size: 0.95rem; }
.poster__caption .ev-ticket { margin-top: 12px; align-self: flex-start; font-family: var(--font-display); font-weight: 700; font-size: 0.9375rem; display: inline-flex; align-items: center; gap: 8px; color: #fff; background: var(--mf-blue); padding: 11px 20px; border-radius: var(--radius-pill); transition: background-color .2s ease, transform .2s ease, box-shadow .2s ease; }
.poster__caption .ev-ticket .arrow { transition: transform .2s ease; }
.poster__caption .ev-ticket:hover { background: #18407f; transform: translateY(-1px); box-shadow: 0 8px 18px -8px rgba(31,78,158,0.6); }
.poster__caption .ev-ticket:hover .arrow { transform: translateX(4px); }

/* Filmstrip end-cap */
.poster--end { display: block; text-decoration: none; }
.poster__endcard {
  aspect-ratio: 1 / 1.414; border-radius: var(--radius-sm);
  background: linear-gradient(155deg, var(--mf-blue) 0%, #2C66C0 55%, #3BA9A6 130%);
  color: #fff; display: flex; flex-direction: column; justify-content: space-between;
  padding: clamp(22px, 2.4vw, 34px); box-shadow: 0 18px 40px -28px rgba(20,40,80,0.5);
  transition: transform .4s cubic-bezier(.2,.7,.2,1);
}
.poster--end:hover .poster__endcard { transform: translateY(-8px) scale(1.012); }
.poster__endcard .color-bars span { height: 9px; width: 22px; }
.poster__endtitle { font-family: var(--font-display); font-weight: 900; font-size: clamp(1.9rem, 1rem + 2.4vw, 2.8rem); line-height: 0.95; letter-spacing: -0.02em; }
.poster__endlink { font-family: var(--font-display); font-weight: 700; font-size: 1.0625rem; display: inline-flex; align-items: center; gap: 8px; }
.poster--end:hover .poster__endlink .arrow { transform: translateX(4px); transition: transform .2s; }

/* ============================================================
   Claim band — kräftiges Rur-Blau, emotional
   ============================================================ */
.claim-band { background: linear-gradient(180deg, #2A6CAE 0%, #2456A4 52%, #1F4E9E 100%); color: #fff; text-align: center; padding-block: clamp(64px, 9vw, 120px); position: relative; overflow: hidden; }
.claim-band::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(70% 120% at 50% 50%, rgba(120,180,210,0.18), transparent 70%); }
.claim-band .container { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 22px; }
.claim-band p.eyebrow { font-family: var(--font-text); font-weight: 700; text-transform: uppercase; letter-spacing: var(--ls-kicker); font-size: 0.9375rem; color: rgba(255,255,255,0.78); margin: 0; }
.claim-band h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(1.85rem, 1rem + 3.4vw, 3.4rem); line-height: 1.02; letter-spacing: -0.015em; margin: 0; max-width: 18ch; text-wrap: balance; }
.claim-band .color-bars { margin-top: 4px; }
.claim-band .color-bars span { height: 8px; width: 32px; }

/* ============================================================
   Rückblicke — Erinnerungs-Pinnwand / Polaroids an der Lichterkette
   ============================================================ */
.section--warm { background: linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%); }
.memoryboard {
  position: relative;
  width: 100%;
  aspect-ratio: 1600 / 1240;
  margin-top: clamp(36px, 4.5vw, 64px);
}
.polaroid {
  position: absolute;
  left: var(--x, 50%); top: var(--y, 0%);
  width: var(--w, 16%);
  margin: 0;
  background: #fff; padding: 12px 12px 0;
  border-radius: 3px;
  box-shadow: 0 16px 30px -18px rgba(40,30,15,0.5), 0 2px 6px rgba(0,0,0,0.07);
  transform: translateX(-50%) rotate(var(--rot, 0deg)); transform-origin: center;
  transition: transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease;
}
.polaroid:hover { transform: translateX(-50%) rotate(0deg) translateY(-6px) scale(1.03); box-shadow: 0 26px 44px -18px rgba(40,30,15,0.55); z-index: 20; }
/* mobile: calm stacked flow instead of the positioned wall */
@media (max-width: 760px) {
  .memoryboard { position: static; aspect-ratio: auto; display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(18px, 4vw, 30px); }
  .polaroid { position: static; width: 100%; transform: rotate(var(--rot, 0deg)); }
}
@media (max-width: 440px) {
  .memoryboard { grid-template-columns: 1fr; }
}
.polaroid__pin {
  position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
  width: 20px; height: 20px; border-radius: 50%;
  background:
    radial-gradient(circle at 36% 32%, rgba(255,255,255,0.85), rgba(255,255,255,0) 45%),
    var(--pin, var(--mf-grey));
  box-shadow: 0 4px 7px rgba(0,0,0,0.28);
}
.polaroid__photo { aspect-ratio: 1 / 1; overflow: hidden; background: var(--mf-blue-tint); }
.polaroid--portrait  .polaroid__photo { aspect-ratio: 4 / 5; }
.polaroid--landscape .polaroid__photo { aspect-ratio: 5 / 4; }
.polaroid__photo image-slot { width: 100%; height: 100%; }
.polaroid figcaption {
  font-family: "Caveat", cursive; font-weight: 600;
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.6rem); line-height: 1.3;
  text-align: center; color: #3A3A3A; padding: 10px 10px 14px;
  overflow-wrap: break-word;
}

/* ============================================================
   Über uns
   ============================================================ */
.about__grid { margin-top: clamp(40px, 5vw, 64px); display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px, 5vw, 80px); align-items: center; }
.about__text p { margin: 0 0 20px; }
.about__claims { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.claim-chip { font-family: var(--font-display); font-weight: 700; font-size: 1rem; padding: 10px 18px; border: 2px solid var(--mf-blue); border-radius: var(--radius-pill); color: var(--mf-blue); }
.about__photo { aspect-ratio: 4 / 3; overflow: hidden; background: var(--mf-blue-tint); border: 1px solid rgba(0,0,0,0.05); }
.about__photo image-slot { width: 100%; height: 100%; }

/* ============================================================
   Kontakt
   ============================================================ */
.contact__grid { margin-top: clamp(40px, 5vw, 64px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 6vw, 96px); }
.contact-lines { font-size: 1.1875rem; line-height: 1.85; }
.contact-lines a { color: var(--mf-blue); border-bottom: 2px solid rgba(31,78,158,0.25); transition: border-color .2s; }
.contact-lines a:hover { border-color: var(--mf-blue); }
.contact-lines strong { font-weight: 700; color: var(--ink-soft); }
.contact__label { font-family: var(--font-text); font-weight: 700; text-transform: uppercase; letter-spacing: var(--ls-label); font-size: 0.8125rem; color: var(--mf-blue); margin: 0 0 14px; }
.social-row { display: flex; gap: 12px; margin-top: 8px; flex-wrap: wrap; }
.social-row a { display: inline-flex; align-items: center; gap: 10px; font-weight: 700; font-size: 0.95rem; color: var(--mf-blue); padding: 12px 18px; border: 2px solid var(--mf-blue); border-radius: var(--radius-pill); transition: background-color .2s, color .2s; }
.social-row a:hover { background: var(--mf-blue); color: #fff; }
.newsletter { margin-top: 36px; }
.newsletter form { display: flex; gap: 10px; margin-top: 14px; max-width: 460px; flex-wrap: wrap; }
.newsletter input { flex: 1 1 220px; font-family: var(--font-text); font-size: 1rem; padding: 16px 18px; border: 2px solid var(--mf-line); border-radius: var(--radius-sm); color: var(--ink-soft); background: #fff; }
.newsletter input:focus { outline: none; border-color: var(--mf-blue); }
.newsletter .hint { font-size: 0.8125rem; color: var(--mf-muted); margin-top: 10px; }

/* ============================================================
   Footer — Rur-Blau
   ============================================================ */
.footer { background: var(--mf-blue); color: rgba(255,255,255,0.82); padding-block: clamp(56px, 7vw, 92px); }
.footer a { color: rgba(255,255,255,0.82); transition: color .2s; }
.footer a:hover { color: #fff; }
.footer__top { display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; align-items: flex-start; }
.footer__brand { display: flex; flex-direction: column; gap: 18px; max-width: 320px; }
.footer__logo { background: #fff; padding: 16px 20px; border-radius: var(--radius-md); width: fit-content; }
.footer__logo img { width: 210px; height: auto; object-fit: contain; }
.footer__brand p { margin: 0; font-size: 0.95rem; color: rgba(255,255,255,0.72); line-height: 1.6; }
.footer__cols { display: flex; gap: clamp(40px, 6vw, 88px); flex-wrap: wrap; }
.footer__col h4 { font-family: var(--font-display); font-weight: 700; font-size: 0.8125rem; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.62); margin: 0 0 16px; }
.footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; font-size: 0.95rem; }
.footer__credit { margin-top: clamp(40px, 5vw, 64px); padding-top: 28px; border-top: 1px solid rgba(255,255,255,0.22); display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.footer__credit-text { font-family: var(--font-text); font-weight: 700; font-size: 0.75rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.58); }
.footer__credit-logo { display: block; line-height: 0; background: #FBF7EF; padding: 10px 18px; border-radius: var(--radius-md); box-shadow: 0 10px 24px -14px rgba(0,0,0,0.55); transition: transform .2s ease; }
.footer__credit-logo:hover { transform: translateY(-2px); }
.footer__credit-logo img { width: clamp(220px, 24vw, 300px); height: auto; }
.footer__legal { margin-top: 22px; padding-top: 0; border-top: none; display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: 0.8125rem; color: rgba(255,255,255,0.62); }
.footer__legal .legal-ids { color: rgba(255,255,255,0.5); }

/* ============================================================
   Scroll reveal
   ============================================================ */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ============================================================
   Responsive
   ============================================================ */
.menu-backdrop { display: none; }

@media (max-width: 1080px) {
  .upcoming__list { grid-template-columns: 1fr; }
  .upcoming__list .date-row { border-right: none !important; padding-left: 0 !important; }
  .upcoming__list .date-row:hover { padding-left: 8px !important; }
}

@media (max-width: 860px) {
  .nav__links {
    position: fixed; inset: 0 0 0 auto; width: min(82vw, 360px);
    background: #fff; flex-direction: column; align-items: flex-start; justify-content: center;
    gap: 28px; padding: 80px 40px; transform: translateX(100%);
    transition: transform .35s cubic-bezier(.2,.7,.2,1); z-index: 105;
  }
  .nav.menu-open .nav__links { transform: translateX(0); }
  .nav__links a:not(.btn) { font-size: 1.375rem; font-family: var(--font-display); font-weight: 700; color: var(--mf-blue); }
  .nav__cta { display: none; }
  .nav__toggle { display: flex; }
  .nav.menu-open .menu-backdrop, .menu-open .menu-backdrop { display: block; position: fixed; inset: 0; background: rgba(31,78,158,0.32); z-index: 104; }
  .about__grid, .contact__grid { grid-template-columns: 1fr; }
  .about__photo { order: -1; }
  .memoryboard { grid-template-columns: repeat(2, 1fr); }
  .footer__top { flex-direction: column; }
}

@media (max-width: 520px) {
  .hero__sub { max-width: none; }
  .nav__brand .wordmark { font-size: 1.1rem; }
  .footer__legal { flex-direction: column; }
  .events__head { flex-direction: column; align-items: flex-start; gap: 18px; }
  .memoryboard { grid-template-columns: 1fr; padding-inline: clamp(20px, 7vw, 40px); }
}

/* ============================================================
   Polaroid Lightbox
   ============================================================ */
.mf-lightbox {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(15, 15, 20, 0.80);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.22s ease;
}
.mf-lightbox.is-open { opacity: 1; pointer-events: auto; }
.mf-lightbox__polaroid {
  position: relative;
  background: #fff;
  padding: 14px 14px 0;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
  max-width: min(380px, 85vw);
}
.mf-lightbox__pin {
  position: absolute;
  top: -9px; left: 50%;
  transform: translateX(-50%);
  width: 14px; height: 14px;
  border-radius: 50%;
  box-shadow: 0 2px 5px rgba(0,0,0,0.35);
}
.mf-lightbox__photo { width: 100%; overflow: hidden; }
.mf-lightbox__img { display: block; width: 100%; height: 100%; object-fit: cover; }
.mf-lightbox__caption {
  font-family: 'Caveat', cursive;
  font-size: 18px; font-weight: 600;
  text-align: center; color: #333;
  margin: 0; padding: 10px 8px 14px; line-height: 1.3;
}
.mf-lightbox__close {
  position: fixed; top: 24px; right: 28px;
  background: none; border: none;
  color: #fff; font-size: 28px; line-height: 1;
  cursor: pointer; opacity: 0.75; padding: 0;
}
.mf-lightbox__close:hover { opacity: 1; }

/* Screen-reader only utility */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
