/* ============================================================
   Davis Chamber of Commerce — "The Davis Story" (magazine)
   Palette: white / navy / amber / teal ONLY
   ============================================================ */

:root{
  --white:#ffffff;
  --tint:#f5f9fc;
  --navy:#054C70;
  --ink:#08294a;
  --blue:#0a72bc;
  --amber:#d4853a;
  --amber-dk:#b86a23;
  --teal:#2bb1a4;
  --teal-lt:#3ecdc4;
  --text:#0f2d44;
  --muted:#456277;
  --line:#dde8f0;

  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --news:"Newsreader", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --wrap:1180px;
  --gut:clamp(1.2rem,5vw,3rem);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }

body{
  font-family:var(--sans);
  color:var(--text);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:var(--blue);text-decoration:none}

.wrap{width:min(100% - var(--gut)*2, var(--wrap));margin-inline:auto}
.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}
.skip{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:.7rem 1rem;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}

:focus-visible{outline:3px solid var(--amber);outline-offset:3px;border-radius:3px}

/* ---------- Kickers / shared type ---------- */
.kicker{
  font-family:var(--sans);font-weight:700;text-transform:uppercase;
  letter-spacing:.2em;font-size:.72rem;color:var(--amber-dk);
  display:inline-block;margin-bottom:1rem;
}
.kicker::before{content:"";display:inline-block;width:26px;height:2px;background:var(--amber);
  vertical-align:middle;margin-right:.6rem;margin-bottom:.2em}
.kicker-center{display:block;text-align:center}
.kicker-center::before{display:none}
.kicker-light{color:var(--teal-lt)}
.kicker-light::before{background:var(--teal-lt)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:.7rem 1.3rem;border-radius:6px;border:2px solid transparent;
  cursor:pointer;transition:background .2s ease, color .2s ease, transform .2s ease, border-color .2s ease;
  text-align:center;
}
.btn-lg{padding:.95rem 1.8rem;font-size:1.02rem}
.btn-join{background:var(--amber);color:#241204}
.btn-join:hover{background:var(--amber-dk);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.65)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;transform:translateY(-2px)}

/* ============================================================
   HEADER (sticky)
   ============================================================ */
.site-head{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,0);
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
}
.head-inner{display:flex;align-items:center;gap:1.5rem;padding:1.1rem 0}
.site-head.is-stuck{background:rgba(255,255,255,.97);box-shadow:0 1px 0 var(--line),0 10px 30px -22px rgba(8,41,74,.5);backdrop-filter:saturate(1.4) blur(6px)}
.site-head.is-stuck .head-inner{padding:.65rem 0}

/* On the hero (not stuck), header text is white over the photo */
.brand{display:flex;align-items:center;gap:.7rem;color:#fff}
.brand-mark{
  display:grid;place-items:center;width:42px;height:42px;flex:0 0 42px;
  background:var(--amber);color:#241204;border-radius:8px;
  font-family:var(--serif);font-weight:900;font-size:1.15rem;letter-spacing:-.02em;
}
.brand-words{display:flex;flex-direction:column;line-height:1.05}
.brand-name{font-family:var(--serif);font-weight:700;font-size:1.18rem;letter-spacing:-.01em}
.brand-sub{font-family:var(--sans);font-weight:600;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;opacity:.85}

.main-nav{margin-left:auto;display:flex;gap:1.6rem}
.main-nav a{
  color:#fff;font-weight:600;font-size:.95rem;position:relative;padding:.2rem 0;
}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--amber);transition:width .25s ease}
.main-nav a:hover::after{width:100%}

.head-join{margin-left:.4rem}

/* stuck state recolors header text to ink */
.site-head.is-stuck .brand{color:var(--ink)}
.site-head.is-stuck .main-nav a{color:var(--ink)}
.site-head.is-stuck .brand-sub{opacity:.7}

.nav-toggle{display:none;margin-left:auto;background:none;border:0;width:44px;height:44px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer}
.nav-toggle span{display:block;height:2.5px;width:26px;background:#fff;border-radius:2px;transition:.25s}
.site-head.is-stuck .nav-toggle span{background:var(--ink)}

.mobile-nav{display:none;flex-direction:column;gap:.2rem;background:var(--navy);padding:1rem var(--gut) 1.4rem}
.mobile-nav a{color:#fff;font-weight:600;padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.12)}
.mobile-nav .btn{margin-top:.9rem}
.nav-open .mobile-nav{display:flex}

/* ============================================================
   HERO / COVER
   ============================================================ */
.hero{position:relative;min-height:min(94vh,860px);display:flex;align-items:flex-end;margin-top:calc(-1 * (1.1rem*2 + 42px));padding-top:calc(1.1rem*2 + 42px);isolation:isolate}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%;z-index:-2}
.hero-scrim{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(to top, rgba(8,41,74,.94) 0%, rgba(8,41,74,.72) 26%, rgba(8,41,74,.30) 55%, rgba(8,41,74,.12) 75%, rgba(8,41,74,.28) 100%);
}
.hero-inner{padding-bottom:clamp(2.5rem,7vw,5.5rem);max-width:none}
.cover-flag{
  font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.22em;
  font-size:.72rem;color:#fff;opacity:.92;margin-bottom:1.4rem;
  display:inline-block;border-top:2px solid var(--amber);border-bottom:1px solid rgba(255,255,255,.4);
  padding:.5rem 0;
}
.hero-title{
  font-family:var(--serif);font-weight:600;color:#fff;
  font-size:clamp(2.8rem,2rem+6.5vw,7rem);line-height:.96;letter-spacing:-.02em;
  margin-bottom:1.4rem;text-wrap:balance;
}
.hero-title .line{display:block}
.hero-title em{font-style:italic;font-weight:500;color:var(--amber)}
.hero-lede{
  font-family:var(--news);font-size:clamp(1.1rem,1rem+.7vw,1.5rem);
  color:#eaf3fb;max-width:46ch;line-height:1.45;margin-bottom:2rem;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem}
.hero-byline{
  position:absolute;right:var(--gut);bottom:1.2rem;color:rgba(255,255,255,.7);
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  writing-mode:vertical-rl;
}
@media (max-width:640px){.hero-byline{display:none}}

/* ============================================================
   STORY (1905 FEATURE)
   ============================================================ */
.story{padding:clamp(4rem,9vw,7.5rem) 0;background:var(--white)}
.story-h{
  font-family:var(--serif);font-weight:600;color:var(--ink);
  font-size:clamp(1.9rem,1.3rem+3vw,3.4rem);line-height:1.06;letter-spacing:-.02em;
  max-width:20ch;margin-bottom:3rem;text-wrap:balance;
}
.story-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.story-lead p{font-family:var(--news);font-size:1.18rem;line-height:1.65;color:var(--text);margin-bottom:1.3rem}
.dropcap::first-letter{
  font-family:var(--serif);font-weight:900;float:left;font-size:4.6rem;line-height:.78;
  padding:.35rem .55rem 0 0;color:var(--navy);
}
.dropcap span{color:var(--amber-dk);font-weight:600}
.story-pull{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(1.3rem,1rem+1vw,1.7rem)!important;color:var(--navy);line-height:1.3;
  border-left:3px solid var(--amber);padding-left:1.2rem;margin-top:2rem!important;
}
.story-fig{position:relative}
.story-fig img{border-radius:10px;width:100%;aspect-ratio:3/2.05;object-fit:cover;box-shadow:0 30px 60px -34px rgba(8,41,74,.55)}
.story-fig figcaption{font-family:var(--sans);font-size:.82rem;color:var(--muted);margin-top:.8rem;padding-left:.2rem}

/* ============================================================
   HERITAGE 1905 -> 2026
   ============================================================ */
.heritage{background:var(--tint);border-block:1px solid var(--line);padding:clamp(3rem,7vw,5.5rem) 0;text-align:center}
.years{display:flex;align-items:center;justify-content:center;gap:clamp(.6rem,3vw,2.2rem);line-height:1}
.year-from,.year-to{
  font-family:var(--serif);font-weight:900;letter-spacing:-.03em;
  font-size:clamp(3.2rem,2rem+9vw,9rem);color:var(--ink);
}
.year-to{color:var(--amber)}
.year-arrow{font-family:var(--sans);font-weight:300;font-size:clamp(2rem,5vw,4.5rem);color:var(--teal)}
.years-caption{font-family:var(--news);font-size:clamp(1.05rem,1rem+.4vw,1.35rem);color:var(--muted);margin-top:1.2rem}
.years-caption .count{font-family:var(--serif);font-weight:700;color:var(--navy);font-style:normal}

/* ============================================================
   IMMERSIVE BAND
   ============================================================ */
.band{position:relative;isolation:isolate;min-height:clamp(320px,46vw,520px);display:flex;align-items:center}
.band-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%;z-index:-2}
.band-overlay{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(100deg, rgba(8,41,74,.9) 0%, rgba(5,76,112,.78) 45%, rgba(5,76,112,.4) 100%);
}
.band .wrap{padding-block:2rem}
.band-kicker{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.28em;font-size:.78rem;color:var(--teal-lt);margin-bottom:1rem}
.band-line{font-family:var(--serif);font-weight:500;font-size:clamp(1.6rem,1.1rem+2.4vw,3rem);line-height:1.15;color:#fff;max-width:20ch;text-wrap:balance}

/* ============================================================
   WHY JOIN
   ============================================================ */
.why{padding:clamp(4rem,9vw,7.5rem) 0;background:var(--white)}
.why-h{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:clamp(1.8rem,1.3rem+2.6vw,3rem);line-height:1.08;letter-spacing:-.02em;max-width:22ch;margin-bottom:1rem;text-wrap:balance}
.why-intro{font-family:var(--news);font-size:1.2rem;color:var(--muted);max-width:54ch;margin-bottom:3rem}
.outcomes{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.outcome{padding:1.8rem 1.5rem;border:1px solid var(--line);border-radius:12px;background:var(--white);transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.outcome:hover{transform:translateY(-4px);box-shadow:0 26px 50px -32px rgba(8,41,74,.45);border-color:#cfe1ee}
.o-num{font-family:var(--serif);font-weight:900;font-size:1.05rem;color:var(--amber);display:block;margin-bottom:.9rem;letter-spacing:.04em}
.outcome h3{font-family:var(--serif);font-weight:700;font-size:1.45rem;color:var(--navy);margin-bottom:.6rem}
.outcome p{font-size:.98rem;color:var(--text)}
.outcome strong{color:var(--ink)}
.why-source{font-size:.8rem;color:var(--muted);margin-top:1.2rem;font-style:italic}

.why-cta{
  margin-top:2.6rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.5rem;
  background:var(--tint);border:1px solid var(--line);border-radius:14px;padding:1.8rem 2rem;
}
.why-price{font-family:var(--serif);font-weight:500;font-size:1.45rem;color:var(--ink)}
.why-price strong{color:var(--navy);font-weight:700}
.why-note{font-size:.95rem;color:var(--muted);margin-top:.2rem}
.why-note a{color:var(--blue);font-weight:600}

/* ============================================================
   IMPACT STATS (teal)
   ============================================================ */
.impact{background:var(--ink);padding:clamp(3.5rem,8vw,6rem) 0;color:#fff}
.impact .kicker-center{color:var(--teal-lt);margin-bottom:2.6rem}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat{padding:1rem .5rem;border-top:2px solid rgba(62,205,196,.35)}
.stat-num{display:block;font-family:var(--serif);font-weight:900;letter-spacing:-.02em;
  font-size:clamp(2.2rem,1.4rem+3vw,3.6rem);color:var(--teal-lt);line-height:1}
.stat-unit{font-size:.55em;color:var(--teal);vertical-align:.08em}
.stat-label{display:block;font-size:.92rem;color:#cfe0ec;margin-top:.7rem;max-width:22ch;margin-inline:auto;line-height:1.4}

/* ============================================================
   EVENTS
   ============================================================ */
.events{padding:clamp(4rem,9vw,7.5rem) 0;background:var(--tint)}
.events-h{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:clamp(1.9rem,1.3rem+3vw,3.4rem);letter-spacing:-.02em;margin-bottom:2.6rem}
.ev-feature{display:grid;grid-template-columns:1.1fr 1fr;gap:0;background:var(--white);border-radius:16px;overflow:hidden;box-shadow:0 30px 60px -38px rgba(8,41,74,.45);margin-bottom:2rem}
.ev-feature-media{position:relative;min-height:340px}
.ev-feature-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ev-feature-body{padding:clamp(1.8rem,3vw,3rem)}
.ev-tag{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--amber-dk);margin-bottom:.9rem}
.ev-feature-title{font-family:var(--serif);font-weight:700;font-size:clamp(1.7rem,1.2rem+2vw,2.6rem);color:var(--navy);line-height:1.05;margin-bottom:1rem}
.ev-feature-desc{font-family:var(--news);font-size:1.12rem;color:var(--text);margin-bottom:1.4rem;max-width:42ch}
.ev-meta{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem}
.ev-meta li{font-size:.82rem;font-weight:600;color:var(--ink);background:var(--tint);border:1px solid var(--line);padding:.4rem .8rem;border-radius:999px}

.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.ev-card{background:var(--white);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:transform .25s ease, box-shadow .25s ease}
.ev-card:hover{transform:translateY(-5px);box-shadow:0 28px 50px -34px rgba(8,41,74,.45)}
.ev-card-media{aspect-ratio:7/5;overflow:hidden}
.ev-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.ev-card:hover .ev-card-media img{transform:scale(1.05)}
.ev-card-body{padding:1.3rem 1.4rem 1.6rem}
.ev-card-body h3{font-family:var(--serif);font-weight:700;font-size:1.3rem;color:var(--navy);line-height:1.1;margin-bottom:.5rem}
.ev-card-body p{font-size:.95rem;color:var(--text)}

/* ============================================================
   GALLERY BREATH
   ============================================================ */
.gallery{background:var(--white)}
.gallery-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}
.gallery-strip img{width:100%;height:clamp(180px,22vw,300px);object-fit:cover;transition:filter .4s ease, transform .5s ease}
.gallery-strip img:hover{filter:saturate(1.1)}

/* ============================================================
   VOICES
   ============================================================ */
.voices{padding:clamp(4rem,9vw,7.5rem) 0;background:var(--white)}
.voices-h{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:clamp(1.9rem,1.3rem+3vw,3.4rem);letter-spacing:-.02em;margin-bottom:3rem}
.voices-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,3.5rem)}
.voice{display:grid;grid-template-columns:auto 1fr;gap:1.5rem;align-items:start}
.voice-portrait{width:104px;height:104px;flex:0 0 104px;border-radius:50%;object-fit:cover;border:3px solid var(--white);box-shadow:0 0 0 2px var(--amber)}
.voice blockquote{font-family:var(--news);font-style:italic;font-size:1.18rem;line-height:1.55;color:var(--ink);position:relative}
.voice blockquote::before{content:"\201C";font-family:var(--serif);font-size:2.4rem;color:var(--amber);position:absolute;top:-1.1rem;left:-.3rem;opacity:.5}
.voice figcaption{margin-top:1rem}
.v-name{display:block;font-family:var(--serif);font-weight:700;color:var(--navy);font-size:1.1rem}
.v-role{display:block;font-size:.85rem;color:var(--muted);font-weight:500}

/* ============================================================
   CLOSING CTA
   ============================================================ */
.closing{background:var(--navy);background:linear-gradient(135deg,var(--navy),var(--ink));color:#fff;padding:clamp(4rem,9vw,7rem) 0;text-align:center}
.closing-inner{max-width:none}
.closing-h{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,1.4rem+3.4vw,3.8rem);line-height:1.04;letter-spacing:-.02em;margin-bottom:1rem;text-wrap:balance}
.closing-sub{font-family:var(--news);font-size:1.2rem;color:#dcebf6;max-width:48ch;margin:0 auto 2rem}
.closing-note{font-size:.92rem;color:#a9c6db;margin-top:1.4rem}
.closing-note a{color:var(--teal-lt);font-weight:600}

/* ============================================================
   FOOTER
   ============================================================ */
.site-foot{background:var(--ink);color:#cfe0ec;padding:clamp(3rem,6vw,4.5rem) 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.foot-brand .brand-mark{margin-bottom:1rem}
.foot-name{font-family:var(--serif);font-weight:700;font-size:1.25rem;color:#fff}
.foot-tag{font-size:.92rem;color:#9ec0d6;margin-top:.3rem;max-width:30ch}
.foot-col h3{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--teal-lt);margin-bottom:1rem}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:.6rem}
.foot-col a,.foot-col address a{color:#cfe0ec}
.foot-col a:hover{color:#fff}
.foot-col address{font-style:normal;font-size:.95rem;line-height:1.7}
.foot-cta-col .btn{margin-top:.2rem}
.foot-base{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12)}
.foot-base p{font-size:.82rem;color:#86a8c0}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal.arm{opacity:0;transform:translateY(26px);transition:opacity .7s ease, transform .7s ease}
.reveal.arm.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .outcomes{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:2rem 1rem}
  .ev-grid{grid-template-columns:1fr 1fr}
  .gallery-strip{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:860px){
  .main-nav,.head-join{display:none}
  .nav-toggle{display:flex}
  .story-grid{grid-template-columns:1fr;gap:2.5rem}
  .story-fig{order:-1}
  .ev-feature{grid-template-columns:1fr}
  .ev-feature-media{min-height:240px;aspect-ratio:16/9}
  .voices-grid{grid-template-columns:1fr;gap:2.5rem}
}
@media (max-width:640px){
  .ev-grid{grid-template-columns:1fr}
  .voice{grid-template-columns:1fr;text-align:left}
  .voice-portrait{width:84px;height:84px;flex-basis:84px}
  .why-cta{flex-direction:column;align-items:flex-start}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1 / -1}
  .hero{min-height:88vh}
}
@media (max-width:440px){
  .gallery-strip{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr}
}
