:root {
  --cream: #f5ede0;
  --cream-dark: #ebe0cc;
  --ink: #1a1a1a;
  --ink-soft: #2a2a2a;
  --terracotta: #c14a1a;
  --ochre: #d4a017;
  --coral: #ff6f4d;
  --cobalt: #1d4fa3;
  --max: 1100px;
  --pad-x: clamp(1.25rem, 5vw, 3rem);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--ink);
  background: var(--cream);
  line-height: 1.5;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }

.container { max-width: var(--max); margin-inline: auto; padding-inline: var(--pad-x); }

/* ─── TOP NAV ─── */
.topnav {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--cream);
  border-bottom: 1px solid rgba(26,26,26,0.08);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.topnav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding-block: 1rem;
}
.topnav .brand {
  font-family: 'Archivo Black', sans-serif;
  font-size: 1.1rem;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.topnav nav {
  display: flex;
  gap: clamp(1rem, 3vw, 2rem);
  font-size: 0.95rem;
  font-weight: 600;
}
.topnav nav a {
  position: relative;
  padding-block: 0.25rem;
  transition: color 150ms;
}
.topnav nav a:hover { color: var(--terracotta); }
.topnav nav a[aria-current="page"]::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px;
  background: var(--terracotta);
}

/* ─── HERO ─── */
.hero {
  min-height: 80vh;
  min-height: 80dvh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-block: clamp(3rem, 8vw, 6rem);
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 80% 20%, rgba(193,74,26,0.08), transparent 50%),
    radial-gradient(circle at 20% 80%, rgba(29,79,163,0.06), transparent 50%),
    var(--cream);
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(45deg, transparent, transparent 35px, rgba(26,26,26,0.015) 35px, rgba(26,26,26,0.015) 36px);
  pointer-events: none;
}
.hero.tall { min-height: 100vh; min-height: 100dvh; }

.eyebrow {
  font-size: clamp(0.75rem, 1.2vw, 0.875rem);
  font-weight: 600;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--terracotta);
  margin-bottom: 1.5rem;
}

h1 {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(3rem, 12vw, 8rem);
  line-height: 0.9;
  letter-spacing: -0.02em;
  margin-bottom: 1.5rem;
  color: var(--ink);
}
h1.smaller { font-size: clamp(2.5rem, 8vw, 5rem); }

.tagline {
  font-size: clamp(1.125rem, 2.5vw, 1.625rem);
  font-weight: 500;
  max-width: 38ch;
  margin-bottom: 2rem;
  color: var(--ink-soft);
}
.tagline strong { color: var(--terracotta); font-weight: 700; }

.dates {
  font-size: clamp(1rem, 1.6vw, 1.125rem);
  font-weight: 600;
  letter-spacing: 0.04em;
  padding-block: 1rem;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  display: inline-block;
  padding-inline: 1.5rem;
  margin-bottom: 2.5rem;
}

/* ─── CTA BUTTON ─── */
.btn {
  display: inline-block;
  padding: 1rem 1.5rem;
  font: inherit;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border: 2px solid var(--ink);
  background: var(--ink);
  color: var(--cream);
  cursor: pointer;
  border-radius: 0;
  transition: background 150ms, border-color 150ms;
}
.btn:hover { background: var(--terracotta); border-color: var(--terracotta); }
.btn.outline { background: transparent; color: var(--ink); }
.btn.outline:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }

/* ─── EMAIL FORM ─── */
.cta-form {
  display: flex;
  gap: 0.75rem;
  max-width: 520px;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.cta-form input[type="email"],
.cta-form input[type="text"] {
  flex: 1 1 240px;
  padding: 1rem 1.25rem;
  font: inherit;
  font-size: 1rem;
  border: 2px solid var(--ink);
  background: var(--cream);
  color: var(--ink);
  border-radius: 0;
  transition: background 150ms;
}
.cta-form input:focus { outline: none; background: #fff; }
.cta-form button { padding: 1rem 1.5rem; font: inherit; font-size: 1rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; border: 2px solid var(--ink); background: var(--ink); color: var(--cream); cursor: pointer; border-radius: 0; transition: background 150ms; }
.cta-form button:hover { background: var(--terracotta); border-color: var(--terracotta); }

.form-hint { font-size: 0.875rem; color: var(--ink-soft); opacity: 0.7; }

.form-status { margin-top: 1.25rem; font-weight: 600; }
.form-status.success { color: var(--ink); }
.form-status.error { color: #c00; }
.form-status .success-headline { display: block; font-size: 1.125rem; color: var(--terracotta); margin-bottom: 0.75rem; }
.form-status-sub { display: block; margin-top: 0.75rem; font-size: 0.875rem; font-weight: 500; opacity: 0.7; text-transform: none; letter-spacing: 0; }

.whatsapp-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  margin-top: 0.25rem;
  padding: 0.95rem 1.5rem;
  background: #25D366;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  border: 2px solid #25D366;
  transition: background 150ms, border-color 150ms;
}
.whatsapp-cta:hover { background: #1da851; border-color: #1da851; }

.ig-link { display: inline-block; margin-top: 1rem; font-weight: 600; border-bottom: 2px solid currentColor; padding-bottom: 2px; }

/* ─── SECTIONS ─── */
.section { padding-block: clamp(4rem, 10vw, 7rem); }
.section.dark { background: var(--ink); color: var(--cream); }
.section.cream-dark { background: var(--cream-dark); }
.section h2 {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(2rem, 6vw, 3.5rem);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 2.5rem;
  max-width: 22ch;
}
.section h3 {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(1.25rem, 2.5vw, 1.5rem);
  letter-spacing: -0.01em;
  margin-bottom: 0.75rem;
}
.section p {
  font-size: clamp(1rem, 1.6vw, 1.125rem);
  margin-bottom: 1.25rem;
  max-width: 62ch;
}
.section p strong { color: var(--terracotta); font-weight: 700; }
.section.dark p strong { color: var(--coral); }

.roots { color: var(--cobalt); }
.revolution { color: var(--coral); }

/* ─── LINEUP LIST ─── */
.lineup ol { list-style: none; }
.lineup li {
  display: grid;
  grid-template-columns: minmax(80px, 100px) 1fr;
  gap: clamp(1rem, 3vw, 2rem);
  padding-block: 1.5rem;
  border-top: 1px solid rgba(245,237,224,0.2);
  align-items: baseline;
}
.lineup li:last-child { border-bottom: 1px solid rgba(245,237,224,0.2); }
.day {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(1.5rem, 4vw, 2.25rem);
  color: var(--ochre);
  letter-spacing: -0.02em;
}
.day-headline { color: var(--coral); }
.act { display: flex; flex-direction: column; gap: 0.25rem; }
.act-name { font-family: 'Archivo Black', sans-serif; font-size: clamp(1.25rem, 3vw, 1.75rem); letter-spacing: -0.01em; }
.act-name .star { color: var(--coral); margin-left: 0.25em; }
.act-genre { font-size: 0.95rem; opacity: 0.8; font-weight: 500; }
.act-status {
  display: inline-block;
  width: fit-content;
  margin-top: 0.35rem;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ochre);
  border: 1px solid var(--ochre);
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
}

/* ─── STAT GRID (sponsors page) ─── */
.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(1.5rem, 3vw, 2.5rem);
  margin-top: 2rem;
}
.stat .number {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(2.5rem, 6vw, 4rem);
  line-height: 1;
  color: var(--terracotta);
  margin-bottom: 0.5rem;
}
.stat .label {
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.85;
}

/* ─── TIER GRID (sponsors page) ─── */
.tiers {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}
.tier {
  padding: 2rem 1.75rem;
  background: var(--cream);
  color: var(--ink); /* override .section.dark cream-on-cream invisibility */
  border: 2px solid var(--ink);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
/* Defense in depth: explicit overrides for tier children so descendants don't
   silently inherit cream from .section.dark via specificity quirks or
   accidental future overrides. */
.tier h3,
.tier p,
.tier li,
.tier ul {
  color: var(--ink);
}
.tier.featured {
  background: var(--ink);
  color: var(--cream);
}
.tier.featured h3 { color: var(--coral); }
.tier.featured p,
.tier.featured li,
.tier.featured ul { color: var(--cream); }
.tier .tier-tag {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--terracotta);
}
.tier.featured .tier-tag { color: var(--ochre); }
.tier h3 { margin-bottom: 0.25rem; }
.tier ul {
  list-style: none;
  font-size: 0.95rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.5rem;
}
.tier li::before {
  content: "·";
  display: inline-block;
  margin-right: 0.5em;
  color: var(--terracotta);
  font-weight: 700;
}
.tier.featured li::before { color: var(--coral); }

/* ─── PRESS KIT LIST ─── */
.kit-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
  margin-top: 1.5rem;
}
.kit-item {
  background: var(--cream);
  border: 2px solid var(--ink);
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.kit-item img {
  display: block;
  width: 100%;
  height: 160px;
  object-fit: cover;
  background: var(--cream-dark);
  margin-bottom: 0.75rem;
}
.kit-item .kit-title { font-weight: 700; }
.kit-item .kit-meta { font-size: 0.85rem; opacity: 0.7; }
.kit-item a.download { font-weight: 700; color: var(--terracotta); margin-top: auto; border-bottom: 2px solid currentColor; padding-bottom: 2px; align-self: flex-start; }

/* ─── FACT TABLE ─── */
.fact-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 1.5rem;
  font-size: 1rem;
}
.fact-table th, .fact-table td {
  text-align: left;
  padding: 0.85rem 0;
  border-bottom: 1px solid rgba(26,26,26,0.12);
  vertical-align: top;
}
.fact-table th {
  font-weight: 600;
  width: 32%;
  color: var(--ink-soft);
}
.section.dark .fact-table th { color: var(--ochre); }
.section.dark .fact-table th, .section.dark .fact-table td { border-bottom-color: rgba(245,237,224,0.15); }

/* ─── FOOTER ─── */
footer {
  padding-block: 3rem;
  background: var(--cream-dark);
  color: var(--ink);
  font-size: 0.9rem;
}
footer .container {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  justify-content: space-between;
  align-items: baseline;
}
footer a { font-weight: 600; border-bottom: 1px solid currentColor; }
footer .legal { opacity: 0.6; font-size: 0.8rem; }

/* ─── RESPONSIVE ─── */
@media (max-width: 600px) {
  .topnav nav { gap: 0.9rem; font-size: 0.85rem; }
  .topnav .brand { font-size: 1rem; }
}
@media (max-width: 480px) {
  .lineup li { grid-template-columns: 1fr; gap: 0.5rem; }
  .day { font-size: 1.25rem; }
}
