/* Gateway Academy — shared interior-page patterns
   Used by academics / admissions / student-life / contact.
   Loads after styles.css; reads tokens from colors_and_type.css. */

/* ── Remap retired deep-gold token to navy (passes contrast everywhere) ── */
:root { --gold-700: var(--gateway-navy); }

/* ---------- Photo placeholders ---------- */
.ph {
  position: relative; border-radius: 12px; overflow: hidden;
  background:
    repeating-linear-gradient(135deg,
      rgba(30,60,122,0.06) 0px, rgba(30,60,122,0.06) 11px,
      rgba(30,60,122,0.11) 11px, rgba(30,60,122,0.11) 22px),
    var(--paper);
  border: 1px solid var(--border-subtle);
  display: grid; place-items: center; min-height: 220px;
}
.ph::after {
  content: attr(data-label); font-family: var(--font-sans); font-weight: 700;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--navy-600);
  background: rgba(255,255,255,0.82); padding: 6px 12px; border-radius: 999px; text-align: center;
}
.ph.navy {
  background:
    repeating-linear-gradient(135deg,
      rgba(249,213,2,0.10) 0px, rgba(249,213,2,0.10) 11px,
      rgba(249,213,2,0.04) 11px, rgba(249,213,2,0.04) 22px),
    var(--navy-800);
  border-color: rgba(249,213,2,0.25);
}
.ph.navy::after { color: var(--gateway-navy); background: rgba(249,213,2,0.92); }

/* ---------- Page hero (cinematic, navy, left-aligned — matches homepage hero) ---------- */
.page-hero { position: relative; display: flex; align-items: center; min-height: 388px; background: var(--gateway-navy); color: #fff; overflow: hidden; border-bottom: 4px solid var(--gateway-gold); }
.page-hero .ph-bg {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(820px 460px at 90% 0%, rgba(249,213,2,0.10), transparent 62%),
    linear-gradient(96deg, rgba(11,23,50,0.94) 0%, rgba(13,27,58,0.82) 36%, rgba(15,31,63,0.46) 64%, rgba(15,31,63,0.32) 100%),
    linear-gradient(180deg, rgba(15,31,63,0.32) 0%, rgba(15,31,63,0) 30%, rgba(15,31,63,0.64) 100%),
    var(--hero-img, url('assets/campus-aerial-clean.jpg'));
  background-size: cover, cover, cover, cover;
  background-position: center, center, center, center 44%;
  background-repeat: no-repeat;
}
/* per-page hero imagery (contextual) */
.page-hero.h-academics    { --hero-img: url('assets/students/history-class-celebration.jpg'); }
.page-hero.h-earlycollege { --hero-img: url('assets/students/groups/scottsdale-cc-field-trip.jpg'); }
.page-hero.h-earlycollege .ph-bg { background-position: center, center, center, center 55%; }
.page-hero.h-highschool   { --hero-img: url('assets/student-council.jpg'); }
.page-hero.h-middleschool { --hero-img: url('assets/students/groups/gaming-club-friday.jpg'); }
.page-hero.h-athletics    { --hero-img: url('assets/students/groups/soccer-team-huddle.jpg'); }
.page-hero.h-alumni       { --hero-img: url('assets/students/graduation-cap-toss-banner.jpg'); }
.page-hero.h-alumni .ph-bg {
  background-image:
    linear-gradient(to right, rgba(15,31,63,0.88) 0%, rgba(15,31,63,0.65) 45%, rgba(15,31,63,0.3) 100%),
    var(--hero-img);
  background-position: center 30%;
}
.page-hero.h-athletics .ph-bg {
  background-image:
    linear-gradient(to right, rgba(15,31,63,0.94) 0%, rgba(15,31,63,0.82) 28%, rgba(15,31,63,0.32) 60%, rgba(15,31,63,0.08) 100%),
    var(--hero-img);
  background-position: center 30%;
  background-size: cover;
}
.page-hero.h-admissions   { --hero-img: url('assets/campus-front.jpg'); }
.page-hero.h-studentlife  { --hero-img: url('assets/students/graduation-cap-toss-banner.jpg'); }
.page-hero.h-warriorlife  { --hero-img: url('assets/students/madi-vocals-talent-show.png'); }
.page-hero.h-news         { --hero-img: url('assets/students/groups/basketball-state-champions-banner.jpg'); }
.page-hero.h-contact      { --hero-img: url('assets/campus-front.jpg'); }
.page-hero.h-giving       { --hero-img: url('assets/students/alec-ari-rock-band-vocals.png'); }
.page-hero.h-team         { --hero-img: none; }
.page-hero.h-team .ph-bg {
  background-image:
    radial-gradient(820px 460px at 90% 0%, rgba(249,213,2,0.12), transparent 62%),
    linear-gradient(180deg, var(--gateway-navy) 0%, #16284d 100%);
}
.page-hero.h-careers      { --hero-img: url('assets/students/groups/curriculum-night-art.jpg'); }
.page-hero.h-resources    { --hero-img: url('assets/students/groups/students-campus-terraces.jpg'); }
.page-hero.h-profrecs     { --hero-img: url('assets/campus-mountains.jpg'); }
.page-hero.h-tuition      { --hero-img: url('assets/campus-mountains.jpg'); }
.page-hero.h-calendar     { --hero-img: url('assets/campus-aerial-clean.jpg'); }
/* news photo has a bright white trophy dead-center; give this one a heavier scrim */
.page-hero.h-news .ph-bg {
  background-image:
    radial-gradient(900px 520px at 84% 6%, rgba(249,213,2,0.12), transparent 60%),
    radial-gradient(130% 96% at 50% 54%, rgba(15,31,63,0.60), transparent 76%),
    linear-gradient(180deg, rgba(15,31,63,0.86) 0%, rgba(21,43,90,0.86) 55%, rgba(15,31,63,0.96) 100%),
    url('assets/students/groups/basketball-state-champions-banner.jpg');
}
.page-hero .inner { position: relative; z-index: 1; width: 100%; max-width: 1200px; margin: 0 auto; padding: 88px 32px 80px; text-align: left; }
.page-hero .eyebrow { color: var(--gateway-gold); font-size: 22px; display: inline-flex; align-items: center; gap: 16px; }
.page-hero .eyebrow::before { content: ""; width: 34px; height: 3px; background: var(--gateway-gold); flex-shrink: 0; }
.page-hero h1 {
  font-family: var(--font-display-condensed);
  font-size: clamp(48px, 6vw, 92px); line-height: 0.92; font-weight: 900; letter-spacing: -0.005em;
  text-transform: uppercase; color: #fff; margin: 16px 0 20px; text-align: left;
  text-shadow: 0 2px 28px rgba(11,23,50,0.6);
}
.page-hero .deck { font-size: 19px; line-height: 1.55; color: #EAF0FB; max-width: 620px; margin: 0; text-wrap: pretty; text-shadow: 0 1px 16px rgba(11,23,50,0.85); }

/* staggered entrance for hero copy (skipped under reduced motion / no JS) */
@media (prefers-reduced-motion: no-preference) {
  .page-hero .inner.reveal > * { opacity: 0; transform: translateY(16px); }
  .page-hero .inner.reveal-in > * { opacity: 1; transform: none; transition: opacity 0.6s var(--ease-calm), transform 0.6s var(--ease-snap); }
  .page-hero .inner.reveal-in > *:nth-child(1) { transition-delay: 0.05s; }
  .page-hero .inner.reveal-in > *:nth-child(2) { transition-delay: 0.16s; }
  .page-hero .inner.reveal-in > *:nth-child(3) { transition-delay: 0.27s; }
  .page-hero .inner.reveal-in > *:nth-child(4) { transition-delay: 0.38s; }
}

/* ---------- Section wrappers ---------- */

/* ===== Tuition hero — navy split with a paper "tuition statement" card ===== */
.tu-hero { position: relative; background: linear-gradient(180deg, var(--gateway-navy) 0%, #16284d 100%); color: #fff; overflow: hidden; border-bottom: 4px solid var(--gateway-gold); }
.tu-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(820px 480px at 88% -8%, rgba(249,213,2,0.12), transparent 60%); pointer-events: none; }
.tu-hero .inner { position: relative; z-index: 1; max-width: 1200px; margin: 0 auto; padding: 76px 32px 80px; display: grid; grid-template-columns: 1.04fr 0.96fr; gap: 56px; align-items: center; }
.tu-hero .eyebrow { color: var(--gateway-gold); }
.tu-hero h1 { font-family: var(--font-display-condensed); font-weight: 900; font-size: clamp(42px, 5vw, 76px); line-height: 0.96; letter-spacing: -0.01em; color: #fff; margin: 18px 0 0; text-wrap: balance; text-shadow: 0 2px 24px rgba(11,23,50,0.5); }
.tu-hero .deck { font-size: 19px; line-height: 1.6; color: #C7D2E8; max-width: 480px; margin: 20px 0 0; text-wrap: pretty; }
.tu-hero .cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 30px; }

/* the statement card */
.tu-statement { background: var(--paper); color: var(--gateway-navy); border-radius: 16px; border-top: 5px solid var(--gateway-gold); padding: 30px 32px 26px; box-shadow: 0 30px 70px rgba(8,18,42,0.45); }
.tu-statement .st-label { font-weight: 900; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gateway-navy); opacity: 0.62; }
.tu-line { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; padding: 15px 0; border-bottom: 1px solid rgba(30,60,122,0.14); }
.tu-line:first-of-type { margin-top: 14px; }
.tu-line .k { font-size: 16px; font-weight: 600; color: #2a3f63; }
.tu-line .v { font-size: 16px; font-weight: 800; color: var(--gateway-navy); text-align: right; }
.tu-total { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-top: 20px; }
.tu-total .k { font-size: 19px; font-weight: 800; color: var(--gateway-navy); }
.tu-total .v { font-family: var(--font-display-condensed); font-weight: 900; font-size: clamp(64px, 7vw, 96px); line-height: 0.8; letter-spacing: -0.02em; color: var(--gateway-navy); }
.tu-foot { margin: 18px 0 0; font-size: 13px; line-height: 1.5; color: #51618a; }
@media (max-width: 960px) {
  .tu-hero .inner { grid-template-columns: 1fr; gap: 34px; padding: 56px 22px 60px; }
  .tu-hero h1 { font-size: 46px; }
}

/* ---------- Section wrappers ---------- */
.section { padding: 56px 0; background: #fff; }
.section.alt { background: var(--paper); }
.section.navy { background: var(--gateway-navy); color: #fff; }
/* Explore hub band — balanced padding in its lower-page spot */
.section.explore-band { padding: 56px 0; }
.section.navy .section-head h2 { color: #fff; }
.section.navy .section-head .lead { color: #C7D2E8; }
.section.navy .section-head .eyebrow { color: var(--gateway-gold); }
.statband .section-head .eyebrow, .numbers-band .section-head .eyebrow { color: var(--gateway-gold); background: transparent; padding: 0; border-radius: 0; }

/* ---------- Split (text + media) ---------- */
.split-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split-2.media-left { direction: rtl; }
.split-2.media-left > * { direction: ltr; }
.split-2 .copy h2 { color: var(--gateway-navy); }
.section.navy .split-2 .copy h2 { color: #fff; }
.split-2 .copy p { font-size: 16px; line-height: 1.65; color: var(--fg2); margin: 0 0 16px; max-width: 52ch; }
.section.navy .split-2 .copy p { color: #C7D2E8; }
.split-2 .media { min-height: 360px; }
.split-2 .media.ph { align-self: stretch; }
.media-photo { align-self: stretch; min-height: 380px; border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-card); }
.media-photo img { width: 100%; height: 100%; min-height: 380px; object-fit: cover; display: block; }

/* Student Life photo gallery */
.sl-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.sl-gallery figure { margin: 0; border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-card); background: #fff; }
.sl-gallery img { width: 100%; height: 260px; object-fit: cover; display: block; transition: transform 400ms var(--ease-calm); }
.sl-gallery figure:hover img { transform: scale(1.04); }
.sl-gallery figcaption { padding: 16px 20px; font-size: 13px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gateway-navy); }

/* Callout with photo (instead of big glyph) */
.callout-photo { width: 220px; height: 220px; border-radius: 16px; overflow: hidden; flex-shrink: 0; box-shadow: 0 10px 30px rgba(15,31,63,0.25); }
.callout-photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 500ms var(--ease-calm); }
.callout:hover .callout-photo img { transform: scale(1.04); }

/* ---------- Feature cards ---------- */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.feature-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.feature-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.feature {
  background: #fff; border-radius: 12px; padding: 28px 28px; box-shadow: var(--shadow-card);
  position: relative; transition: box-shadow 220ms var(--ease-calm), transform 220ms var(--ease-calm);
}
.feature:hover { box-shadow: var(--shadow-lift); transform: translateY(-2px); }
.feature .top-rule { position: absolute; top: 0; left: 26px; right: 26px; height: 3px; background: var(--gateway-gold); border-radius: 0 0 2px 2px; }
.feature .kbadge { font-size: 12px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-700); margin-bottom: 10px; }
.feature h3 { font-size: 19px; font-weight: 800; text-transform: uppercase; letter-spacing: -0.005em; color: var(--gateway-navy); margin: 6px 0 9px; line-height: 1.15; }
.feature p { font-size: 14.5px; line-height: 1.55; color: var(--fg2); margin: 0; }
a.feature-link { display: block; text-decoration: none; }
a.feature-link .more { display: inline-block; margin-top: 14px; font-size: 13px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gold-700); }
a.feature-link:hover .more { color: var(--gateway-navy); }
a.feature-link.has-photo { padding-top: 0; overflow: hidden; }
.feature-photo { margin: 0 -26px 18px; height: 180px; overflow: hidden; }
.feature-photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 400ms var(--ease-calm); }
a.feature-link.has-photo:hover .feature-photo img { transform: scale(1.04); }

/* feature variant on navy */
.section.navy .feature { background: rgba(255,255,255,0.04); border: 1px solid rgba(249,213,2,0.22); box-shadow: none; }
.section.navy .feature:hover { background: rgba(249,213,2,0.08); }
.section.navy .feature h3 { color: #fff; }
.section.navy .feature p { color: #C7D2E8; }
.section.navy .feature .kbadge { color: var(--gateway-gold); }

/* ---------- Program tiles (icon + text) ---------- */
.prog-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.prog {
  background: rgba(255,255,255,0.04); border: 1px solid rgba(249,213,2,0.22);
  border-radius: 12px; padding: 28px 24px; transition: background 220ms var(--ease-snap), transform 220ms var(--ease-snap), border-color 220ms var(--ease-snap);
}
.prog:hover { background: rgba(249,213,2,0.08); transform: translateY(-2px); }
.program-grid .prog { text-align: center; display: flex; flex-direction: column; align-items: center; }
.prog .icon { width: 72px; height: 72px; border-radius: 50%; background: #fff; display: grid; place-items: center; margin-bottom: 16px; box-shadow: 0 2px 10px rgba(0,0,0,0.22); }
.prog .icon img { width: 60px; height: 60px; }
.prog h3 { font-size: 17px; font-weight: 800; text-transform: uppercase; letter-spacing: -0.005em; margin: 0 0 7px; color: #fff; }
.prog p { font-size: 13.5px; line-height: 1.5; color: #C7D2E8; margin: 0; }

/* ---------- Stat band ---------- */
.statband { background: var(--navy-800); }
.statband-grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); }
.statband-grid > div { padding: 28px 24px; text-align: center; border-left: 1px solid rgba(249,213,2,0.18); }
.statband-grid > div:first-child { border-left: 0; }
.statband-grid strong { display: block; font-weight: 900; font-size: 42px; line-height: 1; letter-spacing: -0.02em; color: var(--gateway-gold); font-variant-numeric: tabular-nums; margin-bottom: 9px; }
.statband-grid span { font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; color: #C7D2E8; }

/* ---------- Numbered list (steps / requirements) ---------- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.steps.cols-4 { grid-template-columns: repeat(4, 1fr); }
/* Connected journey: each step is a card, numbers threaded by a connector line */
.step { position: relative; background: #fff; border: 1px solid var(--border-subtle); border-radius: 16px; padding: 28px 24px 24px; transition: transform 220ms var(--ease-snap), box-shadow 220ms var(--ease-calm), border-color 220ms var(--ease-calm); }
.step:hover { transform: translateY(-4px); box-shadow: var(--shadow-lift); border-color: rgba(249,213,2,0.55); }
.step .n {
  position: relative; z-index: 1;
  width: 48px; height: 48px; border-radius: 50%; background: var(--gateway-navy); color: var(--gateway-gold);
  font-family: var(--font-display-condensed); font-weight: 900; font-size: 24px; display: grid; place-items: center; margin-bottom: 16px;
  box-shadow: 0 0 0 5px #fff;
}
/* connector line between step numbers (desktop multi-col) */
.steps .step:not(:last-child)::after {
  content: ""; position: absolute; top: calc(26px + 24px); left: calc(24px + 48px); width: calc(100% - 48px); height: 3px;
  background: repeating-linear-gradient(90deg, var(--rule-gold) 0 9px, transparent 9px 16px);
  transform: translateY(-50%); z-index: 0; pointer-events: none;
}
.step h3 { font-size: 18px; font-weight: 800; text-transform: uppercase; color: var(--gateway-navy); margin: 0 0 8px; letter-spacing: -0.005em; }
.step p { font-size: 14.5px; line-height: 1.55; color: var(--fg2); margin: 0; }
.section.navy .step { background: rgba(255,255,255,0.05); border-color: rgba(249,213,2,0.2); }
.section.navy .step:hover { background: rgba(249,213,2,0.07); }
.section.navy .step .n { background: var(--gateway-gold); color: var(--gateway-navy); box-shadow: 0 0 0 5px var(--gateway-navy); }
.section.navy .step h3 { color: #fff; }
.section.navy .step p { color: #C7D2E8; }

/* Navy pill eyebrow — bright gold on navy chip, used on light-bg sections */
#how-to-apply .eyebrow,
#adm-fit .eyebrow,
#news .eyebrow,
#difference .eyebrow {
  display: inline-block;
  background: var(--gateway-navy);
  color: var(--gateway-gold);
  padding: 5px 16px;
  border-radius: 999px;
}

/* ---------- Checklist ---------- */
.checklist { display: grid; gap: 16px; margin: 0; padding: 0; list-style: none; }
.checklist li { font-size: 16px; line-height: 1.5; color: var(--ink); padding-left: 36px; position: relative; }
.checklist li::before {
  content: "✓"; position: absolute; left: 0; top: -1px; width: 24px; height: 24px; border-radius: 50%;
  background: var(--gold-100); color: var(--gold-700); font-weight: 900; font-size: 13px; display: grid; place-items: center;
}
.checklist li b { color: var(--gateway-navy); }

/* ---------- ESA / highlight callout ---------- */
.callout {
  background: var(--gateway-gold); border-radius: 16px; padding: 44px 48px;
  display: grid; grid-template-columns: auto 1fr; gap: 34px; align-items: center;
}
.callout .big { font-size: 86px; font-weight: 900; color: var(--gateway-navy); letter-spacing: -0.04em; line-height: 0.85; }
.callout h2 { font-size: 34px; font-weight: 900; text-transform: uppercase; color: var(--gateway-navy); margin: 0 0 10px; letter-spacing: -0.01em; }
.callout p { font-size: 16px; line-height: 1.6; color: #2a3a5e; margin: 0; max-width: 60ch; }

/* ---------- FAQ ---------- */
.faq { display: grid; gap: 4px; max-width: 880px; margin: 0 auto; }
.faq details { border-bottom: 1px solid var(--border-subtle); padding: 6px 0; }
.faq summary {
  list-style: none; cursor: pointer; padding: 20px 44px 20px 4px; position: relative;
  font-size: 18px; font-weight: 800; color: var(--gateway-navy); letter-spacing: -0.005em;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+"; position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  font-size: 26px; font-weight: 400; color: var(--gold-700); transition: transform 200ms var(--ease-calm);
}
.faq details[open] summary::after { content: "–"; }
.faq .a { padding: 0 44px 20px 4px; font-size: 15px; line-height: 1.6; color: var(--fg2); }

/* ---------- CTA band ---------- */
.cta-band { background: var(--gateway-navy); color: #fff; padding: 48px 0; text-align: center; }
.cta-band h2 { font-size: 50px; font-weight: 900; text-transform: uppercase; color: #fff; letter-spacing: -0.015em; margin: 0 0 14px; }
.cta-band p { font-size: 18px; color: #C7D2E8; max-width: 600px; margin: 0 auto 28px; line-height: 1.55; }
.cta-band .cta-row { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
/* Journey wayfinding link under a CTA — points to the next stage without competing with the buttons */
.cta-continue { margin-top: 20px; font-size: 14px; font-weight: 800; letter-spacing: 0.01em; color: #C7D2E8; }
.cta-continue a { color: var(--gateway-gold); text-decoration: none; border-bottom: 2px solid transparent; padding-bottom: 1px; transition: border-color 160ms var(--ease-calm); }
.cta-continue a:hover { border-color: var(--gateway-gold); }
.cta-continue.on-gold { color: var(--navy-700); }
.cta-continue.on-gold a { color: var(--gateway-navy); }
.cta-continue.on-gold a:hover { border-color: var(--gateway-navy); }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.contact-card { background: #fff; border-radius: 16px; box-shadow: var(--shadow-card); padding: 36px 40px; }
.contact-card h2 { color: var(--gateway-navy); }
.info-list { display: grid; gap: 16px; margin: 0; }
.info-list .row { display: grid; grid-template-columns: 120px 1fr; gap: 16px; align-items: baseline; }
.info-list dt { font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-700); }
.info-list dd { margin: 0; font-size: 16px; line-height: 1.5; color: var(--ink); }
.info-list dd a { font-weight: 700; }
.map.ph { min-height: 280px; }

.form-card { background: #fff; border-radius: 16px; box-shadow: 0 8px 32px rgba(15,31,63,0.12); border: 1px solid var(--border-subtle); overflow: hidden; display: grid; gap: 0; }
.form-card-header { background: var(--gateway-navy); padding: 28px 36px 24px; }
.form-card-header .eyebrow { color: var(--gateway-gold); margin-bottom: 8px; }
.form-card-header h3 { color: #fff; font-size: 22px; font-weight: 800; margin: 0; letter-spacing: -0.01em; }
.form-card-body { padding: 28px 36px; display: grid; gap: 16px; }
.form-card label { display: grid; gap: 8px; font-size: 11px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gateway-navy); }
.form-card input, .form-card select, .form-card textarea {
  font-family: inherit; font-size: 15px; padding: 11px 12px; border-radius: 8px;
  border: 1px solid var(--border-strong); background: #fff; color: var(--ink); font-weight: 400; letter-spacing: 0;
}
.form-card input:focus, .form-card select:focus, .form-card textarea:focus { outline: none; border-color: var(--gateway-navy); box-shadow: 0 0 0 3px rgba(249,213,2,0.35); }
.form-card .row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
/* Contact "Visit us" map overlay */
.map-directions { position: absolute; left: 14px; right: 14px; bottom: 14px; display: flex; align-items: center; gap: 12px; background: rgba(15,31,63,0.86); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); color: #fff; text-decoration: none; padding: 12px 16px; border-radius: 12px; font-size: 13.5px; line-height: 1.35; border: 1px solid rgba(249,213,2,0.35); transition: background 180ms var(--ease-calm); }
.map-directions:hover { background: rgba(15,31,63,0.95); }
.map-directions b { color: #fff; }
.map-directions .pin { flex: none; width: 16px; height: 16px; border-radius: 50% 50% 50% 0; background: var(--gateway-gold); transform: rotate(-45deg); box-shadow: 0 0 0 3px rgba(249,213,2,0.25); animation: pinPulse 2s var(--ease-calm) infinite; }
@keyframes pinPulse { 0%, 100% { box-shadow: 0 0 0 3px rgba(249,213,2,0.28); } 50% { box-shadow: 0 0 0 7px rgba(249,213,2,0.08); } }
@media (prefers-reduced-motion: reduce) { .map-directions .pin { animation: none; } }
.map-directions span:last-child { color: var(--gateway-gold); font-weight: 700; }
.map-directions span:last-child b { color: #fff; font-weight: 800; }
.form-card .row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.form-card .fsec { margin-top: 10px; padding-top: 20px; border-top: 1px solid var(--border-subtle); display: flex; align-items: baseline; gap: 8px; }
.form-card .fsec:first-of-type { margin-top: 0; padding-top: 0; border-top: 0; }
.form-card .fsec .n { font-family: var(--font-display-condensed); font-weight: 900; font-size: 13px; color: var(--gateway-gold); letter-spacing: 0.04em; }
.form-card .fsec h3 { font-family: var(--font-sans); font-size: 16px; font-weight: 800; letter-spacing: 0; text-transform: none; color: var(--gateway-navy); margin: 0; }
.form-card .choices { display: grid; gap: 8px; }
.form-card .choice { display: flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; letter-spacing: 0; text-transform: none; color: var(--ink); cursor: pointer; }
.form-card .choice input { width: auto; padding: 0; margin: 0; accent-color: var(--gateway-navy); }
.form-card .hint { font-size: 11px; font-weight: 600; letter-spacing: 0; text-transform: none; color: var(--fg2); }
.form-card .req { color: #b00020; }
@media (max-width: 640px) {
  .form-card .row-2, .form-card .row-3 { grid-template-columns: 1fr; }
}

/* ---------- 2e Venn ---------- */
/* Base + responsive rules live in the "Two truths" block below (the redesigned
   .tt-grid / .tt-venn layout). The old .venn-wrap/.venn-note markup was retired. */
.venn-section { padding-bottom: 32px; }

/* ---------- Big-number feature (stats storytelling) ---------- */
.bignum-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.bignum {
  background: #fff; border-radius: 16px; padding: 32px 28px; box-shadow: var(--shadow-card);
  border-top: 4px solid var(--gateway-gold);
}
.section.navy .bignum { background: rgba(255,255,255,0.04); border: 1px solid rgba(249,213,2,0.22); border-top: 4px solid var(--gateway-gold); box-shadow: none; }
.bignum strong {
  display: block; font-family: var(--font-display-condensed); font-weight: 900;
  font-size: 72px; line-height: 0.9; letter-spacing: 0.01em; color: var(--gateway-navy);
  font-variant-numeric: tabular-nums; margin-bottom: 6px;
}
.section.navy .bignum strong { color: var(--gateway-gold); }
.bignum .unit { font-size: 36px; }
.bignum h3 { font-size: 17px; font-weight: 800; text-transform: uppercase; letter-spacing: -0.005em; color: var(--gateway-navy); margin: 8px 0 8px; }
.section.navy .bignum h3 { color: #fff; }
.bignum p { font-size: 14.5px; line-height: 1.55; color: var(--fg2); margin: 0; }
.section.navy .bignum p { color: #C7D2E8; }
/* Gold fill on hover for outline-gold buttons sitting on navy */
.numbers-band .btn-outline-gold:hover { background: var(--gateway-gold); color: var(--gateway-navy); border-color: var(--gateway-gold); }

/* ---------- Comparison rows (Gateway vs AZ average) ---------- */
.compare { display: grid; gap: 16px; max-width: 920px; margin: 0 auto; }
.compare-row {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 20px;
  background: #fff; border-radius: 12px; padding: 24px 28px; box-shadow: var(--shadow-card);
}
.compare-row .metric { grid-column: 1 / -1; font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-700); margin-bottom: -4px; }
.compare-side { display: flex; flex-direction: column; gap: 4px; }
.compare-side.gw { align-items: flex-start; }
.compare-side.az { align-items: flex-end; text-align: right; }
.compare-side .big { font-family: var(--font-display-condensed); font-weight: 900; font-size: 48px; line-height: 0.9; letter-spacing: 0.01em; font-variant-numeric: tabular-nums; }
.compare-side.gw .big { color: var(--gateway-navy); }
.compare-side.az .big { color: var(--fg2); }
.compare-side .who { font-size: 11px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; }
.compare-side.gw .who { color: var(--gold-700); }
.compare-side.az .who { color: var(--fg2); }
.compare-vs { width: 40px; height: 40px; border-radius: 50%; background: var(--navy-050); display: grid; place-items: center; font-size: 11px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg2); }

@media (max-width: 960px) {
  .bignum-grid { grid-template-columns: 1fr; }
  .bignum strong { font-size: 60px; }
  .compare-row { padding: 20px 20px; gap: 12px; }
  .compare-side .big { font-size: 36px; }
}

/* ---------- By the Numbers band (home) ---------- */
.numbers-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-top: 8px; }
.numstat { padding: 20px 24px; text-align: center; border-left: 1px solid rgba(249,213,2,0.18); display: flex; flex-direction: column; align-items: center; }
.numstat:first-child { border-left: 0; }
.numstat strong {
  font-family: var(--font-display-condensed); font-weight: 900; color: var(--gateway-gold);
  font-size: 84px; line-height: 0.86; letter-spacing: 0.01em; font-variant-numeric: tabular-nums;
}
.numstat strong .u { font-size: 48px; }
.numstat .nl { margin-top: 12px; font-size: 16px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.02em; color: #fff; }
.numstat .ns { margin-top: 4px; font-size: 13px; color: #C7D2E8; font-weight: 500; }
.numbers-cta { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 40px; }

@media (max-width: 860px) {
  .numbers-grid { grid-template-columns: 1fr 1fr; gap: 28px 0; }
  .numstat:nth-child(3) { border-left: 0; }
  .numstat strong { font-size: 68px; }
}

/* ---------- Yearbook / Warrior Life gallery ---------- */
.gallery-cat { margin-top: 12px; }
.ymasonry { columns: 3; column-gap: 16px; }
.ymasonry figure {
  break-inside: avoid; margin: 0 0 16px; position: relative; border-radius: 12px; overflow: hidden;
  box-shadow: var(--shadow-card); background: #fff;
}
.ymasonry img { width: 100%; display: block; transition: transform 500ms var(--ease-calm); }
.ymasonry figure:hover img { transform: scale(1.05); }
.ymasonry figcaption {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 24px 16px 12px;
  font-size: 12.5px; font-weight: 700; letter-spacing: 0.02em; color: #fff;
  background: linear-gradient(180deg, transparent, rgba(15,31,63,0.82));
  opacity: 0; transform: translateY(6px); transition: opacity 240ms var(--ease-calm), transform 240ms var(--ease-calm);
}
.ymasonry figure:hover figcaption { opacity: 1; transform: none; }

@media (max-width: 900px) { .ymasonry { columns: 2; } }
@media (max-width: 560px) { .ymasonry { columns: 1; } }

/* Champions highlight banner */
.champs { position: relative; border-radius: 16px; overflow: hidden; box-shadow: 0 18px 44px rgba(15,31,63,0.22); }
.champs img { width: 100%; display: block; transition: transform 600ms var(--ease-calm); }
.champs:hover img { transform: scale(1.03); }
.champs .badge-tag {
  position: absolute; top: 18px; left: 18px; background: var(--gateway-gold); color: var(--gateway-navy);
  font-family: var(--font-display-condensed); font-weight: 900; font-size: 22px; letter-spacing: 0.02em;
  text-transform: uppercase; padding: 8px 20px; border-radius: 8px;
}

/* ---------- News & Events grid ---------- */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.news-card { background: #fff; border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-card); display: flex; flex-direction: column; transition: transform 220ms var(--ease-calm), box-shadow 220ms var(--ease-calm); }
.news-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.news-photo { aspect-ratio: 4 / 3; overflow: hidden; background: var(--navy-050); }
.news-photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 400ms var(--ease-calm); }
.news-card:hover .news-photo img { transform: scale(1.05); }
.news-body { padding: 20px 24px 24px; }
.news-body .kbadge { font-size: 11px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-700); margin-bottom: 8px; }
.news-body h3 { font-size: 18px; font-weight: 800; text-transform: uppercase; letter-spacing: -0.005em; color: var(--gateway-navy); margin: 0 0 8px; line-height: 1.15; }
.news-body p { font-size: 14px; line-height: 1.55; color: var(--fg2); margin: 0; }

@media (max-width: 960px) { .news-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) {
  .news-grid { grid-template-columns: 1fr; }
  .feature-grid, .feature-grid.cols-4, .prog-grid { grid-template-columns: 1fr; }
  .page-hero h1 { font-size: 34px; }
  .page-hero .inner { padding: 52px 20px 48px; }
  .split-2 { gap: 24px; }
  .callout { padding: 28px 20px; }
  .cta-band h2 { font-size: 28px; }
  .statband-grid { grid-template-columns: 1fr 1fr; }
  .numbers-grid { grid-template-columns: 1fr 1fr; }
}

/* ---------- Choose Your Path (3 pathways) ---------- */
.pathways { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.pathway { background: #fff; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-card); display: flex; flex-direction: column; border-top: 4px solid var(--gateway-gold); transition: transform 220ms var(--ease-calm), box-shadow 220ms var(--ease-calm); }
.pathway:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.pathway .ph-head { background: var(--gateway-navy); color: #fff; padding: 24px 24px 20px; }
.pathway .ph-num { font-family: var(--font-display-condensed); font-weight: 900; font-size: 30px; color: var(--gateway-gold); line-height: 1; }
.pathway .ph-head h3 { font-size: 22px; font-weight: 800; text-transform: uppercase; letter-spacing: -0.01em; color: #fff; margin: 8px 0 0; line-height: 1.1; }
.pathway .partner-tag { display: inline-block; margin-top: 12px; font-size: 10.5px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gateway-navy); background: var(--gateway-gold); border-radius: 999px; padding: 5px 12px; }
.pathway .ph-body { padding: 24px 24px 28px; flex: 1; display: flex; flex-direction: column; }
.pathway .ph-body > p { font-size: 14.5px; line-height: 1.6; color: var(--fg2); margin: 0 0 16px; }
.pathway .ph-list { list-style: none; margin: 0 0 18px; padding: 0; display: grid; gap: 8px; }
.pathway .ph-list li { font-size: 13.5px; line-height: 1.45; color: var(--ink); padding-left: 24px; position: relative; }
.pathway .ph-list li::before { content: "✓"; position: absolute; left: 0; top: -1px; width: 18px; height: 18px; border-radius: 50%; background: var(--gold-100); color: var(--gold-700); font-weight: 900; font-size: 10px; display: grid; place-items: center; }
.pathway .ph-foot { margin-top: auto; font-size: 12px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gold-700); }

/* Credentials strip */
.creds { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; max-width: 900px; margin: 0 auto; }
.cred { text-align: center; padding: 32px 24px; background: var(--gateway-gold); border-radius: 12px; }
.cred .cn { display: inline-grid; place-items: center; width: 34px; height: 34px; border-radius: 50%; background: rgba(30,60,122,0.16); font-size: 19px; font-weight: 900; color: var(--gateway-navy); line-height: 1; margin-bottom: 14px; }
.cred h4 { font-size: 21px; font-weight: 900; letter-spacing: 0.01em; text-transform: uppercase; color: var(--gateway-navy); margin: 0 0 8px; line-height: 1.1; }
.cred p { font-size: 14px; color: var(--gateway-navy); opacity: 0.85; margin: 0; line-height: 1.45; }

/* Electives chips */
.electives { display: flex; flex-wrap: wrap; gap: 8px; max-width: 920px; margin: 0 auto; justify-content: center; }
.elective { background: #fff; border: 1px solid var(--border-subtle); border-radius: 999px; padding: 10px 20px; font-size: 14px; font-weight: 700; color: var(--gateway-navy); box-shadow: var(--shadow-card); }

/* Partner logos row */
.partners-row { display: flex; flex-wrap: nowrap; align-items: center; justify-content: center; gap: 8px; overflow: hidden; }
.partners-row .pchip { background: #fff; border-radius: 12px; padding: 10px 12px; box-shadow: var(--shadow-card); display: flex; align-items: center; justify-content: center; min-height: 60px; flex: 1 1 0; min-width: 0; }
.partners-row .pchip img { max-height: 36px; max-width: 110px; width: auto; display: block; object-fit: contain; }
.partners-row .pchip.text { font-weight: 800; text-transform: uppercase; letter-spacing: 0.02em; color: var(--gateway-navy); font-size: 15px; }

@media (max-width: 960px) {
  .pathways, .creds { grid-template-columns: 1fr; }
}

/* ---------- Lead intro under hero ---------- */
.intro-band .container { max-width: 880px; text-align: center; padding-top: 44px; padding-bottom: 4px; }
.intro-band p { font-size: 22px; line-height: 1.5; color: var(--gateway-navy); font-weight: 600; text-wrap: pretty; margin: 0; }
.intro-band p .muted { color: var(--fg2); font-weight: 400; }

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .page-hero h1 { font-size: 46px; }
  .split-2, .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .split-2.media-left { direction: ltr; }
  .feature-grid, .feature-grid.cols-4, .prog-grid { grid-template-columns: repeat(2, 1fr); }
  .feature-grid.cols-2 { grid-template-columns: 1fr; }
  .statband-grid { grid-template-columns: repeat(2, 1fr); }
  .statband-grid > div:nth-child(3) { border-left: 0; }
  .steps, .steps.cols-4 { grid-template-columns: 1fr; max-width: 520px; margin-left: auto; margin-right: auto; }
  .steps .step:not(:last-child)::after {
    top: auto; bottom: -24px; left: calc(24px + 24px); width: 3px; height: 24px;
    background: repeating-linear-gradient(180deg, var(--rule-gold) 0 9px, transparent 9px 16px);
    transform: none;
  }
  .callout { grid-template-columns: 1fr; gap: 16px; padding: 32px; text-align: center; }
  .cta-band h2 { font-size: 34px; }
  .intro-band p { font-size: 18px; }
}

/* ============================================================
   VISUAL UPGRADES — homepage & sitewide polish
   All rules are always-visible or hover-only (no entrance
   opacity tricks), so print / reduced-motion / capture are safe.
   ============================================================ */

/* [BIG 1] Section rhythm on flat navy — a fine gold hairline crowns each navy
   section, and a soft radial top-highlight adds depth without any texture image. */
.programs,
.section.navy,
.cta-band {
  background-color: var(--gateway-navy);
}
.programs, .section.navy, .cta-band { position: relative; }
.programs::before, .section.navy::before, .cta-band::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; z-index: 2;
  background: linear-gradient(90deg, transparent, rgba(249,213,2,0.55), transparent);
}
.programs::after, .section.navy::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background: radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,0.055), transparent 62%);
}
.programs > .container, .section.navy > .container, .cta-band > .container { position: relative; z-index: 1; }

/* [BIG 2] Hero — warm gold glow top-right + deeper, more cinematic scrim */
.hero-protect {
  background:
    radial-gradient(760px 460px at 84% 4%, rgba(249,213,2,0.16), transparent 60%),
    radial-gradient(120% 90% at 50% 120%, rgba(11,22,48,0.55), transparent 70%),
    linear-gradient(180deg, rgba(15,31,63,0.60) 0%, rgba(30,60,122,0.46) 42%, rgba(13,27,58,0.92) 100%);
}
/* Hero stat bar → premium: gold figures, cleaner dividers */
/* Hero stat bar — explicit sizes so cascade cannot suppress them */
.hero-strip > div strong { font-size: 42px !important; color: var(--gateway-gold); letter-spacing: -0.02em; }
.hero-strip > div span { font-size: 13px !important; color: rgba(255,255,255,0.85); letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700; }
.hero-strip > div small { font-size: 11px !important; }

/* [BIG 3] Difference cards — ghosted index numerals + gold side accent on hover */
.diff-grid { counter-reset: diffnum; }
.diff-card { counter-increment: diffnum; overflow: hidden; }
.diff-card::before {
  content: counter(diffnum, decimal-leading-zero);
  position: absolute; right: 12px; bottom: -10px; z-index: 0;
  font-family: var(--font-display-condensed); font-weight: 900; font-size: 78px; line-height: 1;
  color: rgba(30,60,122,0.09); pointer-events: none; letter-spacing: -0.02em;
}
.diff-card h3, .diff-card p { position: relative; z-index: 1; }
.diff-card { border-left: 3px solid transparent; transition: box-shadow 220ms var(--ease-calm), transform 220ms var(--ease-calm), border-color 220ms var(--ease-calm); }
.diff-card:hover { border-left-color: var(--gateway-gold); }

/* [BIG 4] Numbers band — each figure on a subtle inset panel with a gold cap rule.
   Equal tracks via minmax(0,1fr) so all four panels match; figure sized to fit. */
.numbers-grid { gap: 16px; grid-template-columns: repeat(4, minmax(0, 1fr)); }
.numstat strong { font-size: clamp(46px, 4.6vw, 64px); }
.numstat strong .u { font-size: 0.56em; }
.numstat {
  border-left: 0;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(249,213,2,0.20);
  border-top: 3px solid var(--gateway-gold);
  border-radius: 12px;
  padding: 32px 20px 28px;
  transition: background 220ms var(--ease-calm), transform 220ms var(--ease-calm);
}
.numstat:hover { background: rgba(249,213,2,0.08); transform: translateY(-3px); }

/* [BIG 5] Section headers — signature centered gold accent rule under every title */
.section-head.center h2::after {
  content: ""; display: block; width: 60px; height: 4px; border-radius: 2px;
  background: var(--gateway-gold); margin: 18px auto 0;
}
.section-head:not(.center) h2::after {
  content: ""; display: block; width: 56px; height: 4px; border-radius: 2px;
  background: var(--gateway-gold); margin: 16px 0 0;
}

/* [6] Nav links — gold underline that grows from center on hover/active */
.nav-trigger { position: relative; }
.nav-trigger::after {
  content: ""; position: absolute; left: 50%; right: 50%; bottom: 2px; height: 2px;
  background: var(--gateway-gold); border-radius: 2px; transition: left 200ms var(--ease-calm), right 200ms var(--ease-calm);
}
.nav-item:hover .nav-trigger::after,
.nav-item.on .nav-trigger::after { left: 12px; right: 12px; }

/* [7] Program icons — gentle scale + soft gold ring on card hover */
.program-icon { transition: transform 260ms var(--ease-calm), box-shadow 260ms var(--ease-calm); }
.program-card:hover .program-icon { transform: scale(1.06); box-shadow: 0 0 0 4px rgba(249,213,2,0.25), 0 2px 10px rgba(0,0,0,0.18); }

/* [8] Feature cards — the "more" arrow glides right on hover */
.feature .more { transition: color 180ms var(--ease-calm), letter-spacing 180ms var(--ease-calm); }
a.feature-link:hover .more { letter-spacing: 0.04em; }

/* [9] Partner chips — lift on hover */
.pchip { transition: transform 200ms var(--ease-calm), box-shadow 200ms var(--ease-calm); }
.pchip:hover { transform: translateY(-2px); box-shadow: 0 8px 18px rgba(15,31,63,0.12); }

/* [10] Accreditation badges — quiet lift on hover */
.abadge-logo { transition: transform 200ms var(--ease-calm); }
.abadge-logo:hover { transform: translateY(-2px); }

/* [11] Footer column headings — small gold tick accent */
.footer-col h4 { position: relative; padding-top: 12px; }
.footer-col h4::before {
  content: ""; position: absolute; top: 0; left: 0; width: 28px; height: 3px;
  background: var(--gateway-gold); border-radius: 2px;
}

/* [12] Custom brand scrollbar (subtle, premium) */
* { scrollbar-color: var(--gateway-navy) #e9edf4; }
::-webkit-scrollbar { width: 12px; height: 12px; }
::-webkit-scrollbar-track { background: #e9edf4; }
::-webkit-scrollbar-thumb { background: var(--gateway-navy); border-radius: 8px; border: 3px solid #e9edf4; }
::-webkit-scrollbar-thumb:hover { background: var(--navy-800); }

/* [13] Announce bar — gold dot reads as a live "enrolling" indicator */
.announce-inner { position: relative; }

/* [14] Testimonial quote mark — larger, warmer */
.tquote::before, .testimonial .mark { color: var(--gateway-gold); }

/* [15] Body links inside prose — gold underline with breathing room */
.split-2 .copy p a, .feature p a, .lede a { text-underline-offset: 3px; text-decoration-color: var(--gateway-gold); }

/* ============================================================
   STUDENT-LIFE PHOTO BAND — warmth between Stories and Partners
   ============================================================ */
.lifeband { padding: 48px 0; background: #fff; overflow: hidden; }
.lifeband .section-head { margin-bottom: 24px; }
.lifeband-ribbon {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  max-width: 1080px; margin: 0 auto; padding: 0 24px;
}
.lifeshot {
  position: relative; margin: 0; border-radius: 16px; overflow: hidden; aspect-ratio: 4 / 5;
  box-shadow: var(--shadow-card); background: var(--navy-800);
}
.lifeshot img { width: 100%; height: 100%; object-fit: cover; display: block; transform: scale(var(--bz, 1)); transition: transform 600ms var(--ease-calm); }
.lifeshot:hover img { transform: scale(calc(var(--bz, 1) * 1.07)); }
.lifeshot figcaption {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 32px 16px 16px;
  font-size: 12px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: #fff;
  background: linear-gradient(transparent, rgba(13,27,58,0.9));
}
.lifeshot::before {
  content: ""; position: absolute; top: 10px; left: 10px; width: 18px; height: 18px; z-index: 1;
  border-top: 2px solid rgba(249,213,2,0.0); border-left: 2px solid rgba(249,213,2,0.0);
  border-radius: 4px 0 0 0; transition: border-color 240ms var(--ease-calm);
}
.lifeshot:hover::before { border-top-color: var(--gateway-gold); border-left-color: var(--gateway-gold); }
@media (max-width: 960px) {
  .lifeband-ribbon { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .lifeband-ribbon { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   PROGRAMS CARDS — more premium icon wells + lift
   ============================================================ */
.program-card { border-radius: 16px; }
.program-card:hover { transform: translateY(-4px); }
.program-icon { box-shadow: 0 0 0 1px rgba(249,213,2,0.38), 0 4px 14px rgba(0,0,0,0.22); }

/* ============================================================
   EXPLORE FEATURE CARDS — bolder photo, gradient foot, gold title accent
   ============================================================ */
.feature-link.has-photo .feature-photo { height: 208px; position: relative; }
.feature-link.has-photo .feature-photo::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(transparent 52%, rgba(13,27,58,0.40));
}
.feature-link.has-photo h3 { position: relative; display: inline-block; }
.feature-link.has-photo h3::after {
  content: ""; display: block; height: 3px; width: 0; border-radius: 2px;
  background: var(--gateway-gold); margin-top: 6px; transition: width 260ms var(--ease-calm);
}
.feature-link.has-photo:hover h3::after { width: 44px; }

/* ============================================================
   NEWS cards (homepage) — gold category chips + fuller top bar
   ============================================================ */
#news .feature { padding-top: 32px; }
#news .feature .top-rule { left: 0; right: 0; height: 4px; border-radius: 12px 12px 0 0; }
#news .feature .kbadge {
  display: inline-block; background: var(--gold-100); color: var(--gold-700);
  padding: 5px 11px; border-radius: 999px; font-size: 11px; margin-bottom: 12px;
}

/* ============================================================
   VISIT CTA — striking navy panel floating on paper (closing bookend)
   ============================================================ */
.visit-cta { background: var(--paper); padding: 48px 24px; }
.visit-cta .container.center {
  position: relative; overflow: hidden; max-width: 1040px;
  background: var(--gateway-gold); border-radius: 24px;
  padding: 76px 56px; box-shadow: 0 30px 70px rgba(15,31,63,0.20);
}
.visit-cta .container.center::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(560px 360px at 94% -10%, rgba(255,255,255,0.18), transparent 60%),
    radial-gradient(460px 300px at 6% 120%, rgba(15,31,63,0.08), transparent 60%);
}
.visit-cta .container.center::after {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; z-index: 1;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.6), transparent);
}
.visit-cta .container.center > * { position: relative; z-index: 1; }
.visit-cta .eyebrow.dark { background: transparent; padding: 0; color: var(--gateway-navy); }
.visit-cta h2 { color: var(--gateway-navy); }
.visit-cta .lead { color: var(--navy-700); }

/* ============================================================
   FORM success state — warm confirmation with a gold check
   (base state is fully visible; the pop only enhances)
   ============================================================ */
.form-success { text-align: center; padding: 24px 8px 12px; }
.form-success .success-check {
  width: 66px; height: 66px; border-radius: 50%;
  background: var(--gateway-gold); color: var(--gateway-navy);
  display: grid; place-items: center; font-size: 34px; font-weight: 900; line-height: 1;
  margin: 0 auto 18px; box-shadow: 0 8px 22px rgba(249,213,2,0.45);
}
.form-success h3 { color: var(--gateway-navy); font-size: 24px; font-weight: 900; text-transform: uppercase; letter-spacing: -0.01em; margin: 0 0 10px; }
.form-success p { color: var(--fg2); font-size: 15px; line-height: 1.6; margin: 0 auto 20px; max-width: 42ch; }
@media (prefers-reduced-motion: no-preference) {
  .form-success .success-check { animation: checkPop 440ms var(--ease-calm); }
  @keyframes checkPop { 0% { transform: scale(0.55); } 60% { transform: scale(1.08); } 100% { transform: scale(1); } }
}

/* ============================================================
   NEW PAGES — Giving · Team · Careers · Tuition
   Reuse shared patterns (split-2, feature-grid, steps, callout,
   numbers band, faq, cta-band); add only what's genuinely new.
   ============================================================ */

/* Giving — "where your gift goes" cards */
.give-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; max-width: 1100px; margin: 0 auto; }
.give-card { background: #fff; border: 1px solid var(--border-subtle); border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-card); display: flex; flex-direction: column; transition: transform 220ms var(--ease-calm), box-shadow 220ms var(--ease-calm); }
.give-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lift); }
.give-card .gphoto { height: 168px; overflow: hidden; background: var(--navy-800); }
.give-card .gphoto img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 600ms var(--ease-calm); }
.give-card:hover .gphoto img { transform: scale(1.06); }
.give-card .gbody { padding: 24px 24px 28px; }
.give-card .gamt { font-family: var(--font-display-condensed); font-weight: 900; font-size: 30px; color: var(--gold-700); letter-spacing: -0.01em; }
.give-card h3 { font-size: 18px; font-weight: 800; color: var(--gateway-navy); margin: 6px 0 8px; }
.give-card p { font-size: 14px; line-height: 1.55; color: var(--fg2); margin: 0; }
@media (max-width: 860px) { .give-grid { grid-template-columns: 1fr; max-width: 460px; } }

/* Giving — actionable impact tiers (amount badge + per-card Give button) */
.give-card { position: relative; }
.give-card .gphoto { position: relative; height: 184px; }
.give-card .gphoto::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,23,50,0.34) 0%, rgba(11,23,50,0) 42%); pointer-events: none; }
.gamt-badge { position: absolute; top: 12px; left: 12px; z-index: 2; background: var(--gateway-gold); color: var(--gateway-navy); font-family: var(--font-display-condensed); font-weight: 900; font-size: 27px; line-height: 1; letter-spacing: -0.01em; padding: 8px 16px; border-radius: 12px; box-shadow: 0 6px 16px rgba(11,23,50,0.32); }
.give-card .gbody { display: flex; flex-direction: column; flex: 1; }
.give-card .gbody p { margin: 0 0 4px; }
.give-btn { margin-top: auto; display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--gateway-gold); color: var(--gateway-navy); font-weight: 800; font-size: 14px; letter-spacing: 0.02em; padding: 12px 20px; border-radius: 12px; text-decoration: none; box-shadow: 0 4px 14px rgba(249,213,2,0.28); transition: filter 180ms var(--ease-calm), transform 200ms var(--ease-snap); }
.give-btn span { transition: transform 200ms var(--ease-snap); }
.give-btn:hover { filter: brightness(0.96); }
.give-btn:hover span { transform: translateX(4px); }

/* ---------- News — editorial press index ---------- */
.press-lead { position: relative; display: block; background: var(--gateway-navy); color: #fff; border-radius: 16px; padding: 40px 40px; overflow: hidden; text-decoration: none; border: 1px solid rgba(249,213,2,0.3); margin-bottom: 8px; transition: transform 240ms var(--ease-snap), box-shadow 240ms var(--ease-calm); }
.press-lead::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--gateway-gold); }
.press-lead:hover { transform: translateY(-3px); box-shadow: 0 20px 44px rgba(15,31,63,0.28); }
.pl-kicker { font-size: 12px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gateway-gold); }
.pl-title { font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: clamp(28px, 3.4vw, 44px); line-height: 1.0; color: #fff; margin: 12px 0 12px; max-width: 22ch; }
.pl-desc { font-size: 16px; line-height: 1.6; color: #C7D2E8; max-width: 64ch; margin: 0 0 18px; }
.pl-more { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gateway-gold); }
.press-lead:hover .pl-more { gap: 12px; }

.press-list { display: grid; margin-top: 26px; border-top: 1px solid var(--border-subtle); }
.press-item { display: grid; grid-template-columns: 200px 1fr auto; gap: 24px; align-items: start; padding: 24px 16px; border-bottom: 1px solid var(--border-subtle); text-decoration: none; transition: background 180ms var(--ease-calm), padding 180ms var(--ease-calm); }
.press-item:hover { background: var(--navy-050); padding-left: 24px; }
.pi-outlet { font-size: 12px; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold-700); padding-top: 3px; }
.pi-main { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.pi-title { font-size: 19px; font-weight: 800; color: var(--gateway-navy); line-height: 1.25; letter-spacing: -0.01em; transition: color 180ms var(--ease-calm); }
.pi-desc { font-size: 14px; line-height: 1.55; color: var(--fg2); max-width: 76ch; }
.pi-arrow { color: var(--gold-700); font-size: 18px; padding-top: 2px; transition: transform 200ms var(--ease-snap); }
.press-item:hover .pi-title { color: var(--gold-700); }
.press-item:hover .pi-arrow { transform: translate(3px, -3px); }
@media (max-width: 760px) {
  .press-item { grid-template-columns: 1fr auto; gap: 4px 16px; }
  .pi-outlet { grid-column: 1 / -1; }
}

/* Ways-to-give compact list */
.ways { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; max-width: 1000px; margin: 0 auto; }
.way { display: flex; gap: 16px; align-items: flex-start; background: #fff; border: 1px solid var(--border-subtle); border-left: 3px solid var(--gateway-gold); border-radius: 12px; padding: 20px 24px; }
.way .wk { font-family: var(--font-display-condensed); font-weight: 900; font-size: 26px; color: var(--navy-200); line-height: 1; flex: none; width: 30px; }
.way h3 { font-size: 16px; font-weight: 800; color: var(--gateway-navy); margin: 0 0 4px; }
.way p { font-size: 13.5px; line-height: 1.5; color: var(--fg2); margin: 0; }
@media (max-width: 720px) { .ways { grid-template-columns: 1fr; } }

/* Team 2026 — filter bar + wide grid */
.team-section { padding: 36px 0 48px; }
.team-filter { display: flex; gap: 8px; margin-bottom: 48px; flex-wrap: wrap; }
.team-filter-btn {
  font-family: inherit; cursor: pointer; border: 1.5px solid var(--border-strong);
  background: #fff; color: var(--gateway-navy); border-radius: 999px;
  padding: 10px 20px; font-size: 13px; font-weight: 700; letter-spacing: 0.04em;
  text-transform: uppercase; transition: all 160ms var(--ease-calm);
  display: inline-flex; align-items: center; gap: 8px;
}
.team-filter-btn:hover { border-color: var(--gateway-navy); background: var(--navy-050); }
.team-filter-btn.active { background: var(--gateway-navy); color: #fff; border-color: var(--gateway-navy); }
.team-filter-count {
  background: rgba(255,255,255,0.2); color: inherit;
  font-size: 11px; font-weight: 800; padding: 1px 7px;
  border-radius: 999px; letter-spacing: 0;
}
.team-filter-btn:not(.active) .team-filter-count { background: var(--navy-050); color: var(--fg2); }
.team-grid-wide { grid-template-columns: repeat(4, minmax(0,1fr)); max-width: none; animation: teamFadeIn 0.28s var(--ease-out-quart); }
@keyframes teamFadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@media (max-width: 1100px) { .team-grid-wide { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 760px)  { .team-grid-wide { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .team-grid-wide { grid-template-columns: 1fr; max-width: 380px; } }

/* Team / faculty cards */
.fac-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; max-width: 1040px; margin: 0 auto; }
.fac-card { background: #fff; border: 1px solid var(--border-subtle); border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-card); display: flex; flex-direction: column; transition: transform 220ms var(--ease-calm), box-shadow 220ms var(--ease-calm); }
.fac-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lift); }
.fac-photo { height: 280px; overflow: hidden; background: var(--gateway-navy); position: relative; }
.fac-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; display: block; transition: transform 480ms var(--ease-calm); }
.fac-card:hover .fac-photo img { transform: scale(1.04); }
.fac-photo.monogram { display: grid; place-items: center; background: linear-gradient(160deg, var(--gateway-navy), var(--navy-800)); }
.fac-photo.monogram span { font-family: var(--font-display-condensed); font-weight: 900; font-size: 88px; color: var(--gateway-gold); letter-spacing: 0.02em; }
.fac-body { padding: 24px 24px 28px; }

/* Compact roster of additional current staff (no photos yet) */
.roster { max-width: 1000px; margin: 40px auto 0; }
.roster-title { font-size: 13px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold-700); text-align: center; margin: 0 0 16px; }
.roster-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.roster-list li { background: #fff; border: 1px solid var(--border-subtle); border-radius: 12px; padding: 12px 16px; display: grid; gap: 2px; }
.roster-list b { font-size: 14px; font-weight: 800; color: var(--gateway-navy); }
.roster-list span { font-size: 12px; font-weight: 600; color: var(--fg2); }
@media (max-width: 960px) { .roster-list { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .roster-list { grid-template-columns: 1fr; } }
.fac-role { font-size: 11px; font-weight: 800; letter-spacing: 0.09em; text-transform: uppercase; color: var(--gold-700); margin-bottom: 6px; }
.fac-card h3 { font-size: 21px; font-weight: 800; color: var(--gateway-navy); margin: 0 0 10px; letter-spacing: -0.01em; }
.fac-body p { font-size: 14px; line-height: 1.6; color: var(--fg2); margin: 0; }
@media (max-width: 860px) { .fac-grid { grid-template-columns: 1fr; max-width: 420px; } }

/* The Warrior family — animal mascots */
.menagerie { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 1040px; margin: 0 auto; }
.critter { text-align: center; }
.critter .cphoto { aspect-ratio: 4 / 3; border-radius: 16px; overflow: hidden; margin: 0 auto 16px; width: 100%; background: var(--navy-800); box-shadow: 0 0 0 4px rgba(249,213,2,0.25), var(--shadow-card); }
.critter .cphoto img { width: 100%; height: 100%; object-fit: cover; display: block; }
.critter h3 { font-size: 17px; font-weight: 800; color: var(--gateway-navy); margin: 0 0 2px; }
.critter .role { font-size: 12px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--gold-700); margin-bottom: 8px; }
.critter p { font-size: 13px; line-height: 1.5; color: var(--fg2); margin: 0 auto; max-width: 26ch; }
@media (max-width: 860px) { .menagerie { grid-template-columns: repeat(2, 1fr); } }

/* Careers — talent pool (honest, no fabricated openings) */
.talent { max-width: 980px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: stretch; }
.talent-areas { background: #fff; border: 1px solid var(--border-subtle); border-top: 4px solid var(--gateway-gold); border-radius: 16px; padding: 28px 32px; }
.ta-label { font-size: 11px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-700); margin-bottom: 16px; }
.ta-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.ta-list li { position: relative; padding-left: 32px; font-size: 16px; font-weight: 700; color: var(--gateway-navy); line-height: 1.35; }
.ta-list li::before { content: ""; position: absolute; left: 0; top: 3px; width: 18px; height: 18px; border-radius: 50%; background: var(--gateway-gold); }
.ta-list li::after { content: ""; position: absolute; left: 6px; top: 7px; width: 5px; height: 9px; border: solid var(--gateway-navy); border-width: 0 2px 2px 0; transform: rotate(45deg); }
.talent-cta { background: var(--gateway-navy); border-radius: 16px; padding: 32px 32px; color: #fff; display: flex; flex-direction: column; }
.talent-cta h3 { font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: 28px; line-height: 1; color: #fff; margin: 0 0 12px; }
.talent-cta p { font-size: 15px; line-height: 1.6; color: #C7D2E8; margin: 0 0 22px; }
.talent-actions { margin-top: auto; display: flex; flex-wrap: wrap; gap: 8px; }
@media (max-width: 720px) { .talent { grid-template-columns: 1fr; } }

/* ---------- Contact — "ways to connect" action cards ---------- */
.cways { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.cway { position: relative; display: flex; flex-direction: column; background: #fff; border: 1px solid var(--border-subtle); border-top: 4px solid var(--gateway-gold); border-radius: 16px; padding: 28px 28px 24px; text-decoration: none; transition: transform 220ms var(--ease-snap), box-shadow 220ms var(--ease-calm), border-color 220ms var(--ease-calm); }
.cway:hover { transform: translateY(-5px); box-shadow: var(--shadow-lift); border-color: rgba(249,213,2,0.55); }
.cway-ic { width: 50px; height: 50px; border-radius: 12px; background: var(--gateway-navy); color: var(--gateway-gold); display: grid; place-items: center; margin-bottom: 16px; transition: background 240ms var(--ease-calm), color 240ms var(--ease-calm); }
.cway-ic svg { width: 26px; height: 26px; }
.cway:hover .cway-ic { background: var(--gateway-gold); color: var(--gateway-navy); }
.cway-k { font-size: 11px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-700); }
.cway-t { font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: 24px; line-height: 1.02; color: var(--gateway-navy); margin: 7px 0 8px; }
.cway-d { font-size: 14.5px; line-height: 1.55; color: var(--fg2); }
.cway-more { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border-subtle); font-size: 12.5px; font-weight: 800; letter-spacing: 0.02em; text-transform: uppercase; color: var(--gateway-navy); display: inline-flex; align-items: center; gap: 8px; }
.cway-arrow { color: var(--gold-700); transition: transform 200ms var(--ease-snap); }
.cway:hover .cway-arrow { transform: translate(3px, 0); }
@media (max-width: 760px) { .cways { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; } }

/* Narrow container + pull quote (used on Giving + future prose) */
.container.narrow { max-width: 820px; }
.pullquote { margin: 0; text-align: center; }
.pullquote blockquote {
  font-family: var(--font-display-condensed); font-weight: 900;
  font-size: clamp(28px, 3.6vw, 42px); line-height: 1.18; letter-spacing: -0.01em;
  color: var(--gateway-navy); margin: 0; text-wrap: balance; position: relative;
}
.pullquote blockquote::before { content: "\201C"; color: var(--gateway-gold); }
.pullquote blockquote::after { content: "\201D"; color: var(--gateway-gold); }
.pullquote figcaption { margin-top: 22px; font-size: 13px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gateway-navy); }

/* ============================================================
   "Bring us the hard questions" — confidence/fit module (navy band).
   Question-led cards, each paired with Gateway's honest answer.
   Sits on .section.navy, so it inherits the gold hairline + glow.
   ============================================================ */
.qa-list { max-width: 1000px; margin: 8px auto 0; }
.qa-row { display: grid; grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr); gap: 40px; align-items: start; padding: 30px 0; border-top: 1px solid rgba(249,213,2,0.22); }
.qa-row:first-child { border-top: none; }
.qa-q { display: flex; gap: 18px; align-items: flex-start; }
.qa-idx { font-family: var(--font-display-condensed); font-weight: 900; font-size: 30px; line-height: 1; color: var(--gateway-gold); flex: none; font-variant-numeric: tabular-nums; }
.qa-q h3 { font-size: 23px; font-weight: 800; color: #fff; margin: 0; line-height: 1.22; letter-spacing: -0.01em; }
.qa-a { font-size: 16px; line-height: 1.65; color: #C7D2E8; margin: 4px 0 0; }
.qa-a b { color: #fff; }
@media (max-width: 760px) {
  .qa-row { grid-template-columns: 1fr; gap: 14px; padding: 26px 0; }
}

/* ---------- Admissions — apply timeline (paper) ---------- */
.apply-flow { max-width: 720px; margin: 10px auto 0; }
.apply-step { position: relative; display: grid; grid-template-columns: 64px 1fr; gap: 28px; padding-bottom: 38px; }
.apply-step:last-child { padding-bottom: 0; }
.apply-step::before { content: ""; position: absolute; left: 31px; top: 60px; bottom: -2px; width: 2px; background: linear-gradient(var(--gateway-gold), rgba(30,60,122,0.18)); }
.apply-step:last-child::before { display: none; }
.apply-node { width: 64px; height: 64px; border-radius: 50%; display: grid; place-items: center; background: #fff; border: 2px solid var(--gateway-gold); font-family: var(--font-display-condensed); font-weight: 900; font-size: 30px; color: var(--gateway-navy); position: relative; z-index: 1; box-shadow: 0 8px 20px rgba(15,31,63,0.1); }
.apply-step:last-child .apply-node { background: var(--gateway-navy); border-color: var(--gateway-navy); color: var(--gateway-gold); }
.apply-body { padding-top: 9px; }
.apply-body h3 { font-size: 22px; color: var(--gateway-navy); margin: 0 0 6px; letter-spacing: -0.01em; }
.apply-body p { font-size: 15.5px; line-height: 1.6; color: var(--fg2); margin: 0; }
@media (max-width: 520px) {
  .apply-step { grid-template-columns: 52px 1fr; gap: 20px; }
  .apply-step::before { left: 25px; top: 50px; }
  .apply-node { width: 52px; height: 52px; font-size: 25px; }
}

/* [C3] Section-heading gold underline draws in as the header reveals.
   No JS reveal (reduced-motion / print) → no .reveal class → full underline shows. */
.section-head.center h2::after { transform-origin: center; }
.section-head:not(.center) h2::after { transform-origin: left; }
.section-head.reveal h2::after { transform: scaleX(0); transition: transform 0.6s var(--ease-calm) 0.18s; }
.section-head.reveal-in h2::after { transform: scaleX(1); }

/* ============================================================
   KIDDOS LUNCH — vendor-branded lunch section (resources page)
   Kiddos brand green sits inside the Gateway system as a vendor
   accent; structure/type stay Gateway. Used only on resources.html.
   ============================================================ */
:root { --kiddos-green: #62ad33; --kiddos-green-dk: #4f9128; --kiddos-mint: #eef6e8; }

/* Kiddos partner credit under the lunch header */
.kiddos-credit { display: inline-flex; align-items: center; gap: 12px; margin-top: 16px; }
.kiddos-credit span { font-size: 11px; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; color: var(--fg2); }
.kiddos-credit img { height: 30px; width: auto; display: block; }

/* Family hub — at-a-glance dashboard cards (on navy band) */
.res-hub .hub-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.hub-card { position: relative; background: #fff; border-radius: 16px; padding: 24px 24px 20px; display: flex; flex-direction: column; gap: 8px;
  text-decoration: none; box-shadow: var(--shadow-card); border: 1px solid var(--border-subtle); border-top: 3px solid var(--gateway-gold); min-height: 188px;
  transition: transform 0.22s var(--ease-snap), box-shadow 0.22s var(--ease-calm), border-color 0.22s var(--ease-calm); }
.hub-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lift); border-color: rgba(249,213,2,0.55); }
.hub-card.is-lunch { border-top-color: var(--kiddos-green); }
.hub-ic { width: 46px; height: 46px; border-radius: 12px; background: var(--gateway-gold); color: var(--gateway-navy); display: grid; place-items: center; margin-bottom: 6px; }
.hub-ic svg { width: 24px; height: 24px; }
.hub-card.is-lunch .hub-ic { background: var(--kiddos-green); color: #fff; }
.hub-card .hub-k { font-size: 11px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg2); }
.hub-card .hub-v { font-family: var(--font-display-condensed); font-weight: 900; font-size: 25px; line-height: 1.05;
  color: var(--gateway-navy); letter-spacing: -0.01em; }
.hub-card .hub-sub { font-size: 13px; color: var(--fg2); margin-top: -2px; }
.hub-card .hub-go { margin-top: auto; padding-top: 12px; font-size: 12.5px; font-weight: 800; letter-spacing: 0.02em; text-transform: uppercase; color: var(--gold-700); display: inline-flex; align-items: center; gap: 8px; }
.hub-go-arrow { transition: transform 0.22s var(--ease-snap); }
.hub-card:hover .hub-go-arrow { transform: translateX(4px); }
@media (max-width: 980px) { .res-hub .hub-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .res-hub .hub-grid { grid-template-columns: 1fr; } }

/* "What's for lunch?" — live today / tomorrow hero cards */
.kiddos-now { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 0 0 36px; }
.know { position: relative; border-radius: 16px; padding: 28px 28px 28px; overflow: hidden; min-height: 168px;
  display: flex; flex-direction: column; }
.know.is-today { background: var(--gateway-navy); color: #fff; }
.know.is-tom { background: #fff; border: 1px solid var(--border-subtle); box-shadow: var(--shadow-card); }
.know .know-when { font-size: 12px; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; display: flex;
  align-items: center; gap: 8px; margin-bottom: 4px; }
.know.is-today .know-when { color: var(--gateway-gold); }
.know.is-tom .know-when { color: var(--kiddos-green-dk); }
.know .know-date { font-size: 13px; font-weight: 600; opacity: 0.85; margin-bottom: 18px; }
.know.is-tom .know-date { color: var(--fg2); opacity: 1; }
.know .know-rest { font-family: var(--font-display-condensed); font-weight: 900; font-size: 30px; line-height: 1.02;
  letter-spacing: -0.01em; margin: auto 0 8px; }
.know.is-today .know-rest { color: #fff; }
.know.is-tom .know-rest { color: var(--gateway-navy); }
.know .know-meal { font-size: 15.5px; line-height: 1.4; }
.know.is-today .know-meal { color: var(--navy-200); }
.know.is-tom .know-meal { color: var(--fg2); }
.know .know-msg { font-size: 17px; font-weight: 600; line-height: 1.4; margin: auto 0 0; }
.know.is-today .know-msg { color: var(--navy-200); }
.know.is-tom .know-msg { color: var(--fg2); }
.know .know-tag { display: inline-block; align-self: flex-start; font-size: 11px; font-weight: 800; letter-spacing: 0.08em;
  text-transform: uppercase; padding: 4px 10px; border-radius: 999px; margin-top: 14px; }
.know.is-today .know-tag { background: rgba(249,213,2,0.18); color: var(--gateway-gold); }
.know.is-tom .know-tag { background: var(--kiddos-mint); color: var(--kiddos-green-dk); }
@media (max-width: 720px) { .kiddos-now { grid-template-columns: 1fr; } }

/* Coming up — known days only (short lead time) */
.kiddos-up { margin-top: 34px; }
.kiddos-up .ku-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 16px; flex-wrap: wrap; }
.kiddos-up .ku-head h3 { font-size: 18px; font-weight: 800; color: var(--gateway-navy); margin: 0; }
.kiddos-up .ku-note { font-size: 13px; color: var(--fg2); max-width: 52ch; }
.kiddos-up .ku-note a { color: var(--gateway-navy); font-weight: 700; }
.ku-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(184px, 1fr)); gap: 12px; }
.ku-card { background: #fff; border: 1px solid var(--border-subtle); border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; }
.ku-card .ku-dow { background: var(--gateway-navy); color: #fff; font-size: 12px; letter-spacing: 0.04em; text-align: center; padding: 9px 6px; }
.ku-card .ku-dow b { font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em; }
.ku-card.closed .ku-dow { background: var(--navy-300); }
.ku-card .ku-body { padding: 16px 16px 16px; flex: 1; }
.ku-card .ku-rest { font-size: 14.5px; font-weight: 800; color: var(--kiddos-green-dk); line-height: 1.2; margin: 0 0 4px; }
.ku-card .ku-meal { font-size: 13px; line-height: 1.45; color: var(--fg2); margin: 0; }
.ku-card .ku-closed { font-size: 13px; font-weight: 600; color: var(--navy-300); }
.ku-empty { display: flex; flex-direction: column; gap: 8px; background: var(--navy-050); border: 1px dashed var(--border-strong);
  border-radius: 16px; padding: 28px 28px; }
.ku-empty strong { font-size: 16px; color: var(--gateway-navy); }
.ku-empty span { font-size: 14px; line-height: 1.55; color: var(--fg2); max-width: 56ch; }
@media (max-width: 480px) { .ku-grid { grid-template-columns: 1fr; } }

/* Full month — Kiddos posts the whole month at once */
.kiddos-month { margin-top: 34px; }
.kiddos-month .km-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 16px; flex-wrap: wrap; }
.kiddos-month .km-head h3 { font-size: 18px; font-weight: 800; color: var(--gateway-navy); margin: 0; }
.km-nav { display: flex; align-items: center; gap: 16px; }
.km-arrow { width: 36px; height: 36px; border-radius: 999px; border: 1px solid var(--border-strong); background: #fff; color: var(--gateway-navy);
  font-size: 20px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .15s; }
.km-arrow:hover:not(:disabled) { background: var(--navy-050); }
.km-arrow:disabled { opacity: 0.32; cursor: default; }
.km-label { font-family: var(--font-display-condensed); font-weight: 900; font-size: 23px; color: var(--gateway-navy); min-width: 184px; text-align: center; }
.km-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.km-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; min-width: 660px; }
.km-dow { font-size: 11px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg2); text-align: center; padding-bottom: 2px; }
.km-cell { background: #fff; border: 1px solid var(--border-subtle); border-radius: 12px; padding: 12px 12px 16px; min-height: 112px; display: flex; flex-direction: column; }
.km-cell.km-pad { background: transparent; border: none; min-height: 0; }
.km-date { font-size: 12px; font-weight: 800; color: var(--fg2); margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.km-today { font-size: 9.5px; font-weight: 800; letter-spacing: 0.07em; text-transform: uppercase; color: var(--gateway-navy);
  background: var(--gateway-gold); border-radius: 999px; padding: 2px 7px; }
.km-rest { font-size: 14px; font-weight: 800; color: var(--kiddos-green-dk); line-height: 1.18; margin: 0 0 3px; }
.km-meal { font-size: 12px; line-height: 1.4; color: var(--fg2); margin: 0; }
.km-cell.is-today { border-color: var(--gateway-gold); box-shadow: 0 0 0 2px var(--gateway-gold); }
.km-cell.closed { background: var(--navy-050); }
.km-x { font-size: 12px; font-weight: 700; color: var(--navy-300); margin-top: auto; }
.km-dash { font-size: 16px; color: var(--border-strong); margin-top: auto; }
.km-foot { margin: 16px 0 0; font-size: 13px; line-height: 1.55; color: var(--fg2); max-width: 64ch; }
.km-foot a { color: var(--gateway-navy); font-weight: 700; }

/* Collapsible full-month lunch (keeps the big grid from eating the page) */
.km-details { margin-top: 20px; }
.km-details > summary { list-style: none; cursor: pointer; width: max-content; margin: 0 auto;
  display: inline-flex; align-items: center; gap: 9px; padding: 12px 22px; border-radius: 999px;
  border: 1px solid var(--border-strong); background: #fff; color: var(--gateway-navy);
  font-size: 13px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase;
  transition: background 0.2s, border-color 0.2s; }
.km-details > summary::-webkit-details-marker { display: none; }
.km-details > summary:hover { background: var(--paper); border-color: var(--gateway-navy); }
.km-chev { transition: transform 0.22s var(--ease-snap); font-size: 11px; }
.km-details[open] > summary { margin-bottom: 4px; }
.km-details[open] .km-chev { transform: rotate(180deg); }

/* Daily bell schedule */
.sched-wrap { max-width: 600px; margin: 34px auto 0; }
.sched-card { background: #fff; border: 1px solid var(--border-subtle); border-radius: 18px; overflow: hidden; box-shadow: var(--shadow-card); }
.sched-top { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; background: var(--gateway-navy); padding: 18px 26px; }
.sched-top span { font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gateway-gold); }
.sched-top strong { font-family: var(--font-display-condensed); font-weight: 900; font-size: 23px; color: #fff; }
.sched-list { list-style: none; margin: 0; padding: 6px 0; }
.sched-row { display: flex; align-items: center; gap: 22px; padding: 11px 26px; }
.sched-row + .sched-row { border-top: 1px solid var(--border-subtle); }
.sched-time { flex: 0 0 116px; font-variant-numeric: tabular-nums; font-weight: 700; font-size: 14px; color: var(--gateway-navy); }
.sched-act { font-size: 15px; color: var(--fg1); font-weight: 600; }
.sched-row.is-break { background: rgba(249, 213, 2, 0.12); }
.sched-row.is-break .sched-time, .sched-row.is-break .sched-act { color: var(--gateway-navy); }
.sched-row.is-open .sched-act { color: var(--gateway-navy); font-weight: 800; }
.sched-foot { margin: 16px auto 0; font-size: 13px; line-height: 1.55; color: var(--fg2); text-align: center; max-width: 56ch; }
.sched-foot a { color: var(--gateway-navy); font-weight: 700; }

/* ============================================================
   2e Venn + By the Numbers — bold redesign (home)
   ============================================================ */

/* ---- Two truths: asymmetric copy column + animated Venn ---- */
.venn-section { padding-bottom: 56px; }
.tt-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: 52px; align-items: center; }
.tt-copy .eyebrow { margin-bottom: 14px; }
.tt-copy h2 { font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: clamp(34px, 4.4vw, 56px); line-height: 0.94; letter-spacing: -0.005em; color: var(--gateway-navy); margin: 0; }
.tt-copy h2::after { content: ""; display: block; width: 56px; height: 4px; border-radius: 2px; background: var(--gateway-gold); margin: 18px 0 0; }
.tt-note { font-size: 18px; line-height: 1.62; color: var(--gateway-navy); font-weight: 500; max-width: 460px; margin: 22px 0 0; text-wrap: pretty; }
.tt-points { display: flex; flex-direction: column; gap: 16px; margin-top: 26px; }
.tt-point { display: flex; gap: 16px; align-items: flex-start; }
.tp-ico { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; background: var(--gateway-gold); position: relative; margin-top: 2px; }
.tp-ico::after { content: ""; position: absolute; left: 9px; top: 5px; width: 6px; height: 11px; border: solid var(--gateway-navy); border-width: 0 2.5px 2.5px 0; transform: rotate(45deg); }
.tp-body { display: flex; flex-direction: column; font-size: 14.5px; line-height: 1.5; color: var(--fg2); }
.tp-body strong { font-size: 14px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.03em; color: var(--gateway-navy); margin-bottom: 3px; }

/* refined, larger Venn */
.tt-venn { display: flex; justify-content: center; }
.venn { position: relative; width: 480px; max-width: 100%; height: 340px; margin: 0; }
.venn .circle { position: absolute; top: 20px; width: 300px; height: 300px; border-radius: 50%; display: flex; align-items: center; }
.venn .c-left { left: 0; background: rgba(30,60,122,0.12); border: 2.5px solid var(--gateway-navy); justify-content: flex-start; padding-left: 28px; }
.venn .c-right { right: 0; background: rgba(249,213,2,0.20); border: 2.5px solid var(--rule-gold); justify-content: flex-end; padding-right: 28px; }
.venn .circle span { width: 122px; font-weight: 900; text-transform: uppercase; font-size: 16px; line-height: 1.16; color: var(--gateway-navy); letter-spacing: -0.005em; }
.venn-center { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 3; text-align: center; background: var(--gateway-gold); border-radius: 16px; padding: 12px 20px; box-shadow: 0 10px 26px rgba(15,31,63,0.28); }
.venn-center strong { display: block; font-size: 15px; font-weight: 900; text-transform: uppercase; color: var(--gateway-navy); letter-spacing: 0.02em; line-height: 1.05; }

/* override the old infinite breathing/glow loops */
.venn .c-left, .venn .c-right, .venn-center { animation: none !important; }

/* entrance: circles converge, center pops — gated on .reveal (skipped for reduced motion) */
.venn .circle, .venn-center { transition: transform 0.75s var(--ease-snap), opacity 0.6s var(--ease-calm); }
.venn.reveal .c-left { opacity: 0; transform: translateX(-30px) scale(0.95); }
.venn.reveal .c-right { opacity: 0; transform: translateX(30px) scale(0.95); }
.venn.reveal .venn-center { opacity: 0; transform: translate(-50%,-50%) scale(0.78); }
.venn.reveal-in .c-left, .venn.reveal-in .c-right { opacity: 1; transform: none; }
.venn.reveal-in .venn-center { opacity: 1; transform: translate(-50%,-50%) scale(1); transition-delay: 0.25s; }

@media (max-width: 860px) {
  .tt-grid { grid-template-columns: 1fr; gap: 34px; }
  .tt-grid > * { min-width: 0; }
  .tt-venn { order: -1; }
  .tt-note { max-width: none; }
}
@media (max-width: 520px) {
  .venn { width: 340px; max-width: 100%; height: 258px; transform: none; }
  .venn .circle { width: 244px; height: 244px; top: 12px; }
  .venn .circle span { width: 104px; font-size: 14px; }
  .venn .c-left { padding-left: 22px; }
  .venn .c-right { padding-right: 22px; }
}

/* ---- By the Numbers: featured comparison + supporting stats ---- */
.numbers-feature { display: grid; grid-template-columns: 1.05fr 1fr; gap: 24px; margin-top: 14px; align-items: stretch; }
.nf-lead { position: relative; background: rgba(255,255,255,0.05); border: 1px solid rgba(249,213,2,0.24); border-radius: 16px; padding: 36px 36px 32px; overflow: hidden; }
.nf-lead::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--gateway-gold); }
.nf-eyebrow { font-size: 12px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gateway-gold); }
.nf-figure { display: flex; align-items: baseline; gap: 2px; font-family: var(--font-display-condensed); font-weight: 900; color: var(--gateway-gold); line-height: 0.82; letter-spacing: 0.01em; font-variant-numeric: tabular-nums; margin: 8px 0 4px; }
.nf-figure .big { font-size: clamp(86px, 11vw, 142px); }
.nf-unit { font-size: clamp(42px, 5.5vw, 68px); }
.nf-label { font-size: 17px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.01em; color: #fff; max-width: 320px; line-height: 1.2; }
.nf-bars { margin-top: 26px; display: flex; flex-direction: column; gap: 16px; }
.nf-bar-tag { display: flex; justify-content: space-between; margin-bottom: 7px; font-size: 12px; font-weight: 800; letter-spacing: 0.05em; text-transform: uppercase; }
.nf-bar.gw .nf-bar-tag { color: var(--gateway-gold); }
.nf-bar.az .nf-bar-tag { color: #C7D2E8; }
.nf-bar-track { position: relative; height: 28px; border-radius: 8px; background: rgba(255,255,255,0.08); overflow: hidden; }
.nf-bar-fill { position: absolute; inset: 0 auto 0 0; width: 0; border-radius: 8px; transition: width 1.2s var(--ease-snap); }
.nf-bar.gw .nf-bar-fill { background: var(--gateway-gold); }
.nf-bar.az .nf-bar-fill { background: rgba(255,255,255,0.30); }
.numbers-feature.in .nf-bar-fill { width: var(--w); }
@media (prefers-reduced-motion: reduce) { .nf-bar-fill { transition: none; } }
.nf-rest { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-content: stretch; }
.nf-card { background: rgba(255,255,255,0.04); border: 1px solid rgba(249,213,2,0.20); border-top: 3px solid var(--gateway-gold); border-radius: 16px; padding: 24px 24px 20px; display: flex; flex-direction: column; justify-content: center; transition: background 220ms var(--ease-calm), transform 220ms var(--ease-calm); }
.nf-card:hover { background: rgba(249,213,2,0.08); transform: translateY(-3px); }
.nf-card strong { font-family: var(--font-display-condensed); font-weight: 900; color: var(--gateway-gold); font-size: clamp(46px, 5vw, 62px); line-height: 0.86; letter-spacing: 0.01em; font-variant-numeric: tabular-nums; }
.nf-card .nl { margin-top: 10px; font-size: 15px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.02em; color: #fff; }
.nf-card .ns { margin-top: 3px; font-size: 12.5px; color: #C7D2E8; font-weight: 500; }
.nf-card.wide { grid-column: 1 / -1; }

@media (max-width: 960px) {
  .numbers-feature { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .nf-rest { grid-template-columns: 1fr; }
  .nf-card.wide { grid-column: auto; }
  .nf-lead { padding: 28px 24px 24px; }
}

/* ---- Explore hub portals (home) — immersive photo doorways ---- */
.xplore-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 10px; }
.xplore-card { position: relative; display: block; min-height: 364px; border-radius: 16px; overflow: hidden; text-decoration: none; color: #fff; box-shadow: 0 12px 32px rgba(0,0,0,0.28); border: 1px solid rgba(249,213,2,0.18); transition: transform 280ms var(--ease-snap), box-shadow 280ms var(--ease-calm), border-color 280ms var(--ease-calm); }
.xplore-photo { position: absolute; inset: 0; z-index: 0; display: block; }
.xplore-photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 620ms var(--ease-calm); }
.xplore-card::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(11,23,50,0.10) 0%, rgba(11,23,50,0.18) 38%, rgba(11,23,50,0.88) 100%); transition: background 320ms var(--ease-calm); }
.xplore-index { position: absolute; top: 15px; left: 17px; z-index: 2; display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display-condensed); font-weight: 900; font-size: 22px; color: var(--gateway-gold); letter-spacing: 0.02em; text-shadow: 0 2px 12px rgba(0,0,0,0.45); }
.xplore-index::before { content: ""; width: 18px; height: 3px; background: var(--gateway-gold); border-radius: 2px; }
.xplore-body { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 24px 20px 24px; display: block; }
.xplore-title { display: inline-block; font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: 27px; line-height: 0.96; letter-spacing: 0.005em; color: #fff; }
.xplore-title::after { content: ""; display: block; height: 3px; width: 0; background: var(--gateway-gold); border-radius: 2px; margin-top: 9px; transition: width 320ms var(--ease-snap); }
.xplore-desc { display: block; font-size: 14px; line-height: 1.5; color: #E7ECF6; margin: 12px 0 0; text-wrap: pretty; }
.xplore-more { display: inline-flex; align-items: center; gap: 8px; margin-top: 15px; font-size: 12px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gateway-gold); }
.xplore-more svg { width: 16px; height: 11px; transition: transform 240ms var(--ease-snap); }
.xplore-card:hover { transform: translateY(-5px); box-shadow: 0 20px 44px rgba(0,0,0,0.36); border-color: rgba(249,213,2,0.5); }
.xplore-card:hover .xplore-photo img { transform: scale(1.06); }
.xplore-card:hover::after { background: linear-gradient(180deg, rgba(11,23,50,0.12) 0%, rgba(11,23,50,0.34) 34%, rgba(11,23,50,0.93) 100%); }
.xplore-card:hover .xplore-title::after { width: 46px; }
.xplore-card:hover .xplore-more svg { transform: translateX(5px); }
.xplore-card:focus-visible { outline: 3px solid var(--gateway-gold); outline-offset: 3px; }

@media (max-width: 1100px) { .xplore-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .xplore-grid { grid-template-columns: 1fr; } .xplore-card { min-height: 304px; } }

/* ---------- Choose Your Path — bold 3-pathway redesign (High School) ---------- */
.pathways { align-items: stretch; }
.pathway { position: relative; border-radius: 16px; border: 1px solid var(--border-subtle); border-top: 4px solid var(--gateway-gold); }
.pathway:hover { transform: translateY(-4px); box-shadow: var(--shadow-lift); border-color: rgba(249,213,2,0.5); }
.pathway .ph-head { position: relative; overflow: hidden; padding: 28px 24px 24px; }
.pathway .ph-num { position: absolute; top: 2px; right: 16px; margin: 0; font-family: var(--font-display-condensed); font-weight: 900; font-size: 92px; line-height: 1; color: rgba(249,213,2,0.16); pointer-events: none; }
.pathway .ph-head h3 { position: relative; max-width: 78%; margin: 0; }
.pathway .partner-tag { position: relative; }
.pathway .ph-list li::before { display: grid; place-items: center; }
.pathway .ph-foot { margin-top: auto; padding-top: 16px; border-top: 1px dashed var(--border-strong); display: flex; flex-direction: column; gap: 3px; }
.ph-foot-label { font-size: 10px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg2); }
.ph-foot-dest { font-size: 15px; font-weight: 900; text-transform: uppercase; letter-spacing: -0.005em; color: var(--gateway-navy); }

/* Featured pathway (Dual Enrollment) — ribbon + gold ring, no transform (reveal-safe) */
.pathway--featured { border: 1px solid rgba(249,213,2,0.55); border-top-width: 0; box-shadow: 0 20px 48px rgba(15,31,63,0.22), 0 0 0 1px rgba(249,213,2,0.3); }
.pathway--featured .ph-head { padding-top: 44px; }
.ph-ribbon { position: absolute; top: 0; left: 0; right: 0; z-index: 2; background: var(--gateway-gold); color: var(--gateway-navy); text-align: center; font-size: 11px; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase; padding: 7px 10px; }

/* Combine banner under the cards */
.path-combine { margin-top: 22px; display: flex; align-items: center; gap: 16px; background: rgba(30,60,122,0.05); border: 1px solid var(--border-subtle); border-left: 4px solid var(--gateway-gold); border-radius: 12px; padding: 20px 28px; }
.path-combine .pc-icon { flex-shrink: 0; width: 42px; height: 42px; border-radius: 50%; background: var(--gateway-gold); color: var(--gateway-navy); display: grid; place-items: center; font-size: 28px; font-weight: 900; line-height: 1; }
.path-combine p { margin: 0; font-size: 15.5px; line-height: 1.55; color: var(--gateway-navy); }
.path-combine strong { font-weight: 900; }
@media (max-width: 560px) { .path-combine { flex-direction: column; text-align: center; gap: 12px; } }

/* ---------- Our Team — photoless monogram directory (bold) ---------- */
.roster-grid { display: grid; gap: 16px; grid-template-columns: repeat(3, 1fr); }
.roster-grid.roster-lead { grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 8px 0 6px; }
.person { position: relative; display: flex; align-items: center; gap: 16px; background: #fff; border: 1px solid var(--border-subtle); border-radius: 16px; padding: 16px 20px; transition: transform 220ms var(--ease-snap), box-shadow 220ms var(--ease-calm), border-color 220ms var(--ease-calm); }
.person:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); border-color: rgba(249,213,2,0.55); }
.person-avatar { flex-shrink: 0; width: 54px; height: 54px; border-radius: 50%; overflow: hidden; background: linear-gradient(150deg, #2a4f97, var(--gateway-navy)); color: var(--gateway-gold); display: grid; place-items: center; font-family: var(--font-display-condensed); font-weight: 900; font-size: 21px; letter-spacing: 0.02em; transition: background 240ms var(--ease-calm), color 240ms var(--ease-calm); }
.person-avatar img { width: 100%; height: 100%; object-fit: cover; }
.person:hover .person-avatar { background: var(--gateway-gold); color: var(--gateway-navy); }
.person-body { min-width: 0; }
.person-tag { display: inline-block; font-size: 9.5px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--navy-600); margin-bottom: 4px; }
.person-name { font-family: var(--font-display-condensed); font-size: 22px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.005em; color: var(--gateway-navy); margin: 0 0 2px; line-height: 1; }
.person-role { font-size: 13px; color: var(--fg2); line-height: 1.35; }

/* Leadership — featured vertical cards, gold-ringed monogram */
.roster-lead .person { flex-direction: column; text-align: center; gap: 16px; padding: 32px 24px 28px; border-top: 4px solid var(--gateway-gold); }
.roster-lead .person-avatar { width: 84px; height: 84px; font-size: 31px; box-shadow: 0 0 0 3px rgba(249,213,2,0.5); }
.roster-lead .person-tag { color: var(--gold-700); }
.roster-lead .person-name { font-size: 26px; }
.roster-divider { margin-top: 60px; }

@media (max-width: 960px) {
  .roster-grid, .roster-grid.roster-lead { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .roster-grid, .roster-grid.roster-lead { grid-template-columns: 1fr; }
}

/* ---------- Academics — bento curriculum map ---------- */
.curric-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.curric-card { grid-column: span var(--span, 1); position: relative; overflow: hidden; background: #fff; border: 1px solid var(--border-subtle); border-top: 4px solid var(--gateway-gold); border-radius: 16px; padding: 28px 28px 24px; display: flex; flex-direction: column; transition: transform 240ms var(--ease-snap), box-shadow 240ms var(--ease-calm), border-color 240ms var(--ease-calm); }
.curric-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lift); border-color: rgba(249,213,2,0.55); }
.curric-index { position: absolute; top: 4px; right: 18px; font-family: var(--font-display-condensed); font-weight: 900; font-size: 82px; line-height: 1; color: rgba(30,60,122,0.06); pointer-events: none; }
.curric-kbadge { position: relative; font-size: 11px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-700); }
.curric-title { position: relative; font-family: var(--font-display-condensed); font-size: 24px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.005em; color: var(--gateway-navy); margin: 9px 0 9px; line-height: 1.02; }
.curric-desc { position: relative; font-size: 14.5px; line-height: 1.55; color: var(--fg2); margin: 0; max-width: 52ch; }
.curric-card.feat { background: var(--gateway-navy); border: 1px solid rgba(249,213,2,0.3); border-top: 4px solid var(--gateway-gold); }
.curric-card.feat .curric-index { color: rgba(249,213,2,0.13); }
.curric-card.feat .curric-kbadge { color: var(--gateway-gold); }
.curric-card.feat .curric-title { color: #fff; font-size: 30px; }
.curric-card.feat .curric-desc { color: #C7D2E8; }
@media (max-width: 960px) {
  .curric-grid { grid-template-columns: repeat(2, 1fr); }
  .curric-card { grid-column: span 1 !important; }
}
@media (max-width: 560px) { .curric-grid { grid-template-columns: 1fr; } }

/* ---------- Early College — animated proof (count-up + comparison bars) ---------- */
.ec-proof .ecp-bars { max-width: 920px; margin: 38px auto 0; display: grid; grid-template-columns: auto 1fr; gap: 34px; align-items: center; }
.ecp-figure { display: flex; align-items: baseline; font-family: var(--font-display-condensed); font-weight: 900; font-size: clamp(92px, 12vw, 168px); line-height: 0.82; color: var(--gateway-gold); letter-spacing: -0.01em; font-variant-numeric: tabular-nums; }
.ecp-figure .pct { font-size: 0.5em; }
.ecp-bar-row { display: flex; flex-direction: column; gap: 16px; }
.ecp-bar-tag { display: flex; justify-content: space-between; margin-bottom: 8px; font-size: 13px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; }
.ecp-bar.gw .ecp-bar-tag { color: var(--gateway-gold); }
.ecp-bar.az .ecp-bar-tag { color: #C7D2E8; }
.ecp-track { position: relative; height: 32px; border-radius: 8px; background: rgba(255,255,255,0.08); overflow: hidden; }
.ecp-fill { position: absolute; inset: 0 auto 0 0; width: 0; border-radius: 8px; transition: width 1.3s var(--ease-snap); }
.ecp-bar.gw .ecp-fill { background: var(--gateway-gold); }
.ecp-bar.az .ecp-fill { background: rgba(255,255,255,0.3); }
.ec-proof.in .ecp-fill { width: var(--w); }
@media (prefers-reduced-motion: reduce) { .ecp-fill { transition: none; } }
.ecp-stats { max-width: 920px; margin: 22px auto 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.ecp-stat { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); border-radius: 16px; padding: 24px 20px; text-align: center; }
.ecp-stat strong { display: block; font-family: var(--font-display-condensed); font-weight: 900; font-size: 52px; line-height: 0.86; color: var(--gateway-gold); font-variant-numeric: tabular-nums; }
.ecp-stat > span { display: block; font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #C7D2E8; margin-top: 10px; }
@media (max-width: 760px) {
  .ec-proof .ecp-bars { grid-template-columns: 1fr; gap: 16px; }
  .ecp-stats { grid-template-columns: 1fr; }
}

/* ---------- Student Life — immersive masonry gallery ---------- */
.sl-mosaic { column-count: 3; column-gap: 16px; margin-top: 8px; }
.sl-tile { position: relative; display: block; break-inside: avoid; margin-bottom: 14px; border-radius: 16px; overflow: hidden; text-decoration: none; box-shadow: 0 8px 22px rgba(0,0,0,0.22); }
.sl-tile img { width: 100%; height: auto; display: block; transition: transform 620ms var(--ease-calm); }
.sl-tile::after { content: ""; position: absolute; inset: 0; background: linear-gradient(transparent 52%, rgba(11,23,50,0.85)); opacity: 0; transition: opacity 280ms var(--ease-calm); }
.sl-tile-cap { position: absolute; left: 15px; right: 15px; bottom: 13px; z-index: 2; color: #fff; font-size: 13px; font-weight: 800; letter-spacing: 0.05em; text-transform: uppercase; opacity: 0; transform: translateY(8px); transition: opacity 280ms var(--ease-calm), transform 280ms var(--ease-snap); text-shadow: 0 1px 8px rgba(0,0,0,0.5); }
.sl-tile::before { content: ""; position: absolute; left: 13px; bottom: 13px; z-index: 2; width: 22px; height: 3px; background: var(--gateway-gold); border-radius: 2px; opacity: 0; transform: translateY(8px); transition: opacity 280ms var(--ease-calm), transform 280ms var(--ease-snap); }
.sl-tile:hover img { transform: scale(1.05); }
.sl-tile:hover::after { opacity: 1; }
.sl-tile:hover .sl-tile-cap { opacity: 1; transform: none; }
.sl-tile:hover::before { opacity: 1; transform: translateY(-30px); }
.sl-tile:focus-visible { outline: 3px solid var(--gateway-gold); outline-offset: 3px; }
@media (max-width: 860px) { .sl-mosaic { column-count: 2; } }
@media (max-width: 520px) { .sl-mosaic { column-count: 1; } }

/* ---------- Athletics — natural-aspect masonry (no crop) ---------- */
.ath-mosaic { column-count: 2; column-gap: 16px; margin-top: 8px; }
.ath-mosaic figure { position: relative; break-inside: avoid; margin: 0 0 16px; border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-card); }
.ath-mosaic img { width: 100%; height: auto; display: block; }
.ath-mosaic figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: 30px 16px 13px; background: linear-gradient(transparent, rgba(15,31,63,0.85)); color: #fff; font-weight: 800; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; }
@media (max-width: 640px) { .ath-mosaic { column-count: 1; } }
.ath-intro-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
@media (max-width: 760px) { .ath-intro-grid { grid-template-columns: 1fr; gap: 28px; } }

/* ============================================================
   Guides — SEO content hub + pillar articles
   ============================================================ */
.guide-hero { background: var(--gateway-navy); color: #fff; border-bottom: 4px solid var(--gateway-gold); padding: 64px 0 52px; position: relative; }
.guide-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(680px 360px at 88% 0%, rgba(249,213,2,0.10), transparent 62%); pointer-events: none; }
.guide-hero .container { position: relative; z-index: 1; }
.guide-hero .eyebrow { color: var(--gateway-gold); }
.guide-hero h1 { font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: clamp(38px, 5.4vw, 68px); line-height: 0.94; letter-spacing: -0.005em; color: #fff; margin: 12px 0 18px; }
.guide-deck { font-size: 19px; line-height: 1.6; color: #C7D2E8; max-width: 60ch; margin: 0; }
.guide-deck strong { color: var(--gateway-gold); font-weight: 800; }
.guide-meta { font-size: 13px; color: #9fb2d6; letter-spacing: 0.02em; margin: 18px 0 0; }
.crumb { font-size: 13px; font-weight: 700; color: #9fb2d6; margin-bottom: 18px; }
.crumb a { color: var(--gateway-gold); text-decoration: none; }
.crumb a:hover { text-decoration: underline; }

/* Prose body */
.guide-body .container { max-width: 760px; }
.guide-lead { font-size: 20px; line-height: 1.6; color: var(--gateway-navy); font-weight: 500; border-left: 4px solid var(--gateway-gold); padding-left: 24px; margin: 0 0 10px; }
.guide-body h2 { font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: clamp(24px, 3vw, 34px); line-height: 1.0; color: var(--gateway-navy); margin: 40px 0 12px; }
.guide-body p { font-size: 17px; line-height: 1.7; color: var(--fg1); margin: 14px 0; }
.guide-body strong { color: var(--gateway-navy); font-weight: 700; }
.guide-body .steps { margin: 22px 0 8px; }
.guide-faq { margin-top: 48px; padding-top: 8px; border-top: 1px solid var(--border-subtle); }
.guide-faq h2 { margin-top: 28px; }

/* Featured pillar card (hub) */
.guides-index .container { max-width: 920px; }
.guide-feature { position: relative; display: block; background: var(--gateway-navy); color: #fff; border-radius: 16px; border: 1px solid rgba(249,213,2,0.3); padding: 36px 40px; text-decoration: none; overflow: hidden; transition: transform 240ms var(--ease-snap), box-shadow 240ms var(--ease-calm); }
.guide-feature::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--gateway-gold); }
.guide-feature:hover { transform: translateY(-4px); box-shadow: 0 20px 44px rgba(15,31,63,0.26); }
.gf-tag { display: block; font-size: 12px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gateway-gold); }
.gf-title { display: block; font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: clamp(26px, 3.4vw, 40px); line-height: 1.0; color: #fff; margin: 10px 0 10px; }
.gf-desc { display: block; font-size: 16px; line-height: 1.55; color: #C7D2E8; max-width: 64ch; }
.gf-go { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; font-size: 13px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gateway-gold); }
.guide-feature:hover .gf-go { gap: 12px; }

/* Topic route cards (hub + article "next") */
.guide-next { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 18px; }
.gn-card { position: relative; display: flex; flex-direction: column; background: #fff; border: 1px solid var(--border-subtle); border-left: 4px solid var(--gateway-gold); border-radius: 12px; padding: 24px 24px; text-decoration: none; transition: transform 200ms var(--ease-snap), box-shadow 200ms var(--ease-calm), border-color 200ms var(--ease-calm); }
.gn-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.gn-tag { font-size: 10.5px; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold-700); margin-bottom: 7px; }
.gn-t { font-size: 18px; font-weight: 800; color: var(--gateway-navy); letter-spacing: -0.005em; }
.gn-d { font-size: 14px; line-height: 1.5; color: var(--fg2); margin-top: 5px; }
.gn-go { position: absolute; top: 20px; right: 22px; color: var(--gold-700); font-size: 18px; transition: transform 200ms var(--ease-snap); }
.gn-card:hover .gn-go { transform: translateX(4px); }
@media (max-width: 640px) { .guide-next { grid-template-columns: 1fr; } }

/* Guide reading aids — TL;DR + eligibility checklist + read-time */
.gm-read { display: inline-block; font-weight: 800; color: var(--gateway-gold); letter-spacing: 0.04em; text-transform: uppercase; font-size: 12px; }
.guide-tldr { background: var(--gateway-navy); border-radius: 16px; border-top: 4px solid var(--gateway-gold); padding: 24px 28px; margin: 24px 0 8px; }
.guide-tldr .tldr-label { font-size: 11px; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gateway-gold); margin-bottom: 14px; }
.tldr-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 12px 28px; }
.tldr-list li { position: relative; padding-left: 28px; font-size: 15px; line-height: 1.4; color: #EAF0FB; }
.tldr-list li strong { color: #fff; font-weight: 800; }
.tldr-list li::before { content: ""; position: absolute; left: 0; top: 1px; width: 18px; height: 18px; border-radius: 50%; background: var(--gateway-gold); }
.tldr-list li::after { content: ""; position: absolute; left: 6px; top: 5px; width: 5px; height: 9px; border: solid var(--gateway-navy); border-width: 0 2px 2px 0; transform: rotate(45deg); }
.qualify { background: var(--paper); border: 1px solid var(--border-subtle); border-left: 4px solid var(--gateway-gold); border-radius: 12px; padding: 24px 28px; margin: 20px 0 8px; }
.qualify-head { font-size: 16px; font-weight: 900; color: var(--gateway-navy); margin-bottom: 14px; }
.qualify-list { list-style: none; margin: 0 0 14px; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 28px; }
.qualify-list li { position: relative; padding-left: 28px; font-size: 15px; line-height: 1.45; color: var(--fg1); }
.qualify-list li::before { content: ""; position: absolute; left: 2px; top: 2px; width: 18px; height: 18px; border-radius: 50%; background: var(--gateway-gold); }
.qualify-list li::after { content: ""; position: absolute; left: 8px; top: 6px; width: 5px; height: 9px; border: solid var(--gateway-navy); border-width: 0 2px 2px 0; transform: rotate(45deg); }
.qualify-note { font-size: 14.5px; color: var(--fg2); margin: 0; font-style: italic; }
@media (max-width: 560px) { .tldr-list, .qualify-list { grid-template-columns: 1fr; } }

/* ---------- Partner showcase (home) — partners framed as proof ---------- */
.partner-show { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 8px; }
.partner-card { background: rgba(255,255,255,0.06); border: 1px solid rgba(249,213,2,0.25); border-top: 3px solid var(--gateway-gold); border-radius: 16px; padding: 28px 24px 28px; display: flex; flex-direction: column; transition: transform 220ms var(--ease-snap), background 220ms var(--ease-calm), border-color 220ms var(--ease-calm); }
.partner-card:hover { transform: translateY(-4px); background: rgba(249,213,2,0.08); border-color: rgba(249,213,2,0.6); }
.pc-logo { background: #fff; border-radius: 12px; padding: 28px 20px; min-height: 160px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; overflow: hidden; }
.pc-logo img { max-width: 100%; width: auto; display: block; object-fit: contain; }
.pc-name { font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: 20px; line-height: 1; color: var(--gateway-gold); margin: 0 0 8px; }
.pc-impact { font-size: 14px; line-height: 1.5; color: #C7D2E8; margin: 0; }
.partner-accred { margin-top: 32px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,0.12); text-align: center; }
.pa-label { display: block; font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--navy-200); margin-bottom: 14px; }
.pa-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 14px; }
.pa-row .pchip { background: #fff; border-radius: 12px; padding: 14px 20px; box-shadow: var(--shadow-card); display: flex; align-items: center; justify-content: center; min-height: 72px; }
.pa-row .pchip img { max-height: 46px; max-width: 150px; width: auto; display: block; object-fit: contain; }
@media (max-width: 900px) { .partner-show { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .partner-show { grid-template-columns: 1fr; } }

/* ---------- Events / Visit ---------- */
.event-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 8px; }
.event-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--border-subtle); border-top: 4px solid var(--gateway-gold); border-radius: 16px; padding: 28px 28px 24px; transition: transform 220ms var(--ease-snap), box-shadow 220ms var(--ease-calm), border-color 220ms var(--ease-calm); }
.event-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lift); border-color: rgba(249,213,2,0.55); }
.event-card.featured { background: var(--gateway-navy); border: 1px solid rgba(249,213,2,0.3); border-top: 4px solid var(--gateway-gold); }
.ec-tag { font-size: 11px; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold-700); }
.event-card.featured .ec-tag { color: var(--gateway-gold); }
.ec-title { font-family: var(--font-display-condensed); font-weight: 900; text-transform: uppercase; font-size: 24px; line-height: 1; color: var(--gateway-navy); margin: 9px 0 10px; }
.event-card.featured .ec-title { color: #fff; }
.ec-when { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 800; color: var(--fg2); margin-bottom: 12px; }
.event-card.featured .ec-when { color: #C7D2E8; }
.ec-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--gateway-gold); flex-shrink: 0; }
.ec-desc { font-size: 14.5px; line-height: 1.55; color: var(--fg2); margin: 0 0 18px; }
.event-card.featured .ec-desc { color: #C7D2E8; }
.ec-rsvp { margin-top: auto; align-self: flex-start; background: none; border: 0; cursor: pointer; font-family: inherit; font-size: 13px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; color: var(--gold-700); display: inline-flex; align-items: center; gap: 8px; padding: 4px 0; transition: gap 180ms var(--ease-snap); }
.event-card.featured .ec-rsvp { color: var(--gateway-gold); }
.ec-rsvp:hover { gap: 12px; }
.events-note { text-align: center; font-size: 14px; color: var(--fg2); margin: 26px auto 0; max-width: 60ch; }
.events-note a { color: var(--gateway-navy); font-weight: 700; }
.rsvp-card { max-width: 640px; margin: 0 auto; }
@media (max-width: 640px) { .event-grid { grid-template-columns: 1fr; } }

/* ---------- Alumni & Outcomes ---------- */
.alum-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 8px; }
.alum-stat { background: rgba(255,255,255,0.05); border: 1px solid rgba(249,213,2,0.2); border-top: 3px solid var(--gateway-gold); border-radius: 16px; padding: 28px 20px; text-align: center; }
.alum-stat strong { display: block; font-family: var(--font-display-condensed); font-weight: 900; font-size: clamp(40px, 5vw, 56px); line-height: 0.86; color: var(--gateway-gold); letter-spacing: -0.01em; font-variant-numeric: tabular-nums; }
.alum-stat span { display: block; font-size: 13px; font-weight: 600; color: #C7D2E8; margin-top: 12px; line-height: 1.4; }
.consent { display: flex; align-items: flex-start; gap: 8px; font-size: 13.5px; line-height: 1.5; color: var(--fg2); font-weight: 500; text-transform: none; letter-spacing: 0; }
.consent input { width: 18px; height: 18px; margin-top: 2px; flex-shrink: 0; accent-color: var(--gateway-navy); }
@media (max-width: 760px) { .alum-stats { grid-template-columns: 1fr 1fr; } }

/* ---------- Mobile single-column safety (authoritative — keep LAST) ----------
   At phone widths an earlier @media(max-width:960px) rule sets .feature-grid / .steps
   to repeat(2,1fr); with equal specificity it was winning over the 600px 1fr rule by
   source order, leaving 2 columns (and horizontal overflow) on phones. This block,
   being last, restores a single column at ≤600px for every card grid. */
@media (max-width: 600px) {
  .feature-grid,
  .feature-grid.cols-2,
  .feature-grid.cols-4,
  .steps,
  .steps.cols-4,
  .prog-grid { grid-template-columns: 1fr; }
  /* long wayfinding CTAs (e.g. "Explore the High School Program →") must wrap, not overflow */
  .btn { max-width: 100%; white-space: normal; }
  /* the 3-up "vs" comparison stacks on phones (never collapsed before → overflow) */
  .compare-row { grid-template-columns: 1fr; text-align: center; gap: 12px; }
  .compare-vs { margin: 0 auto; }
}

/* ---------- Print — make content pages (Admissions, Tuition, Calendar…) readable on paper ---------- */
@media print {
  .nav-utility, .nav-inner, .nav-links, .nav-mobile, .nav-scrim,
  #ga-enroll-bar, #ga-tour-btn, .skip-link,
  .footer .socials, .modal-scrim, .map-directions,
  .cal-hero-ctas, .leg-reset { display: none !important; }
  html, body { background: #fff !important; }
  .site, .section, .section.navy, .section.alt, .page-hero { background: #fff !important; color: #000 !important; }
  h1, h2, h3, h4, p, li, dt, dd,
  .page-hero h1, .section.navy h2, .section.navy h3, .section.navy p { color: #000 !important; text-shadow: none !important; }
  .eyebrow, .eyebrow.dark, .kbadge, .fac-role { color: #1E3C7A !important; }
  .section, .page-hero { padding: 14px 0 !important; }
  .feature, .step, .bignum, .news-card, .pathway, .mand-card { box-shadow: none !important; border: 1px solid #ccc !important; break-inside: avoid; }
  a[href^="http"]::after { content: " (" attr(href) ")"; font-size: 0.85em; color: #555; word-break: break-all; }
  * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

/* ---------- Alumni stat band (gold) — symmetric, divider-free, baseline-aligned ---------- */
.alumni-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px;
  max-width: 940px; margin: 0 auto; align-items: start;
}
.alumni-stat { display: grid; justify-items: center; text-align: center; }
.alumni-stat-num {
  font-family: var(--font-display-condensed); font-weight: 900; font-size: 78px; line-height: 0.9;
  color: var(--gateway-navy); font-variant-numeric: tabular-nums;
}
.alumni-stat-rule { width: 36px; height: 3px; background: var(--gateway-navy); opacity: 0.22; border-radius: 2px; margin: 16px 0 14px; }
.alumni-stat-label {
  font-size: 14px; font-weight: 800; letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--gateway-navy); line-height: 1.25; min-height: 2.5em;
  display: flex; align-items: flex-start; justify-content: center;
}
.alumni-stat-note { font-size: 13px; color: var(--gateway-navy); opacity: 0.62; font-style: italic; margin-top: 6px; }
@media (max-width: 760px) {
  .alumni-stats { grid-template-columns: repeat(2, 1fr); gap: 40px 24px; }
  .alumni-stat-num { font-size: 60px; }
}

/* ============================================================
   Minor polish pass — mobile UX + typography
   ============================================================ */
@media (max-width: 600px) {
  /* Bigger touch targets for the mobile-menu dropdown sub-links (WCAG 2.5.5 ~44px) */
  .nav-mobile .m-group-items a { padding-top: 13px; padding-bottom: 13px; }
  /* 16px form fields stop iOS Safari from zooming in when a field gains focus */
  .form-card input, .form-card select, .form-card textarea,
  .modal input, .modal select, .modal textarea { font-size: 16px; }
  /* Tighter section rhythm on phones */
  .section { padding-top: 42px; padding-bottom: 42px; }
  /* The sticky nav is shorter on phones — a smaller anchor offset avoids a big gap on #jumps */
  [id] { scroll-margin-top: 84px; }
}
/* Headings settle into balanced lines instead of leaving an orphan word */
.section-head h2, .page-hero .inner h1 { text-wrap: balance; }

/* ---------- Student Life — Animals feature (gold) ---------- */
.sl-animals { background: var(--gateway-gold); border-radius: 18px; overflow: hidden; display: grid; grid-template-columns: 1fr 1fr; align-items: center; box-shadow: 0 10px 30px rgba(15,31,63,0.12); }
.sl-animals-photo { display: block; font-size: 0; }
.sl-animals-photo img { display: block; width: 100%; height: auto; }
.sl-animals-copy { padding: 40px 44px; }
.sl-animals-copy .eyebrow.dark { margin-bottom: 10px; }
.sl-animals-copy h2 { font-size: 34px; font-weight: 900; text-transform: uppercase; color: var(--gateway-navy); margin: 0 0 12px; letter-spacing: -0.01em; line-height: 1; }
.sl-animals-copy p { font-size: 16px; line-height: 1.6; color: #2a3a5e; margin: 0; max-width: 52ch; }
@media (max-width: 760px) { .sl-animals { grid-template-columns: 1fr; } .sl-animals-copy { padding: 28px 24px; } }
