/* ─────────────────────────────────────────────────────────────────────
   CMS Builder — variant CSS for section types built via /sadmin/cms/.
   Designed to layer on top of the canonical site stylesheet (styles.css).
   Every variant is curated and on-brand: editors pick a variant, never
   a free-form color/font.
   Brand palette: #35405B (navy) · #21BFE1 (sky blue) · #A8916E (mint)
   ───────────────────────────────────────────────────────────────────── */

/* ── Button: secondary (the renderer's middle option between primary
   and ghost). Mirrors styles.css btn-hero-primary geometry but uses a
   restrained outlined treatment so it doesn't compete with primary. */
.btn-hero-secondary {
  background: #ffffff;
  color: #35405B;
  border: 1px solid rgba(53, 64, 91, .18);
  box-shadow: 0 6px 18px rgba(53, 64, 91, .08);
}
.btn-hero-secondary:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(53, 64, 91, .14);
  background: #f9fafb;
  color: #35405B;
}
/* On dark/navy heroes, secondary should adopt the ghost treatment so
   it doesn't punch a white hole in a navy section. */
.cms-hero--bg-navy .btn-hero-secondary,
.cms-cta--bg-navy .btn-hero-secondary,
.cms-cards--bg-navy .btn-hero-secondary {
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .25);
  color: #ffffff;
}
.cms-hero--bg-navy .btn-hero-secondary:hover,
.cms-cta--bg-navy .btn-hero-secondary:hover,
.cms-cards--bg-navy .btn-hero-secondary:hover {
  background: rgba(255, 255, 255, .16);
  color: #ffffff;
}

/* ── Hero v2 — bg variants ─────────────────────────────────────────── */
.cms-hero--bg-navy { background: #35405B; color: #fff; }
.cms-hero--bg-navy .hero-h1 { color: #fff; }
.cms-hero--bg-navy .hero-sub { color: rgba(255,255,255,.82); }
.cms-hero--bg-navy .hero-stat-value { color: #fff; }
.cms-hero--bg-navy .hero-stat-label { color: rgba(255,255,255,.7); }

/* Hero stat-style variants */
.cms-hero--stat-bordered .hero-stat { border: 1px solid rgba(53,64,91,.12); }
.cms-hero--stat-glass    .hero-stat { background: rgba(255,255,255,.6); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,.5); box-shadow: 0 4px 16px rgba(53,64,91,.06); }
.cms-hero--stat-minimal  .hero-stat { background: transparent; border: 0; padding: 14px 0; }
.cms-hero--bg-navy.cms-hero--stat-bordered .hero-stat { border-color: rgba(255,255,255,.18); }
.cms-hero--bg-navy.cms-hero--stat-glass    .hero-stat { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18); color: #fff; }

/* ── Split v2 ──────────────────────────────────────────────────────── */
.cms-split {}
.cms-split-grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap: 56px; align-items: center; }
.cms-split--media-right .cms-split-grid { direction: ltr; }
.cms-split--media-left  .cms-split-grid > .cms-split-media { order: 0; }
.cms-split--media-left  .cms-split-grid > .cms-split-copy  { order: 1; }
.cms-split--media-right .cms-split-grid > .cms-split-media { order: 1; }
.cms-split--media-right .cms-split-grid > .cms-split-copy  { order: 0; }

.cms-split-media img,
.cms-split-video { border-radius: 14px; box-shadow: 0 18px 45px rgba(53,64,91,.16); width: 100%; height: auto; display: block; }
.cms-split-video { aspect-ratio: 16/9; background: #111827; overflow: hidden; display: grid; place-items: center; }
.cms-split-video iframe,
.cms-split-video video { width: 100%; height: 100%; border: 0; }

.cms-split-copy .eyebrow { margin-bottom: 12px; }
.cms-split-copy .section-h2 { text-align: left; margin-top: 0; }
.cms-split-copy .section-lead { text-align: left; }
.cms-split-cta { margin-top: 20px; }

.cms-split--bg-soft { background: #faf9fc; }
.cms-split--bg-navy { background: #35405B; color: #fff; }
.cms-split--bg-navy .section-h2 { color: #fff; }
.cms-split--bg-navy .section-lead { color: rgba(255,255,255,.78); }

@media (max-width: 820px) {
  .cms-split-grid { grid-template-columns: 1fr; gap: 32px; }
  .cms-split-grid > .cms-split-media { order: 0 !important; }
  .cms-split-grid > .cms-split-copy  { order: 1 !important; }
}

/* ── Benefits grid — cards ─────────────────────────────────────────── */
.cms-cards--bg-soft { background: #faf9fc; }
.cms-cards--bg-navy { background: #35405B; }
.cms-cards--bg-navy .section-h2 { color: #fff; }
.cms-cards--bg-navy .section-h2 em,
.cms-cards--bg-navy .section-h2 .hero-h1-script { color: #21BFE1; }
.cms-cards--bg-navy .section-lead { color: rgba(255,255,255,.78); }

.cms-cards-grid { display: grid; gap: 18px; margin-top: 32px; }
.cms-cards--cols-2 .cms-cards-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.cms-cards--cols-3 .cms-cards-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
.cms-cards--cols-4 .cms-cards-grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
@media (max-width: 900px) {
  .cms-cards--cols-3 .cms-cards-grid,
  .cms-cards--cols-4 .cms-cards-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 560px) {
  .cms-cards-grid { grid-template-columns: 1fr !important; }
}

.cms-card { background: #fff; border-radius: 12px; padding: 24px; transition: transform .2s ease, box-shadow .2s ease; }
.cms-card-icon  { font-size: 28px; margin-bottom: 14px; display: inline-block; }
.cms-card-title { font-size: 17px; font-weight: 700; color: #35405B; margin: 0 0 8px; line-height: 1.3; }
.cms-card-body  { font-size: 14px; color: #6b7280; line-height: 1.55; margin: 0; }

/* Card style variants */
.cms-cards--style-bordered .cms-card { border: 1px solid #e5e7eb; box-shadow: 0 1px 2px rgba(53,64,91,.04); }
.cms-cards--style-shadow   .cms-card { border: 1px solid transparent; box-shadow: 0 10px 28px rgba(53,64,91,.08); }
.cms-cards--style-lift     .cms-card { border: 1px solid #e5e7eb; box-shadow: 0 4px 14px rgba(53,64,91,.05); }

/* Hover variants */
.cms-cards--hover-lift .cms-card:hover { transform: translateY(-2px); box-shadow: 0 16px 36px rgba(53,64,91,.10); }
.cms-cards--hover-glow .cms-card:hover { box-shadow: 0 0 0 2px #21BFE1, 0 12px 28px rgba(33,191,225,.25); }
.cms-cards--hover-none .cms-card:hover { transform: none; }

/* Icon color */
.cms-cards--icon-mint .cms-card-icon { color: #A8916E; }
.cms-cards--icon-sky  .cms-card-icon { color: #21BFE1; }
.cms-cards--icon-navy .cms-card-icon { color: #35405B; }

/* Cards on navy bg: dark surfaces */
.cms-cards--bg-navy .cms-card { background: #425072; border-color: transparent; color: #fff; }
.cms-cards--bg-navy .cms-card-title { color: #fff; }
.cms-cards--bg-navy .cms-card-body  { color: rgba(255,255,255,.72); }
.cms-cards--bg-navy.cms-cards--style-shadow .cms-card { box-shadow: 0 18px 40px rgba(0,0,0,.30); }
.cms-cards--bg-navy.cms-cards--hover-lift   .cms-card:hover { box-shadow: 0 24px 52px rgba(0,0,0,.40); }

/* ── Icon tile row ─────────────────────────────────────────────────── */
.cms-tiles--bg-navy { background: #35405B; }
.cms-tiles--bg-navy .cms-tiles-heading,
.cms-tiles--bg-navy .cms-tile-label { color: #fff; }
.cms-tiles-heading { text-align: center; color: #35405B; font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin: 0 0 18px; }
.cms-tiles-row { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.cms-tile { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; background: #fff; border: 1px solid #e5e7eb; transition: transform .15s ease, box-shadow .15s ease; }
.cms-tile-icon  { color: #21BFE1; font-size: 20px; }
.cms-tile-label { font-weight: 600; color: #35405B; font-size: 14px; }
.cms-tile:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(53,64,91,.08); }

.cms-tiles--style-chip   .cms-tile { border-radius: 999px; }
.cms-tiles--style-square .cms-tile { border-radius: 8px; }
.cms-tiles--style-circle .cms-tile { width: 96px; height: 96px; border-radius: 999px; flex-direction: column; padding: 12px; justify-content: center; text-align: center; }
.cms-tiles--style-circle .cms-tile-icon { font-size: 28px; }
.cms-tiles--style-circle .cms-tile-label { font-size: 12px; }
.cms-tiles--bg-navy .cms-tile { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18); }

/* ── Photo gallery ─────────────────────────────────────────────────── */
.cms-gallery-grid { display: grid; gap: 14px; margin-top: 36px; }
.cms-gallery--layout-3 .cms-gallery-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
.cms-gallery--layout-4 .cms-gallery-grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
.cms-gallery--layout-masonry .cms-gallery-grid { columns: 3; column-gap: 14px; display: block; }
.cms-gallery--layout-masonry .cms-gallery-item { display: block; margin: 0 0 14px; break-inside: avoid; }
@media (max-width: 900px) {
  .cms-gallery--layout-3 .cms-gallery-grid,
  .cms-gallery--layout-4 .cms-gallery-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .cms-gallery--layout-masonry .cms-gallery-grid { columns: 2; }
}
@media (max-width: 560px) {
  .cms-gallery-grid { grid-template-columns: 1fr !important; }
  .cms-gallery--layout-masonry .cms-gallery-grid { columns: 1; }
}
.cms-gallery-item { position: relative; aspect-ratio: 4/3; overflow: hidden; border-radius: 14px; display: block; cursor: zoom-in; background: #35405B; box-shadow: 0 12px 30px rgba(53,64,91,.10); }
.cms-gallery--layout-masonry .cms-gallery-item { aspect-ratio: auto; }
.cms-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; display: block; }
.cms-gallery-item::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(53,64,91,0) 50%, rgba(53,64,91,.55) 100%); opacity: 0; transition: opacity .25s ease; pointer-events: none; }
.cms-gallery-item:hover img { transform: scale(1.08); }
.cms-gallery-item:hover::after { opacity: 1; }
.cms-gallery-zoom { position: absolute; top: 14px; right: 14px; width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.92); color: #35405B; border-radius: 999px; opacity: 0; transform: translateY(-6px); transition: opacity .25s ease, transform .25s ease; box-shadow: 0 4px 12px rgba(0,0,0,.15); }
.cms-gallery-item:hover .cms-gallery-zoom { opacity: 1; transform: translateY(0); }
.cms-gallery-zoom .material-symbols-outlined { font-size: 20px; }
.cms-gallery-footer { text-align: center; margin-top: 28px; }

/* ── Lightbox ──────────────────────────────────────────────────────── */
.cms-lightbox { position: fixed; inset: 0; background: rgba(53,64,91,.94); backdrop-filter: blur(4px); z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 32px; animation: cms-lb-fade .25s ease; }
.cms-lightbox[hidden] { display: none; }
@keyframes cms-lb-fade { from {opacity:0;} to {opacity:1;} }
.cms-lightbox__img-wrap { position: relative; max-width: min(1200px, 92vw); max-height: 84vh; }
.cms-lightbox__img      { max-width: 100%; max-height: 84vh; object-fit: contain; border-radius: 12px; box-shadow: 0 30px 80px rgba(0,0,0,.5); }
.cms-lightbox__caption  { position: absolute; left: 0; right: 0; bottom: -36px; text-align: center; color: rgba(255,255,255,.82); font-size: 14px; }
.cms-lightbox__close,
.cms-lightbox__prev,
.cms-lightbox__next     { position: absolute; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25); color: #fff; width: 48px; height: 48px; border-radius: 999px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background .2s ease, transform .2s ease; backdrop-filter: blur(8px); }
.cms-lightbox__close:hover,
.cms-lightbox__prev:hover,
.cms-lightbox__next:hover { background: rgba(33,191,225,.35); transform: scale(1.08); }
.cms-lightbox__close { top: 24px; right: 24px; }
.cms-lightbox__prev  { left: 24px; top: 50%; transform: translateY(-50%); }
.cms-lightbox__next  { right: 24px; top: 50%; transform: translateY(-50%); }
.cms-lightbox__prev:hover { transform: translateY(-50%) scale(1.08); }
.cms-lightbox__next:hover { transform: translateY(-50%) scale(1.08); }
.cms-lightbox__counter { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); color: rgba(255,255,255,.82); font-size: 13px; }

/* ── CTA block ─────────────────────────────────────────────────────── */
.cms-cta--bg-soft { background: #faf9fc; }
.cms-cta--bg-navy { background: #35405B; color: #fff; }
.cms-cta--bg-navy .section-h2 { color: #fff; }
.cms-cta--bg-navy .section-h2 .hero-h1-script { color: #21BFE1; }
.cms-cta--bg-navy .section-lead { color: rgba(255,255,255,.82); }
.cms-cta-inner { max-width: 760px; margin: 0 auto; }
.cms-cta--align-left .cms-cta-inner { margin: 0; text-align: left; }
.cms-cta--align-left .hero-cta-row { justify-content: flex-start !important; }

/* ── FAQ block ─────────────────────────────────────────────────────── */
.cms-faq--bg-soft { background: #faf9fc; }
.cms-faq-list { max-width: 760px; margin: 32px auto 0; display: grid; gap: 12px; }
.cms-faq--cols-2 .cms-faq-list { max-width: 1080px; grid-template-columns: repeat(2, minmax(0,1fr)); }
@media (max-width: 720px) { .cms-faq--cols-2 .cms-faq-list { grid-template-columns: 1fr; } }
.cms-faq-item { background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; padding: 16px 20px; transition: border-color .2s ease, box-shadow .2s ease; }
.cms-faq-item[open] { border-color: #21BFE1; box-shadow: 0 8px 24px rgba(33,191,225,.10); }
.cms-faq-item summary { display: flex; justify-content: space-between; align-items: center; gap: 16px; cursor: pointer; list-style: none; font-weight: 600; color: #35405B; font-size: 15px; }
.cms-faq-item summary::-webkit-details-marker { display: none; }
.cms-faq-chevron { color: #21BFE1; font-size: 22px; transition: transform .2s ease; }
.cms-faq-item[open] .cms-faq-chevron { transform: rotate(180deg); }
.cms-faq-answer { margin-top: 12px; color: #6b7280; font-size: 14px; line-height: 1.6; }

/* ── Schools carousel — reuses .schools-grid + .school-card from styles.css ──── */
.cms-schools--bg-navy { background: #35405B; }
.cms-schools--bg-navy .section-h2 { color: #fff; }
.cms-schools--bg-navy .section-h2 .hero-h1-script { color: #21BFE1; }
.cms-schools--bg-navy .section-lead { color: rgba(255,255,255,.78); }
.cms-schools--layout-carousel .schools-grid { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; gap: 18px; padding-bottom: 12px; }
.cms-schools--layout-carousel .schools-grid > .school-card { flex: 0 0 280px; scroll-snap-align: start; }

/* ── Page-level shell ──────────────────────────────────────────────── */
main.cms-page { display: block; }
