/* =====================================================================
   BASE — reset, typography, global utilities
   ===================================================================== */

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--cream);
  color: var(--charcoal);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.62;
  -webkit-font-smoothing: antialiased;
}

.wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}

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

h1, h2, h3 {
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--navy);
}

img { max-width: 100%; height: auto; }

p { margin: 0 0 1em; }

/* --- kicker label --- */
.kicker {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 0.7rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin: 0 0 1rem;
  display: block;
}

/* --- dek (large intro paragraph) --- */
.dek {
  font-family: var(--serif);
  font-size: 1.25rem;
  line-height: 1.58;
  color: var(--ink-60);
}

/* --- scroll-reveal --- */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}
.reveal.in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  * { scroll-behavior: auto !important; }
}

/* --- section blocks --- */
section.blk { padding: var(--breath) 0; }
section.blk-sm { padding: var(--breath-sm) 0; }

.sec-head { max-width: 62ch; margin-bottom: 3rem; }
.sec-head h2 {
  font-size: clamp(2.1rem, 4vw, 3.3rem);
  line-height: 1.08;
  margin: 0.4rem 0 1rem;
}
.sec-head p {
  font-family: var(--serif);
  font-size: 1.2rem;
  color: var(--ink-60);
  margin: 0;
}

/* --- navy band --- */
.band-navy { background: var(--navy); color: var(--cream); }
.band-navy .kicker { color: var(--gold); }
.band-navy .sec-head h2 { color: #fff; }
.band-navy .sec-head p { color: #cfd6df; }

/* --- responsive base --- */
@media (max-width: 920px) {
  .wrap { padding: 0 22px; }
  section.blk { padding: clamp(3.2rem, 9vh, 5rem) 0; }
}

@media (max-width: 600px) {
  body { font-size: 16px; }
}
