/* =====================================================================
   ANTONIO & CAROL — WEDDING WEBSITE
   Style: Editorial (unified with the home page redesign)
   ---------------------------------------------------------------------
   Single source of truth for typography, colour, layout, components.
   Inner-page palette and type now match the home page so the brand
   feel doesn't whiplash when you click into Our Story / Travel / FAQs.
   The old rustic token names (rust, sage, moss) are kept as aliases
   so existing component CSS continues to resolve cleanly.
   ===================================================================== */

/* Fonts: Fraunces (display serif, variable opsz/SOFT) + Inter (body & labels).
   No more JetBrains Mono — labels carry the editorial feel via Inter
   uppercase + wide letter-spacing instead. */
@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght,SOFT@0,9..144,500..900,50;0,9..144,500..900,100;1,9..144,400..700,50;1,9..144,400..700,100&family=Inter:wght@400;500;600&display=swap");

/* ---------- 1. Design tokens ---------- */
:root {
  /* Palette — editorial (matches home page) */
  --cream:        #ECE4CE;
  --paper:        #F5EFDD;
  --bone:         #F5EFDD;
  --sand:         #E2D8B8;
  --terracotta:   #D8682E;
  --terracotta-2: #B85320;
  --blue:         #7B95A8;
  --blue-deep:    #3A5260;  /* darkened from #4F6A7E for WCAG AA on cream */
  --ink:          #3A2618;  /* warm dark brown */
  --ink-2:        #5A3A24;
  --ink-soft:     #7A5A40;
  --gold:         #B8956A;
  --stone:        #C9C0B2;
  --line:         rgba(58, 38, 24, 0.16);

  /* Backwards-compatible aliases so existing rustic component CSS keeps
     working. Cards, eyebrows, buttons etc still reference --rust/--sage/
     --moss/--charcoal — these now resolve to the editorial colours. */
  --rust:         var(--terracotta);
  --rust-deep:    var(--terracotta-2);
  --sage:         var(--blue);
  --sage-deep:    var(--blue-deep);
  --moss:         var(--ink-soft);
  --charcoal:     var(--ink-2);

  /* Type — Fraunces is the new serif (was Cormorant Garamond) */
  --serif:  "Fraunces", "Cormorant Garamond", "Iowan Old Style", Georgia, serif;
  --sans:   "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

  /* Spacing */
  --s-1: 0.25rem; --s-2: 0.5rem; --s-3: 0.75rem; --s-4: 1rem;
  --s-5: 1.5rem; --s-6: 2rem; --s-7: 3rem; --s-8: 4rem;
  --s-9: 6rem; --s-10: 8rem;

  /* Layout */
  --max-w: 1180px;
  --max-w-narrow: 760px;
  --radius: 4px;
  --radius-lg: 8px;

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

/* ---------- 2. Reset & base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--cream);
  color: var(--charcoal);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.65;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; display: block; }
a { color: var(--rust-deep); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; transition: color 160ms var(--ease); }
a:hover { color: var(--rust); }
hr { border: 0; height: 1px; background: var(--line); margin: var(--s-7) 0; }

/* ---------- 3. Type ---------- */
h1, h2, h3, h4 {
  font-family: var(--serif);
  color: var(--ink);
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-4);
}
h1 { font-size: clamp(2.4rem, 6vw, 4.4rem); font-weight: 400; }
h2 { font-size: clamp(1.9rem, 4vw, 2.8rem); font-weight: 400; }
h3 { font-size: clamp(1.35rem, 2.4vw, 1.7rem); font-weight: 500; }
h4 { font-size: 1.05rem; font-weight: 600; font-family: var(--sans); letter-spacing: 0.06em; text-transform: uppercase; color: var(--moss); }
p  { margin: 0 0 var(--s-4); }
p:last-child { margin-bottom: 0; }

.eyebrow {
  font-family: var(--sans);
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--blue-deep);  /* editorial blue, matches home eyebrows */
  display: inline-block;
  margin-bottom: var(--s-4);
}
.script { font-family: var(--serif); font-style: italic; font-weight: 500; color: var(--ink-soft); }

/* ---------- 4. Layout ---------- */
.container { width: 100%; max-width: var(--max-w); margin: 0 auto; padding: 0 var(--s-5); }
.container-narrow { width: 100%; max-width: var(--max-w-narrow); margin: 0 auto; padding: 0 var(--s-5); }
.section { padding: var(--s-9) 0; }
.section-tight { padding: var(--s-7) 0; }
@media (max-width: 720px) { .section { padding: var(--s-7) 0; } }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-7); align-items: center; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-5); }
@media (max-width: 900px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; gap: var(--s-5); } }
@media (max-width: 900px) and (min-width: 600px) { .grid-3, .grid-4 { grid-template-columns: 1fr 1fr; } }

/* ---------- 5. Header / nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(244, 239, 231, 0.92);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; padding: var(--s-4) 0; }
/* Brand on inner pages now matches the home wordmark:
   Antonio in --ink, italic & in --blue, Carol in --blue. */
.brand {
  font-family: var(--serif);
  font-weight: 700;
  font-size: 1.4rem;
  color: var(--ink); text-decoration: none; letter-spacing: -0.01em;
}
.brand .amp { color: var(--blue); font-style: italic; font-weight: 700; padding: 0 0.12em; }
.brand .brand-carol { color: var(--blue); }
.nav-links { display: flex; gap: var(--s-5); list-style: none; margin: 0; padding: 0; }
.nav-links a {
  text-decoration: none; color: var(--charcoal);
  font-size: 0.92rem; font-weight: 500; letter-spacing: 0.02em;
  padding: var(--s-2) 0;
  border-bottom: 1.5px solid transparent;
  display: inline-block;
  transition: border-color 160ms var(--ease), color 160ms var(--ease), transform 200ms ease;
}
.nav-links a:hover, .nav-links a[aria-current="page"] {
  color: var(--terracotta);
  border-bottom-color: var(--terracotta);
  transform: translateX(2px);
}
.nav-toggle { display: none; background: none; border: 0; padding: var(--s-2); cursor: pointer; color: var(--ink); }
.nav-toggle svg { display: block; }

@media (max-width: 880px) {
  .nav-links {
    position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; gap: 0;
    background: var(--paper);
    border-bottom: 1px solid var(--line);
    padding: var(--s-4) var(--s-5);
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: transform 200ms var(--ease), opacity 200ms var(--ease);
  }
  .nav-links a { padding: var(--s-3) 0; border-bottom: 1px solid var(--line); }
  .nav-links a:last-child { border-bottom: 0; }
  .nav-open .nav-links { transform: none; opacity: 1; pointer-events: auto; }
  .nav-toggle { display: inline-flex; }
}

/* ---------- 6. Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  padding: 0.95rem 1.6rem;
  border-radius: 999px;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: background 180ms var(--ease), color 180ms var(--ease), border-color 180ms var(--ease), transform 180ms var(--ease);
}
.btn-primary { background: var(--rust); color: var(--paper); }
.btn-primary:hover { background: var(--rust-deep); color: var(--paper); transform: translateY(-1px); }
.btn-secondary { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-secondary:hover { background: var(--ink); color: var(--paper); }
.btn-ghost { background: transparent; color: var(--rust); padding: 0.7rem 0; border-radius: 0; border-bottom: 1.5px solid var(--rust); }
.btn-ghost:hover { color: var(--rust-deep); border-bottom-color: var(--rust-deep); }

/* ---------- 7. Hero ---------- */
.hero {
  position: relative;
  min-height: 100svh; min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  text-align: center; overflow: hidden;
  background: linear-gradient(180deg, #EFE6D6 0%, #E2D6BD 35%, #BFA98A 65%, #8B9A7B 100%);
}
.hero::after {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 110%, rgba(168, 90, 62, 0.18) 0%, transparent 60%),
    radial-gradient(ellipse at 50% -20%, rgba(255, 245, 220, 0.45) 0%, transparent 55%);
  pointer-events: none;
}
.hero-inner { position: relative; z-index: 2; padding: var(--s-8) var(--s-5); color: var(--ink); }
.hero-eyebrow {
  font-family: var(--sans);
  font-size: 0.78rem; letter-spacing: 0.4em; text-transform: uppercase;
  color: var(--rust-deep); margin-bottom: var(--s-6);
}
.hero h1 {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  font-size: clamp(3.4rem, 11vw, 8rem); line-height: 0.95; letter-spacing: -0.02em;
  color: var(--ink); margin: 0;
}
.hero h1 .amp {
  display: block; font-size: 0.55em; font-style: italic;
  color: var(--rust); margin: var(--s-2) 0;
}
.hero-meta {
  margin-top: var(--s-6);
  font-family: var(--sans);
  font-size: 0.95rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--charcoal);
}
.hero-meta .dot { color: var(--rust); margin: 0 0.6em; }
.hero-cta { margin-top: var(--s-7); display: flex; gap: var(--s-4); justify-content: center; flex-wrap: wrap; }
.hero-scroll {
  position: absolute; bottom: var(--s-5); left: 50%; transform: translateX(-50%);
  font-size: 0.7rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--moss); opacity: 0.75;
}
.hero-scroll::after {
  content: ""; display: block; width: 1px; height: 36px;
  background: linear-gradient(180deg, var(--moss), transparent);
  margin: var(--s-2) auto 0;
}
.hero-corner { position: absolute; width: 180px; height: 180px; opacity: 0.5; pointer-events: none; }
.hero-corner.tl { top: var(--s-5); left: var(--s-5); }
.hero-corner.br { bottom: var(--s-5); right: var(--s-5); transform: rotate(180deg); }
@media (max-width: 720px) { .hero-corner { width: 100px; height: 100px; } }

/* ---------- 8. Countdown ---------- */
.countdown { display: flex; justify-content: center; gap: var(--s-5); margin-top: var(--s-7); flex-wrap: wrap; }
.countdown-cell { min-width: 80px; text-align: center; }
.countdown-num {
  font-family: var(--serif);
  font-size: clamp(2rem, 4.5vw, 3rem);
  color: var(--ink);
  display: block; line-height: 1;
}
.countdown-label {
  font-size: 0.7rem; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--moss); margin-top: var(--s-2); display: block;
}

/* ---------- 9. Cards & tiles ---------- */
.card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--s-6);
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease);
}
.card:hover { transform: translateY(-2px); box-shadow: 0 12px 30px -18px rgba(45, 42, 38, 0.25); }
.card h3 { margin-bottom: var(--s-2); }
.card-meta { font-size: 0.85rem; color: var(--moss); letter-spacing: 0.05em; }
a.card { display: block; text-decoration: none; color: var(--charcoal); }
a.card h3 { color: var(--ink); }

.tile-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); }
@media (max-width: 900px) { .tile-grid { grid-template-columns: 1fr 1fr; } }
.tile {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--s-5);
  text-decoration: none;
  color: var(--ink);
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: var(--s-3);
  transition: background 160ms var(--ease), transform 200ms var(--ease);
}
.tile:hover { background: var(--sand); transform: translateY(-2px); color: var(--ink); }
.tile-icon { color: var(--rust); }
.tile-label { font-family: var(--serif); font-size: 1.2rem; font-weight: 500; }
.tile-sub { font-size: 0.78rem; color: var(--moss); letter-spacing: 0.1em; text-transform: uppercase; }

/* ---------- 10. Schedule ---------- */
.schedule-day { margin-bottom: var(--s-7); }
.schedule-day h2 { color: var(--rust); font-style: italic; margin-bottom: var(--s-2); }
.schedule-day .date {
  color: var(--moss); font-size: 0.85rem;
  letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: var(--s-5);
}

.event {
  display: grid; grid-template-columns: 130px 1fr; gap: var(--s-5);
  padding: var(--s-4) 0; border-top: 1px solid var(--line);
}
.event:last-child { border-bottom: 1px solid var(--line); }
.event-time { font-family: var(--serif); font-size: 1.5rem; color: var(--rust); line-height: 1.2; }
.event-time .am { display: block; font-size: 0.7rem; font-family: var(--sans); color: var(--moss); letter-spacing: 0.2em; text-transform: uppercase; }
.event-body h3 { margin: 0 0 var(--s-1); font-size: 1.2rem; }
.event-meta { font-size: 0.85rem; color: var(--moss); margin-bottom: var(--s-2); }
.event-meta span { margin-right: var(--s-4); }
.event-tag {
  display: inline-block; font-size: 0.68rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 2px 10px; background: var(--sand); color: var(--moss); border-radius: 999px;
}
.event-tag.day { background: rgba(168, 90, 62, 0.12); color: var(--rust-deep); }
.event-tag.evening { background: rgba(139, 154, 123, 0.18); color: var(--sage-deep); }
.event-tag.weekend { background: rgba(184, 149, 106, 0.18); color: #8B6A3F; }
@media (max-width: 600px) {
  .event { grid-template-columns: 1fr; gap: var(--s-2); }
  .event-time { font-size: 1.3rem; }
}

/* ---------- 11. Forms ---------- */
.form-grid { display: grid; gap: var(--s-5); }
.field { display: flex; flex-direction: column; gap: var(--s-2); }
.field label { font-size: 0.85rem; font-weight: 600; color: var(--ink); letter-spacing: 0.02em; }
.field .hint { font-size: 0.8rem; color: var(--moss); margin-top: -2px; }
.input, .select, .textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  border: 1px solid var(--stone);
  background: var(--paper);
  border-radius: var(--radius);
  font-family: var(--sans);
  font-size: 1rem;
  color: var(--ink);
  transition: border-color 160ms var(--ease), background 160ms var(--ease);
}
.input:focus, .select:focus, .textarea:focus { outline: none; border-color: var(--rust); background: #fff; }
.textarea { resize: vertical; min-height: 100px; }

.radio-group, .check-group { display: flex; gap: var(--s-3); flex-wrap: wrap; }
.radio-pill {
  position: relative;
  display: inline-flex; align-items: center;
  padding: 0.7rem 1.2rem;
  border: 1.5px solid var(--stone);
  border-radius: 999px;
  cursor: pointer;
  font-size: 0.95rem;
  background: var(--paper);
  transition: all 160ms var(--ease);
}
.radio-pill input { position: absolute; opacity: 0; pointer-events: none; }
.radio-pill:hover { border-color: var(--charcoal); }
.radio-pill:has(input:checked) { background: var(--rust); border-color: var(--rust); color: var(--paper); }

.guest-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1.5fr;
  gap: var(--s-3);
  align-items: end;
  padding: var(--s-4);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  margin-bottom: var(--s-3);
}
.guest-row .input, .guest-row .select { padding: 0.65rem 0.9rem; font-size: 0.95rem; }
.guest-row .field { gap: var(--s-1); }
.guest-row label { font-size: 0.75rem; color: var(--moss); }
@media (max-width: 600px) { .guest-row { grid-template-columns: 1fr; } }

.form-status {
  margin-top: var(--s-5);
  padding: var(--s-4) var(--s-5);
  border-radius: var(--radius-lg);
  font-size: 0.95rem;
  display: none;
}
.form-status.is-success { display: block; background: rgba(139, 154, 123, 0.18); color: var(--sage-deep); border-left: 4px solid var(--sage-deep); }
.form-status.is-error { display: block; background: rgba(168, 90, 62, 0.12); color: var(--rust-deep); border-left: 4px solid var(--rust); }

/* ---------- 12. FAQ accordion ---------- */
.faq { border-top: 1px solid var(--line); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q {
  width: 100%; text-align: left;
  background: none; border: 0;
  padding: var(--s-5) 0;
  font-family: var(--serif); font-size: 1.25rem; color: var(--ink);
  cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: var(--s-4);
}
.faq-q:focus-visible { outline: 2px solid var(--rust); outline-offset: 4px; }
.faq-q::after {
  content: "+";
  font-size: 1.6rem; color: var(--rust);
  font-family: var(--sans); font-weight: 300;
  transition: transform 200ms var(--ease);
}
.faq-item[aria-expanded="true"] .faq-q::after { content: "–"; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 280ms var(--ease); }
.faq-item[aria-expanded="true"] .faq-a { max-height: 800px; }
.faq-a-inner { padding: 0 0 var(--s-5); color: var(--charcoal); }

/* ---------- 13. Photo placeholder ---------- */
.photo-placeholder {
  position: relative;
  aspect-ratio: 4 / 5;
  background:
    linear-gradient(135deg, rgba(184, 149, 106, 0.18), rgba(139, 154, 123, 0.18)),
    repeating-linear-gradient(45deg, rgba(45, 42, 38, 0.04) 0 1px, transparent 1px 14px);
  background-color: var(--sand);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center; flex-direction: column;
  color: var(--moss); text-align: center; padding: var(--s-5);
}
.photo-placeholder.wide { aspect-ratio: 16 / 9; }
.photo-placeholder.square { aspect-ratio: 1 / 1; }
.photo-placeholder svg { opacity: 0.45; margin-bottom: var(--s-3); }
.photo-placeholder em { font-family: var(--serif); font-style: italic; font-size: 1rem; color: var(--moss); }

/* ---------- 14. Footer (editorial — matches home page) ---------- */
.site-footer {
  position: relative;
  z-index: 2;
  background: #3A2618;
  color: #ECE4CE;
  padding: 80px 0 36px;
  margin-top: var(--s-9);
}
.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.18;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.site-footer .container {
  position: relative;
  z-index: 2;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  align-items: start;
  padding-top: 40px;
  border-top: 1px solid rgba(245, 239, 221, 0.18);
  margin-bottom: 0;
}
.site-footer h4 {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  font-size: 11.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  color: #7B95A8;
  margin: 0 0 18px;
}
.footer-grid ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-family: "Fraunces", "Recoleta", Georgia, serif;
  font-weight: 500;
  font-size: 20px;
}
.site-footer a {
  color: #ECE4CE;
  text-decoration: none;
  display: inline-block;
  transition: color .15s ease, transform .25s ease;
}
.site-footer a:hover { color: #D8682E; transform: translateX(4px); }
.footer-info {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  font-size: 12px;
  letter-spacing: 0.18em;
  line-height: 1.9;
  text-transform: uppercase;
  color: #F5EFDD;
  opacity: 0.8;
}
.footer-bottom {
  margin-top: 50px;
  padding-top: 22px;
  border-top: 1px solid rgba(245, 239, 221, 0.18);
  display: flex;
  justify-content: space-between;
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #F5EFDD;
  opacity: 0.65;
}
@media (max-width: 1100px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .footer-grid { grid-template-columns: 1fr; gap: 30px; }
  .footer-bottom { flex-direction: column; gap: 8px; }
}

/* ---------- 15. Two-column ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-8); align-items: center; }
.split-content h2 { margin-top: 0; }
@media (max-width: 900px) { .split { grid-template-columns: 1fr; gap: var(--s-5); } }

/* ---------- 16. Tag/legend ---------- */
.legend { display: flex; gap: var(--s-4); flex-wrap: wrap; margin-bottom: var(--s-5); }
.legend-item { display: flex; align-items: center; gap: var(--s-2); font-size: 0.85rem; color: var(--moss); }
.legend-dot { width: 10px; height: 10px; border-radius: 999px; }

/* ---------- 17. Page header ---------- */
.page-header {
  text-align: center;
  padding: var(--s-9) 0 var(--s-7);
  background: var(--cream);
  border-bottom: 1px solid var(--line);
}
.page-header h1 {
  font-style: normal;
  font-weight: 700;
  font-variation-settings: "opsz" 144, "SOFT" 50;
  letter-spacing: -0.02em;
}
.page-header .lede { max-width: 620px; margin: var(--s-4) auto 0; color: var(--ink-soft); font-size: 1.05rem; }

/* ---------- 18. Misc utilities ---------- */
.muted { color: var(--moss); }
.center { text-align: center; }
.mt-4 { margin-top: var(--s-4); }
.mt-5 { margin-top: var(--s-5); }
.mt-6 { margin-top: var(--s-6); }
.mb-3 { margin-bottom: var(--s-3); }
.mb-5 { margin-bottom: var(--s-5); }
.lede { font-size: 1.15rem; line-height: 1.6; color: var(--charcoal); }
.lede em { font-style: italic; color: var(--moss); }

/* ---------- 19. Password gate ---------- */
.gate {
  position: fixed; inset: 0; z-index: 999;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(180deg, var(--cream), var(--sand));
  padding: var(--s-5);
}
.gate-card {
  width: 100%; max-width: 440px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--s-7);
  text-align: center;
  box-shadow: 0 20px 60px -30px rgba(45, 42, 38, 0.3);
}
.gate-card h1 { font-style: italic; font-size: 2rem; margin-bottom: var(--s-3); }
.gate-card .input { text-align: center; letter-spacing: 0.2em; text-transform: uppercase; }
.gate-error { color: var(--rust-deep); font-size: 0.85rem; margin-top: var(--s-2); display: none; }
.gate-error.show { display: block; }

/* ---------- 20. Admin dashboard ---------- */
.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); margin-bottom: var(--s-7); }
@media (max-width: 900px) { .kpi-grid { grid-template-columns: 1fr 1fr; } }
.kpi { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--s-5); }
.kpi-label { font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--moss); margin-bottom: var(--s-3); }
.kpi-value { font-family: var(--serif); font-size: 2.6rem; color: var(--ink); line-height: 1; }
.kpi-sub { font-size: 0.85rem; color: var(--moss); margin-top: var(--s-2); }

.admin-table {
  width: 100%; border-collapse: collapse;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.admin-table th, .admin-table td {
  padding: var(--s-3) var(--s-4); text-align: left;
  border-bottom: 1px solid var(--line);
  font-size: 0.92rem;
}
.admin-table th {
  background: var(--sand); font-weight: 600; color: var(--ink);
  font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase;
}
.admin-table tbody tr:last-child td { border-bottom: 0; }
.admin-table tbody tr:hover { background: var(--sand); }

.pill { display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; }
.pill.yes { background: rgba(139, 154, 123, 0.25); color: var(--moss); }
.pill.no { background: rgba(168, 90, 62, 0.18); color: var(--rust-deep); }
.pill.pending { background: var(--sand); color: var(--moss); }

.toolbar { display: flex; gap: var(--s-3); align-items: center; justify-content: space-between; flex-wrap: wrap; margin-bottom: var(--s-5); }
.toolbar .input, .toolbar .select { padding: 0.55rem 0.9rem; font-size: 0.9rem; }

/* ---------- 21. Print ---------- */
@media print {
  body { background: #fff !important; color: #000 !important; font-size: 11pt; }
  .site-header, .site-footer, .nav-toggle, .hero-scroll, .gate,
  .btn, .cta-row, .footer-grid, .footer-bottom,
  .ticker { display: none !important; }
  .page-header { padding: 0 0 var(--s-3) !important; background: #fff !important; border-bottom: 1px solid #ccc; }
  .page-header h1 { font-size: 28pt !important; color: #000 !important; }
  .section { padding: var(--s-5) 0 !important; }
  a { color: #000 !important; text-decoration: underline; }
  .card { background: #fff !important; border: 1px solid #ccc !important; box-shadow: none !important; page-break-inside: avoid; }
  .event { page-break-inside: avoid; }
  @page { margin: 14mm; }
}
