/* =============================================================
   CNW LEAN STYLESHEET — single file, no preprocessor
   ============================================================= */

/* ---------- Design Tokens ---------- */
:root {
  /* Brand colors */
  --parchment: #F2EDE3;
  --toned-ivory: #FAF7ED;
  --cloud-dancer: #F0F1ED;
  --mountain-charcoal: #51534A;
  --stone-gray: #919388;
  --burnished-bronze: #B8741A;
  --heritage-sun: #FAA21B;
  --deep-navy: #1B2A3B;
  --idaho-forest: #2F4636;
  --twilight-slate: #3F5867;
  --white: #FFFFFF;

  /* Typography */
  --font-display: 'Instrument Serif', Georgia, serif;
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  /* Fluid type scale (clamp(min, preferred, max)) */
  --fs-eyebrow: 12px;
  --fs-caption: clamp(11px, 0.7vw, 12px);
  --fs-body: clamp(15px, 1.05vw, 17px);
  --fs-body-lead: clamp(17px, 1.3vw, 22px);
  --fs-body-tight: clamp(13px, 0.95vw, 14px);
  --fs-h4: clamp(22px, 2vw, 30px);
  --fs-h3: clamp(28px, 2.8vw, 42px);
  --fs-h2: clamp(36px, 5vw, 72px);
  --fs-h2-tight: clamp(32px, 4vw, 56px);
  --fs-h1: clamp(48px, 9.5vw, 144px);
  --fs-stat-anchor: clamp(120px, 18vw, 240px);
  --fs-stat-mini: clamp(40px, 4.5vw, 64px);
  --fs-wordmark: clamp(80px, 18vw, 280px);

  /* Layout */
  --container-max: 1200px;
  --container-pad: clamp(24px, 5vw, 80px);
  --section-y: clamp(72px, 11vw, 160px);
  --section-y-lg: clamp(100px, 14vw, 220px);
  --section-y-sm: clamp(64px, 8vw, 120px);

  /* Animation */
  --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --dur-fast: 0.4s;
  --dur-base: 0.7s;
  --dur-slow: 1.1s;
}

/* ---------- Reset / Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: var(--fs-body);
  line-height: 1.65;
  color: var(--mountain-charcoal);
  background: var(--parchment);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
h1, h2, h3, h4, h5, h6, p, blockquote, ul, ol, figure { margin: 0; }
ul, ol { padding: 0; list-style: none; }
em, i { font-style: italic; }
.italic { font-style: italic; }
hr { border: 0; }
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--mountain-charcoal); color: var(--parchment);
  padding: 12px 16px; z-index: 9999;
}
.skip-link:focus { left: 0; }

/* ---------- Container ---------- */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-inline: var(--container-pad);
  width: 100%;
}

/* ---------- Typography ---------- */
.eyebrow {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--fs-eyebrow);
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--burnished-bronze);
  line-height: 1;
}
.eyebrow--on-dark { color: var(--heritage-sun); }
.eyebrow--accent { color: var(--heritage-sun); }
.eyebrow--center { text-align: center; }
.h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-h1);
  line-height: 1.06;
  letter-spacing: -0.01em;
  color: var(--mountain-charcoal);
}
.h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-h2);
  line-height: 1.14;
  color: var(--mountain-charcoal);
}
.h2--tight { font-size: var(--fs-h2-tight); }
.h2--center { text-align: center; }
.h2--on-dark { color: var(--parchment); }
.h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-h3);
  line-height: 1.24;
  color: var(--mountain-charcoal);
}
.h3--on-dark { color: var(--parchment); }
.h4 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-h4);
  line-height: 1.27;
  color: var(--mountain-charcoal);
}
.h4--center { text-align: center; }
.body { font-size: var(--fs-body); line-height: 1.65; color: var(--mountain-charcoal); }
.body--lead { font-size: var(--fs-body-lead); line-height: 1.5; color: var(--stone-gray); }
.body--tight { font-size: var(--fs-body-tight); line-height: 1.55; color: var(--stone-gray); }
.body--light { color: var(--stone-gray); }
.body--strong { font-weight: 600; color: var(--mountain-charcoal); }
.body--on-dark { color: var(--parchment); }
.body--on-dark.body--strong { color: var(--parchment); }
.body--center { text-align: center; }
.caption { font-size: var(--fs-caption); line-height: 1.55; color: var(--stone-gray); }
.caption--center { text-align: center; }

/* ---------- Divider ---------- */
.divider {
  display: block; height: 2px; width: 32px; background: var(--burnished-bronze);
  border: 0; margin: 0;
}
.divider--accent { background: var(--burnished-bronze); }
.divider--accent-dark { background: var(--heritage-sun); }
.divider--center { margin-inline: auto; }

/* ---------- Pill CTA ---------- */
.cta-pill {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 14px 8px 14px 28px;
  background: var(--heritage-sun); color: var(--mountain-charcoal);
  font-family: var(--font-sans); font-weight: 600; font-size: 13px;
  letter-spacing: 1.2px; text-transform: uppercase;
  border-radius: 999px;
  transition: background var(--dur-fast) var(--ease-out-quart), color var(--dur-fast) var(--ease-out-quart), transform 0.3s var(--ease-out-quart);
  white-space: nowrap;
}
.cta-pill__arrow {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 999px;
  background: var(--mountain-charcoal); color: var(--heritage-sun);
  font-size: 14px; font-weight: 600;
  transition: transform 0.3s var(--ease-out-quart), background var(--dur-fast), color var(--dur-fast);
}
.cta-pill:hover { background: var(--mountain-charcoal); color: var(--heritage-sun); transform: translateY(-2px); }
.cta-pill:hover .cta-pill__arrow { background: var(--heritage-sun); color: var(--mountain-charcoal); transform: translateX(4px); }
.cta-pill--dark { background: var(--mountain-charcoal); color: var(--heritage-sun); }
.cta-pill--dark .cta-pill__arrow { background: var(--heritage-sun); color: var(--mountain-charcoal); }
.cta-pill--dark:hover { background: var(--heritage-sun); color: var(--mountain-charcoal); }
.cta-pill--dark:hover .cta-pill__arrow { background: var(--mountain-charcoal); color: var(--heritage-sun); }
.cta-pill--light { background: var(--parchment); color: var(--burnished-bronze); }
.cta-pill--light .cta-pill__arrow { background: var(--burnished-bronze); color: var(--parchment); }
.cta-pill--light:hover { background: var(--burnished-bronze); color: var(--parchment); }
.cta-pill--light:hover .cta-pill__arrow { background: var(--parchment); color: var(--burnished-bronze); }
.cta-pill--ghost { background: var(--deep-navy); color: var(--parchment); }
.cta-pill--ghost .cta-pill__arrow { background: var(--parchment); color: var(--deep-navy); }
.cta-pill--ghost:hover { background: var(--parchment); color: var(--deep-navy); }
.cta-pill--ghost:hover .cta-pill__arrow { background: var(--deep-navy); color: var(--parchment); }

.link-bronze {
  display: inline-block;
  font-family: var(--font-sans); font-weight: 600; font-size: 12px;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--burnished-bronze);
  transition: color var(--dur-fast), transform 0.3s var(--ease-out-quart);
  border-bottom: 1px solid transparent;
}
.link-bronze:hover { color: var(--mountain-charcoal); transform: translateX(4px); }
.link-bronze--on-dark { color: var(--heritage-sun); }
.link-bronze--on-dark:hover { color: var(--parchment); }

/* ---------- Placeholders ---------- */
.placeholder {
  display: flex; align-items: center; justify-content: center;
  background: var(--deep-navy); color: var(--parchment); opacity: 0.6;
  font-family: var(--font-sans); font-size: 11px; letter-spacing: 2.5px;
  text-transform: uppercase; padding: 24px 16px; text-align: center;
  border-radius: 4px; aspect-ratio: 4/3;
}
.placeholder--anchor { aspect-ratio: 2/1; }
.placeholder--media { aspect-ratio: 16/10; }
.placeholder--inline {
  display: inline-block; padding: 0; background: none; color: var(--stone-gray);
  text-transform: none; letter-spacing: 0; font-size: 12px; font-weight: 400;
  aspect-ratio: auto; opacity: 1;
}

/* ---------- SITE HEADER ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--parchment);
  border-bottom: 1px solid color-mix(in srgb, var(--stone-gray) 30%, transparent);
  backdrop-filter: saturate(1.2);
}
.site-header__inner {
  max-width: var(--container-max);
  margin: 0 auto; padding: 16px var(--container-pad);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.site-header__logo img { height: 44px; width: auto; }
.site-header__nav ul { display: flex; gap: 32px; align-items: center; }
.site-header__nav a {
  font-family: var(--font-sans); font-weight: 600; font-size: 12px;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--mountain-charcoal);
  transition: color var(--dur-fast);
}
.site-header__nav a:hover { color: var(--burnished-bronze); }
.site-header__hamburger {
  display: none; width: 44px; height: 44px; flex-direction: column;
  justify-content: center; align-items: center; gap: 5px;
}
.site-header__hamburger span { display: block; width: 22px; height: 2px; background: var(--mountain-charcoal); transition: transform 0.3s, opacity 0.3s; }
.site-header__mobile { display: none; }
@media (max-width: 900px) {
  .site-header__nav, .site-header__cta { display: none; }
  .site-header__hamburger { display: flex; }
  .site-header__mobile {
    display: block; max-height: 0; overflow: hidden;
    transition: max-height 0.4s var(--ease-out-quart);
    background: var(--parchment);
    border-top: 1px solid color-mix(in srgb, var(--stone-gray) 30%, transparent);
  }
  body.menu-open .site-header__mobile { max-height: 100vh; }
  body.menu-open .site-header__hamburger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  body.menu-open .site-header__hamburger span:nth-child(2) { opacity: 0; }
  body.menu-open .site-header__hamburger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .site-header__mobile ul { padding: 16px 24px 24px; }
  .site-header__mobile li { padding: 12px 0; border-bottom: 1px solid color-mix(in srgb, var(--stone-gray) 20%, transparent); }
  .site-header__mobile a { font-family: var(--font-sans); font-weight: 600; font-size: 14px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--mountain-charcoal); }
  .site-header__mobile .mobile-cta { color: var(--burnished-bronze); }
}

/* ---------- SECTION BASE ---------- */
.section { padding-block: var(--section-y); position: relative; }
.section--empty { padding-block: 120px; text-align: center; }
.section__header { text-align: center; margin-bottom: clamp(36px, 5vw, 56px); }
.section__header .eyebrow { margin-bottom: 16px; }
.section__header .h2 { margin-bottom: 16px; }
.section__header .body--lead { max-width: 780px; margin: 0 auto; }

/* Card primitives */
.card {
  background: var(--toned-ivory);
  border: 1px solid var(--mountain-charcoal);
  border-radius: 4px;
  padding: clamp(24px, 2.5vw, 40px);
  display: flex; flex-direction: column; gap: 16px;
}
.card .divider:first-child { margin-bottom: 4px; }
.card--dark { background: var(--deep-navy); border-color: var(--deep-navy); }
.card--featured { gap: 16px; }
.card .link-bronze { margin-top: auto; }

/* ---------- 1. HERO ---------- */
.section--hero { padding-top: clamp(80px, 9vw, 160px); padding-bottom: clamp(64px, 7vw, 120px); background: var(--parchment); }
.hero__inner { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 32px; }
.hero__headline { max-width: 1100px; }
.hero__subhead { max-width: 780px; }
.hero__actions { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.hero__phone { font-size: 13px; color: var(--stone-gray); font-family: var(--font-sans); }
.hero__anchor { width: 100%; max-width: 1120px; margin-top: 16px; }
.hero__anchor img, .hero__anchor .placeholder { width: 100%; aspect-ratio: 2/1; object-fit: cover; border-radius: 4px; }

/* ---------- 2. MISSION 2COL ---------- */
.section--mission_2col { background: var(--parchment); }
.mission__grid { display: grid; grid-template-columns: 1.7fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: start; }
.mission__copy { display: flex; flex-direction: column; gap: 20px; }
.mission__card { background: var(--twilight-slate); color: var(--parchment); padding: 32px 36px; border-radius: 4px; display: flex; flex-direction: column; gap: 14px; }
.mission__phone { font-family: var(--font-display); font-size: 32px; line-height: 1.2; color: var(--parchment); }
.mission__email { font-family: var(--font-sans); font-size: 15px; color: var(--parchment); }
.mission__locations { font-family: var(--font-sans); font-size: 13px; line-height: 1.7; color: var(--parchment); }
.mission__card .cta-pill { align-self: flex-start; margin-top: 4px; }
@media (max-width: 820px) { .mission__grid { grid-template-columns: 1fr; } }

/* ---------- BENTO LAYOUTS ---------- */
.bento { display: grid; gap: 20px; }
.bento--360, .bento--audiences {
  grid-template-columns: 1.97fr 1fr;
  grid-template-rows: auto auto;
  grid-template-areas:
    "featured small-stack"
    "wide cta-card";
}
.bento .card--featured { grid-area: featured; }
.bento .bento__small-stack { grid-area: small-stack; display: grid; gap: 20px; }
.bento .card--wide { grid-area: wide; flex-direction: row; align-items: center; gap: 32px; }
.bento .card--cta-dark { grid-area: cta-card; background: var(--deep-navy); border-color: var(--deep-navy); align-items: center; justify-content: center; text-align: center; gap: 14px; padding: 28px; }
.bento .card--cta-sun { grid-area: cta-card; background: var(--heritage-sun); border-color: var(--heritage-sun); align-items: center; justify-content: center; text-align: center; gap: 14px; padding: 28px; }
.card--wide__left { flex: 0 0 250px; display: flex; flex-direction: column; gap: 8px; }
.card--wide__right { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.card--wide .divider { margin: 0; }
.card--cta-dark__title { font-family: var(--font-display); font-style: italic; font-size: 22px; line-height: 1.27; color: var(--parchment); }
.card--cta-sun__title { font-family: var(--font-display); font-style: italic; font-size: 24px; line-height: 1.25; color: var(--mountain-charcoal); }
.section--bento_360_framework { background: var(--cloud-dancer); }
.section--bento_audiences { background: var(--parchment); }
@media (max-width: 900px) {
  .bento--360, .bento--audiences {
    grid-template-columns: 1fr;
    grid-template-areas: "featured" "small-stack" "wide" "cta-card";
  }
  .bento .card--wide { flex-direction: column; align-items: stretch; gap: 16px; }
  .card--wide__left { flex: initial; }
}

/* ---------- 4. IMAGE BACKDROP ---------- */
.section--image_backdrop { padding-block: var(--section-y-lg); text-align: center; color: var(--parchment); position: relative; overflow: hidden; }
.section--image_backdrop.section--navy { background: var(--deep-navy); }
.section--image_backdrop.section--slate { background: var(--twilight-slate); }
.section--image_backdrop.section--forest { background: var(--idaho-forest); }
.section--image_backdrop::before {
  content: ''; position: absolute; inset: auto 0 0 0; height: 100vh;
  background: var(--bg-image) bottom center / cover no-repeat;
  opacity: 0.18; pointer-events: none;
}
.image_backdrop__inner { position: relative; display: flex; flex-direction: column; align-items: center; gap: 32px; }
.image_backdrop__credit { font-family: var(--font-sans); font-weight: 600; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--parchment); opacity: 0.6; }
.image_backdrop__inner .h2 { max-width: 1100px; }

/* ---------- 5. CPA STAT ---------- */
.section--cpa_stat { background: var(--parchment); text-align: center; }
.cpa_stat__inner { display: flex; flex-direction: column; align-items: center; gap: 24px; }
.cpa_stat__number {
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: var(--fs-stat-anchor); line-height: 1;
  color: var(--burnished-bronze);
}
.cpa_stat__caption { max-width: 640px; font-size: var(--fs-body-lead); }
.cpa_stat__disclosure { max-width: 840px; margin-top: 24px; }

/* ---------- 6. PROCESS GRID ---------- */
.section--process_grid { background: var(--parchment); }
.process_grid__primary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.process_card__num { font-family: var(--font-display); font-style: italic; font-size: 40px; line-height: 1.1; color: var(--burnished-bronze); }
.process_card__title { font-family: var(--font-sans); font-weight: 600; font-size: 17px; color: var(--mountain-charcoal); line-height: 1.4; }
.process_grid__secondary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; margin-top: 48px; }
.process_mini { display: flex; flex-direction: column; gap: 6px; }
.process_mini__head { display: flex; align-items: baseline; gap: 12px; }
.process_mini__num { font-family: var(--font-display); font-style: italic; font-size: 20px; color: var(--burnished-bronze); }
.process_mini__title { font-family: var(--font-sans); font-weight: 600; font-size: 14px; color: var(--mountain-charcoal); }
@media (max-width: 820px) {
  .process_grid__primary { grid-template-columns: 1fr; }
  .process_grid__secondary { grid-template-columns: 1fr; gap: 24px; }
}

/* ---------- 8. HERITAGE 2COL ---------- */
.section--heritage_2col { background: var(--parchment); }
.heritage__grid { display: grid; grid-template-columns: 1.07fr 1fr; gap: clamp(48px, 8vw, 96px); align-items: start; }
.heritage__copy { display: flex; flex-direction: column; gap: 24px; }
.heritage__copy .h2 { font-size: var(--fs-h2-tight); line-height: 1.21; }
.heritage__milestones { display: flex; flex-direction: column; }
.milestone { padding: 20px 0; border-bottom: 1px solid color-mix(in srgb, var(--stone-gray) 50%, transparent); }
.milestone:last-child { border-bottom: 0; }
.milestone__head { display: flex; align-items: baseline; gap: 16px; }
.milestone__year { font-family: var(--font-display); font-style: italic; font-size: 36px; line-height: 1.1; color: var(--burnished-bronze); }
.milestone__title { font-family: var(--font-sans); font-weight: 600; font-size: 14px; color: var(--mountain-charcoal); }
.milestone .body { margin-top: 4px; }
@media (max-width: 820px) { .heritage__grid { grid-template-columns: 1fr; } }

/* ---------- 9. WORDMARK ---------- */
.section--wordmark { background: var(--parchment); padding-block: clamp(64px, 9vw, 120px); display: flex; justify-content: center; align-items: center; }
.wordmark__text {
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: var(--fs-wordmark); line-height: 1;
  color: var(--burnished-bronze); opacity: 0.85; text-align: center;
}

/* ---------- 10. PULL QUOTE ---------- */
.section--pull_quote { background: var(--idaho-forest); padding-block: clamp(120px, 16vw, 220px); text-align: center; color: var(--parchment); }
.pull_quote__inner { display: flex; flex-direction: column; align-items: center; gap: 48px; }
.pull_quote__text {
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: clamp(28px, 5vw, 64px); line-height: 1.22;
  color: var(--parchment); max-width: 1100px; margin: 0;
}

/* ---------- 11. FAQ ---------- */
.section--faq_accordion { background: var(--cloud-dancer); }
.faq__inner { max-width: 1000px; margin: 0 auto; }
.faq__list { display: flex; flex-direction: column; }
.faq__item { border-bottom: 1px solid color-mix(in srgb, var(--stone-gray) 50%, transparent); }
.faq__item:first-child { border-top: 1px solid color-mix(in srgb, var(--stone-gray) 50%, transparent); }
.faq__q {
  cursor: pointer; list-style: none; padding: 28px 0;
  display: flex; justify-content: space-between; align-items: flex-start; gap: 24px;
  font-family: var(--font-display); font-weight: 400; font-size: 22px; line-height: 1.45;
  color: var(--mountain-charcoal);
}
.faq__q::-webkit-details-marker, .faq__q::marker { display: none; }
.faq__q::after { content: ''; }
.faq__icon { position: relative; width: 24px; height: 24px; flex-shrink: 0; margin-top: 6px; }
.faq__icon::before, .faq__icon::after { content: ''; position: absolute; top: 50%; left: 50%; background: var(--burnished-bronze); transform: translate(-50%, -50%); transition: transform 0.3s var(--ease-out-quart); }
.faq__icon::before { width: 18px; height: 2px; }
.faq__icon::after { width: 2px; height: 18px; }
details[open] .faq__icon::after { transform: translate(-50%, -50%) rotate(90deg); opacity: 0; }
.faq__a { padding: 0 0 28px; max-width: 840px; }

/* ---------- 12. NUMBERS BENTO ---------- */
.section--numbers_bento { background: var(--parchment); }
.numbers__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 20px; align-items: stretch; }
.numbers__anchor { text-align: center; align-items: center; justify-content: center; gap: 16px; padding: 40px; }
.numbers__anchor-num { font-family: var(--font-display); font-style: italic; font-size: var(--fs-stat-anchor); line-height: 1; color: var(--mountain-charcoal); }
.numbers__stack { display: grid; gap: 12px; }
.numbers__mini { flex-direction: row; align-items: center; gap: 24px; padding: 24px; }
.numbers__mini-num { font-family: var(--font-display); font-style: italic; font-size: var(--fs-stat-mini); color: var(--mountain-charcoal); line-height: 1; }
.numbers__mini-label { font-size: var(--fs-body-tight); color: var(--stone-gray); }
@media (max-width: 820px) { .numbers__grid { grid-template-columns: 1fr; } }

/* ---------- 13. TEAM ---------- */
.section--team { background: var(--idaho-forest); color: var(--parchment); }
.team__grid { display: grid; grid-template-columns: 240fr 620fr 240fr; gap: 20px; align-items: stretch; }
.team__left-stack { display: flex; flex-direction: column; gap: 16px; }
.team__portrait { background: var(--twilight-slate); border-radius: 4px; aspect-ratio: 3/4; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.team__portrait:nth-child(2) { background: var(--mountain-charcoal); }
.team__portrait--tall { aspect-ratio: 1/2.05; height: 100%; }
.team__portrait img { width: 100%; height: 100%; object-fit: cover; }
.team__portrait .placeholder { width: 100%; height: 100%; aspect-ratio: auto; background: none; opacity: 0.85; }
.team__panel { background: var(--burnished-bronze); border-color: var(--burnished-bronze); border-radius: 4px; padding: 48px; display: flex; flex-direction: column; gap: 20px; align-items: center; justify-content: center; text-align: center; }
.team__quote { font-family: var(--font-display); font-style: italic; font-size: clamp(24px, 2.6vw, 36px); line-height: 1.33; color: var(--parchment); margin: 0; }
.team__panel .body { color: var(--parchment); }
@media (max-width: 900px) {
  .team__grid { grid-template-columns: 1fr; }
  .team__portrait--tall { aspect-ratio: 3/4; }
}

/* ---------- 14. PARTNERS ---------- */
.section--partners { background: var(--cloud-dancer); padding-block: clamp(64px, 8vw, 96px); }
.partners__inner { display: flex; flex-direction: column; align-items: center; gap: 32px; text-align: center; }
.partners__grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; width: 100%; }
.partners__slot { border: 1px solid color-mix(in srgb, var(--stone-gray) 60%, transparent); border-radius: 8px; padding: 24px; min-height: 72px; display: flex; align-items: center; justify-content: center; transition: border-color var(--dur-fast), transform 0.3s var(--ease-out-quart); }
.partners__slot:hover { border-color: var(--burnished-bronze); transform: translateY(-2px); }
.partners__slot img { max-height: 32px; width: auto; opacity: 0.7; transition: opacity var(--dur-fast); }
.partners__slot:hover img { opacity: 1; }
@media (max-width: 820px) { .partners__grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- 15. PERSPECTIVES ---------- */
.section--perspectives { background: var(--parchment); }
.perspectives__lead { max-width: 960px; margin: 0 auto 48px; align-items: center; text-align: center; padding: 48px; }
.perspectives__quote { font-family: var(--font-display); font-style: italic; font-size: clamp(22px, 2.5vw, 32px); line-height: 1.44; color: var(--mountain-charcoal); margin: 0; }
.perspectives__minis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 32px; }
.perspectives__mini { background: var(--toned-ivory); border: 1px solid color-mix(in srgb, var(--stone-gray) 60%, transparent); border-left: 4px solid var(--burnished-bronze); border-radius: 0 4px 4px 0; padding: 32px 28px; display: flex; flex-direction: column; gap: 14px; }
@media (max-width: 820px) { .perspectives__minis { grid-template-columns: 1fr; } }

/* ---------- 16. INSIGHTS ---------- */
.section--insights { background: var(--cloud-dancer); }
.insights__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.insights__card { padding: 0; overflow: hidden; gap: 0; transition: transform 0.4s var(--ease-out-quart), box-shadow 0.4s; }
.insights__card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px -10px rgba(81,83,74,0.18); }
.insights__media { display: block; aspect-ratio: 16/10; overflow: hidden; }
.insights__media img, .insights__media .placeholder { width: 100%; height: 100%; object-fit: cover; aspect-ratio: auto; }
.insights__body { padding: 28px 28px 32px; display: flex; flex-direction: column; gap: 12px; }
.insights__body .h4 { font-size: 22px; line-height: 1.36; }
.insights__cta { display: flex; justify-content: center; margin-top: 32px; }
@media (max-width: 900px) { .insights__grid { grid-template-columns: 1fr; } }

/* ---------- SITE FOOTER ---------- */
.site-footer { background: var(--mountain-charcoal); color: var(--parchment); font-family: var(--font-sans); }
.site-footer__cta { padding-block: clamp(72px, 10vw, 120px); }
.site-footer__cta-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 60px; align-items: center; }
.site-footer__cta-copy .eyebrow { margin-bottom: 20px; }
.site-footer__cta-copy .h2 { margin-bottom: 20px; font-size: clamp(32px, 4vw, 56px); }
.site-footer__cta-copy .body { max-width: 600px; }
.site-footer__cta-actions { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.site-footer__cta-actions .cta-pill { align-self: flex-start; }
.site-footer__brand { padding: 64px var(--container-pad) 32px; border-top: 1px solid var(--burnished-bronze); max-width: var(--container-max); margin: 0 auto; }
.site-footer__brand-grid { display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.site-footer__brand img { height: 64px; width: auto; margin-bottom: 12px; }
.site-footer__tagline { font-family: var(--font-display); font-style: italic; font-size: 22px; color: var(--parchment); }
.site-footer__social { display: flex; gap: 12px; }
.site-footer__social a { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 999px; border: 1px solid var(--stone-gray); color: var(--parchment); font-weight: 600; font-size: 11px; transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast); }
.site-footer__social a:hover { background: var(--heritage-sun); border-color: var(--heritage-sun); color: var(--mountain-charcoal); }
.site-footer__nav { padding-block: 32px 64px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 48px; }
.site-footer__nav ul { display: flex; flex-direction: column; gap: 8px; }
.site-footer__nav a, .site-footer__nav .body { color: var(--parchment); font-weight: 300; font-size: 14px; line-height: 1.7; }
.site-footer__nav a:hover { color: var(--heritage-sun); }
.site-footer__nav .eyebrow { margin-bottom: 16px; }
.site-footer__nav address { font-style: normal; color: var(--parchment); font-weight: 300; }
.site-footer__nav address em { color: var(--stone-gray); }
.site-footer__legal { background: var(--idaho-forest); padding: 28px var(--container-pad); }
.site-footer__legal p { font-size: 12px; line-height: 1.7; color: var(--stone-gray); margin: 0 0 8px; }
.site-footer__legal p:last-child { margin: 0; }
@media (max-width: 900px) {
  .site-footer__cta-grid { grid-template-columns: 1fr; }
  .site-footer__nav { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .site-footer__brand-grid { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 580px) { .site-footer__nav { grid-template-columns: 1fr; } }

/* ---------- 17. CARDS GRID (generic) ---------- */
.section--cards_grid { background: var(--parchment); }
.cards_grid__items {
  display: grid;
  grid-template-columns: repeat(var(--cards-cols, 4), 1fr);
  gap: 20px;
}
.cards_grid__card { gap: 14px; }
.cards_grid__card .h3, .cards_grid__card .h4 { margin-top: 4px; }
.cards_grid__icon { font-family: var(--font-display); font-style: italic; font-size: 48px; color: var(--burnished-bronze); line-height: 1; }
.cards_grid__media { aspect-ratio: 4/3; overflow: hidden; border-radius: 4px; margin: -24px -24px 8px; }
.cards_grid__media img { width: 100%; height: 100%; object-fit: cover; }
.cards_grid__cta { display: flex; justify-content: center; margin-top: 40px; }
.cards_grid__card--dark { background: var(--deep-navy); color: var(--parchment); border-color: var(--deep-navy); }
.cards_grid__card--dark .h3, .cards_grid__card--dark .h4 { color: var(--parchment); }
.cards_grid__card--dark .body { color: var(--parchment); }
.cards_grid__card--bronze { background: var(--burnished-bronze); color: var(--parchment); border-color: var(--burnished-bronze); }
.cards_grid__card--bronze .h3, .cards_grid__card--bronze .h4 { color: var(--parchment); }
.cards_grid__card--bronze .eyebrow { color: var(--parchment); }
@media (max-width: 900px) { .cards_grid__items { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .cards_grid__items { grid-template-columns: 1fr; } }

/* ---------- 18. PROSE ---------- */
.section--prose { background: var(--parchment); padding-block: clamp(72px, 9vw, 140px); }
.prose__inner { max-width: 760px; margin: 0 auto; }
.prose__inner--article { max-width: 820px; }
.prose__header { margin-bottom: 56px; padding-bottom: 32px; border-bottom: 1px solid color-mix(in srgb, var(--stone-gray) 40%, transparent); }
.prose__header .eyebrow { margin-bottom: 16px; }
.prose__header .h2 { font-size: clamp(32px, 4vw, 56px); line-height: 1.16; margin-bottom: 16px; }
.prose__title { font-size: clamp(36px, 5.5vw, 72px); line-height: 1.08; margin-bottom: 20px; }
.prose__dek { font-size: clamp(18px, 1.7vw, 22px); line-height: 1.5; color: var(--stone-gray); margin-bottom: 24px; max-width: 720px; }
.prose__meta { display: flex; flex-wrap: wrap; gap: 14px 24px; font-family: var(--font-sans); font-weight: 500; font-size: 13px; letter-spacing: 0.3px; color: var(--stone-gray); margin-top: 16px; }
.prose__meta span { display: inline-flex; align-items: center; gap: 6px; }
.prose__meta span + span::before { content: '·'; margin-right: 24px; color: var(--burnished-bronze); }
.prose__byline { color: var(--mountain-charcoal); font-weight: 600; }
.prose__featured { margin: -16px 0 64px; }
.prose__featured img { width: 100%; aspect-ratio: 2/1; object-fit: cover; border-radius: 4px; }
.prose__featured figcaption { margin-top: 12px; text-align: center; font-size: 12px; color: var(--stone-gray); }
.prose__body { font-family: var(--font-sans); font-weight: 300; font-size: 17px; line-height: 1.75; color: var(--mountain-charcoal); }
.prose__body > * + * { margin-top: 1.2em; }
.prose__body p { margin: 0; }
.prose__body .prose__h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(28px, 3vw, 36px); line-height: 1.24; margin-top: 2em; margin-bottom: 0.4em; color: var(--mountain-charcoal); }
.prose__body .prose__h3 { font-family: var(--font-display); font-weight: 400; font-size: clamp(22px, 2vw, 26px); line-height: 1.3; margin-top: 1.6em; margin-bottom: 0.4em; }
.prose__body .prose__list { padding-left: 1.2em; list-style: disc outside; }
.prose__body .prose__list--ordered { list-style: decimal outside; }
.prose__body .prose__list li { margin-top: 0.5em; }
.prose__body .prose__list li::marker { color: var(--burnished-bronze); }
.prose__body .prose__quote { font-family: var(--font-display); font-style: italic; font-size: clamp(20px, 1.8vw, 24px); line-height: 1.5; color: var(--mountain-charcoal); border-left: 3px solid var(--burnished-bronze); padding: 8px 0 8px 24px; margin-block: 1.4em; }
.prose__body .prose__callout { background: var(--toned-ivory); border-left: 3px solid var(--burnished-bronze); padding: 24px 28px; margin-block: 1.8em; }
.prose__body .prose__callout p { font-size: 15px; line-height: 1.65; color: var(--mountain-charcoal); }
.prose__body a { color: var(--burnished-bronze); border-bottom: 1px solid color-mix(in srgb, var(--burnished-bronze) 40%, transparent); transition: color var(--dur-fast), border-color var(--dur-fast); }
.prose__body a:hover { color: var(--mountain-charcoal); border-color: var(--mountain-charcoal); }
.prose__body strong { font-weight: 600; color: var(--mountain-charcoal); }
.prose__body em { font-style: italic; }

/* Fluent Forms inside contact_block and schedule_block — basic styling overrides */
.contact__shortcode .ff-default,
.schedule__shortcode .ff-default { background: transparent; padding: 0; }
.contact__shortcode .ff-el-group,
.schedule__shortcode .ff-el-group { margin-bottom: 18px; }
.contact__shortcode .ff-el-input--label label,
.schedule__shortcode .ff-el-input--label label {
  font-family: var(--font-sans); font-weight: 600; font-size: 12px;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--mountain-charcoal);
  margin-bottom: 8px;
}
.contact__shortcode input[type=text], .contact__shortcode input[type=email],
.contact__shortcode input[type=tel], .contact__shortcode select,
.contact__shortcode textarea,
.schedule__shortcode input[type=text], .schedule__shortcode input[type=email],
.schedule__shortcode input[type=tel], .schedule__shortcode select,
.schedule__shortcode textarea {
  font-family: var(--font-sans); font-size: 16px; padding: 14px 16px;
  background: var(--toned-ivory); border: 1px solid color-mix(in srgb, var(--stone-gray) 50%, transparent);
  border-radius: 4px; color: var(--mountain-charcoal); transition: border-color var(--dur-fast);
  width: 100%;
}
.contact__shortcode input:focus, .contact__shortcode textarea:focus, .contact__shortcode select:focus,
.schedule__shortcode input:focus, .schedule__shortcode textarea:focus, .schedule__shortcode select:focus {
  border-color: var(--burnished-bronze); outline: none; background: var(--parchment);
}
.contact__shortcode button[type=submit], .contact__shortcode .ff-btn-submit,
.schedule__shortcode button[type=submit], .schedule__shortcode .ff-btn-submit {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 14px 28px;
  background: var(--heritage-sun); color: var(--mountain-charcoal);
  font-family: var(--font-sans); font-weight: 600; font-size: 13px;
  letter-spacing: 1.2px; text-transform: uppercase;
  border-radius: 999px; border: 0;
  transition: background var(--dur-fast), color var(--dur-fast), transform 0.3s var(--ease-out-quart);
  cursor: pointer;
}
.contact__shortcode button[type=submit]:hover, .contact__shortcode .ff-btn-submit:hover,
.schedule__shortcode button[type=submit]:hover, .schedule__shortcode .ff-btn-submit:hover {
  background: var(--mountain-charcoal); color: var(--heritage-sun); transform: translateY(-2px);
}

/* ---------- 19. CONTACT BLOCK ---------- */
.section--contact_block { background: var(--parchment); }
.contact__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: start; }
.contact__form-col { display: flex; flex-direction: column; gap: 16px; }
.contact__form { display: flex; flex-direction: column; gap: 18px; margin-top: 16px; }
.contact__row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.contact__field { display: flex; flex-direction: column; gap: 8px; }
.contact__field > span { font-family: var(--font-sans); font-weight: 600; font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--mountain-charcoal); }
.contact__field .optional { color: var(--stone-gray); font-weight: 400; text-transform: none; letter-spacing: 0; }
.contact__field input, .contact__field select, .contact__field textarea {
  font-family: var(--font-sans); font-size: 16px; padding: 14px 16px;
  background: var(--toned-ivory); border: 1px solid color-mix(in srgb, var(--stone-gray) 50%, transparent);
  border-radius: 4px; color: var(--mountain-charcoal); transition: border-color var(--dur-fast), background var(--dur-fast);
  outline: none; resize: vertical;
}
.contact__field input:focus, .contact__field select:focus, .contact__field textarea:focus {
  border-color: var(--burnished-bronze); background: var(--parchment);
}
.contact__form .cta-pill { align-self: flex-start; margin-top: 8px; }
.contact__status { font-size: 14px; color: var(--burnished-bronze); min-height: 1.5em; }
.contact__status.error { color: #b00020; }
.contact__status.success { color: var(--idaho-forest); }
.contact__sidebar { display: flex; flex-direction: column; gap: 24px; position: sticky; top: 100px; }
.contact__card { background: var(--twilight-slate); color: var(--parchment); padding: 32px; border-radius: 4px; display: flex; flex-direction: column; gap: 12px; }
.contact__phone { font-family: var(--font-display); font-size: 32px; color: var(--parchment); line-height: 1.2; }
.contact__email { font-family: var(--font-sans); font-size: 15px; color: var(--parchment); }
.contact__locations { display: flex; flex-direction: column; gap: 16px; padding: 24px 0; }
.contact__locations .eyebrow { margin-bottom: 8px; }
.contact__location { padding: 16px 0; border-bottom: 1px solid color-mix(in srgb, var(--stone-gray) 40%, transparent); }
.contact__location:last-child { border-bottom: 0; }
.contact__location-name { font-family: var(--font-sans); font-weight: 600; font-size: 14px; color: var(--mountain-charcoal); margin-bottom: 4px; }
.contact__location-address, .contact__location-phone { font-size: 13px; line-height: 1.6; color: var(--stone-gray); }
@media (max-width: 900px) {
  .contact__grid { grid-template-columns: 1fr; }
  .contact__sidebar { position: static; }
  .contact__row { grid-template-columns: 1fr; }
}

/* ---------- 20. SCHEDULE ---------- */
.section--schedule_block { background: var(--parchment); }
.schedule__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(40px, 6vw, 80px); align-items: start; }
.schedule__copy { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 100px; }
.schedule__bullets { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.schedule__bullets li { display: flex; gap: 12px; font-size: 15px; line-height: 1.6; color: var(--mountain-charcoal); }
.schedule__bullet-icon { color: var(--burnished-bronze); font-weight: 700; font-size: 20px; line-height: 1; }
.schedule__widget { border: 1px solid color-mix(in srgb, var(--stone-gray) 40%, transparent); border-radius: 4px; min-height: 600px; overflow: hidden; background: var(--toned-ivory); }
.schedule__iframe { width: 100%; min-height: 600px; border: 0; }
.schedule__placeholder { padding: 60px 32px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; min-height: 600px; }
@media (max-width: 900px) { .schedule__grid { grid-template-columns: 1fr; } .schedule__copy { position: static; } }

/* =============================================================
   GSAP INITIAL STATES + ITRIX-STYLE ANIMATION HELPERS
   ============================================================= */

/* Generic fade-up items */
[data-gsap-item] { opacity: 0; transform: translateY(28px); }
[data-gsap-wordmark] { opacity: 0; transform: scale(0.95); }
.gsap-ready [data-gsap-item],
.gsap-ready [data-gsap-wordmark] { will-change: transform, opacity; }

/* Word-mask reveals — outer span clips, inner span gets translated */
.word { display: inline-block; overflow: hidden; vertical-align: top; line-height: inherit; padding: 0.05em 0; margin: -0.05em 0; }
.word__inner { display: inline-block; will-change: transform; }
/* When a parent heading has italic emphasis via <em>, preserve it in the inner */
.h1 em .word__inner, .h2 em .word__inner, .h3 em .word__inner,
em > .word .word__inner { font-style: italic; }

/* Ken Burns CSS variable read by image_backdrop ::before */
/* Ken Burns on the backdrop ::before was removed from the JS hot path —
   leaving the pseudo as a static layer eliminates one source of scroll jank. */

/* Image clip-path reveal — initial state set via JS, this just preps GPU */
.gsap-ready .hero__anchor img,
.gsap-ready .insights__media img,
.gsap-ready .team__portrait img,
.gsap-ready .cards_grid__media img {
  will-change: transform, clip-path;
}

/* Insights card image zoom on hover (paired with existing translateY) */
.insights__media { overflow: hidden; }
.insights__media img {
  transition: transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  transform-origin: center;
}
.insights__card:hover .insights__media img { transform: scale(1.06); }

/* Bento + cards_grid card hover — subtle border-color shift to bronze */
.bento .card, .cards_grid__card {
  transition: border-color 0.5s var(--ease-out-quart),
              transform 0.5s var(--ease-out-quart),
              box-shadow 0.5s var(--ease-out-quart);
}
.bento .card:hover, .cards_grid__card:hover {
  border-color: var(--burnished-bronze);
  transform: translateY(-3px);
  box-shadow: 0 10px 26px -14px rgba(81, 83, 74, 0.18);
}
/* Dark-variant cards (audiences featured, schedule CTA) — bronze border on dark looks subtle but present */
.bento .card--dark:hover, .bento .card--cta-dark:hover {
  border-color: var(--burnished-bronze);
}
.bento .card--cta-sun:hover { transform: translateY(-3px); }

/* Partner slot hover (already has translateY; add transition) */
.partners__slot { transition: border-color 0.4s var(--ease-out-quart), transform 0.4s var(--ease-out-quart); }

/* Dividers under eyebrows + featured slots — JS draws scaleX 0 → 1 */
.gsap-ready .section--pull_quote .divider,
.gsap-ready [data-gsap-section] .divider--accent,
.gsap-ready [data-gsap-section] .divider--accent-dark {
  will-change: transform;
}

/* Reduced motion — disable all the animation niceties */
@media (prefers-reduced-motion: reduce) {
  [data-gsap-item], [data-gsap-wordmark] { opacity: 1 !important; transform: none !important; }
  .word__inner { transform: none !important; }
  .hero__anchor img, .insights__media img, .team__portrait img, .cards_grid__media img {
    clip-path: none !important; transform: none !important;
  }
  .section--image_backdrop::before { transform: scale(1) !important; }
  .insights__card:hover .insights__media img { transform: none !important; }
  .bento .card:hover, .cards_grid__card:hover { transform: none !important; }
}

/* ---------- 404 / Error page ---------- */
.section--error { background: var(--parchment); padding-block: clamp(120px, 14vw, 180px); }
.error__inner { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 24px; max-width: 900px; margin: 0 auto; }
.h1--error { font-size: clamp(48px, 7vw, 96px); line-height: 1.1; }
.error__lead { max-width: 680px; }
.error__actions { display: flex; gap: 16px; flex-wrap: wrap; justify-content: center; margin-top: 16px; }
.error__sitemap { margin-top: 48px; padding-top: 32px; border-top: 1px solid color-mix(in srgb, var(--stone-gray) 40%, transparent); width: 100%; max-width: 600px; }
.error__sitemap .eyebrow { margin-bottom: 16px; text-align: center; }
.error__sitemap ul { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 32px; text-align: left; }
.error__sitemap a { font-family: var(--font-sans); font-weight: 600; font-size: 13px; letter-spacing: 0.5px; color: var(--burnished-bronze); border-bottom: 1px solid transparent; transition: color var(--dur-fast), border-color var(--dur-fast); }
.error__sitemap a:hover { color: var(--mountain-charcoal); border-bottom-color: var(--mountain-charcoal); }
@media (max-width: 580px) { .error__sitemap ul { grid-template-columns: 1fr; } }

/* No-JS fallback — make sure nothing stays hidden if JS fails to run */
html.no-js [data-gsap-item],
html.no-js [data-gsap-wordmark],
html.no-js .word__inner { opacity: 1 !important; transform: none !important; }
