/* ============================================================
   Country on the Quay — holding page
   Mobile-first. Brand palette sampled from festival artwork.
   ============================================================ */

:root {
  --ink-navy:        #0a1f3d;
  --ink-navy-deep:   #001020;
  --barn-red:        #7a1f1f;
  --barn-red-bright: #a02828;
  --parchment:       #ece1c4;
  --parchment-light: #f4ead0;
  --wood-brown:      #5d431d;
  --wood-brown-dark: #3a2a14;

  --font-display: "Rye", "Georgia", serif;
  --font-body:    "Lora", Georgia, "Times New Roman", serif;

  --container:    1180px;
  --container-narrow: 720px;
  --radius:       6px;
  --shadow-md:    0 4px 14px rgba(0,0,0,.18);
  --shadow-lg:    0 14px 40px rgba(0,0,0,.35);
}

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

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--ink-navy);
  background: var(--parchment);
  -webkit-font-smoothing: antialiased;
}

img, picture { max-width: 100%; display: block; }

a { color: var(--barn-red); text-decoration-thickness: 1px; text-underline-offset: .15em; }
a:hover, a:focus-visible { color: var(--barn-red-bright); }

:focus-visible {
  outline: 3px solid var(--barn-red-bright);
  outline-offset: 3px;
  border-radius: 2px;
}

.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--ink-navy); color: var(--parchment-light);
  padding: .75rem 1rem; z-index: 100; font-weight: 700;
}
.skip-link:focus { left: 0; }

.container {
  width: 100%;
  max-width: var(--container);
  padding: 0 1.25rem;
  margin: 0 auto;
}
.container--narrow { max-width: var(--container-narrow); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-block;
  font-family: var(--font-display);
  letter-spacing: .04em;
  font-size: 1rem;
  padding: .9rem 1.75rem;
  border-radius: var(--radius);
  border: 2px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: transform .15s ease, background-color .15s ease, box-shadow .15s ease;
}
.btn--primary {
  background: var(--barn-red);
  color: var(--parchment-light);
  box-shadow: var(--shadow-md);
}
.btn--primary:hover, .btn--primary:focus-visible {
  background: var(--barn-red-bright);
  color: var(--parchment-light);
  transform: translateY(-1px);
}
.btn--ghost {
  background: transparent;
  color: var(--parchment-light);
  border-color: color-mix(in srgb, var(--parchment-light) 60%, transparent);
}
.btn--ghost:hover, .btn--ghost:focus-visible {
  background: rgba(255,255,255,.06);
  color: var(--parchment-light);
  border-color: var(--parchment-light);
}
.btn--lg {
  font-size: 1.15rem;
  padding: 1.1rem 2.25rem;
  letter-spacing: .06em;
}
@media (min-width: 720px) {
  .btn--lg { font-size: 1.25rem; padding: 1.2rem 2.75rem; }
}

/* ---------- Section heads ---------- */
.section-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.85rem, 4vw, 2.75rem);
  line-height: 1.1;
  color: var(--ink-navy);
  text-align: center;
  margin: 0 0 .75rem;
  letter-spacing: .01em;
}
.section-lede {
  text-align: center;
  font-size: 1.125rem;
  max-width: 52ch;
  margin: 0 auto 2.5rem;
  color: color-mix(in srgb, var(--ink-navy) 85%, transparent);
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  background: var(--ink-navy-deep);
  overflow: hidden;
}
.hero__art img {
  width: 100%;
  height: auto;
  display: block;
}
.hero__overlay {
  /* On mobile the artwork already contains all the info — overlay sits below. */
  background: linear-gradient(180deg, var(--ink-navy-deep) 0%, var(--ink-navy) 100%);
  color: var(--parchment-light);
  padding: 2.5rem 1.25rem 3rem;
  text-align: center;
}
.hero__content {
  max-width: 720px;
  margin: 0 auto;
}
.hero__eyebrow {
  font-family: var(--font-display);
  letter-spacing: .15em;
  text-transform: uppercase;
  font-size: .9rem;
  color: var(--parchment);
  margin: 0 0 .5rem;
  opacity: .9;
}
.hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 7vw, 3.5rem);
  line-height: 1;
  color: var(--parchment-light);
  margin: 0 0 1rem;
}
.hero__tagline {
  font-size: 1.15rem;
  margin: 0 auto 1.75rem;
  max-width: 38ch;
  color: color-mix(in srgb, var(--parchment-light) 90%, transparent);
}
.hero__ctas {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
}
.hero__small-print {
  margin: 1.25rem auto 0;
  max-width: 56ch;
  font-size: .82rem;
  text-align: center;
  text-wrap: balance;
  letter-spacing: .02em;
  color: color-mix(in srgb, var(--parchment-light) 75%, transparent);
}

@media (min-width: 768px) {
  /* Show banner at full natural aspect ratio — never crop the artwork.
     Background fills any letterboxing on ultra-wide screens. */
  .hero { background: var(--ink-navy-deep); }
  .hero__art {
    max-width: 1920px;
    margin: 0 auto;
  }
  .hero__art img {
    width: 100%;
    height: auto;
    max-height: 90vh;
    object-fit: contain;
    object-position: center;
  }
  .hero__overlay {
    padding: 2.5rem 2rem 3.5rem;
  }
}

/* ---------- Countdown ---------- */
.countdown {
  background: var(--ink-navy);
  color: var(--parchment-light);
  padding: 3rem 0;
  border-top: 4px solid var(--barn-red);
  border-bottom: 4px solid var(--barn-red);
}
.countdown .section-title { color: var(--parchment-light); }
.countdown__grid {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 1rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .5rem;
  text-align: center;
  max-width: 600px;
  margin-left: auto; margin-right: auto;
}
.countdown__grid li {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(236,225,196,.2);
  border-radius: var(--radius);
  padding: 1rem .25rem;
  display: flex; flex-direction: column;
}
.countdown__grid strong {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 6vw, 2.75rem);
  line-height: 1;
  color: var(--parchment-light);
  font-variant-numeric: tabular-nums;
  font-weight: 400;
}
.countdown__grid span {
  display: block;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-top: .5rem;
  color: var(--parchment);
  opacity: .8;
}
.countdown__caption {
  text-align: center;
  font-style: italic;
  color: color-mix(in srgb, var(--parchment-light) 80%, transparent);
  margin: 0;
}

/* ---------- Tickets CTA band ---------- */
.tickets-cta {
  background: linear-gradient(135deg, var(--barn-red) 0%, var(--barn-red-bright) 100%);
  color: var(--parchment-light);
  padding: 3rem 0;
  border-bottom: 4px solid var(--ink-navy-deep);
}
.tickets-cta__inner {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  align-items: center;
  text-align: center;
}
.tickets-cta__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.85rem, 4vw, 2.5rem);
  line-height: 1.05;
  margin: 0 0 .35rem;
  color: var(--parchment-light);
}
.tickets-cta__lede {
  margin: 0;
  font-size: 1.05rem;
  color: color-mix(in srgb, var(--parchment-light) 92%, transparent);
  max-width: 50ch;
}
.tickets-cta .btn--primary {
  background: var(--ink-navy-deep);
  color: var(--parchment-light);
  border-color: var(--ink-navy-deep);
}
.tickets-cta .btn--primary:hover,
.tickets-cta .btn--primary:focus-visible {
  background: var(--ink-navy);
  border-color: var(--ink-navy);
  transform: translateY(-1px);
}
@media (min-width: 720px) {
  .tickets-cta__inner {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
    gap: 2rem;
  }
  .tickets-cta__lede { max-width: 56ch; }
}
.tickets-cta__small-print {
  margin: 1.5rem auto 0;
  max-width: 56ch;
  font-size: .82rem;
  text-align: center;
  text-wrap: balance;
  letter-spacing: .02em;
  color: color-mix(in srgb, var(--parchment-light) 78%, transparent);
}

/* ---------- What's on ---------- */
.whats-on {
  background: var(--parchment);
  padding: 4rem 0;
}
.features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
@media (min-width: 600px) { .features { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .features { grid-template-columns: repeat(5, 1fr); gap: 1rem; } }

.feature {
  background: var(--parchment-light);
  border: 1px solid color-mix(in srgb, var(--wood-brown) 30%, transparent);
  border-top: 4px solid var(--barn-red);
  border-radius: var(--radius);
  padding: 1.5rem 1.25rem;
  box-shadow: var(--shadow-md);
}
.feature h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.25rem;
  margin: 0 0 .5rem;
  color: var(--ink-navy);
}
.feature p {
  margin: 0;
  font-size: .98rem;
  color: color-mix(in srgb, var(--ink-navy) 85%, transparent);
}

/* ---------- Gallery / carousel ---------- */
.gallery {
  background: var(--ink-navy-deep);
  color: var(--parchment-light);
  padding: 4rem 0 2.5rem;
}
.gallery .section-title { color: var(--parchment-light); }
.gallery .section-lede { color: color-mix(in srgb, var(--parchment-light) 80%, transparent); margin-bottom: 2rem; }

.carousel {
  list-style: none;
  margin: 0;
  padding: 0 1.25rem;
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: var(--barn-red) var(--ink-navy-deep);
}
.carousel:focus-visible { outline: 3px solid var(--barn-red-bright); outline-offset: 4px; }
.carousel::-webkit-scrollbar { height: 8px; }
.carousel::-webkit-scrollbar-track { background: var(--ink-navy); }
.carousel::-webkit-scrollbar-thumb { background: var(--barn-red); border-radius: 4px; }

.carousel__slide {
  flex: 0 0 88%;
  scroll-snap-align: center;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  background: var(--ink-navy);
  aspect-ratio: 3 / 2;
}
.carousel__slide img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
@media (min-width: 720px) {
  .carousel__slide { flex-basis: 60%; }
}
@media (min-width: 1100px) {
  .carousel__slide { flex-basis: 42%; }
}

.carousel__hint {
  text-align: center;
  font-size: .85rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  margin-top: 1.25rem;
  color: color-mix(in srgb, var(--parchment-light) 60%, transparent);
}

/* ---------- Location / map ---------- */
.location {
  background: var(--parchment);
  padding: 4rem 0;
}
.location__map {
  position: relative;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 4px solid var(--ink-navy);
  background: var(--ink-navy-deep);
}
.location__map iframe {
  width: 100%; height: 100%;
  border: 0;
  display: block;
}
.location__directions {
  text-align: center;
  margin-top: 1.5rem;
}

/* ---------- Signup ---------- */
.signup {
  background: var(--wood-brown-dark);
  color: var(--parchment-light);
  padding: 4rem 0;
}
.signup .section-title { color: var(--parchment-light); }
.signup .section-lede { color: color-mix(in srgb, var(--parchment-light) 85%, transparent); }

.signup__form { margin: 0 auto; max-width: 540px; }
.signup__label {
  display: block;
  font-family: var(--font-display);
  letter-spacing: .05em;
  font-size: .9rem;
  margin-bottom: .5rem;
  color: var(--parchment);
}
.signup__row {
  display: flex; flex-wrap: wrap; gap: .75rem;
}
.signup__input {
  flex: 1 1 240px;
  font-family: var(--font-body);
  font-size: 1rem;
  padding: .9rem 1rem;
  border-radius: var(--radius);
  border: 2px solid color-mix(in srgb, var(--parchment-light) 50%, transparent);
  background: var(--parchment-light);
  color: var(--ink-navy);
  min-width: 0;
}
.signup__input:focus { border-color: var(--barn-red-bright); outline: none; }
.signup__row .btn { flex: 0 0 auto; }
.signup__small {
  font-size: .85rem;
  margin: .9rem 0 0;
  color: color-mix(in srgb, var(--parchment-light) 70%, transparent);
}
.signup__status {
  margin: 1rem 0 0;
  min-height: 1.5em;
  font-weight: 600;
}
.signup__status.is-success { color: #b8e0a8; }
.signup__status.is-error   { color: #ffb3a8; }

/* ---------- Get involved ---------- */
.get-involved { background: var(--parchment); padding: 4rem 0 5rem; }
.involved-grid {
  display: grid; grid-template-columns: 1fr; gap: 1.25rem;
}
@media (min-width: 720px) { .involved-grid { grid-template-columns: repeat(3, 1fr); } }

.involved-card {
  background: var(--parchment-light);
  border: 1px solid color-mix(in srgb, var(--wood-brown) 25%, transparent);
  border-radius: var(--radius);
  padding: 1.75rem 1.5rem;
  box-shadow: var(--shadow-md);
}
.involved-card h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.35rem;
  margin: 0 0 .5rem;
  color: var(--ink-navy);
}
.involved-card p { margin: 0 0 1rem; }

.link-arrow {
  display: inline-block;
  font-weight: 600;
  text-decoration: none;
  border-bottom: 2px solid var(--barn-red);
  padding-bottom: 2px;
  word-break: break-word;
}
.link-arrow::after {
  content: " \2192"; transition: transform .15s ease;
  display: inline-block;
}
.link-arrow:hover::after { transform: translateX(3px); }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--ink-navy-deep);
  color: var(--parchment);
  padding: 2.5rem 0;
  font-size: .95rem;
}
.site-footer__inner {
  display: flex; flex-direction: column; gap: 1rem;
  align-items: center; text-align: center;
}
.site-footer__brand {
  font-family: var(--font-display);
  font-size: 1.1rem;
  margin: 0;
  color: var(--parchment-light);
}
.site-footer__social { display: flex; gap: 1.5rem; }
.site-footer__social a { color: var(--parchment); text-decoration: none; border-bottom: 1px solid transparent; }
.site-footer__social a:hover { color: var(--parchment-light); border-bottom-color: var(--barn-red); }
.site-footer__credit { margin: 0; opacity: .7; font-size: .85rem; }

.site-footer__legal {
  display: flex; gap: 1.25rem; flex-wrap: wrap; justify-content: center;
  font-size: .85rem;
}
.site-footer__legal a { color: var(--parchment); text-decoration: none; border-bottom: 1px solid transparent; }
.site-footer__legal a:hover { color: var(--parchment-light); border-bottom-color: var(--barn-red); }

@media (min-width: 720px) {
  .site-footer__inner { flex-direction: row; flex-wrap: wrap; justify-content: space-between; text-align: left; }
  .site-footer__legal { justify-content: flex-end; }
}

/* ---------- Consent banner ---------- */
.consent-banner {
  position: fixed;
  inset: auto 0 0 0;
  z-index: 1000;
  background: var(--ink-navy-deep);
  color: var(--parchment-light);
  border-top: 4px solid var(--barn-red);
  box-shadow: 0 -10px 40px rgba(0,0,0,.5);
  animation: cb-slide .25s ease-out;
}
@keyframes cb-slide { from { transform: translateY(100%); } to { transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) { .consent-banner { animation: none; } }

.consent-banner__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 1.25rem 1.25rem 1.5rem;
  display: grid;
  gap: .75rem;
  grid-template-areas:
    "title"
    "desc"
    "actions";
}
.consent-banner__title {
  grid-area: title;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.15rem;
  margin: 0;
  color: var(--parchment-light);
}
.consent-banner__desc {
  grid-area: desc;
  margin: 0;
  font-size: .95rem;
  line-height: 1.5;
  color: color-mix(in srgb, var(--parchment-light) 88%, transparent);
}
.consent-banner__desc a { color: var(--parchment-light); text-decoration: underline; }
.consent-banner__actions {
  grid-area: actions;
  display: flex; gap: .75rem; flex-wrap: wrap;
}
.consent-banner__actions .btn { padding: .65rem 1.5rem; font-size: .95rem; white-space: nowrap; }

@media (min-width: 720px) {
  .consent-banner__inner {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "title   actions"
      "desc    actions";
    align-items: center;
    column-gap: 1.5rem;
    row-gap: .35rem;
  }
  .consent-banner__actions { align-self: center; flex-wrap: nowrap; }
}

/* ---------- Legal pages (privacy, cookies) ---------- */
.legal-page { background: var(--parchment); }
.legal-header {
  background: var(--ink-navy);
  padding: 1.25rem 0;
  border-bottom: 4px solid var(--barn-red);
}
.legal-header__brand {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--parchment-light);
  text-decoration: none;
  letter-spacing: .03em;
}
.legal-header__brand:hover { color: var(--parchment); }

.legal { padding: 3rem 0 5rem; }
.legal h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 5vw, 2.75rem);
  color: var(--ink-navy);
  margin: 0 0 .5rem;
}
.legal h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.4rem;
  color: var(--ink-navy);
  margin: 2.25rem 0 .75rem;
}
.legal h3 {
  font-size: 1.1rem;
  margin: 1.5rem 0 .5rem;
  color: var(--ink-navy);
}
.legal p, .legal li { font-size: 1rem; }
.legal ul { padding-left: 1.25rem; }
.legal__meta {
  font-size: .9rem;
  color: color-mix(in srgb, var(--ink-navy) 70%, transparent);
  margin-bottom: 2rem;
}
.legal__home { margin-top: 3rem; font-weight: 600; }
.legal code {
  background: color-mix(in srgb, var(--wood-brown) 15%, transparent);
  padding: 1px 6px;
  border-radius: 3px;
  font-size: .9em;
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0 1.5rem;
  font-size: .92rem;
  background: var(--parchment-light);
  box-shadow: var(--shadow-md);
  border-radius: var(--radius);
  overflow: hidden;
}
.legal-table th, .legal-table td {
  padding: .65rem .85rem;
  text-align: left;
  border-bottom: 1px solid color-mix(in srgb, var(--wood-brown) 25%, transparent);
  vertical-align: top;
}
.legal-table th {
  background: color-mix(in srgb, var(--wood-brown) 15%, transparent);
  font-weight: 700;
}
.legal-table tr:last-child td { border-bottom: 0; }
@media (max-width: 600px) {
  .legal-table { font-size: .85rem; }
  .legal-table th, .legal-table td { padding: .5rem .55rem; }
}
