:root {
  --bg: #082922;
  --bg-2: #051d18;
  --panel: rgba(13, 56, 47, 0.65);
  --panel-soft: rgba(13, 56, 47, 0.96);
  --panel-dark: #092e27;
  --text: #f0f7f5;
  --text-dark: #ffffff;
  --muted: rgba(240, 247, 245, 0.65);
  --muted-dark: rgba(255, 255, 255, 0.65);
  --line: rgba(255, 255, 255, 0.08);
  --line-dark: rgba(255, 255, 255, 0.12);
  --accent: #57d8a5;
  --accent-soft: rgba(87, 216, 165, 0.2);
  --shadow: 0 8px 30px rgba(0, 0, 0, 0.25);
  --radius-xl: 18px;
  --radius-lg: 12px;
  --radius-md: 10px;
  color-scheme: dark;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, var(--bg), var(--bg-2));
  overflow-x: hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

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

img {
  display: block;
  max-width: 100%;
}

button,
input,
textarea {
  font: inherit;
}

.backdrop {
  display: none;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem clamp(1rem, 3vw, 2rem);
  background: rgba(13, 56, 47, 0.75);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  min-width: 0;
}

.brand__logo {
  height: 5rem;
  width: auto;
  display: block;
  object-fit: contain;
  margin: -0.75rem 0;
}

.brand__mark {
  width: 3rem;
  height: 3rem;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--accent);
  color: #ffffff;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.brand__text {
  display: grid;
  line-height: 1.1;
}

.brand__text strong {
  font-family: "Playfair Display", serif;
  font-size: 1rem;
  color: var(--text-dark);
}

.brand__text small {
  color: var(--muted);
  font-size: 0.78rem;
}

.topnav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.35rem;
}

.nav-group {
  position: relative;
}

.nav-group > summary {
  list-style: none;
}

.nav-group > summary::-webkit-details-marker {
  display: none;
}

.nav-group > summary,
.topnav > a {
  padding: 0.5rem 0.75rem;
  border-radius: 999px;
  border: 1px solid transparent;
  color: var(--text-dark);
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

.topnav a:hover,
.topnav a.is-active,
.nav-group > summary:hover,
.nav-group[open] > summary {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.06);
  transform: translateY(-2px) scale(1.02);
}

.nav-group__menu {
  position: absolute;
  right: 0;
  top: calc(100% + 0.5rem);
  display: grid;
  min-width: 16rem;
  padding: 0.45rem;
  border-radius: 10px;
  background: var(--panel);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity 160ms ease, visibility 160ms ease, transform 160ms ease;
  z-index: 30;
}

.nav-group[open] .nav-group__menu,
.nav-group:focus-within .nav-group__menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-group__menu a {
  padding: 0.6rem 0.75rem;
  border-radius: 8px;
  color: var(--text-dark);
}

.nav-group__menu a:hover,
.nav-group__menu a.is-active {
  background: rgba(255, 255, 255, 0.035);
}

main {
  width: min(1320px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 1rem 0 4rem;
}

.section {
  padding: clamp(2rem, 4.8vw, 4.5rem) 0;
}

.section__header {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
  gap: 1rem;
  align-items: end;
  margin-bottom: 1.4rem;
}

.section__header h2,
.hero h1,
.panel h3,
.offering-card h3,
.carousel__slide h3,
.coming-soon-card strong,
.redirect-card h3 {
  margin: 0;
  font-family: "Playfair Display", serif;
  letter-spacing: -0.02em;
}

.section__header h2,
.hero h1 {
  font-size: clamp(2.2rem, 4vw, 4.8rem);
  line-height: 0.96;
}

.section__header p,
.lede,
.panel p,
.feature-card p,
.stat-card p,
.timeline p,
.coming-soon-card p,
.redirect-card p,
.contact-card strong,
.contact-form label {
  color: var(--muted);
}

.eyebrow,
.panel__label,
.offering-card__tag,
.carousel__label,
.accordion-card__eyebrow {
  display: inline-flex;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.7rem;
  color: rgba(247, 250, 248, 0.65);
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.95fr);
  gap: 1rem;
  align-items: stretch;
}

.hero__panel,
.hero__gallery,
.panel,
.offering-card,
.carousel,
.stat-card,
.feature-card,
.accordion-card,
.contact-card,
.coming-soon-card,
.redirect-card {
  box-shadow: var(--shadow);
  transition: transform 300ms cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 300ms ease, border-color 300ms ease;
}

.panel,
.offering-card,
.carousel,
.stat-card,
.feature-card,
.accordion-card,
.contact-card,
.coming-soon-card,
.redirect-card {
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  transition: transform 300ms cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 300ms ease, border-color 300ms ease;
}

.panel {
  padding: clamp(1.25rem, 2vw, 2rem);
}

/* Presentation slide styles */
.slide {
  padding: clamp(1rem, 2vw, 1.5rem);
  margin: 1rem 0;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(251,253,251,0.02), rgba(251,253,251,0.01));
  border: 1px solid rgba(255, 255, 255, 0.06);
}
.slide h2 {
  margin-top: 0;
  font-size: 1.05rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
.slide h3 {
  margin: 0.35rem 0 0.6rem;
}

/* Slides layout helpers */
.slides-container {
  max-width: 1100px;
  margin: 2rem auto;
}
.slides-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.logo {
  width: 180px;
  height: auto;
  border-radius: 6px;
  padding: 8px;
  background: var(--panel);
  border: 1px solid var(--line);
}

.panel--light {
  background: var(--panel);
  color: var(--text-dark);
  border-color: rgba(255, 255, 255, 0.06);
}

.panel--light .panel__label,
.panel--light p,
.panel--light .lede,
.panel--light .contact-form label {
  color: var(--muted-dark);
}

.panel--dark {
  background: linear-gradient(180deg, rgba(10, 56, 57, 0.95), rgba(9, 48, 49, 0.98));
}

.panel--overlap {
  transform: translateY(-0.35rem);
}

.hero__panel {
  padding: clamp(1.4rem, 2.8vw, 2.4rem);
  background: linear-gradient(180deg, rgba(13, 56, 47, 0.98), rgba(9, 46, 39, 0.92));
  color: var(--text-dark);
  overflow: hidden;
}

.hero__panel .eyebrow {
  color: var(--accent-soft);
}

.hero__panel h1 {
  margin-top: 0.7rem;
  margin-bottom: 1rem;
  max-width: 12ch;
}

.lede {
  margin: 0;
  max-width: 38rem;
  line-height: 1.75;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin: 1.45rem 0 1.15rem;
}

.button {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0.82rem 1.15rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 700;
  transition: transform 250ms cubic-bezier(0.2, 0.8, 0.2, 1), background 250ms ease, box-shadow 250ms ease, border-color 250ms ease;
}

.button:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 8px 25px rgba(87, 216, 165, 0.25);
}

.button--solid {
  color: #ffffff;
  background: var(--accent);
  border-color: transparent;
  box-shadow: 0 6px 20px rgba(111, 223, 175, 0.12);
}

.button--ghost {
  background: transparent;
  border-color: var(--accent);
  color: var(--accent);
}

.hero__facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.hero__facts article {
  padding: 0.95rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--line);
}

.hero__facts span {
  display: block;
  margin-bottom: 0.35rem;
  color: rgba(255,255,255,0.78);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.72rem;
}

.hero__facts strong {
  color: var(--text-dark);
  line-height: 1.35;
}

.hero__gallery {
  display: grid;
  grid-template-columns: 1fr 0.75fr 1fr;
  gap: 0.9rem;
}

.hero__gallery--minimal {
  grid-template-columns: 1fr;
  align-content: start;
}

.hero-frame {
  display: grid;
  gap: 0.7rem;
  padding: 1.5rem;
  min-height: 12rem;
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--line);
}

.hero-frame h2,
.hero-frame h3 {
  margin: 0;
  font-family: "Playfair Display", serif;
  letter-spacing: -0.02em;
}

.hero-frame h2 {
  font-size: clamp(1.8rem, 3vw, 3rem);
  max-width: 10ch;
}

.hero-frame h3 {
  font-size: 1.4rem;
  max-width: 14ch;
}

.hero-frame p {
  margin: 0;
  max-width: 34rem;
  color: var(--muted);
  line-height: 1.7;
}

.hero-frame--accent {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(255, 255, 255, 0.01));
}

.mosaic {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.02);
}

.mosaic::before,
.mosaic::after,
.mosaic__tile::after,
.mosaic__image::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.mosaic::before {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.01), rgba(255, 255, 255, 0.02));
}

.mosaic--desktop {
  display: grid;
  gap: 1rem;
  padding: 1rem;
  align-content: center;
}

.mosaic__screen {
  min-height: 16.5rem;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: linear-gradient(135deg, rgba(16, 59, 56, 0.95), rgba(6, 34, 35, 0.98));
  position: relative;
  overflow: hidden;
}

.mosaic__screen::after {
  inset: auto 50% -1.4rem;
  width: 5.5rem;
  height: 1.4rem;
  transform: translateX(-50%);
  border-radius: 0 0 999px 999px;
  background: linear-gradient(180deg, #e8ede7, #cfd8d2);
}

.mosaic__screen-glow {
  background:
    radial-gradient(circle at 24% 32%, rgba(215, 239, 218, 0.18), transparent 18%),
    radial-gradient(circle at 62% 58%, rgba(32, 157, 87, 0.18), transparent 22%),
    linear-gradient(125deg, rgba(255, 255, 255, 0.01), transparent 58%);
}

.mosaic__plant {
  background:
    radial-gradient(circle at 17% 22%, rgba(201, 230, 205, 0.82) 0 2.8%, transparent 3%),
    radial-gradient(circle at 28% 32%, rgba(104, 164, 87, 0.9) 0 4%, transparent 4.2%),
    radial-gradient(circle at 44% 26%, rgba(60, 122, 72, 0.9) 0 4.2%, transparent 4.4%),
    radial-gradient(circle at 61% 36%, rgba(82, 141, 108, 0.66) 0 5.2%, transparent 5.4%),
    radial-gradient(circle at 72% 46%, rgba(37, 106, 88, 0.45) 0 7%, transparent 7.2%),
    linear-gradient(180deg, rgba(9, 51, 43, 0.2), rgba(9, 51, 43, 0.42));
}

.mosaic__caption {
  display: grid;
  gap: 0.15rem;
  padding-inline: 0.05rem;
}

.mosaic__caption strong {
  font-family: "Playfair Display", serif;
  font-size: 1.15rem;
}

.mosaic__caption span {
  color: var(--muted);
}

.mosaic--vertical {
  background: rgba(255, 255, 255, 0.02);
  padding: 1rem;
}

.mosaic__stack {
  display: grid;
  gap: 0.85rem;
}

.mosaic__image {
  min-height: 5rem;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  background: linear-gradient(135deg, rgba(9, 49, 50, 0.96), rgba(25, 103, 74, 0.5));
  border: 1px solid var(--line);
}

.mosaic__image--1 {
  min-height: 8.6rem;
  background:
    radial-gradient(circle at 22% 26%, rgba(210, 236, 212, 0.7), transparent 15%),
    radial-gradient(circle at 65% 38%, rgba(35, 126, 84, 0.38), transparent 24%),
    linear-gradient(135deg, rgba(12, 56, 47, 0.96), rgba(27, 89, 63, 0.68));
}

.mosaic__image--2 {
  background:
    radial-gradient(circle at 68% 30%, rgba(214, 235, 210, 0.45), transparent 18%),
    radial-gradient(circle at 32% 70%, rgba(31, 157, 87, 0.18), transparent 22%),
    linear-gradient(135deg, rgba(10, 49, 49, 0.94), rgba(44, 121, 82, 0.46));
}

.mosaic__image--3 {
  min-height: 8rem;
  background:
    radial-gradient(circle at 40% 24%, rgba(230, 243, 230, 0.45), transparent 14%),
    radial-gradient(circle at 64% 64%, rgba(32, 157, 87, 0.2), transparent 22%),
    linear-gradient(135deg, rgba(7, 39, 40, 0.96), rgba(16, 72, 55, 0.58));
}

.mosaic--tiles {
  display: grid;
  grid-template-columns: 1.05fr 0.78fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 0.85rem;
}

.mosaic__tile {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(12, 52, 52, 0.98), rgba(29, 96, 70, 0.5));
  border: 1px solid var(--line);
}

.mosaic__tile--wide {
  grid-column: 1 / 3;
  background:
    radial-gradient(circle at 20% 78%, rgba(31, 157, 87, 0.22), transparent 16%),
    radial-gradient(circle at 62% 28%, rgba(209, 234, 208, 0.12), transparent 24%),
    linear-gradient(135deg, rgba(8, 46, 47, 0.97), rgba(37, 95, 68, 0.42));
}

.mosaic__tile--tall {
  grid-column: 3;
  grid-row: 1 / 3;
  background:
    radial-gradient(circle at 54% 18%, rgba(239, 244, 234, 0.28), transparent 12%),
    radial-gradient(circle at 28% 70%, rgba(31, 157, 87, 0.18), transparent 18%),
    linear-gradient(135deg, rgba(7, 38, 39, 0.98), rgba(15, 72, 55, 0.4));
}

.mosaic__tile--square {
  background:
    radial-gradient(circle at 74% 32%, rgba(31, 157, 87, 0.22), transparent 18%),
    radial-gradient(circle at 28% 72%, rgba(209, 234, 208, 0.1), transparent 24%),
    linear-gradient(135deg, rgba(11, 50, 45, 0.96), rgba(42, 86, 57, 0.38));
}

.mosaic__tile--accent {
  background: linear-gradient(135deg, rgba(206, 228, 212, 0.16), rgba(23, 95, 70, 0.12));
}

.about-grid,
.offerings-grid,
.split-layout,
.leadership-grid,
.contact-layout,
.accordion-grid,
.feature-grid,
.detail-grid,
.timeline,
.contact-cards {
  display: grid;
  gap: 0.9rem;
}

.about-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.about-grid > :first-child {
  grid-column: span 2;
}

.stat-card,
.feature-card,
.accordion-card,
.contact-card,
.coming-soon-card {
  padding: 1.1rem;
  background: var(--panel);
  border: 1px solid var(--line);
}

.stat-card span,
.coming-soon-card span,
.contact-card span {
  color: var(--accent-soft);
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-size: 0.7rem;
}

.stat-card strong,
.contact-card strong,
.coming-soon-card strong,
.feature-card strong {
  display: block;
  margin: 0.55rem 0 0.35rem;
  font-family: "Playfair Display", serif;
  font-size: 1.02rem;
}

.offerings-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.offering-card {
  grid-column: span 4;
  padding: 1.25rem;
  background: var(--panel);
  color: var(--text-dark);
  border: 1px solid var(--line);
}

.offering-card--wide {
  grid-column: span 6;
}

.offering-card__tag {
  color: var(--accent);
}

.offering-card h3 {
  margin-top: 0.6rem;
  margin-bottom: 0.5rem;
  font-size: 1.45rem;
}

.offering-card p {
  margin: 0;
  line-height: 1.65;
  color: var(--muted);
}

.showcase__rail {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  gap: 1rem;
  align-items: center;
}

.carousel {
  padding: 1.1rem;
  background: var(--panel);
  border: 1px solid var(--line);
}

.carousel__slides {
  position: relative;
  min-height: 13.5rem;
}

.carousel__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 260ms ease, transform 260ms ease;
  padding: 1.1rem;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(10, 54, 55, 0.92), rgba(8, 43, 44, 0.96));
}

.carousel__slide.is-active {
  opacity: 1;
  transform: translateY(0);
}

.carousel__slide h3 {
  margin-top: 0.55rem;
  margin-bottom: 0.4rem;
  font-size: 1.9rem;
}

.carousel__slide p {
  max-width: 34rem;
  color: var(--muted);
  line-height: 1.7;
}

.carousel__controls {
  display: flex;
  gap: 0.45rem;
  margin-top: 0.95rem;
}

.carousel__dot {
  width: 0.7rem;
  height: 0.7rem;
  border-radius: 50%;
  border: 0;
  background: rgba(255, 255, 255, 0.06);
  cursor: pointer;
}

.carousel__dot.is-active {
  background: linear-gradient(135deg, #e8f1df, #b8dcc0);
  box-shadow: 0 0 0 4px rgba(232, 241, 223, 0.08);
}

.program-intro {
  margin-bottom: 1rem;
}

.program-intro p {
  margin: 0;
  line-height: 1.75;
  color: rgba(247, 250, 248, 0.8);
}

.accordion-card {
  overflow: hidden;
  padding: 0;
}

.accordion-card summary {
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 0.6rem 1rem;
  align-items: center;
  padding: 1rem 1.1rem;
}

.accordion-card summary::-webkit-details-marker {
  display: none;
}

.accordion-card strong {
  font-family: "Playfair Display", serif;
  font-size: 1.05rem;
}

.accordion-card__chevron {
  width: 1.9rem;
  height: 1.9rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.02);
  transition: transform 160ms ease;
}

.accordion-card[open] .accordion-card__chevron {
  transform: rotate(45deg);
}

.accordion-card__body {
  padding: 0 1.1rem 1.1rem;
}

.detail-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 1rem;
}

.detail-grid h3 {
  margin: 0 0 0.45rem;
  font-size: 1rem;
}

.detail-grid ul {
  margin: 0;
  padding-left: 1.1rem;
  color: rgba(247, 250, 248, 0.8);
  line-height: 1.7;
}

.detail-grid p {
  color: rgba(247, 250, 248, 0.8);
  line-height: 1.65;
}

.split-layout {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  align-items: start;
}

.split-layout--reverse {
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
}

.feature-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.feature-card {
  min-height: 7.75rem;
}

.timeline div {
  padding: 1rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.02);
}

.timeline span {
  color: var(--accent-soft);
  font-weight: 800;
  letter-spacing: 0.14em;
  font-size: 0.72rem;
}

.timeline strong {
  display: block;
  margin: 0.4rem 0 0.3rem;
  font-family: "Playfair Display", serif;
}

.redirect-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.35rem;
}

.redirect-card span {
  color: var(--accent-soft);
  font-weight: 700;
}

.leadership-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.95fr);
}

.coming-soon-card {
  background: rgba(255, 255, 255, 0.02);
}

.contact-layout {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
}

.contact-form {
  display: grid;
  gap: 0.85rem;
}

.contact-form label {
  display: grid;
  gap: 0.45rem;
  font-weight: 700;
  color: var(--text-dark);
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 0.95rem 1rem;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text-dark);
  outline: none;
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: color-mix(in srgb, var(--accent) 60%, #000 40%);
  box-shadow: 0 0 0 3px rgba(87, 216, 165, 0.08);
}

.contact-cards {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-card--accent {
  background: linear-gradient(180deg, rgba(206, 228, 212, 0.12), rgba(255, 255, 255, 0.02));
}

.footer {
  width: min(1320px, calc(100% - 2rem));
  margin: 0 auto 1.4rem;
  padding-top: 0.85rem;
  color: var(--muted);
  border-top: 1px solid var(--line);
}

@media (max-width: 1100px) {
  .hero,
  .section__header,
  .showcase__rail,
  .split-layout,
  .split-layout--reverse,
  .leadership-grid,
  .contact-layout {
    grid-template-columns: 1fr;
  }

  .hero__gallery {
    grid-template-columns: 1fr 1fr;
  }

  .hero__gallery--minimal {
    grid-template-columns: 1fr;
  }

  .mosaic--tiles {
    grid-template-columns: 1fr 1fr;
  }

  .mosaic__tile--tall {
    grid-column: 2;
    grid-row: 1 / 3;
  }

  .about-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-grid > :first-child {
    grid-column: 1 / -1;
  }

  .offerings-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .offering-card,
  .offering-card--wide {
    grid-column: auto;
  }
}

@media (max-width: 760px) {
  .topbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .topnav {
    justify-content: flex-start;
  }

  main {
    width: min(100% - 1rem, 1320px);
    padding-top: 0.75rem;
  }

  .hero__facts,
  .hero__gallery,
  .about-grid,
  .offerings-grid,
  .feature-grid,
  .contact-cards,
  .detail-grid {
    grid-template-columns: 1fr;
  }

  .mosaic--tiles,
  .mosaic__tile--wide,
  .mosaic__tile--tall,
  .mosaic__tile--square {
    grid-column: auto;
    grid-row: auto;
  }

  .redirect-card {
    flex-direction: column;
    align-items: flex-start;
  }
}
.stat-card:hover, .feature-card:hover, .offering-card:hover, .contact-card:hover, .accordion-card:hover, .coming-soon-card:hover, .redirect-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.4);
  border-color: rgba(87, 216, 165, 0.35);
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
.section {
  animation: fadeUp 0.8s cubic-bezier(0.2, 0.8, 0.2, 1) both;
}
.section:nth-child(2) { animation-delay: 0.1s; }
.section:nth-child(3) { animation-delay: 0.2s; }
.section:nth-child(4) { animation-delay: 0.3s; }
