/* GHNA public site */
:root {
  --color-bg: #f4f7f5;
  --color-surface: #ffffff;
  --color-text: #16281c;
  --color-muted: #556b5f;
  --color-accent: #0d7a4f;
  --color-accent-dark: #095c3b;
  --color-accent-soft: rgba(13, 122, 79, 0.09);
  --color-footer: #0f2418;
  --color-footer-text: #c8d9ce;
  --font-sans: "Segoe UI", system-ui, -apple-system, sans-serif;
  --shadow: 0 1px 3px rgba(15, 36, 24, 0.07);
  --shadow-md: 0 4px 14px rgba(15, 36, 24, 0.1);
  --shadow-lg: 0 8px 28px rgba(15, 36, 24, 0.12);
  --radius: 12px;
  --nav-flyout-shadow:
    0 2px 4px rgba(15, 36, 24, 0.04),
    0 20px 48px -12px rgba(15, 36, 24, 0.2);
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --wrap: 1100px;
  --header-sticky-offset: 4.65rem;
  --fec-ink: #0a0a0a;
  --fec-orange: #f58220;
  --fec-white: #ffffff;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

[id^="a-"],
[id^="e-"],
[id^="l-"],
[id^="hub-"],
#who-we-are,
#why-green-hydrogen,
#alignment,
#mission-vision,
#home,
#homepage-teaser,
#home-value-proposition,
#home-focus-areas,
#home-featured-programs,
#home-news-events,
#home-cta,
#events-calendar,
#events-news {
  scroll-margin-top: var(--header-sticky-offset);
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-bg);
}

body.theme-acep {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.is-page-loading {
  overflow: hidden;
}

.page-load {
  position: fixed;
  inset: 0;
  z-index: 200000;
  display: grid;
  place-items: center;
  pointer-events: auto;
  transition:
    opacity 0.42s var(--ease-out),
    visibility 0.42s var(--ease-out);
}

.page-load__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.86);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

body.theme-acep .page-load__backdrop {
  background: rgba(10, 31, 20, 0.9);
}

.page-load__spin {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.page-load__logo {
  display: block;
  width: auto;
  height: clamp(4.25rem, 16vw, 8rem);
  max-width: min(88vw, 280px);
  object-fit: contain;
  animation: page-load-logo-rotate 3.2s linear infinite;
  filter: drop-shadow(0 10px 32px rgba(15, 36, 24, 0.22));
}

body.theme-acep .page-load__logo {
  filter: drop-shadow(0 12px 36px rgba(0, 0, 0, 0.45));
}

.page-load__logo--icon {
  height: clamp(3.5rem, 12vw, 5.5rem);
  max-width: min(28vw, 5.5rem);
}

.page-load.page-load--done {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

@keyframes page-load-logo-rotate {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .page-load__logo {
    animation: none;
  }

  .page-load {
    transition-duration: 0.15s;
  }
}

@media (scripting: none) {
  .page-load {
    display: none !important;
  }

  body.is-page-loading {
    overflow: visible;
  }
}

.skip-link {
  position: absolute;
  left: -999px;
  top: 0;
  z-index: 1000;
  padding: 0.75rem 1rem;
  background: var(--color-accent);
  color: #fff;
  text-decoration: none;
}

.skip-link:focus {
  left: 0;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.wrap {
  width: min(100% - 2rem, var(--wrap));
  margin-inline: auto;
}

.site-header {
  background: var(--color-surface);
  box-shadow: 0 1px 0 rgba(15, 36, 24, 0.06), 0 4px 20px rgba(15, 36, 24, 0.06);
  position: sticky;
  top: 0;
  z-index: 100;
  transition:
    box-shadow 0.45s var(--ease-out),
    background 0.35s ease;
}

.site-header.site-header--elevated {
  box-shadow:
    0 1px 0 rgba(15, 36, 24, 0.08),
    0 12px 36px rgba(15, 36, 24, 0.1);
}

.site-header__inner {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 0;
}

.site-header__brand-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  min-height: 3.1rem;
  padding: 0.42rem 0;
}

.site-logo {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  color: var(--color-text);
  font-weight: 700;
  font-size: 0.94rem;
  line-height: 1.2;
  max-width: min(100%, 520px);
  flex: 1 1 auto;
  min-width: 0;
}

.site-logo__mark {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.site-logo__img {
  display: block;
  height: 38px;
  width: auto;
  max-width: min(132px, 28vw);
  object-fit: contain;
}

/* Full horizontal wordmark (~2:1) — assets/branding/logo-ghna.png; tighter when site name sits beside */
.site-logo--wordmark .site-logo__img {
  height: clamp(38px, 5.2vw, 54px);
  max-width: min(300px, 72vw);
}

.site-logo__name {
  color: var(--color-accent-dark);
  font-weight: 700;
  font-size: clamp(0.8rem, 2vw, 0.95rem);
  line-height: 1.2;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

/* Hamburger — mobile / narrow */
.nav-toggle {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.55rem;
  height: 2.55rem;
  padding: 0;
  border: 1px solid rgba(13, 122, 79, 0.25);
  border-radius: 8px;
  background: var(--color-surface);
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}

.nav-toggle:hover,
.nav-toggle:focus-visible {
  background: rgba(13, 122, 79, 0.06);
  border-color: var(--color-accent);
  outline: none;
}

.nav-toggle[aria-expanded="true"] {
  background: rgba(13, 122, 79, 0.1);
  border-color: var(--color-accent-dark);
}

.nav-toggle__icon {
  display: block;
  width: 1.25rem;
  height: 2px;
  background: var(--color-accent-dark);
  border-radius: 1px;
  position: relative;
  transition: background 0.2s;
}

.nav-toggle__icon::before,
.nav-toggle__icon::after {
  content: "";
  position: absolute;
  left: 0;
  width: 1.25rem;
  height: 2px;
  background: var(--color-accent-dark);
  border-radius: 1px;
  transition: transform 0.2s;
}

.nav-toggle__icon::before {
  top: -6px;
}

.nav-toggle__icon::after {
  top: 6px;
}

.nav-toggle[aria-expanded="true"] .nav-toggle__icon {
  background: transparent;
}

.nav-toggle[aria-expanded="true"] .nav-toggle__icon::before {
  top: 0;
  transform: rotate(45deg);
}

.nav-toggle[aria-expanded="true"] .nav-toggle__icon::after {
  top: 0;
  transform: rotate(-45deg);
}

/* Primary navigation (dropdown menus) */
body.theme-acep .site-nav {
  font-family: var(--font-ui, var(--font-sans));
}

.site-nav {
  width: 100%;
}

.site-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  border-top: 1px solid rgba(13, 122, 79, 0.1);
}

.site-nav__item {
  margin: 0;
  border-bottom: 1px solid rgba(13, 122, 79, 0.07);
}

.site-nav__item:last-child {
  border-bottom: none;
}

.site-nav__item--has-sub {
  position: relative;
}

.site-nav__top {
  display: flex;
  align-items: stretch;
  width: 100%;
  gap: 0;
}

.site-nav__link--parent {
  flex: 1 1 auto;
  min-width: 0;
  text-align: left;
}

.site-nav__megatoggle {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.45rem;
  margin: 0;
  padding: 0;
  border: none;
  border-left: 1px solid rgba(13, 122, 79, 0.12);
  background: transparent;
  cursor: pointer;
  color: inherit;
  transition:
    color 0.2s var(--ease-out),
    background 0.2s ease;
}

.site-nav__megatoggle-icon {
  display: block;
  width: 0.45rem;
  height: 0.45rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  margin-top: -0.2rem;
  opacity: 0.55;
  transition: transform 0.28s var(--ease-out), opacity 0.2s ease;
}

.site-nav__item--has-sub.is-sub-open > .site-nav__top .site-nav__megatoggle-icon {
  transform: rotate(225deg);
  margin-top: 0.1rem;
  opacity: 0.9;
}

.site-nav__megatoggle:hover,
.site-nav__megatoggle:focus-visible {
  color: var(--color-accent-dark);
  background: var(--color-accent-soft);
  outline: none;
}

.site-nav__megatoggle:focus-visible {
  box-shadow: inset 0 0 0 2px var(--color-accent);
}

.site-nav__item--has-sub.is-active-group > .site-nav__top .site-nav__link--parent {
  color: var(--color-accent-dark);
  border-left-color: var(--color-accent);
  background: rgba(13, 122, 79, 0.08);
  padding-left: 0.75rem;
}

.site-nav__sub {
  list-style: none;
  margin: 0;
  padding: 0.1rem 0 0.55rem 0.7rem;
  display: none;
}

.site-nav__sub-item {
  margin: 0;
}

.site-nav__sub-item + .site-nav__sub-item {
  margin-top: 0.15rem;
}

.site-nav__sub-link {
  display: block;
  padding: 0.5rem 0.55rem 0.5rem 0.65rem;
  font-size: 0.93rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.012em;
  color: var(--color-text);
  text-decoration: none;
  border-radius: 9px;
  border-left: 3px solid transparent;
  transition:
    background 0.18s ease,
    color 0.18s ease,
    border-color 0.18s ease;
}

.site-nav__sub-link:hover,
.site-nav__sub-link:focus-visible {
  background: var(--color-accent-soft);
  color: var(--color-accent-dark);
  outline: none;
}

.site-nav__sub-link:focus-visible {
  border-left-color: var(--color-accent);
  box-shadow: 0 0 0 1px rgba(13, 122, 79, 0.18);
}

.site-nav__sub-link.is-active {
  font-weight: 700;
  color: var(--color-accent-dark);
  background: rgba(13, 122, 79, 0.12);
  border-left-color: var(--color-accent);
}

.site-nav__sub-link--cta {
  margin-top: 0.4rem;
  margin-right: 0.35rem;
  padding: 0.52rem 0.85rem;
  text-align: center;
  border-radius: 8px;
  font-size: 0.9rem;
  border-left: none !important;
  background: linear-gradient(168deg, #0d8f5f 0%, var(--color-accent) 42%, var(--color-accent-dark) 100%);
  color: #fff !important;
  font-weight: 600;
  letter-spacing: 0.03em;
  box-shadow: 0 2px 10px rgba(13, 122, 79, 0.38);
}

.site-nav__sub-link--cta:hover,
.site-nav__sub-link--cta:focus-visible {
  background: linear-gradient(168deg, var(--color-accent-dark) 0%, #074830 100%);
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(9, 92, 59, 0.45);
}

.site-nav__sub-link--cta:focus-visible {
  box-shadow:
    0 0 0 2px #fff,
    0 0 0 4px var(--color-accent),
    0 4px 16px rgba(9, 92, 59, 0.4);
}

@media (max-width: 880px) {
  .site-nav__item--has-sub.is-sub-open > .site-nav__sub {
    display: block;
  }
}

.site-nav__link {
  display: block;
  color: var(--color-text);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.94rem;
  letter-spacing: 0.015em;
  padding: 0.65rem 0.15rem;
  border-left: 3px solid transparent;
  transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.site-nav__link:hover,
.site-nav__link:focus-visible {
  color: var(--color-accent-dark);
  background: var(--color-accent-soft);
  outline: none;
}

.site-nav__link:focus-visible {
  border-radius: 8px;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--color-accent);
}

.site-nav__link.is-active {
  color: var(--color-accent-dark);
  border-left-color: var(--color-accent);
  background: rgba(13, 122, 79, 0.08);
  padding-left: 0.75rem;
}

.site-nav__link--cta {
  margin: 0.5rem 0 0.75rem;
  padding: 0.65rem 1rem;
  text-align: center;
  border-radius: 8px;
  border: 1px solid var(--color-accent);
  border-left-width: 1px;
  background: var(--color-accent);
  color: #fff;
}

.site-nav__link--cta:hover,
.site-nav__link--cta:focus-visible {
  background: var(--color-accent-dark);
  color: #fff;
  border-color: var(--color-accent-dark);
}

.site-nav__link--cta.is-active {
  border-left-width: 1px;
  padding-left: 1rem;
  background: var(--color-accent-dark);
  color: #fff;
}

/* Mobile: panel hidden until open */
@media (max-width: 880px) {
  .site-nav:not(.is-open) {
    display: none;
  }

  .site-nav.is-open {
    display: block;
    padding: 0.28rem 0.45rem 0.72rem;
    margin-top: 0.12rem;
    background: linear-gradient(180deg, #fbfdfb 0%, #fff 55%);
    border: 1px solid rgba(13, 122, 79, 0.12);
    border-radius: 0 0 14px 14px;
    box-shadow: var(--nav-flyout-shadow);
  }
}

/* Desktop: horizontal bar, logo + site name left — links right */
@media (min-width: 881px) {
  .site-header__inner {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: clamp(0.55rem, 1.75vw, 1.5rem);
    min-height: 3.28rem;
    padding: 0.28rem 0;
  }

  .site-header__brand-row {
    min-height: unset;
    padding: 0;
    width: auto;
    flex: 0 1 auto;
    justify-content: flex-start;
  }

  .nav-toggle {
    display: none;
  }

  .site-nav {
    display: block !important;
    width: auto;
    flex: 0 0 auto;
    margin-left: auto;
  }

  .site-nav__list {
    flex-direction: row;
    align-items: stretch;
    flex-wrap: wrap;
    justify-content: flex-end;
    row-gap: 0.25rem;
    column-gap: clamp(0.35rem, 1.2vw, 0.85rem);
    border-top: none;
  }

  .site-logo--wordmark .site-logo__img {
    max-width: min(320px, 38vw);
  }

  .site-nav__item {
    border-bottom: none;
    display: flex;
    align-items: stretch;
  }

  .site-nav__link {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem clamp(0.5rem, 1vw, 0.92rem);
    border-left: none;
    border-radius: 5px;
    white-space: nowrap;
    font-size: 0.88rem;
    font-weight: 600;
  }

  .site-nav__top {
    display: inline-flex;
    width: auto;
    align-items: stretch;
  }

  .site-nav__link--parent {
    flex: 0 0 auto;
    border-left: none;
    border-radius: 5px;
  }

  .site-nav__megatoggle {
    display: none;
  }

  .site-nav__item--has-sub.is-active-group > .site-nav__top .site-nav__link--parent {
    border-left: none;
    padding-left: clamp(0.5rem, 1vw, 0.92rem);
    box-shadow: inset 0 -2px 0 var(--color-accent);
    background: rgba(13, 122, 79, 0.1);
  }

  .site-nav__link:hover,
  .site-nav__link:focus-visible,
  .site-nav__link--parent:hover,
  .site-nav__link--parent:focus-visible {
    background: rgba(13, 122, 79, 0.07);
  }

  .site-nav__link.is-active {
    background: rgba(13, 122, 79, 0.11);
    color: var(--color-accent-dark);
    box-shadow: inset 0 -2px 0 var(--color-accent);
  }

  .site-nav__item--has-sub::after {
    content: "";
    position: absolute;
    left: 0.15rem;
    right: 0.15rem;
    top: 100%;
    height: 0.4rem;
    z-index: 199;
  }

  .site-nav__sub {
    position: absolute;
    top: calc(100% + 0.18rem);
    left: 50%;
    transform: translate3d(-50%, 8px, 0);
    min-width: min(18.5rem, calc(100vw - 2rem));
    max-width: min(20rem, 94vw);
    max-height: min(70vh, 26rem);
    overflow-x: hidden;
    overflow-y: auto;
    padding: 0.35rem;
    margin: 0;
    display: block;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(13, 122, 79, 0.11);
    border-radius: 11px;
    border-top: 2px solid var(--color-accent);
    box-shadow: var(--nav-flyout-shadow);
    z-index: 200;
    scrollbar-width: thin;
    scrollbar-color: rgba(13, 122, 79, 0.35) transparent;
    transition:
      opacity 0.22s var(--ease-out),
      transform 0.24s var(--ease-out),
      visibility 0.22s;
  }

  .site-nav__item--has-sub:hover > .site-nav__sub,
  .site-nav__item--has-sub:focus-within > .site-nav__sub {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    transform: translate3d(-50%, 0, 0);
  }

  .site-nav__sub-item + .site-nav__sub-item {
    margin-top: 0;
    border-top: 1px solid rgba(13, 122, 79, 0.07);
  }

  .site-nav__sub-link {
    padding: 0.45rem 0.72rem 0.45rem 0.78rem;
    font-size: 0.88rem;
    white-space: normal;
  }

  .site-nav__sub-link--cta {
    margin: 0.3rem 0.35rem 0.3rem;
    padding: 0.48rem 0.78rem;
    font-size: 0.88rem;
  }
}

/* Institute shell: slim bar nav — uppercase labels, violet accent */
body.theme-acep .site-nav__link,
body.theme-acep .site-nav__link--parent {
  text-transform: uppercase;
  letter-spacing: 0.09em;
  font-weight: 700;
  color: #374151;
}

body.theme-acep .site-nav__link:hover,
body.theme-acep .site-nav__link:focus-visible,
body.theme-acep .site-nav__link--parent:hover,
body.theme-acep .site-nav__link--parent:focus-visible {
  color: var(--acep-nav-active);
  background: rgba(147, 51, 234, 0.07);
}

body.theme-acep .site-nav__link.is-active,
body.theme-acep .site-nav__link--parent.is-active {
  color: var(--acep-nav-active);
  border-left-color: var(--acep-nav-active);
  background: rgba(147, 51, 234, 0.09);
}

body.theme-acep .site-nav__item--has-sub.is-active-group > .site-nav__top .site-nav__link--parent {
  color: var(--acep-nav-active);
  border-left-color: var(--acep-nav-active);
  background: rgba(147, 51, 234, 0.09);
}

@media (min-width: 881px) {
  body.theme-acep .site-nav__link,
  body.theme-acep .site-nav__link--parent {
    font-size: 0.82rem;
    letter-spacing: 0.1em;
    color: #1f2937;
  }

  body.theme-acep .site-nav__link.is-active,
  body.theme-acep .site-nav__link--parent.is-active {
    background: transparent;
    box-shadow: none;
    color: var(--acep-nav-active);
  }

  body.theme-acep .site-nav__item--has-sub.is-active-group > .site-nav__top .site-nav__link--parent {
    background: transparent;
    box-shadow: none;
    color: var(--acep-nav-active);
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-nav__megatoggle-icon,
  .site-nav__sub {
    transition: none !important;
  }

  .site-nav__item--has-sub:hover > .site-nav__sub,
  .site-nav__item--has-sub:focus-within > .site-nav__sub {
    transform: translate3d(-50%, 0, 0);
  }
}

.site-main {
  min-height: 50vh;
  padding-bottom: 3rem;
}

.not-found-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

.hero {
  background: linear-gradient(135deg, #0f3d28 0%, var(--color-accent) 55%, #1a6b47 100%);
  color: #fff;
  padding: 3.5rem 0 4rem;
}

.hero__inner {
  max-width: 720px;
}

.hero h1 {
  margin: 0 0 1rem;
  font-size: clamp(1.85rem, 4vw, 2.5rem);
  line-height: 1.15;
  font-weight: 700;
}

.hero__tagline {
  font-size: 1.15rem;
  opacity: 0.95;
  margin: 0 0 1.5rem;
}

.btn {
  display: inline-block;
  padding: 0.65rem 1.25rem;
  border-radius: var(--radius);
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  font: inherit;
  transition:
    transform 0.22s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.22s ease,
    background 0.22s ease,
    color 0.22s ease,
    filter 0.22s ease;
}

.btn:active {
  transform: translateY(1px);
}

.btn--light {
  background: #fff;
  color: var(--color-accent-dark);
}

.btn--light:hover,
.btn--light:focus-visible {
  background: #e8f5ef;
}

.btn--primary {
  background: var(--color-accent);
  color: #fff;
}

.btn--primary:hover,
.btn--primary:focus-visible {
  background: var(--color-accent-dark);
}

.btn--lg {
  padding: 0.82rem 1.65rem;
  font-size: 1.05rem;
}

.section {
  padding: 3rem 0;
}

.section__title {
  margin: 0 0 1.5rem;
  font-size: clamp(1.45rem, 3.5vw, 1.85rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-accent-dark);
}

/* Page H1 accent — add class .section__title--ruled on main headings only */
.section__title--ruled::after {
  content: "";
  display: block;
  width: 2.85rem;
  height: 3px;
  margin-top: 0.55rem;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--color-accent) 0%, rgba(13, 122, 79, 0.2) 100%);
}

.contact-hero__title--ruled::after {
  content: "";
  display: block;
  width: 2.85rem;
  height: 3px;
  margin-top: 0.55rem;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(167, 243, 208, 0.95) 0%, rgba(255, 255, 255, 0.28) 100%);
}

.hub-page__micro {
  margin: -0.35rem 0 1.1rem;
  max-width: 44rem;
  font-size: 0.94rem;
  line-height: 1.55;
  color: var(--color-muted);
  font-weight: 500;
}

.contact-hero__micro {
  margin: -0.25rem 0 0.85rem;
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.82);
  max-width: 40rem;
}

.section--surface {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.97) 0%, var(--color-surface) 12rem, var(--color-surface) 100%),
    var(--color-surface);
  border-bottom: 1px solid rgba(13, 122, 79, 0.06);
}

body.theme-acep .section__title {
  letter-spacing: -0.025em;
}

/* Partner hub landing (partner.php) */
.partner-hub__inner {
  max-width: 52rem;
}

.partner-hub__lead {
  max-width: 40rem;
}

.partner-hub__grid {
  list-style: none;
  margin: 2rem 0 0;
  padding: 0;
  display: grid;
  gap: 1.15rem;
  grid-template-columns: 1fr;
}

@media (min-width: 700px) {
  .partner-hub__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }
}

.partner-hub__card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1.35rem 1.3rem 1.4rem;
  text-decoration: none;
  color: inherit;
  background: linear-gradient(165deg, #fff 0%, #f8faf9 100%);
  border: 1px solid rgba(13, 122, 79, 0.14);
  border-radius: calc(var(--radius) + 2px);
  box-shadow: 0 2px 12px rgba(15, 36, 24, 0.06);
  transition:
    transform 0.26s var(--ease-out),
    box-shadow 0.26s ease,
    border-color 0.22s ease;
}

.partner-hub__card:hover,
.partner-hub__card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(13, 122, 79, 0.32);
  box-shadow: 0 14px 36px rgba(15, 36, 24, 0.12);
  outline: none;
}

.partner-hub__card:focus-visible {
  box-shadow:
    0 14px 36px rgba(15, 36, 24, 0.12),
    0 0 0 2px #fff,
    0 0 0 4px var(--color-accent);
}

.partner-hub__card-kicker {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 0.45rem;
}

.partner-hub__card-title {
  margin: 0 0 0.55rem;
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1.25;
  color: var(--color-accent-dark);
  letter-spacing: -0.02em;
}

.partner-hub__card-text {
  margin: 0 0 1rem;
  flex: 1 1 auto;
  font-size: 0.96rem;
  line-height: 1.58;
  color: var(--color-muted);
}

.partner-hub__card-cta {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--color-accent-dark);
}

.partner-hub__card:hover .partner-hub__card-cta,
.partner-hub__card:focus-visible .partner-hub__card-cta {
  color: var(--color-accent);
}

.partner-hub__more {
  margin: 2rem 0 0;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--color-muted);
}

body.theme-acep .partner-hub__card-title {
  font-family: var(--font-ui, var(--font-sans));
}

/* Hub pages — quick jump card grid */
.hub-jump {
  margin: 0 0 2rem;
  padding: 0 0 1.5rem;
  border-bottom: 1px solid rgba(13, 122, 79, 0.09);
}

.hub-jump__heading {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--color-accent-dark);
}

.hub-jump__intro {
  margin: 0 0 1rem;
  max-width: 40rem;
  font-size: 0.94rem;
  line-height: 1.55;
  color: var(--color-muted);
}

.hub-jump__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.75rem;
  grid-template-columns: 1fr;
}

@media (min-width: 520px) {
  .hub-jump__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 900px) {
  .hub-jump__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
  }
}

.hub-jump__card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  height: 100%;
  padding: 0.95rem 1rem 0.85rem;
  text-decoration: none;
  color: inherit;
  background: linear-gradient(165deg, #fdfefe 0%, #f5faf7 100%);
  border: 1px solid rgba(13, 122, 79, 0.12);
  border-radius: 10px;
  box-shadow: 0 1px 4px rgba(15, 36, 24, 0.04);
  transition:
    transform 0.22s var(--ease-out),
    border-color 0.2s ease,
    box-shadow 0.22s ease;
  position: relative;
  padding-right: 1.75rem;
}

.hub-jump__card:hover,
.hub-jump__card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(13, 122, 79, 0.28);
  box-shadow: 0 8px 24px rgba(15, 36, 24, 0.09);
  outline: none;
}

.hub-jump__card:focus-visible {
  box-shadow:
    0 8px 24px rgba(15, 36, 24, 0.09),
    0 0 0 2px #fff,
    0 0 0 4px var(--color-accent);
}

.hub-jump__card-title {
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.3;
  color: var(--color-accent-dark);
  letter-spacing: -0.015em;
}

.hub-jump__card-sum {
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--color-muted);
  font-weight: 500;
}

.hub-jump__card-go {
  position: absolute;
  right: 0.65rem;
  bottom: 0.65rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-accent);
  opacity: 0.75;
}

.hub-jump__card:hover .hub-jump__card-go,
.hub-jump__card:focus-visible .hub-jump__card-go {
  opacity: 1;
}

body.theme-acep .hub-jump__card-title {
  font-family: var(--font-ui, var(--font-sans));
}

/* Social proof / reach band */
.social-proof-band {
  margin: 0;
  padding: 2rem 0;
  background: linear-gradient(105deg, rgba(13, 122, 79, 0.09) 0%, rgba(13, 122, 79, 0.03) 45%, rgba(21, 101, 192, 0.06) 100%);
  border-top: 1px solid rgba(13, 122, 79, 0.08);
  border-bottom: 1px solid rgba(13, 122, 79, 0.08);
}

.social-proof-band__inner {
  text-align: center;
  max-width: 44rem;
  margin-inline: auto;
}

.social-proof-band__quote {
  margin: 0 0 1.15rem;
  padding: 0;
  border: none;
  font-size: clamp(1rem, 2.2vw, 1.12rem);
  line-height: 1.55;
  font-weight: 600;
  color: var(--color-text);
}

.social-proof-band__quote p {
  margin: 0;
}

.social-proof-band__chips {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.45rem 0.55rem;
}

.social-proof-band__chip {
  margin: 0;
  padding: 0.32rem 0.65rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-accent-dark);
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(13, 122, 79, 0.15);
  border-radius: 999px;
}

.social-proof-band__social {
  list-style: none;
  margin: 1.35rem 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.45rem 1.1rem;
}

.social-proof-band__social li {
  margin: 0;
}

.social-proof-band__social a {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-accent-dark);
  text-decoration: none;
}

.social-proof-band__social a:hover,
.social-proof-band__social a:focus-visible {
  text-decoration: underline;
}

body.theme-acep .social-proof-band__quote {
  font-family: var(--font-ui, var(--font-sans));
}

.is-home .social-proof-band {
  margin-top: 0;
}

.grid-cards {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.card {
  background: var(--color-surface);
  border-radius: var(--radius);
  padding: 1.35rem;
  box-shadow: var(--shadow);
  transition:
    transform 0.25s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.25s ease;
}

.card__meta {
  font-size: 0.9rem;
  color: var(--color-muted);
  margin: 0 0 0.5rem;
}

.card h3 {
  margin: 0 0 0.5rem;
  font-size: 1.15rem;
}

.card p {
  margin: 0;
  color: var(--color-muted);
}

.card__img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 8px;
  margin-bottom: 1rem;
}

.mission-vision {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.mission-vision article {
  position: relative;
  background: linear-gradient(180deg, #fff 0%, #fafcfb 100%);
  padding: 1.75rem 1.85rem;
  padding-top: calc(1.75rem + 2px);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  border: 1px solid rgba(13, 122, 79, 0.08);
  overflow: hidden;
}

.mission-vision article::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-accent) 0%, #1fa06a 45%, var(--color-accent-dark) 100%);
}

.mission-vision h2 {
  margin-top: 0;
  color: var(--color-accent-dark);
}

.leadership-tree {
  list-style: none;
  margin: 0;
  padding: 0;
}

.leadership-tree ul {
  list-style: none;
  margin: 0.75rem 0 0 1rem;
  padding: 0 0 0 1rem;
  border-left: 2px solid #c5ddcf;
}

.leadership-tree__card {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  background: var(--color-surface);
  padding: 1.25rem;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  margin-bottom: 0.75rem;
}

.leadership-tree__card--click {
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.2s, transform 0.15s;
}

.leadership-tree__card--click:hover,
.leadership-tree__card--click:focus-visible {
  box-shadow: 0 6px 24px rgba(15, 36, 24, 0.12);
  transform: translateY(-2px);
  outline: none;
}

.leadership-tree__hint {
  margin: 0.5rem 0 0;
  font-size: 0.9rem;
}

.card--click {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.2s, transform 0.15s;
}

.card--click:hover,
.card--click:focus-visible {
  box-shadow: 0 8px 28px rgba(15, 36, 24, 0.12);
  transform: translateY(-2px);
  outline: none;
}

.card--click .text-link {
  text-decoration: underline;
}

.card__footer-hint {
  margin: 0.75rem 0 0;
  font-size: 0.9rem;
}

.card__teaser {
  margin: 0.5rem 0 0;
  font-size: 0.94rem;
  line-height: 1.5;
  color: var(--color-muted);
}

.card__read-more {
  display: inline-block;
  margin-top: 0.75rem;
  padding: 0.38rem 0.95rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--color-accent-dark);
  line-height: 1.2;
  border-radius: 999px;
  border: 1px solid rgba(13, 122, 79, 0.35);
  background: var(--color-accent-soft);
}

.card--click:hover .card__read-more,
.card--click:focus-visible .card__read-more {
  border-color: rgba(13, 122, 79, 0.55);
  background: rgba(13, 122, 79, 0.14);
}

.leadership-tree__photo {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 50%;
  flex-shrink: 0;
}

.leadership-tree__role {
  font-weight: 700;
  color: var(--color-accent-dark);
  margin: 0 0 0.25rem;
}

.leadership-tree__name {
  margin: 0 0 0.5rem;
}

.leadership-tree__bio {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.95rem;
}

.form-group {
  margin-bottom: 1.25rem;
}

.form-group label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.35rem;
}

.form-group input,
.form-group textarea {
  width: 100%;
  max-width: 520px;
  padding: 0.6rem 0.75rem;
  border: 1px solid #c5ddcf;
  border-radius: 8px;
  font: inherit;
}

.form-group textarea {
  min-height: 140px;
  resize: vertical;
}

.form-honeypot {
  position: absolute;
  left: -9999px;
  height: 0;
  overflow: hidden;
}

.alert {
  padding: 1rem 1.25rem;
  border-radius: var(--radius);
  margin-bottom: 1.5rem;
}

.alert--success {
  background: #e3f4ea;
  color: var(--color-accent-dark);
}

.alert--error {
  background: #fce8e8;
  color: #8b1a1a;
}

.site-footer {
  margin-top: auto;
  background: var(--color-footer);
  color: var(--color-footer-text);
}

.site-footer__main {
  padding: 3rem 0 2rem;
}

.site-footer__grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.site-footer__title {
  color: #fff;
  display: block;
  margin-bottom: 0.75rem;
}

.site-footer__blurb {
  margin: 0;
  font-size: 0.95rem;
  opacity: 0.9;
  line-height: 1.5;
}

.site-footer__heading {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 1rem;
  color: #fff;
}

.site-footer__links,
.site-footer__social {
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-footer__links li,
.site-footer__social li {
  margin-bottom: 0.5rem;
}

.site-footer a {
  color: var(--color-footer-text);
  text-decoration: none;
}

.site-footer a:hover,
.site-footer a:focus-visible {
  color: #fff;
  text-decoration: underline;
}

.site-footer__contact {
  margin: 0 0 0.75rem;
  font-size: 0.95rem;
}

.site-footer__bar {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  padding: 1rem 0;
}

.site-footer__bar-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
}

.site-footer__legal {
  margin: 0;
  font-size: 0.85rem;
  opacity: 0.85;
}

.text-link {
  color: var(--color-accent);
  font-weight: 600;
}

.text-link:hover,
.text-link:focus-visible {
  color: var(--color-accent-dark);
}

.page-intro {
  max-width: 720px;
  margin-bottom: 2rem;
}

.lead {
  font-size: 1.1rem;
  color: var(--color-muted);
}

/* -------------------------------------------------------------------------
   Homepage (body.is-home) — large hero, pillars, bento activities
   ------------------------------------------------------------------------- */
body.is-home {
  /* Slightly wider than site default (--wrap: 1100px); still capped, not full-bleed */
  --wrap: min(92vw, 1240px);
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-ui: "Outfit", var(--font-sans);
  font-family: var(--font-ui);
  font-size: 1.0625rem;
}

body.is-home .site-main {
  padding-bottom: 0;
}

body.is-home h1,
body.is-home h2,
body.is-home h3,
body.is-home .section-home__title,
body.is-home .hero-home__title {
  font-family: var(--font-display);
}

.btn--xl {
  padding: 0.9rem 1.75rem;
  font-size: 1.05rem;
  border-radius: 999px;
}

.btn--ghost {
  background: transparent;
  color: #fff;
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.85);
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}

.btn--outline-dark {
  background: transparent;
  color: var(--color-accent-dark);
  box-shadow: inset 0 0 0 2px var(--color-accent);
}

.btn--outline-dark:hover,
.btn--outline-dark:focus-visible {
  background: rgba(13, 122, 79, 0.08);
}

/* Hero */
.hero-home {
  position: relative;
  min-height: 0;
  display: flex;
  align-items: flex-start;
  padding: clamp(1.1rem, 3vw, 1.65rem) 0 clamp(1.25rem, 3.5vw, 1.85rem);
  color: #fff;
  overflow: hidden;
}

.hero-home__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse 90% 70% at 75% 15%, rgba(134, 239, 172, 0.22), transparent 55%),
    radial-gradient(ellipse 55% 45% at 8% 85%, rgba(45, 212, 191, 0.14), transparent 50%),
    linear-gradient(168deg, #042218 0%, #0a3d2a 30%, #0d7a4f 62%, #064e3b 100%);
}

.hero-home__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.35;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.07'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

.hero-home__content {
  position: relative;
  z-index: 1;
  max-width: 56rem;
}

@media (prefers-reduced-motion: no-preference) {
  body.is-home .hero-home__content {
    animation: ghna-fade-up 0.95s cubic-bezier(0.22, 1, 0.36, 1) 0.1s both;
  }

  body.is-home .hero-home__bg {
    animation: ghna-hero-bg-drift 18s ease-in-out infinite alternate;
  }
}

@keyframes ghna-fade-up {
  from {
    opacity: 0;
    transform: translateY(1.35rem);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes ghna-hero-bg-drift {
  0% {
    filter: brightness(1) saturate(1);
  }
  100% {
    filter: brightness(1.07) saturate(1.08);
  }
}

.hero-home__kicker {
  margin: 0 0 0.4rem;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.82);
}

.hero-home__title {
  margin: 0 0 0.5rem;
  font-size: clamp(1.65rem, 5.2vw, 2.65rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.02em;
  text-wrap: balance;
}

.hero-home__lead {
  margin: 0 0 0.85rem;
  font-size: clamp(0.95rem, 2vw, 1.12rem);
  font-weight: 400;
  line-height: 1.45;
  max-width: 38rem;
  color: rgba(255, 255, 255, 0.92);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

.hero-home__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem 0.65rem;
  margin-bottom: 0.65rem;
}

.hero-home .btn--xl {
  padding: 0.58rem 1.2rem;
  font-size: 0.92rem;
}

.hero-home__scroll {
  margin: 0;
  padding-top: 0;
}

.hero-home__scroll-link {
  color: rgba(255, 255, 255, 0.75);
  font-size: 0.82rem;
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.35);
}

.hero-home__scroll-link:hover,
.hero-home__scroll-link:focus-visible {
  color: #fff;
  border-bottom-color: #fff;
}

/* Section layout */
.section-home {
  padding: clamp(3.5rem, 8vw, 6rem) 0;
}

.section-home__header {
  max-width: 40rem;
  margin-bottom: clamp(2rem, 5vw, 3rem);
}

.section-home__header--center {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.section-home__header--center .section-home__intro {
  margin-left: auto;
  margin-right: auto;
}

.home-eyebrow {
  margin: 0 0 0.5rem;
  font-family: var(--font-ui);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
}

.home-eyebrow--on-dark {
  color: #7ee4bd;
}

.section-home__title {
  margin: 0 0 0.75rem;
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight: 700;
  line-height: 1.12;
  color: var(--color-accent-dark);
  letter-spacing: -0.02em;
}

.section-home__intro {
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.65;
  color: var(--color-muted);
}

.section-home__footer-actions {
  margin-top: 2.5rem;
}

.section-home__cta-line {
  margin: 2.5rem 0 0;
  text-align: center;
}

.home-empty {
  font-size: 1.1rem;
  color: var(--color-muted);
}

.home-empty a {
  color: var(--color-accent);
  font-weight: 600;
}

/* Pillars */
.section-home--pillars {
  background: var(--color-bg);
}

.pillar-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: clamp(1.25rem, 3vw, 2rem);
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 900px) {
  .pillar-grid {
    grid-template-columns: 1fr;
  }
}

.pillar-card {
  background: var(--color-surface);
  padding: clamp(1.75rem, 4vw, 2.5rem);
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(15, 36, 24, 0.07);
  border: 1px solid rgba(13, 122, 79, 0.12);
  position: relative;
  overflow: hidden;
}

.pillar-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-accent), #34d399);
}

.pillar-card__num {
  display: block;
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1;
  color: rgba(13, 122, 79, 0.2);
  margin-bottom: 0.5rem;
}

.pillar-card__title {
  margin: 0 0 0.65rem;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-accent-dark);
}

.pillar-card__text {
  margin: 0;
  color: var(--color-muted);
  line-height: 1.65;
}

a.pillar-card--link {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s, box-shadow 0.2s;
}

a.pillar-card--link:hover,
a.pillar-card--link:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(15, 36, 24, 0.12);
  outline: none;
}

/* Mission band */
.section-home--mission {
  background: linear-gradient(180deg, #0f291c 0%, #0d3d28 45%, #0a3020 100%);
  color: #e8f5ef;
}

.section-home--mission .section-home__title {
  color: #fff;
}

.mission-home {
  display: grid;
  gap: clamp(1.5rem, 3vw, 2rem);
  grid-template-columns: repeat(2, 1fr);
}

@media (max-width: 768px) {
  .mission-home {
    grid-template-columns: 1fr;
  }
}

.mission-home__card {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 20px;
  padding: clamp(2rem, 4vw, 2.75rem);
}

.mission-home__label {
  margin: 0 0 1rem;
  font-size: 1.5rem;
  font-weight: 700;
  color: #b8f5d9;
}

.mission-home__text {
  margin: 0 0 1.25rem;
  font-size: 1.1rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.88);
}

.mission-home__link {
  font-weight: 600;
  color: #7ee4bd;
  text-decoration: none;
}

.mission-home__link:hover,
.mission-home__link:focus-visible {
  color: #fff;
  text-decoration: underline;
}

a.mission-home__card--link {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
}

a.mission-home__card--link:hover,
a.mission-home__card--link:focus-visible {
  background: rgba(255, 255, 255, 0.1);
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
  outline: none;
}

.mission-home__link--fake {
  font-weight: 600;
  color: #7ee4bd;
  text-decoration: none;
}

a.mission-home__card--link:hover .mission-home__link--fake,
a.mission-home__card--link:focus-visible .mission-home__link--fake {
  color: #fff;
  text-decoration: underline;
}

/* Events showcase */
.section-home--events {
  background: var(--color-surface);
}

.events-showcase {
  display: grid;
  gap: 1.25rem;
}

@media (min-width: 700px) {
  .events-showcase {
    grid-template-columns: repeat(2, 1fr);
  }
}

.event-tile {
  display: flex;
  gap: 1.25rem;
  padding: 1.5rem;
  background: var(--color-bg);
  border-radius: 16px;
  border: 1px solid rgba(13, 122, 79, 0.15);
  min-height: 8rem;
  transition: box-shadow 0.2s, border-color 0.2s;
}

.event-tile:hover {
  box-shadow: 0 8px 32px rgba(15, 36, 24, 0.08);
  border-color: rgba(13, 122, 79, 0.28);
}

a.event-tile {
  text-decoration: none;
  color: inherit;
}

a.event-tile:focus-visible {
  outline: 3px solid var(--color-accent);
  outline-offset: 3px;
}

.event-tile__hint {
  margin: 0.65rem 0 0;
  font-size: 0.88rem;
}

.event-tile__date {
  flex-shrink: 0;
  width: 4.5rem;
  text-align: center;
  padding: 0.5rem;
  background: var(--color-accent-dark);
  color: #fff;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  line-height: 1.15;
}

.event-tile__day {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 700;
}

.event-tile__mon {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  opacity: 0.9;
}

.event-tile__year {
  font-size: 0.7rem;
  opacity: 0.75;
  margin-top: 0.15rem;
}

.event-tile__type {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 0.35rem;
}

.event-tile__title {
  margin: 0 0 0.35rem;
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-text);
}

.event-tile__loc {
  margin: 0 0 0.35rem;
  font-size: 0.9rem;
  color: var(--color-muted);
}

.event-tile__desc {
  margin: 0;
  font-size: 0.95rem;
  color: var(--color-muted);
  line-height: 1.55;
}

/* Activities bento */
.section-home--activities {
  background: linear-gradient(180deg, #f0f7f3 0%, var(--color-bg) 100%);
}

.activities-bento {
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 960px) {
  .activities-bento {
    grid-template-columns: 1.25fr 1fr;
    align-items: start;
  }
}

.activities-bento__feature {
  position: relative;
  background: var(--color-surface);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(15, 36, 24, 0.1);
  border: 1px solid rgba(13, 122, 79, 0.1);
}

a.activities-bento__feature {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s, box-shadow 0.2s;
}

a.activities-bento__feature:hover,
a.activities-bento__feature:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 18px 48px rgba(15, 36, 24, 0.16);
  outline: none;
}

.activities-bento__feature--new {
  border-color: rgba(13, 122, 79, 0.42);
  box-shadow:
    0 18px 48px rgba(13, 122, 79, 0.18),
    0 0 0 1px rgba(13, 122, 79, 0.12);
  animation: home-new-pop 0.85s cubic-bezier(0.22, 1, 0.36, 1) 0.1s both;
}

@keyframes home-new-pop {
  0% {
    opacity: 0;
    transform: translateY(12px) scale(0.985);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .activities-bento__feature--new {
    animation: none;
  }
}

.activity-new-badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 3;
  padding: 0.4rem 0.75rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(135deg, #f59e0b 0%, #ea580c 100%);
  border-radius: 8px;
  box-shadow: 0 6px 20px rgba(234, 88, 12, 0.45);
}

.activity-new-pill {
  display: inline-block;
  margin-right: 0.4rem;
  padding: 0.15rem 0.5rem;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  vertical-align: middle;
  color: #fff;
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
  border-radius: 5px;
}

.activity-new-pill--inline {
  margin-right: 0.5rem;
  margin-bottom: 0.15rem;
  flex-shrink: 0;
}

.activities-bento__img-wrap {
  position: relative;
  z-index: 0;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: linear-gradient(135deg, #d1fae5, #a7f3d0);
}

.activities-bento__img-wrap--placeholder {
  min-height: 200px;
  background: linear-gradient(145deg, #0d7a4f 0%, #065f46 100%);
  opacity: 0.9;
}

.activities-bento__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.activities-bento__feature-text {
  padding: clamp(1.5rem, 3vw, 2rem);
}

.activities-bento__feature-title {
  margin: 0 0 0.75rem;
  font-size: clamp(1.5rem, 2.5vw, 1.85rem);
  font-weight: 700;
  color: var(--color-accent-dark);
}

.activities-bento__feature-summary {
  margin: 0;
  font-size: 1.1rem;
  line-height: 1.65;
  color: var(--color-muted);
}

.activities-bento__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.activities-bento__item {
  display: flex;
  gap: 1rem;
  padding: 1.1rem 1.25rem;
  background: var(--color-surface);
  border-radius: 14px;
  border: 1px solid rgba(13, 122, 79, 0.12);
  align-items: flex-start;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

a.activities-bento__item:hover,
a.activities-bento__item:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(15, 36, 24, 0.1);
  outline: none;
}

.activities-bento__item--new {
  border-color: rgba(234, 88, 12, 0.28);
  box-shadow: 0 10px 32px rgba(234, 88, 12, 0.1);
}

.activities-bento__thumb {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 10px;
  flex-shrink: 0;
}

.activities-bento__item-title {
  margin: 0 0 0.35rem;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-text);
}

.activities-bento__item-summary {
  margin: 0;
  font-size: 0.95rem;
  color: var(--color-muted);
  line-height: 1.5;
}

/* CTA band */
.section-home--cta {
  padding: clamp(4rem, 10vw, 6.5rem) 0;
  background: linear-gradient(135deg, #059669 0%, #0d7a4f 40%, #047857 100%);
  color: #fff;
  text-align: center;
}

.section-home--cta-inner {
  max-width: 38rem;
}

.cta-band__title {
  margin: 0 0 1rem;
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.cta-band__text {
  margin: 0 0 2rem;
  font-size: 1.2rem;
  line-height: 1.6;
  opacity: 0.95;
}

.cta-band__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

/* Homepage — image slider */
.section-home--slider {
  padding: 0;
  background: #0a1f16;
}

.home-carousel {
  position: relative;
}

.home-carousel__viewport {
  overflow: hidden;
  width: 100%;
}

.home-carousel__track {
  display: flex;
  transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}

.home-carousel__slide {
  flex: 0 0 100%;
  min-width: 100%;
  position: relative;
}

.home-carousel__slide-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.home-carousel__slide-link:focus-visible {
  outline: 3px solid #7ee4bd;
  outline-offset: -3px;
}

.home-carousel__media {
  position: relative;
  aspect-ratio: 2.3 / 1;
  max-height: min(78vh, 720px);
  overflow: hidden;
  background: #062a1c;
}

@media (max-width: 700px) {
  .home-carousel__media {
    aspect-ratio: 4 / 3;
    max-height: 55vh;
  }
}

.home-carousel__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.85s ease;
}

.home-carousel__slide:hover .home-carousel__img,
.home-carousel__slide-link:hover .home-carousel__img {
  transform: scale(1.06);
}

.home-carousel__shine {
  pointer-events: none;
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255, 255, 255, 0.06) 45%, transparent 55%);
  opacity: 0.9;
}

.home-carousel__caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 2rem 1rem 2.5rem;
  background: linear-gradient(transparent, rgba(6, 28, 20, 0.88));
  color: #fff;
}

.home-carousel__headline {
  margin: 0 0 0.35rem;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 3vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

.home-carousel__subline {
  margin: 0 0 1rem;
  font-size: 1.05rem;
  line-height: 1.5;
  max-width: 36rem;
  opacity: 0.95;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.4);
}

.home-carousel__btn {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
}

.home-carousel__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 1rem 1rem 1.5rem;
  background: #0a1f16;
}

.home-carousel__arrow {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}

.home-carousel__arrow:hover,
.home-carousel__arrow:focus-visible {
  background: rgba(255, 255, 255, 0.18);
  border-color: #fff;
  outline: none;
}

.home-carousel__arrow:active {
  transform: scale(0.96);
}

.home-carousel__dots {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  justify-content: center;
}

.home-carousel__dot {
  width: 10px;
  height: 10px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.35);
  cursor: pointer;
  transition: transform 0.2s, background 0.2s;
}

.home-carousel__dot:hover,
.home-carousel__dot:focus-visible {
  background: rgba(255, 255, 255, 0.65);
  outline: none;
}

.home-carousel__dot.is-active {
  background: #7ee4bd;
  transform: scale(1.25);
}

/* Home — hover zoom on activity images */
body.is-home .img-hover-zoom {
  overflow: hidden;
  border-radius: 12px 12px 0 0;
}

body.is-home .img-hover-zoom .activities-bento__img {
  transition: transform 0.7s ease;
}

body.is-home .img-hover-zoom:hover .activities-bento__img {
  transform: scale(1.07);
}

body.is-home .activities-bento__item {
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

body.is-home .activities-bento__thumb {
  transition: transform 0.55s ease;
}

body.is-home .activities-bento__item:hover {
  border-color: rgba(13, 122, 79, 0.35);
  box-shadow: 0 8px 28px rgba(15, 36, 24, 0.1);
}

body.is-home .activities-bento__item:hover .activities-bento__thumb {
  transform: scale(1.1);
}

body.is-home .pillar-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

body.is-home .pillar-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(15, 36, 24, 0.14);
}

/* Important announcement modal */
.home-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  box-sizing: border-box;
}

.home-modal[hidden] {
  display: none !important;
}

.home-modal--open {
  display: flex;
}

.home-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(4, 22, 15, 0.72);
  backdrop-filter: blur(4px);
}

.home-modal__box {
  position: relative;
  z-index: 1;
  width: min(100%, 480px);
  max-height: min(88vh, 640px);
  overflow: auto;
  background: var(--color-surface);
  border-radius: 16px;
  padding: 2rem 1.75rem 1.75rem;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(13, 122, 79, 0.2);
}

.home-modal__close {
  position: absolute;
  top: 0.75rem;
  right: 0.85rem;
  width: 2.5rem;
  height: 2.5rem;
  border: none;
  background: transparent;
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
  color: var(--color-muted);
  border-radius: 8px;
  transition: background 0.2s, color 0.2s;
}

.home-modal__close:hover,
.home-modal__close:focus-visible {
  background: var(--color-bg);
  color: var(--color-text);
  outline: none;
}

.home-modal__title {
  margin: 0 0 1rem;
  font-family: var(--font-display);
  font-size: 1.65rem;
  font-weight: 700;
  color: var(--color-accent-dark);
  padding-right: 2rem;
}

.home-modal__body {
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--color-text);
}

.home-modal__action {
  margin: 1.25rem 0 0;
}

.home-modal__dismiss {
  margin: 1.5rem 0 0;
  padding-top: 1rem;
  border-top: 1px solid rgba(13, 122, 79, 0.15);
}

.home-modal__ok {
  width: 100%;
  justify-content: center;
}

/* -------------------------------------------------------------------------
   Contact page — corporate layout
   ------------------------------------------------------------------------- */
.contact-hero {
  background: linear-gradient(135deg, #0a3224 0%, #0d5c3e 48%, #0a4230 100%);
  color: #fff;
  padding: clamp(2.25rem, 5vw, 3.5rem) 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.contact-hero__inner {
  max-width: 720px;
}

.contact-hero__eyebrow {
  margin: 0 0 0.5rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(167, 243, 208, 0.95);
}

.contact-hero__title {
  margin: 0 0 1rem;
  font-size: clamp(2rem, 4vw, 2.65rem);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -0.02em;
}

.contact-hero__lead {
  margin: 0;
  font-size: 1.0625rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.9);
  max-width: 42rem;
}

.contact-body {
  padding: clamp(2.5rem, 5vw, 4rem) 0 4rem;
  background: #eef4f0;
}

.contact-layout {
  max-width: 1080px;
}

.contact-alert {
  grid-column: 1 / -1;
  padding: 1.1rem 1.35rem;
  border-radius: 10px;
  margin-bottom: 1.75rem;
  border: 1px solid transparent;
}

.contact-alert strong {
  display: block;
  font-size: 0.95rem;
  margin-bottom: 0.35rem;
}

.contact-alert p {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.55;
}

.contact-alert--success {
  background: #e8f7ee;
  border-color: #9dc7ae;
  color: #14532d;
}

.contact-alert--error {
  background: #fef2f2;
  border-color: #f5c4c4;
  color: #7f1d1d;
}

.contact-layout__grid {
  display: grid;
  gap: clamp(1.75rem, 3vw, 2.5rem);
  align-items: start;
}

@media (min-width: 900px) {
  .contact-layout__grid {
    grid-template-columns: minmax(260px, 340px) 1fr;
  }
}

.contact-aside__heading {
  margin: 0 0 0.5rem;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-accent-dark);
  letter-spacing: -0.01em;
}

.contact-aside__intro {
  margin: 0 0 1.5rem;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--color-muted);
}

.contact-cards {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.contact-card {
  display: flex;
  gap: 1rem;
  padding: 1.15rem 1.25rem;
  background: var(--color-surface);
  border-radius: 12px;
  border: 1px solid rgba(13, 122, 79, 0.14);
  box-shadow: 0 2px 12px rgba(15, 36, 24, 0.05);
}

.contact-card__icon {
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 10px;
  background: rgba(13, 122, 79, 0.1);
  color: var(--color-accent-dark);
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-card__body {
  min-width: 0;
}

.contact-card__label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 0.35rem;
}

.contact-card__value {
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-text);
}

.contact-card__link {
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--color-accent-dark);
  text-decoration: none;
  word-break: break-word;
}

.contact-card__link:hover,
.contact-card__link:focus-visible {
  color: var(--color-accent);
  text-decoration: underline;
}

.contact-aside__empty {
  margin: 0 0 1.5rem;
  padding: 1rem 1.15rem;
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--color-muted);
  background: rgba(255, 255, 255, 0.7);
  border-radius: 10px;
  border: 1px dashed rgba(13, 122, 79, 0.25);
}

.contact-aside__note {
  margin-top: 1.75rem;
  padding: 1.15rem 1.25rem;
  background: rgba(13, 122, 79, 0.06);
  border-radius: 10px;
  border-left: 4px solid var(--color-accent);
}

.contact-aside__follow {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(13, 122, 79, 0.12);
}

.contact-aside__follow-heading {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin: 0 0 0.65rem;
  color: var(--color-accent-dark);
}

.contact-aside__social {
  list-style: none;
  margin: 0;
  padding: 0;
}

.contact-aside__social li {
  margin-bottom: 0.45rem;
}

.contact-aside__social a {
  font-weight: 600;
  color: var(--color-accent);
  text-decoration: none;
}

.contact-aside__social a:hover,
.contact-aside__social a:focus-visible {
  text-decoration: underline;
}

.contact-aside__note strong {
  display: block;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-accent-dark);
  margin-bottom: 0.4rem;
}

.contact-aside__note p {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--color-muted);
}

.contact-form-panel {
  background: var(--color-surface);
  border-radius: 16px;
  padding: clamp(1.75rem, 4vw, 2.5rem);
  border: 1px solid rgba(13, 122, 79, 0.12);
  box-shadow: 0 12px 40px rgba(15, 36, 24, 0.08);
}

.contact-form-panel__title {
  margin: 0 0 0.35rem;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: -0.02em;
}

.contact-form-panel__hint {
  margin: 0 0 1.5rem;
  font-size: 0.88rem;
  color: var(--color-muted);
}

.contact-form__row {
  margin-bottom: 1.15rem;
}

.contact-form__row--split {
  display: grid;
  gap: 1.15rem;
}

@media (min-width: 560px) {
  .contact-form__row--split {
    grid-template-columns: 1fr 1fr;
  }
}

.contact-form__field {
  margin-bottom: 1.15rem;
}

.contact-form__row--split .contact-form__field {
  margin-bottom: 0;
}

.contact-form__label {
  display: block;
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 0.4rem;
}

.contact-form__req {
  color: #b91c1c;
  font-weight: 700;
}

.contact-form__input {
  width: 100%;
  padding: 0.75rem 0.95rem;
  font: inherit;
  font-size: 1rem;
  color: var(--color-text);
  background: #fafcfb;
  border: 1px solid #c5ddcf;
  border-radius: 8px;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.contact-form__input::placeholder {
  color: #8aa396;
}

.contact-form__input:hover {
  border-color: #9dc4b0;
}

.contact-form__input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(13, 122, 79, 0.18);
  background: #fff;
}

.contact-form__textarea {
  resize: vertical;
  min-height: 140px;
  line-height: 1.55;
}

.contact-form__captcha {
  margin-top: 0.35rem;
}

.contact-form__captcha-hint {
  margin: 0.25rem 0 0.65rem;
  font-size: 0.9rem;
  color: var(--color-text-muted, #5a6e62);
}

.contact-form__captcha-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1rem;
}

.contact-form__captcha-img {
  display: block;
  border-radius: 6px;
  border: 1px solid var(--color-border, #cfe3d8);
}

.contact-form__captcha-input {
  max-width: 12rem;
}

.contact-form__captcha-math {
  margin: 0 0 0.5rem;
  font-weight: 600;
  color: var(--color-text);
}

.contact-form__actions {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(13, 122, 79, 0.12);
}

.contact-form__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 200px;
  padding: 0.85rem 1.75rem;
  font: inherit;
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(180deg, #0f8f5f 0%, #0d7a4f 100%);
  border: 1px solid #065f46;
  border-radius: 8px;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(13, 122, 79, 0.25);
  transition: filter 0.2s, transform 0.15s, box-shadow 0.2s;
}

.contact-form__submit:hover {
  filter: brightness(1.05);
  box-shadow: 0 4px 16px rgba(13, 122, 79, 0.3);
}

.contact-form__submit:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(13, 122, 79, 0.35);
}

.contact-form__submit:active {
  transform: translateY(1px);
}

.contact-form__privacy {
  margin: 1rem 0 0;
  font-size: 0.78rem;
  line-height: 1.5;
  color: var(--color-muted);
  max-width: 36rem;
}

/* Home page templates (see Admin → Site settings → Home page layout) */
.hero-home--compact {
  min-height: auto;
  padding: clamp(1.15rem, 3vw, 1.85rem) 0;
}

.hero-home--compact .hero-home__title {
  margin-bottom: 0.55rem;
  font-size: clamp(1.55rem, 4.5vw, 2.5rem);
}

.hero-home--compact .hero-home__lead {
  margin-bottom: 0.85rem;
  font-size: clamp(0.92rem, 1.9vw, 1.08rem);
}

.hero-home--compact .hero-home__actions {
  margin-bottom: 0.65rem;
}

.is-home--spotlight .section-home--slider {
  padding-top: 0;
  padding-bottom: 0;
}

.is-home--spotlight .section-home--slider + .hero-home {
  margin-top: 0;
}

.section-home--minimal-split {
  background: var(--color-bg);
}

.home-minimal-grid {
  display: grid;
  gap: clamp(1.75rem, 4vw, 2.5rem);
}

@media (min-width: 768px) {
  .home-minimal-grid {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}

.home-minimal-grid--spotlights-only {
  max-width: 44rem;
  margin-inline: auto;
}

@media (min-width: 768px) {
  .home-minimal-grid--spotlights-only {
    grid-template-columns: 1fr;
  }
}

.home-minimal-panel {
  background: var(--color-surface);
  border: 1px solid rgba(13, 122, 79, 0.12);
  border-radius: 12px;
  padding: clamp(1.25rem, 3vw, 1.75rem);
  box-shadow: 0 4px 24px rgba(15, 36, 24, 0.06);
}

.home-minimal-panel__title {
  margin-top: 0.35rem;
  margin-bottom: 1rem;
  font-size: clamp(1.35rem, 3vw, 1.65rem);
}

.home-minimal-empty {
  margin: 0;
  font-size: 0.95rem;
}

.home-minimal-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.home-minimal-list__item {
  margin: 0;
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
}

.home-minimal-list__item:last-child {
  border-bottom: none;
}

.home-minimal-list__link {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.65rem 0;
  text-decoration: none;
  color: inherit;
  transition: color 0.15s;
}

.home-minimal-list__item--new .home-minimal-list__link {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
}

.home-minimal-list__link:hover,
.home-minimal-list__link:focus-visible {
  color: var(--color-accent-dark);
}

.home-minimal-list__meta {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-accent);
}

.home-minimal-list__text {
  font-weight: 600;
  line-height: 1.35;
}

.home-minimal-more {
  margin: 1rem 0 0;
  font-size: 0.9rem;
}

/* Scroll reveals & motion (site.js adds .reveal / .is-visible; skipped when prefers-reduced-motion) */
@media (prefers-reduced-motion: no-preference) {
  .reveal {
    --reveal-delay: 0s;
    opacity: 0;
    transform: translateY(1.75rem);
    transition:
      opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1),
      transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--reveal-delay);
  }

  .reveal.is-visible {
    opacity: 1;
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  body.is-home .hero-home__bg {
    animation: none !important;
  }
}

/* -------------------------------------------------------------------------
   Institute home layout (is-home--acep) — bold hero, vision, news/events
   ------------------------------------------------------------------------- */
body.is-home--acep,
body.theme-acep {
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-ui: "DM Sans", var(--font-sans);
  --acep-nav-active: #9333ea;
  --acep-orange: #ea580c;
  --acep-orange-mid: #f97316;
  --acep-orange-bright: #fb923c;
  font-family: var(--font-ui);
  font-size: 1.0625rem;
}

body.is-home--acep .site-main {
  padding-bottom: 0;
}

body.theme-acep:not(.is-home) .site-main {
  padding-bottom: 3rem;
}

.site-preheader {
  font-size: 0.78rem;
}

.site-preheader--acep {
  background: #0a1f14;
  color: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.site-preheader--bare {
  background: #eaf5ef;
  color: var(--color-accent-dark);
  border-bottom: 1px solid rgba(13, 122, 79, 0.15);
}

.site-preheader__inner {
  width: 100%;
  max-width: none;
  margin-inline: 0;
  padding: 0.26rem clamp(0.35rem, 2vw, 0.85rem);
  box-sizing: border-box;
}

.site-preheader__marquee-host {
  position: relative;
  width: 100%;
}

.site-preheader__marquee {
  overflow: hidden;
  container-type: inline-size;
  container-name: site-preheader-marquee;
  /* Narrow fades so text runs closer to both viewport edges */
  mask-image: linear-gradient(
    90deg,
    transparent,
    #000 2%,
    #000 98%,
    transparent
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent,
    #000 2%,
    #000 98%,
    transparent
  );
}

.site-preheader__track {
  display: flex;
  width: max-content;
  font-weight: 600;
  font-size: 0.8rem;
  letter-spacing: 0.025em;
  text-transform: none;
  line-height: 1.42;
  opacity: 0.95;
  animation: site-preheader-marquee 9s linear infinite;
}

.site-preheader__chunk {
  flex-shrink: 0;
  white-space: nowrap;
}

.site-preheader__sep {
  opacity: 0.55;
  padding-right: 1.65rem;
  font-weight: 500;
}

.site-preheader--acep .site-preheader__track {
  font-size: 0.78rem;
  letter-spacing: 0.032em;
}

.site-preheader--bare .site-preheader__track {
  font-size: 0.82rem;
  font-weight: 500;
  opacity: 1;
}

@keyframes site-preheader-marquee {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

@supports (width: 1cqw) {
  @keyframes site-preheader-marquee {
    /* Enter from right edge of strip; -50% = one duplicated chunk for a seamless loop. */
    0% {
      transform: translateX(100cqw);
    }

    100% {
      transform: translateX(calc(100cqw - 50%));
    }
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-preheader__marquee {
    mask-image: none;
    -webkit-mask-image: none;
  }

  .site-preheader__track {
    animation: none;
    width: 100%;
    max-width: 100%;
    flex-wrap: wrap;
    justify-content: center;
    transform: none;
    text-align: center;
    row-gap: 0.15rem;
  }

  .site-preheader__chunk + .site-preheader__chunk {
    display: none;
  }
}

@media (min-width: 700px) and (prefers-reduced-motion: reduce) {
  .site-preheader__track {
    justify-content: flex-start;
    text-align: left;
  }
}

.site-header--acep {
  background: #fff;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: 1px solid rgba(15, 36, 24, 0.07);
  box-shadow: 0 1px 0 rgba(15, 36, 24, 0.04);
}

body.is-home--acep .site-header--acep.site-header--elevated,
body.theme-acep .site-header--acep.site-header--elevated {
  background: #fff;
  box-shadow: 0 2px 16px rgba(15, 36, 24, 0.08);
}

body.is-home--acep h1,
body.is-home--acep h2,
body.is-home--acep h3,
body.is-home--acep .acep-hero__title,
body.is-home--acep .acep-vision__headline,
body.theme-acep h1,
body.theme-acep h2,
body.theme-acep h3,
body.theme-acep .section__title,
body.theme-acep .acep-hero__title,
body.theme-acep .acep-vision__headline {
  font-family: var(--font-display);
}

/* Featured event ribbon */
.acep-strip {
  background: linear-gradient(90deg, #0d7a4f 0%, #0a5c3c 100%);
  color: #fff;
  padding: 0.65rem 0 !important;
}

.acep-strip__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1.25rem;
  justify-content: space-between;
}

.acep-strip__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.acep-strip__chip {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  background: rgba(255, 255, 255, 0.18);
  border-radius: 4px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.acep-strip__title {
  margin: 0;
  flex: 1 1 200px;
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1.35;
}

.acep-strip__cta {
  color: #fff;
  font-weight: 700;
  font-size: 0.88rem;
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 2px solid rgba(255, 255, 255, 0.5);
}

.acep-strip__cta:hover,
.acep-strip__cta:focus-visible {
  border-bottom-color: #fff;
  color: #fff;
}

/* Hero */
.acep-hero {
  position: relative;
  padding: clamp(3rem, 7vw, 5rem) 0 clamp(3.5rem, 8vw, 5.5rem) !important;
  color: #fff;
  overflow: hidden;
}

.acep-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse 85% 55% at 50% -10%, rgba(251, 146, 60, 0.12), transparent 52%),
    radial-gradient(ellipse 80% 60% at 70% 0%, rgba(134, 239, 172, 0.12), transparent 50%),
    linear-gradient(165deg, #031910 0%, #0a3220 42%, #0d5c3a 78%, #042f24 100%);
}

.acep-hero__bg::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.55;
  background-image:
    linear-gradient(118deg, rgba(255, 255, 255, 0.05) 23.5%, transparent 24%),
    linear-gradient(298deg, rgba(255, 255, 255, 0.045) 23.5%, transparent 24%),
    linear-gradient(38deg, transparent 58%, rgba(255, 255, 255, 0.028) 58.5%, transparent 59.5%);
  background-size: 52px 90px, 52px 90px, 120px 120px;
  background-position:
    0 0,
    26px 45px,
    10% 20%;
  pointer-events: none;
}

.acep-hero__content {
  position: relative;
  z-index: 1;
  max-width: 46rem;
}

.acep-hero__content--center {
  max-width: 56rem;
  margin-inline: auto;
  text-align: center;
}

.acep-hero--event {
  padding-top: clamp(3.25rem, 8vw, 5.5rem) !important;
}

.acep-hero__kicker--event {
  color: rgba(253, 230, 200, 0.95);
}

/* Featured event: FEC-style hero (conference branding — green mesh, orange accents) */
.acep-hero--fec-brand {
  padding-top: clamp(2.75rem, 7vw, 4.5rem) !important;
  padding-bottom: clamp(3rem, 8vw, 5rem) !important;
}

.acep-hero--fec-brand .acep-hero__bg {
  background:
    radial-gradient(ellipse 65% 55% at 50% 110%, rgba(245, 130, 32, 0.14), transparent 58%),
    radial-gradient(ellipse 45% 40% at 85% 15%, rgba(251, 191, 36, 0.08), transparent 50%),
    linear-gradient(168deg, #042216 0%, #0a3d28 28%, #0d5c38 58%, #063022 100%);
}

.acep-hero--fec-brand .acep-hero__bg::before {
  opacity: 0.5;
  background-image:
    linear-gradient(115deg, rgba(255, 255, 255, 0.06) 22%, transparent 22.6%),
    linear-gradient(295deg, rgba(255, 255, 255, 0.045) 22%, transparent 22.6%),
    linear-gradient(55deg, transparent 62%, rgba(0, 0, 0, 0.07) 62.5%, transparent 63%);
  background-size:
    64px 110px,
    64px 110px,
    100px 100px;
  background-position:
    0 0,
    32px 55px,
    18% 12%;
}

/* FEC mirror home: hero + vision only */
body.is-home--acep:has(.acep-hero--fec-brand) .acep-org-teaser,
body.is-home--acep:has(.acep-hero--fec-brand) .section-home--slider,
body.is-home--acep:has(.acep-hero--fec-brand) .ghna-alignment-strip,
body.is-home--acep:has(.acep-hero--fec-brand) .acep-home-jump,
body.is-home--acep:has(.acep-hero--fec-brand) .section-home--value-chain,
body.is-home--acep:has(.acep-hero--fec-brand) .section-home--programmes-preview,
body.is-home--acep:has(.acep-hero--fec-brand) .acep-news-events,
body.is-home--acep:has(.acep-hero--fec-brand) .acep-cta {
  display: none !important;
}

body.is-home--acep:has(.acep-hero--fec-brand) .acep-vision .acep-vision__headline {
  color: #0f172a;
}

body.is-home--acep:has(.acep-hero--fec-brand) .acep-vision__body {
  color: #334155;
}

body.is-home--acep:has(.acep-hero--fec-brand) .acep-vision__body p {
  margin: 0 0 1rem;
}

body.is-home--acep:has(.acep-hero--fec-brand) .acep-vision__body p:last-child {
  margin-bottom: 0;
}

.acep-fec-hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5rem 0.85rem;
  margin: 1.5rem 0 0;
  max-width: 40rem;
  font-size: clamp(0.92rem, 2.1vw, 1.05rem);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.96);
  text-align: center;
  line-height: 1.45;
}

.acep-fec-hero__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.acep-fec-hero__meta-ic {
  font-size: 1.02em;
  line-height: 1;
  opacity: 0.95;
}

.acep-fec-hero__meta-sep {
  color: rgba(255, 255, 255, 0.5);
  font-weight: 500;
  letter-spacing: 0.06em;
  user-select: none;
}

.acep-fec-hero__actions {
  margin-top: 1.85rem !important;
}

.acep-fec-hero__register {
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-weight: 800 !important;
  font-size: 0.82rem !important;
  padding: 0.95rem 2.1rem !important;
}

.acep-hero__block-label {
  margin: 0 0 0.35rem;
}

.acep-hero__content--fec .acep-hero__block-label {
  text-align: center;
}

.acep-hero__block-label--fec {
  color: var(--fec-orange);
  opacity: 0.95;
}

.acep-home-jump {
  background: #f8faf9;
  border-top: 1px solid rgba(13, 122, 79, 0.1);
  border-bottom: 1px solid rgba(13, 122, 79, 0.08);
}

.acep-home-jump__inner {
  padding: 0.15rem 0;
}

.acep-home-jump__title {
  margin: 0 0 0.5rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent-dark);
}

.acep-home-jump__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.75rem;
  align-items: center;
}

.acep-home-jump__link {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-accent);
  text-decoration: none;
  white-space: nowrap;
}

.acep-home-jump__link:hover,
.acep-home-jump__link:focus-visible {
  text-decoration: underline;
  color: var(--color-accent-dark);
}

@media (max-width: 640px) {
  .acep-home-jump__link {
    white-space: normal;
  }
}

.acep-hero__kicker--fec {
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 1.25rem !important;
}

.acep-hero__content--fec {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.acep-hero__actions--fec {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.75rem;
}

.acep-hero__btn--fec-ghost {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid rgba(255, 255, 255, 0.85) !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  font-weight: 700 !important;
  text-transform: none !important;
  letter-spacing: 0.04em !important;
}

.acep-hero__btn--fec-ghost:hover,
.acep-hero__btn--fec-ghost:focus-visible {
  background: rgba(255, 255, 255, 0.12) !important;
  color: #fff !important;
  filter: none !important;
}

/* Conference tile (public home) */
.event-fec-card {
  display: block;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 1.35rem 1.25rem 1.5rem;
  background: var(--fec-ink);
  color: var(--fec-white);
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  text-decoration: none;
  box-shadow:
    0 0 0 1px rgba(245, 130, 32, 0.12),
    0 16px 48px rgba(0, 0, 0, 0.45);
  transition:
    transform 0.25s var(--ease-out),
    box-shadow 0.25s ease,
    border-color 0.2s ease;
}

.event-fec-card:hover,
.event-fec-card:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(245, 130, 32, 0.45);
  box-shadow:
    0 0 0 1px rgba(245, 130, 32, 0.35),
    0 22px 56px rgba(0, 0, 0, 0.55);
  outline: none;
}

.event-fec-card--hero {
  max-width: 28.5rem;
  padding: clamp(1.85rem, 4.2vw, 2.5rem) clamp(1.55rem, 4vw, 2.1rem);
  margin-inline: auto;
}

.event-fec-card--compact {
  padding: 1.15rem 1rem 1.25rem;
}

.event-fec-card__acronym {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-end;
  justify-content: center;
  gap: 0.08em;
  font-family: var(--font-ui, var(--font-sans));
  font-weight: 800;
  line-height: 0.85;
  margin: 0 0 0.85rem;
  letter-spacing: 0.02em;
}

.event-fec-card--hero .event-fec-card__acronym {
  font-size: clamp(2.75rem, 10vw, 4.25rem);
  margin-bottom: 1rem;
}

.event-fec-card--compact .event-fec-card__acronym {
  font-size: clamp(1.65rem, 6vw, 2.15rem);
  margin-bottom: 0.65rem;
}

.event-fec-card__letter {
  color: var(--fec-orange);
}

.event-fec-card__mark {
  display: inline-flex;
  align-items: flex-end;
  line-height: 0;
}

.event-fec-card__globe {
  display: block;
  width: 1em;
  height: 1em;
}

.event-fec-card__mid {
  margin: 0 0 0.65rem;
  text-align: center;
  font-family: var(--font-ui, var(--font-sans));
  font-size: 0.95rem;
  font-weight: 500;
  line-height: 1.35;
}

.event-fec-card--hero .event-fec-card__mid {
  font-size: clamp(0.95rem, 2.4vw, 1.12rem);
  margin-bottom: 0.85rem;
}

.event-fec-card__mid-white {
  color: var(--fec-white);
}

.event-fec-card__mid-orange {
  color: var(--fec-orange);
  font-weight: 700;
}

.event-fec-card__yearline {
  margin: 0;
  text-align: center;
  font-family: var(--font-ui, var(--font-sans));
  font-weight: 800;
  color: var(--fec-white);
  letter-spacing: 0.04em;
  line-height: 1;
}

.event-fec-card--hero .event-fec-card__yearline {
  font-size: clamp(2rem, 7vw, 3rem);
}

.event-fec-card--compact .event-fec-card__yearline {
  font-size: clamp(1.35rem, 4vw, 1.75rem);
}

.event-fec-card__foot {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.35rem 0.65rem;
  margin-top: 1.1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
  font-size: 0.82rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.72);
}

.event-fec-card__foot-item:not(:first-child)::before {
  content: "·";
  margin-right: 0.65rem;
  color: rgba(245, 130, 32, 0.85);
  font-weight: 800;
}

.event-fec-card__loc {
  margin: 0.5rem 0 0;
  text-align: center;
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.55);
}

.acep-event-fec-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.acep-hero__title--event {
  margin: 0 0 1.35rem;
  font-size: clamp(2rem, 5.8vw, 3.65rem);
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: -0.03em;
}

.acep-hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.65rem 1.35rem;
  margin: 0 0 1.85rem;
  font-size: clamp(0.95rem, 2vw, 1.05rem);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.93);
}

.acep-hero__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.acep-hero__meta-icon {
  flex-shrink: 0;
  opacity: 0.88;
}

.acep-hero__actions--center {
  justify-content: center;
}

.acep-hero__kicker {
  margin: 0 0 0.75rem;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(200, 255, 220, 0.95);
}

.acep-hero__title {
  margin: 0 0 1.25rem;
  font-size: clamp(2.15rem, 5.5vw, 3.35rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.acep-hero__lead {
  margin: 0 0 2rem;
  font-size: clamp(1.05rem, 2.2vw, 1.22rem);
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.92);
}

.acep-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.acep-hero__btn {
  border-radius: 6px;
  padding: 0.75rem 1.35rem;
  font-weight: 600;
  font-size: 0.95rem;
}

.acep-hero__btn--cta-pill {
  border-radius: 999px;
  padding: 0.8rem 1.85rem;
  font-weight: 800;
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: linear-gradient(180deg, var(--acep-orange-bright) 0%, var(--acep-orange) 100%);
  color: #fff !important;
  border: none;
  box-shadow: 0 4px 20px rgba(234, 88, 12, 0.38);
}

.acep-hero__btn--cta-pill:hover,
.acep-hero__btn--cta-pill:focus-visible {
  filter: brightness(1.06);
  color: #fff !important;
}

.acep-hero__btn--cta-pill:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 2px #fff,
    0 0 0 4px var(--acep-orange-mid),
    0 4px 22px rgba(234, 88, 12, 0.42);
}

.acep-hero__btn--primary {
  background: linear-gradient(180deg, var(--acep-orange-bright) 0%, var(--acep-orange) 100%);
  color: #fff !important;
  border: none;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 4px 20px rgba(234, 88, 12, 0.35);
}

.acep-hero__btn--primary:hover,
.acep-hero__btn--primary:focus-visible {
  filter: brightness(1.06);
  color: #fff !important;
}

.acep-hero__btn--ghost {
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255, 255, 255, 0.85);
  box-shadow: none;
}

.acep-hero__btn--ghost:hover,
.acep-hero__btn--ghost:focus-visible {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}

/* Vision band */
body.is-home--acep .acep-vision,
body.theme-acep .acep-vision {
  --acep-vision-bg: #f3f4f6;
}

.acep-vision {
  background: var(--acep-vision-bg, #fafcfa);
  border-top: 1px solid rgba(13, 122, 79, 0.1);
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
}

.acep-vision__grid {
  display: grid;
  gap: clamp(1.25rem, 4vw, 2.25rem);
  align-items: start;
}

@media (min-width: 768px) {
  .acep-vision__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
  }
}

.acep-vision__col--lead {
  text-align: left;
}

.acep-vision__col--body {
  text-align: left;
}

.acep-kicker {
  margin: 0 0 0.75rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--acep-orange, var(--color-accent));
}

.acep-vision__headline {
  margin: 0;
  font-size: clamp(1.55rem, 3.5vw, 2.25rem);
  font-weight: 800;
  line-height: 1.18;
  color: #111827;
}

.acep-vision__body {
  color: #4b5563;
  line-height: 1.75;
  font-size: 1.02rem;
}

.acep-vision__body p {
  margin: 0;
}

.acep-vision__more {
  margin: 1rem 0 0;
}

.acep-org-teaser {
  background: #f8faf9;
  border-top: 1px solid rgba(13, 122, 79, 0.08);
  border-bottom: 1px solid rgba(13, 122, 79, 0.08);
}

.acep-org-teaser__inner {
  max-width: 52rem;
}

.acep-org-teaser__kicker {
  margin-bottom: 0.5rem;
}

.acep-org-teaser__text {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.65;
  color: #374151;
}

/* Latest / publication grid */
.acep-latest {
  background: #fff;
}

.acep-news-events {
  background: #fff;
  border-top: 1px solid rgba(13, 122, 79, 0.08);
}

.acep-news-events__header {
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
  padding-bottom: 1rem;
  border-bottom: 3px solid var(--color-accent);
}

.acep-news-events__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #14261a;
}

.acep-news-events__intro {
  margin: 0;
  font-size: 1rem;
  color: var(--color-muted);
  line-height: 1.55;
  max-width: 44rem;
}

.acep-news-events__grid {
  display: grid;
  gap: 2.5rem;
  align-items: start;
}

@media (min-width: 960px) {
  .acep-news-events__grid {
    grid-template-columns: 1.15fr 0.85fr;
    gap: 3rem;
  }

  .acep-news-events__grid--news-only {
    grid-template-columns: 1fr;
    max-width: 48rem;
  }
}

.acep-subsection-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 1.25rem;
  padding-bottom: 0.65rem;
  border-bottom: 2px solid rgba(13, 122, 79, 0.15);
}

.acep-subsection-head__title {
  margin: 0;
  font-family: var(--font-ui, var(--font-sans));
  font-size: 1.05rem;
  font-weight: 800;
  color: #14261a;
  letter-spacing: 0.02em;
}

.acep-subsection-head__link {
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--color-accent);
  text-decoration: none;
  white-space: nowrap;
}

.acep-subsection-head__link:hover,
.acep-subsection-head__link:focus-visible {
  text-decoration: underline;
}

.acep-pub-grid--stacked {
  grid-template-columns: 1fr !important;
}

.acep-section-head {
  display: grid;
  gap: 0.35rem 1.5rem;
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
  border-bottom: 3px solid var(--color-accent);
  padding-bottom: 1rem;
}

@media (min-width: 640px) {
  .acep-section-head {
    grid-template-columns: 1fr auto;
    align-items: end;
  }

  .acep-section-head__link {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
  }
}

.acep-section-head__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.5vw, 1.65rem);
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #14261a;
}

.acep-section-head__sub {
  margin: 0;
  font-size: 0.98rem;
  color: var(--color-muted);
}

.acep-section-head__link {
  font-weight: 700;
  color: var(--color-accent);
  text-decoration: none;
  white-space: nowrap;
}

.acep-section-head__link:hover,
.acep-section-head__link:focus-visible {
  text-decoration: underline;
}

.acep-empty {
  color: var(--color-muted);
  font-size: 1.05rem;
}

.acep-pub-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}

@media (min-width: 700px) {
  .acep-pub-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.acep-pub-grid--secondary {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(13, 122, 79, 0.12);
}

@media (min-width: 700px) {
  .acep-pub-grid--secondary {
    grid-template-columns: repeat(3, 1fr);
  }
}

.acep-pub-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--color-surface);
  border: 1px solid rgba(13, 122, 79, 0.12);
  border-radius: 4px;
  padding: 1.15rem;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 4px 20px rgba(15, 36, 24, 0.06);
  transition:
    transform 0.25s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.25s ease;
}

.acep-pub-card:hover,
.acep-pub-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 12px 36px rgba(15, 36, 24, 0.12);
  outline: none;
}

.acep-pub-card__label {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 0.65rem;
}

.acep-pub-card__media {
  margin: 0 -1.15rem 1rem;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #e8f2ec;
}

.acep-pub-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.acep-pub-card:hover .acep-pub-card__media img {
  transform: scale(1.05);
}

.acep-pub-card__title {
  margin: 0 0 0.4rem;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.25;
  color: #14261a;
}

.acep-pub-card__date {
  margin: 0 0 0.5rem;
  font-size: 0.8rem;
  color: var(--color-muted);
}

.acep-pub-card__excerpt {
  margin: 0 0 0.75rem;
  font-size: 0.92rem;
  color: var(--color-muted);
  line-height: 1.55;
  flex: 1;
}

.acep-pub-card__more {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--color-accent);
  margin-top: auto;
}

.acep-pub-card--compact {
  padding: 1rem 1.15rem;
}

.acep-pub-card--compact .acep-pub-card__title {
  font-size: 1rem;
}

/* Events board */
.acep-events {
  background: var(--color-bg);
}

.acep-event-board {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid rgba(13, 122, 79, 0.12);
  border-radius: var(--radius);
  overflow: hidden;
  background: #fff;
  box-shadow: var(--shadow);
}

.acep-event-row {
  display: grid;
  grid-template-columns: 7.5rem 1fr auto;
  gap: 0.75rem 1rem;
  align-items: center;
  padding: 1rem 1.15rem;
  text-decoration: none;
  color: inherit;
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
  transition: background 0.2s ease;
}

.acep-event-row:last-child {
  border-bottom: none;
}

.acep-event-row:hover,
.acep-event-row:focus-visible {
  background: rgba(13, 122, 79, 0.05);
  outline: none;
}

@media (max-width: 640px) {
  .acep-event-row {
    grid-template-columns: 1fr;
  }

  .acep-event-row__go {
    justify-self: start;
  }
}

.acep-event-row__date {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-accent-dark);
}

.acep-event-row__body {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}

.acep-event-row__title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: #14261a;
}

.acep-event-row__loc {
  font-size: 0.85rem;
  color: var(--color-muted);
}

.acep-event-row__go {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-accent);
  white-space: nowrap;
}

/* Statement + CTA */
.acep-statement {
  background: #fff;
  border-top: 1px solid rgba(13, 122, 79, 0.1);
}

.acep-statement__inner {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  color: var(--color-muted);
  line-height: 1.7;
}

.acep-statement__inner p {
  margin: 0 0 1rem;
}

.acep-cta {
  background: linear-gradient(135deg, #0a3d28 0%, #0d7a4f 48%, #095c3b 100%);
  color: #fff;
  text-align: center;
}

.acep-cta__inner {
  max-width: 40rem;
  margin: 0 auto;
}

.acep-cta__title {
  margin: 0 0 0.75rem;
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3.5vw, 2.35rem);
  font-weight: 700;
}

.acep-cta__text {
  margin: 0 0 1.75rem;
  opacity: 0.95;
  font-size: 1.1rem;
  line-height: 1.6;
}

.acep-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

body.is-home--acep .section-home--slider {
  padding-top: 0;
  background: #0a1a12;
}

/* Footer variant on institute home */
.site-footer--acep .site-footer__heading {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.95;
}

.site-footer--acep .site-footer__grid {
  gap: 2rem 2.5rem;
}

/* Long-form content pages */
.tagline-block {
  font-size: clamp(1.08rem, 2.4vw, 1.32rem);
  font-weight: 700;
  font-family: var(--font-display, Georgia, serif);
  color: var(--color-accent-dark);
  margin: 0 0 1.35rem;
  line-height: 1.38;
  letter-spacing: -0.02em;
  max-width: 42rem;
}

.content-prose {
  max-width: 48rem;
}

.content-prose--compact {
  margin-bottom: 2rem;
}

.content-prose h2 {
  margin: 2rem 0 0.75rem;
  font-size: 1.25rem;
}

body.theme-acep .content-prose h2 {
  font-family: var(--font-display);
  font-size: 1.22rem;
  font-weight: 700;
  color: #14261a;
  letter-spacing: -0.02em;
}

.content-prose h2:first-child {
  margin-top: 0;
}

.content-prose h3 {
  margin: 1.5rem 0 0.5rem;
  font-size: 1.05rem;
}

.content-prose p {
  margin: 0 0 1rem;
}

/* ----- Photos & media (galleries, prose images, image-heavy pages) ----- */
.content-prose img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 1.25rem auto;
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
}

.content-prose figure {
  margin: 1.75rem 0;
}

.content-prose figure img {
  margin: 0 auto;
}

.content-prose figcaption {
  margin: 0.6rem 0 0;
  font-size: 0.9rem;
  color: var(--color-muted);
  text-align: center;
  line-height: 1.45;
}

.media-frame {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  background: var(--color-surface);
  line-height: 0;
}

.media-frame img {
  display: block;
  width: 100%;
  height: auto;
}

.photo-grid {
  list-style: none;
  margin: 1.5rem 0 2rem;
  padding: 0;
  display: grid;
  gap: 1.15rem;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr));
}

.photo-grid__figure {
  margin: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.photo-grid__frame {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  background: #e8eeea;
  aspect-ratio: 4 / 3;
}

.photo-grid__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s var(--ease-out);
}

.img-hover-zoom:hover .photo-grid__img,
.img-hover-zoom:focus-within .photo-grid__img {
  transform: scale(1.04);
}

.photo-grid__caption {
  margin: 0.55rem 0 0;
  font-size: 0.88rem;
  line-height: 1.4;
  color: var(--color-muted);
}

.section--media-rich {
  padding: 2.75rem 0;
}

.section--media-rich .section__title {
  margin-bottom: 0.75rem;
}

.content-card {
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
}

.content-card:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.content-list {
  margin: 0 0 1rem;
  padding-left: 1.25rem;
}

.content-list li {
  margin-bottom: 0.35rem;
}

.content-list--values li {
  margin-bottom: 0.6rem;
}

.content-list--ordered {
  list-style: decimal;
}

.text-muted,
.muted {
  color: var(--color-muted);
  font-size: 0.98rem;
}

.btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

/* Restructured site: alignment strip, home grids, CTAs */
.ghna-alignment-strip {
  background: linear-gradient(90deg, rgba(13, 122, 79, 0.12) 0%, rgba(13, 122, 79, 0.04) 100%);
  border-top: 1px solid rgba(13, 122, 79, 0.1);
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
  padding: 0.85rem 0 !important;
}

.ghna-alignment-strip__inner {
  margin: 0;
  text-align: center;
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--color-text);
}

.ghna-alignment-strip__inner p {
  margin: 0;
  line-height: 1.5;
}

body.is-home--acep .ghna-alignment-strip,
.ghna-alignment-strip--home {
  background: rgba(10, 31, 20, 0.06);
}

.ghna-home-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 1rem;
}

@media (min-width: 600px) {
  .ghna-home-grid--five {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 980px) {
  .ghna-home-grid--five {
    grid-template-columns: repeat(5, 1fr);
    gap: 0.85rem;
  }
}

.ghna-home-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1.2rem 1.05rem 1.05rem;
  background: linear-gradient(165deg, #fff 0%, #fafcfb 100%);
  border: 1px solid rgba(13, 122, 79, 0.12);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  text-decoration: none;
  color: inherit;
  transition:
    border-color 0.25s var(--ease-out),
    box-shadow 0.28s var(--ease-out),
    transform 0.28s var(--ease-out);
}

.ghna-home-card:hover,
.ghna-home-card:focus-visible {
  border-color: rgba(13, 122, 79, 0.35);
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
  outline: none;
}

.ghna-home-card:focus-visible {
  box-shadow: var(--shadow-lg), 0 0 0 2px #fff, 0 0 0 4px var(--color-accent);
}

.ghna-home-card__num {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--color-accent);
  letter-spacing: 0.08em;
  margin-bottom: 0.35rem;
}

.ghna-home-card__title {
  margin: 0 0 0.5rem;
  font-size: 1.02rem;
  line-height: 1.25;
  font-family: var(--font-display);
  color: #14261a;
}

.programmes-card__title--acep {
  font-size: 0.82rem !important;
  line-height: 1.3 !important;
}

.ghna-home-card--compact .ghna-home-card__title {
  font-size: 0.92rem;
}

.ghna-home-card__text {
  margin: 0 0 0.75rem;
  flex: 1 1 auto;
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--color-muted);
}

.ghna-home-card__more {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-accent);
}

.section-home--value-chain {
  background: #f3faf6;
  padding-top: 2.5rem !important;
  padding-bottom: 2.5rem !important;
}

.section-home--programmes-preview,
.acep-section-tight {
  padding-top: 2.25rem !important;
  padding-bottom: 2.25rem !important;
}

.section-home--programmes-preview {
  background: var(--color-surface);
}

.content-prose article[id],
.content-prose h2[id],
.content-card[id] {
  scroll-margin-top: var(--header-sticky-offset);
}

.acep-section-extra {
  margin: 1.25rem 0 0;
  text-align: center;
}

.acep-focus-grid .ghna-home-card {
  background: #fff;
}

.cta-band__actions--triple,
.acep-cta__actions--triple {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  justify-content: center;
}

.btn--outline {
  background: transparent;
  color: var(--color-accent-dark);
  box-shadow: inset 0 0 0 2px var(--color-accent);
}

.btn--outline:hover,
.btn--outline:focus-visible {
  background: rgba(13, 122, 79, 0.08);
}

.section__title--subsection {
  font-size: 1.35rem;
  margin-top: 2.5rem;
}

.site-footer__heading--follow {
  margin-top: 1.35rem;
  margin-bottom: 0.5rem;
  font-size: 0.72rem;
}

.section-home__footer-dot {
  display: inline-block;
  margin: 0 0.45rem;
  opacity: 0.45;
  font-weight: 400;
}

/* Team page (institute directory; content from Admin → Team / leadership + Content) */
.team-page__inner {
  max-width: 58rem;
}

.team-page__title {
  text-align: center;
  margin-bottom: 0.65rem;
}

.team-page__intro {
  text-align: center;
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2rem;
}

.team-page__empty {
  color: var(--color-muted);
  padding: 2rem;
  text-align: center;
  border: 1px dashed rgba(13, 122, 79, 0.25);
  border-radius: var(--radius);
}

.team-directory {
  border: 1px solid rgba(21, 74, 132, 0.18);
  border-radius: 6px;
  overflow: hidden;
  margin-bottom: 2.5rem;
  background: #fff;
  box-shadow: 0 1px 0 rgba(15, 36, 24, 0.04);
}

.team-member {
  display: grid;
  grid-template-columns: minmax(140px, 200px) 1fr;
  gap: clamp(1.1rem, 3vw, 1.75rem);
  align-items: start;
  padding: clamp(1.25rem, 3vw, 1.75rem) clamp(1rem, 3vw, 1.5rem);
  border-bottom: 1px solid rgba(21, 74, 132, 0.12);
}

a.team-member--link {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition:
    background 0.18s ease,
    box-shadow 0.18s ease;
}

a.team-member--link:hover {
  background: rgba(21, 74, 132, 0.045);
}

a.team-member--link:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.team-member:last-child {
  border-bottom: none;
}

@media (max-width: 640px) {
  .team-member {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }

  .team-member__body {
    width: 100%;
  }
}

.team-member__photo {
  flex-shrink: 0;
  border-radius: 6px;
  overflow: hidden;
  background: #e8eef5;
  aspect-ratio: 4 / 5;
  max-height: 280px;
}

.team-member__photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.team-member__photo--placeholder {
  min-height: 200px;
  background: linear-gradient(145deg, #eef4f8 0%, #dde7ef 100%);
}

.team-member__name {
  margin: 0 0 0.35rem;
  font-size: clamp(1.15rem, 2.5vw, 1.35rem);
  font-weight: 800;
  color: #153b5c;
  line-height: 1.2;
}

body.theme-acep .team-member__name {
  font-family: var(--font-ui, var(--font-sans));
  letter-spacing: 0.02em;
}

.team-member__role {
  margin: 0 0 0.85rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: #5b6478;
  line-height: 1.35;
}

.team-member__bio {
  font-size: 0.98rem;
  color: var(--color-text);
  line-height: 1.65;
}

.team-member__bio p {
  margin: 0;
}

.team-member__linkedin {
  margin: 0.85rem 0 0;
  font-size: 0.9rem;
}

.team-member__linkedin-hint {
  font-weight: 600;
  color: var(--color-accent-dark);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.15em;
}

a.team-member--link:hover .team-member__linkedin-hint {
  color: var(--color-accent);
}

/* Leadership structure diagram + outline (Team page) */
.leadership-structure {
  margin-top: 3rem;
  padding-top: 2.5rem;
  border-top: 1px solid rgba(21, 74, 132, 0.15);
}

.leadership-structure__heading {
  margin: 0 0 0.65rem;
  font-size: clamp(1.15rem, 2.5vw, 1.45rem);
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.2;
  color: #153b5c;
  text-align: center;
  text-transform: uppercase;
}

.leadership-structure__lede {
  margin: 0 auto 1.75rem;
  max-width: 40rem;
  text-align: center;
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--color-muted);
}

.leadership-structure__figure {
  margin: 0 0 2.25rem;
  padding: 0;
}

.leadership-structure__figure-inner {
  background: linear-gradient(180deg, #f6f9fc 0%, #eef4f8 100%);
  border: 1px solid rgba(21, 74, 132, 0.14);
  border-radius: calc(var(--radius) + 2px);
  box-shadow: var(--shadow-md);
  padding: clamp(0.85rem, 2.5vw, 1.35rem);
  overflow: hidden;
}

.leadership-structure__chart {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 auto;
}

.leadership-structure__caption {
  margin: 0.85rem 0 0;
  font-size: 0.88rem;
  line-height: 1.45;
  color: var(--color-muted);
  text-align: center;
}

.leadership-structure__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
}

.leadership-structure__item {
  margin: 0;
  padding: 1.15rem 1.25rem;
  background: var(--color-surface);
  border: 1px solid rgba(13, 122, 79, 0.12);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border-left: 4px solid var(--color-accent);
}

.leadership-structure__item:nth-child(2) {
  border-left-color: #1a5f7a;
}

.leadership-structure__item:nth-child(3) {
  border-left-color: #f58220;
}

.leadership-structure__item:nth-child(4) {
  border-left-color: #0d7a4f;
}

.leadership-structure__item:nth-child(5) {
  border-left-color: #2e6b9e;
}

.leadership-structure__item:nth-child(6) {
  border-left-color: #153b5c;
}

.leadership-structure__item--wide {
  grid-column: 1 / -1;
}

@media (min-width: 720px) {
  .leadership-structure__item--wide {
    grid-column: span 2;
  }
}

@media (min-width: 1100px) {
  .leadership-structure__list {
    grid-template-columns: repeat(3, 1fr);
  }

  .leadership-structure__item--wide {
    grid-column: 1 / -1;
  }
}

.leadership-structure__role {
  margin: 0 0 0.4rem;
  font-size: 1.02rem;
  font-weight: 700;
  color: var(--color-accent-dark);
  line-height: 1.25;
}

.leadership-structure__desc {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-text);
}

.leadership-structure__sub {
  margin: 0.75rem 0 0;
  padding: 0.65rem 0 0 1.15rem;
  border-top: 1px solid rgba(13, 122, 79, 0.1);
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--color-muted);
}

.leadership-structure__sub li {
  margin-bottom: 0.35rem;
}

.leadership-structure__sub li:last-child {
  margin-bottom: 0;
}

.leadership-structure__note {
  margin: 1.75rem 0 0;
  font-size: 0.9rem;
  color: var(--color-muted);
  text-align: center;
}

body.theme-acep .leadership-structure__heading,
body.theme-acep .leadership-structure__role {
  font-family: var(--font-ui, var(--font-sans));
}

/* ----- Events detail, events page news, global news rail ----- */
[id^='e-'] {
  scroll-margin-top: var(--header-sticky-offset);
}

.events-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1.25rem;
  margin: 0 0 2rem;
  padding: 0;
}

.events-subnav__link {
  font-weight: 600;
  font-size: 0.98rem;
  color: var(--color-accent);
  text-decoration: none;
  border-bottom: 2px solid rgba(13, 122, 79, 0.25);
}

.events-subnav__link:hover,
.events-subnav__link:focus-visible {
  border-bottom-color: var(--color-accent);
  color: var(--color-accent-dark);
}

/* News & spotlights block on events.php (#events-news) */
.events-news {
  margin-top: 3rem;
  padding-top: 2.5rem;
}

.events-news__panel {
  background: linear-gradient(165deg, var(--color-surface) 0%, #f8faf9 100%);
  border: 1px solid rgba(13, 122, 79, 0.12);
  border-radius: calc(var(--radius) + 4px);
  box-shadow: var(--shadow-md);
  padding: clamp(1.75rem, 4vw, 2.5rem);
}

.events-news__head {
  margin-bottom: 1.75rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
}

.events-news__eyebrow {
  margin: 0 0 0.4rem;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
}

.events-news__title {
  margin: 0 0 0.65rem;
  font-size: clamp(1.35rem, 3vw, 1.65rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--color-accent-dark);
}

.events-news__intro {
  margin: 0 0 1rem;
  max-width: 44rem;
  font-size: 1.02rem;
  line-height: 1.55;
  color: var(--color-muted);
}

.events-news__all-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-accent-dark);
  text-decoration: none;
  border-bottom: 2px solid rgba(13, 122, 79, 0.28);
  padding-bottom: 1px;
  transition:
    color 0.2s ease,
    border-color 0.2s ease;
}

.events-news__all-link::after {
  content: "→";
  font-size: 0.9em;
  opacity: 0.85;
}

.events-news__all-link:hover,
.events-news__all-link:focus-visible {
  color: var(--color-accent);
  border-bottom-color: var(--color-accent);
}

.events-news__empty {
  margin: 0;
  padding: 1.25rem 1.35rem;
  background: var(--color-accent-soft);
  border-radius: var(--radius);
  color: var(--color-text);
  font-size: 1rem;
}

.events-news__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
}

.events-news__cell {
  margin: 0;
}

.events-news-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--color-surface);
  border: 1px solid rgba(13, 122, 79, 0.1);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition:
    box-shadow 0.25s var(--ease-out),
    border-color 0.25s ease,
    transform 0.25s var(--ease-out);
}

.events-news-card:hover,
.events-news-card:focus-visible {
  border-color: rgba(13, 122, 79, 0.22);
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.events-news-card:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.events-news-card__media {
  aspect-ratio: 16 / 9;
  background: #e8eeea;
  overflow: hidden;
}

.events-news-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.events-news-card__media--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(13, 122, 79, 0.08) 0%, rgba(13, 122, 79, 0.03) 100%);
}

.events-news-card__ph {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(9, 92, 59, 0.45);
}

.events-news-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1.15rem 1.2rem 1.25rem;
}

.events-news-card__title {
  margin: 0 0 0.5rem;
  font-size: 1.06rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--color-accent-dark);
}

.events-news-card__summary {
  margin: 0 0 0.85rem;
  font-size: 0.94rem;
  line-height: 1.55;
  color: var(--color-muted);
  flex: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.events-news-card__cta {
  margin-top: auto;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-accent);
}

.events-news-card:hover .events-news-card__cta,
.events-news-card:focus-visible .events-news-card__cta {
  color: var(--color-accent-dark);
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

body.theme-acep .events-news__title,
body.theme-acep .events-news-card__title {
  font-family: var(--font-ui, var(--font-sans));
}

/* —— Event detail (single event / conference page) —— */
.event-detail {
  padding: 0;
  background: var(--color-bg);
}

.event-detail__hero {
  background:
    linear-gradient(152deg, rgba(13, 122, 79, 0.09) 0%, rgba(255, 255, 255, 0.55) 38%, rgba(244, 247, 245, 0.98) 100%),
    var(--color-surface);
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
  padding: 2.35rem 0 2.65rem;
}

.event-detail__crumb {
  font-size: 0.88rem;
  margin: 0 0 1.2rem;
  color: var(--color-muted);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.55rem;
}

.event-detail__crumb-link {
  color: var(--color-accent-dark);
  font-weight: 600;
  text-decoration: none;
}

.event-detail__crumb-link:hover,
.event-detail__crumb-link:focus-visible {
  text-decoration: underline;
}

.event-detail__crumb-current {
  color: var(--color-text);
  font-weight: 600;
}

.event-detail__crumb-sep {
  opacity: 0.42;
  margin: 0 0.1rem;
}

.event-detail__title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.85rem 1.35rem;
  margin-bottom: 1.5rem;
}

.event-detail__title {
  margin: 0;
  flex: 1 1 16rem;
  min-width: 0;
  font-size: clamp(1.68rem, 4.6vw, 2.42rem);
  font-weight: 800;
  letter-spacing: -0.038em;
  line-height: 1.1;
  color: var(--color-accent-dark);
}

.event-detail__title-row .event-detail__status {
  margin: 0.4rem 0 0;
  flex-shrink: 0;
}

.event-detail__status {
  margin: 0 0 1.25rem;
}

.event-detail__badge {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.38rem 0.75rem;
  border-radius: 999px;
  background: rgba(13, 122, 79, 0.14);
  color: var(--color-accent-dark);
  border: 1px solid rgba(13, 122, 79, 0.2);
}

.event-detail__badge--past {
  background: rgba(91, 100, 120, 0.1);
  color: var(--color-muted);
  border-color: rgba(91, 100, 120, 0.18);
}

.event-detail__facts {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(auto-fit, minmax(13.5rem, 1fr));
  max-width: 52rem;
}

.event-detail__fact {
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(13, 122, 79, 0.12);
  border-radius: 14px;
  padding: 0.85rem 1.05rem;
  box-shadow: 0 1px 0 rgba(15, 36, 24, 0.04);
}

.event-detail__fact-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: rgba(9, 92, 59, 0.72);
  margin-bottom: 0.4rem;
}

.event-detail__fact-value {
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.4;
}

.event-detail__body-wrap {
  padding: 2.5rem 0 3.75rem;
  max-width: 52rem;
  margin-inline: auto;
}

.event-detail__prose {
  font-size: 1.06rem;
  line-height: 1.78;
  color: var(--color-text);
  margin: 0 0 2rem;
  max-width: 50rem;
}

.event-detail__cta-card {
  margin: 0 0 2.5rem;
  padding: 1.4rem 1.5rem 1.45rem 1.65rem;
  background: var(--color-surface);
  border-radius: 16px;
  border: 1px solid rgba(13, 122, 79, 0.13);
  box-shadow: var(--shadow-md);
  position: relative;
}

.event-detail__cta-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, var(--color-accent) 0%, rgba(13, 122, 79, 0.35) 100%);
  border-radius: 16px 0 0 16px;
}

.event-detail__cta-card .event-detail__actions {
  margin: 0;
}

.event-detail__actions {
  margin: 0 0 2.5rem;
}

.event-detail__btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1rem;
  align-items: center;
}

.event-detail__register-note {
  margin: 0.85rem 0 0;
  max-width: 44rem;
  font-size: 0.96rem;
  line-height: 1.55;
  color: var(--color-muted);
}

.event-detail__alert {
  max-width: 50rem;
  padding: 1.15rem 1.35rem;
  border-radius: 14px;
  margin: 0 0 1.75rem;
  font-size: 0.98rem;
  line-height: 1.55;
}

.event-detail__alert--success {
  background: linear-gradient(135deg, rgba(13, 122, 79, 0.11) 0%, rgba(13, 122, 79, 0.05) 100%);
  border: 1px solid rgba(13, 122, 79, 0.28);
  color: var(--color-text);
}

.event-detail__alert--error {
  background: rgba(180, 60, 50, 0.08);
  border: 1px solid rgba(180, 60, 50, 0.35);
  color: var(--color-text);
}

.event-detail__alert p {
  margin: 0.4rem 0 0;
}

.event-detail__register-panel {
  max-width: 48rem;
  margin: 0 0 2.5rem;
  padding: 1.5rem 1.35rem 1.65rem;
  background:
    linear-gradient(180deg, rgba(13, 122, 79, 0.045) 0%, var(--color-surface) 4rem),
    var(--color-surface);
  border: 1px solid rgba(13, 122, 79, 0.14);
  border-radius: 16px;
  box-shadow:
    0 8px 32px rgba(15, 36, 24, 0.07),
    0 1px 0 rgba(255, 255, 255, 0.75) inset;
}

body.theme-acep .event-detail__title {
  font-family: var(--font-ui, var(--font-sans));
}

body.theme-acep .event-detail__hero {
  background:
    linear-gradient(155deg, rgba(10, 31, 20, 0.06) 0%, rgba(255, 255, 255, 0.97) 45%, #fff 100%);
  border-bottom-color: rgba(15, 36, 24, 0.08);
}

body.theme-acep .event-detail__fact {
  background: rgba(255, 255, 255, 0.92);
}

.event-detail__reg-section-title {
  font-size: 1.28rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 0.85rem;
  color: var(--color-accent-dark);
}

.event-detail__reg-lead {
  margin: 0 0 1.35rem;
  font-size: 1.02rem;
  line-height: 1.65;
  color: var(--color-text);
}

.event-detail__reg-lead.lead {
  font-size: 1.05rem;
}

.event-reg-form__header {
  margin-bottom: 1.5rem;
  padding-bottom: 1.2rem;
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
}

.event-reg-form .form-group {
  margin-bottom: 0;
}

.event-reg-form__section {
  margin-bottom: 1.25rem;
  padding: 1.15rem 1.2rem 1.3rem;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(13, 122, 79, 0.1);
  border-radius: 14px;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.88) inset;
}

.event-reg-form__section:last-of-type {
  margin-bottom: 0;
}

.event-reg-form__section--footer {
  background: rgba(13, 122, 79, 0.045);
  border-color: rgba(13, 122, 79, 0.14);
}

.event-reg-form__section-title {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  font-size: 1.02rem;
  font-weight: 800;
  letter-spacing: -0.018em;
  margin: 0 0 1.05rem;
  color: var(--color-accent-dark);
  line-height: 1.28;
}

.event-reg-form__step {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.72rem;
  height: 1.72rem;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--color-accent) 0%, var(--color-accent-dark) 100%);
  color: #fff;
  font-size: 0.88rem;
  font-weight: 800;
  box-shadow: 0 2px 10px rgba(13, 122, 79, 0.28);
}

.event-reg-form__fields {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.event-reg-form__fieldset--flush {
  margin: 0;
  padding: 0;
  border: 0;
}

.event-reg-form__row2 {
  display: grid;
  gap: 1rem 1.15rem;
  grid-template-columns: 1fr;
}

@media (min-width: 560px) {
  .event-reg-form__row2 {
    grid-template-columns: 1fr 1fr;
  }
}

.event-reg-form__label {
  display: block;
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--color-text);
  margin-bottom: 0.36rem;
}

.event-reg-form__label--block {
  margin-bottom: 0.45rem;
}

.event-reg-form__optional {
  font-weight: 500;
  color: var(--color-muted);
  font-size: 0.88em;
}

.event-reg-form__micro {
  margin: 0 0 0.55rem;
  font-size: 0.86rem;
  color: var(--color-muted);
  line-height: 1.45;
}

.event-reg-form__choice-block .event-reg-form__micro {
  margin-top: -0.15rem;
}

.event-reg-form__name-grid {
  display: grid;
  gap: 0.85rem 1rem;
  grid-template-columns: minmax(0, 10rem) 1fr 1fr;
}

.event-reg-form select,
.event-reg-form input[type="text"],
.event-reg-form input[type="email"],
.event-reg-form input[type="tel"],
.event-reg-form input[type="number"] {
  width: 100%;
  max-width: none;
  padding: 0.62rem 0.78rem;
  border: 1px solid rgba(15, 36, 24, 0.13);
  border-radius: 10px;
  font: inherit;
  background: #fff;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.event-reg-form select:focus,
.event-reg-form input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-soft);
}

.event-reg-form textarea {
  width: 100%;
  max-width: none;
  padding: 0.62rem 0.78rem;
  border: 1px solid rgba(15, 36, 24, 0.13);
  border-radius: 10px;
  font: inherit;
}

.event-reg-form__radios {
  list-style: none;
  margin: 0;
  padding: 0;
}

.event-reg-form__radios li {
  margin: 0;
}

.event-reg-form__radios--inline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.event-reg-form__radios--grid {
  display: grid;
  gap: 0.45rem 0.6rem;
  grid-template-columns: 1fr;
}

@media (min-width: 480px) {
  .event-reg-form__radios--grid {
    grid-template-columns: 1fr 1fr;
  }
}

.event-reg-form__radios--hear {
  grid-template-columns: 1fr;
}

@media (min-width: 600px) {
  .event-reg-form__radios--hear {
    grid-template-columns: 1fr 1fr;
  }
}

.event-reg-form__radios--stack {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.event-reg-form__chip {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  margin: 0;
  padding: 0.5rem 0.78rem;
  min-height: 2.7rem;
  border-radius: 10px;
  border: 1px solid rgba(15, 36, 24, 0.11);
  background: rgba(255, 255, 255, 0.98);
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    background 0.15s ease,
    box-shadow 0.15s ease;
  font-size: 0.91rem;
  font-weight: 500;
  line-height: 1.32;
}

.event-reg-form__chip:hover {
  border-color: rgba(13, 122, 79, 0.35);
}

.event-reg-form__chip:has(input:checked) {
  border-color: var(--color-accent);
  background: rgba(13, 122, 79, 0.09);
  box-shadow: 0 0 0 1px rgba(13, 122, 79, 0.15);
}

.event-reg-form__chip input {
  flex-shrink: 0;
  width: 1.08rem;
  height: 1.08rem;
  accent-color: var(--color-accent);
}

.event-reg-form__chip--wide {
  align-items: flex-start;
}

.event-reg-form__chip--wide span {
  flex: 1;
  min-width: 0;
}

.event-reg-form__hint {
  display: block;
  font-size: 0.84rem;
  color: var(--color-muted);
  margin-top: 0.35rem;
  line-height: 1.4;
}

.event-reg-form__note {
  font-size: 0.86rem;
  color: var(--color-muted);
  margin: 0.75rem 0 0;
  line-height: 1.5;
  padding: 0.65rem 0.9rem;
  background: rgba(13, 122, 79, 0.07);
  border-radius: 10px;
  border-left: 3px solid var(--color-accent);
}

.event-reg-form__captcha-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1rem;
  margin-top: 0.35rem;
}

.event-reg-form__captcha-img {
  border-radius: 10px;
  border: 1px solid rgba(15, 36, 24, 0.12);
}

.event-reg-form__captcha-input {
  max-width: 12rem;
}

.event-reg-form__math {
  font-weight: 700;
  margin: 0.35rem 0 0.25rem;
  color: var(--color-text);
}

.event-reg-form__submit-wrap {
  margin-top: 0.35rem;
  padding-top: 0.5rem;
}

.event-reg-form__submit {
  margin-top: 0;
  min-width: 12rem;
}

.event-reg-form__check {
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  font-weight: 500;
  line-height: 1.5;
  padding: 0.65rem 0.75rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(13, 122, 79, 0.08);
  cursor: pointer;
}

.event-reg-form__check input {
  margin-top: 0.2rem;
  accent-color: var(--color-accent);
  flex-shrink: 0;
}

@media (max-width: 640px) {
  .event-reg-form__name-grid {
    grid-template-columns: 1fr;
  }
}

.event-detail__register-intro {
  margin: 0 0 1rem;
  font-size: 0.95rem;
  color: var(--color-muted);
}

.event-detail__req {
  color: var(--color-accent-dark);
  font-weight: 700;
}

.event-detail__hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.event-detail__form-grid {
  display: grid;
  gap: 1rem 1.25rem;
  margin-bottom: 1.15rem;
}

@media (min-width: 560px) {
  .event-detail__form-grid {
    grid-template-columns: 1fr 1fr;
  }

  .event-detail__form-grid--full {
    grid-column: 1 / -1;
  }
}

.event-detail__subhead {
  font-size: 1.12rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-accent-dark);
  margin: 0 0 1.1rem;
}

.event-detail__spotlights {
  margin-top: 0.5rem;
  padding-top: 2.25rem;
  border-top: 1px solid rgba(13, 122, 79, 0.12);
}

.event-detail__spotlight-cards {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.85rem;
  grid-template-columns: 1fr;
}

@media (min-width: 700px) {
  .event-detail__spotlight-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

.event-detail__spotlight-card {
  margin: 0;
}

.event-detail__spotlight-link {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  height: 100%;
  min-height: 100%;
  padding: 1.05rem 1.15rem;
  text-decoration: none;
  color: inherit;
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(13, 122, 79, 0.11);
  border-radius: 14px;
  transition:
    box-shadow 0.22s var(--ease-out),
    border-color 0.2s ease,
    transform 0.2s var(--ease-out);
}

.event-detail__spotlight-link:hover,
.event-detail__spotlight-link:focus-visible {
  border-color: rgba(13, 122, 79, 0.28);
  box-shadow: var(--shadow-md);
  outline: none;
  transform: translateY(-2px);
}

.event-detail__spotlight-title {
  font-weight: 700;
  font-size: 1.02rem;
  color: var(--color-accent-dark);
  line-height: 1.3;
}

.event-detail__spotlight-sum {
  font-size: 0.9rem;
  color: var(--color-muted);
  line-height: 1.5;
  font-weight: 400;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.event-detail__spotlights-foot {
  margin: 1.35rem 0 0;
}

.event-detail__spotlights-all {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--color-accent);
  text-decoration: none;
}

.event-detail__spotlights-all:hover,
.event-detail__spotlights-all:focus-visible {
  color: var(--color-accent-dark);
  text-decoration: underline;
}

.site-news-rail {
  background: linear-gradient(180deg, rgba(13, 122, 79, 0.06) 0%, rgba(250, 252, 251, 1) 100%);
  border-top: 1px solid rgba(13, 122, 79, 0.08);
  padding: 2.25rem 0;
}

.site-news-rail__title {
  margin: 0 0 1.25rem;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-accent-dark);
}

.site-news-rail__grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.site-news-rail__col-title {
  margin: 0 0 0.65rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text);
}

.site-news-rail__list {
  margin: 0;
  padding-left: 1.15rem;
  font-size: 0.95rem;
}

.site-news-rail__list li {
  margin-bottom: 0.45rem;
}

.site-news-rail__list a {
  font-weight: 600;
}

.site-news-rail__meta {
  display: block;
  font-size: 0.82rem;
  color: var(--color-muted);
  font-weight: 400;
}

.site-news-rail__more {
  margin: 0.85rem 0 0;
  font-size: 0.92rem;
}

body.theme-acep .site-news-rail__title {
  font-family: var(--font-ui, var(--font-sans));
}

/* ----- What we do — In action (visual companion page) ----- */
.what-we-do__visual-promo {
  margin: -0.35rem 0 1.75rem;
}

.what-we-do__visual-promo-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: 700;
  font-size: 1rem;
  color: var(--color-accent-dark);
  text-decoration: none;
  padding: 0.55rem 0;
  border-bottom: 2px solid rgba(13, 122, 79, 0.35);
  transition:
    color 0.2s ease,
    border-color 0.2s ease;
}

.what-we-do__visual-promo-link::after {
  content: "→";
  font-size: 0.95em;
}

.what-we-do__visual-promo-link:hover,
.what-we-do__visual-promo-link:focus-visible {
  color: var(--color-accent);
  border-bottom-color: var(--color-accent);
}

/* What we do — Capacity pillar (#capacity): structured, neat layout */
.wwd-pillar-detail--capacity {
  margin: 0 0 2.25rem;
  padding: 0;
  border-bottom: 1px solid rgba(13, 122, 79, 0.12);
  padding-bottom: 2rem;
}

.wwd-pillar-detail--capacity + .content-card {
  padding-top: 0.15rem;
}

.wwd-pillar-detail__hero {
  position: relative;
  margin: 0 0 0;
  padding: 0;
  border-radius: calc(var(--radius) + 6px);
  overflow: hidden;
  background: linear-gradient(152deg, #1e88e5 0%, #1565c0 42%, #0d3d7a 72%, #082f52 100%);
  color: #fff;
  box-shadow:
    0 16px 40px -8px rgba(13, 71, 130, 0.35),
    0 1px 0 rgba(255, 255, 255, 0.14) inset;
}

.wwd-pillar-detail__hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 55% at 100% 0%, rgba(255, 255, 255, 0.14) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 0% 100%, rgba(0, 0, 0, 0.12) 0%, transparent 50%);
  pointer-events: none;
}

.wwd-pillar-detail__hero-inner {
  position: relative;
  z-index: 1;
  padding: clamp(1.5rem, 4.5vw, 2.15rem) clamp(1.25rem, 3.5vw, 2rem);
  max-width: 40rem;
}

.wwd-pillar-detail__eyebrow {
  margin: 0 0 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.wwd-pillar-detail__eyebrow-text {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.9;
}

.wwd-pillar-detail__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.5rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.38);
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.wwd-pillar-detail__title {
  margin: 0 0 0.65rem;
  font-size: clamp(1.4rem, 3.4vw, 1.85rem);
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: -0.025em;
  text-shadow: 0 1px 14px rgba(0, 0, 0, 0.2);
}

.wwd-pillar-detail__summary {
  margin: 0;
  font-size: clamp(0.94rem, 2vw, 1.04rem);
  line-height: 1.58;
  opacity: 0.93;
}

.wwd-pillar-detail__surface {
  margin-top: 1.25rem;
  padding: clamp(1.25rem, 3vw, 1.65rem);
  background: var(--color-surface);
  border: 1px solid rgba(21, 101, 192, 0.11);
  border-radius: calc(var(--radius) + 4px);
  box-shadow: 0 1px 0 rgba(15, 36, 24, 0.04);
}

.wwd-pillar-detail__quickfacts {
  list-style: none;
  margin: 0 0 1.35rem;
  padding: 0 0 1.25rem;
  display: grid;
  gap: 0.65rem 1rem;
  border-bottom: 1px solid rgba(13, 122, 79, 0.09);
}

@media (min-width: 640px) {
  .wwd-pillar-detail__quickfacts {
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem 1.25rem;
    margin-bottom: 1.5rem;
    padding-bottom: 1.35rem;
  }
}

.wwd-pillar-detail__quickfact {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.45;
  font-weight: 600;
  color: #2c3d4f;
}

.wwd-pillar-detail__quickfact-mark {
  flex-shrink: 0;
  width: 0.4rem;
  height: 0.4rem;
  margin-top: 0.38rem;
  border-radius: 50%;
  background: linear-gradient(145deg, #42a5f5 0%, #1565c0 100%);
  box-shadow: 0 0 0 2px rgba(21, 101, 192, 0.2);
}

.wwd-pillar-detail__quickfact-text {
  min-width: 0;
}

.wwd-pillar-detail__layout {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

@media (min-width: 960px) {
  .wwd-pillar-detail__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
    gap: 1.75rem 2rem;
    align-items: start;
  }

  .wwd-pillar-detail__focus {
    margin: 0;
  }
}

.wwd-pillar-detail__lead {
  margin: 0 0 1.15rem;
  font-size: 1.02rem;
  line-height: 1.68;
  color: var(--color-text);
}

.wwd-pillar-detail__primary .wwd-pillar-detail__lead:last-child {
  margin-bottom: 0;
}

.wwd-pillar-detail__programme {
  margin: 0;
  padding: 1.05rem 1.15rem 1.15rem;
  background: #f8fafc;
  border: 1px solid rgba(21, 101, 192, 0.12);
  border-radius: calc(var(--radius) - 2px);
}

.wwd-pillar-detail__programme-head {
  margin-bottom: 0.65rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid rgba(21, 101, 192, 0.1);
}

.wwd-pillar-detail__programme-kicker {
  display: block;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1565c0;
  margin-bottom: 0.35rem;
}

.wwd-pillar-detail__programme-title {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 800;
  line-height: 1.3;
  color: #142a40;
  letter-spacing: -0.015em;
}

.wwd-pillar-detail__programme-intro {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.65;
  color: var(--color-text);
}

.wwd-pillar-detail__focus-head {
  margin-bottom: 0.9rem;
}

.wwd-pillar-detail__focus-title {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--color-accent-dark);
}

.wwd-pillar-detail__focus-sub {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--color-muted);
}

.wwd-pillar-detail__focus-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.75rem;
  grid-template-columns: 1fr;
}

@media (min-width: 520px) {
  .wwd-pillar-detail__focus-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.wwd-pillar-detail__focus-card {
  display: flex;
  gap: 0.75rem;
  align-items: stretch;
  margin: 0;
  min-height: 100%;
  padding: 0.95rem 1rem;
  background: #fff;
  border: 1px solid rgba(21, 101, 192, 0.1);
  border-radius: 10px;
  box-shadow: 0 1px 3px rgba(15, 36, 24, 0.04);
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}

.wwd-pillar-detail__focus-card:hover {
  border-color: rgba(21, 101, 192, 0.28);
  box-shadow: 0 4px 16px rgba(13, 61, 122, 0.08);
}

.wwd-pillar-detail__focus-num {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.95rem;
  height: 1.95rem;
  margin-top: 0.05rem;
  border-radius: 8px;
  background: linear-gradient(160deg, #2196f3 0%, #0d47a1 100%);
  color: #fff;
  font-size: 0.8rem;
  font-weight: 800;
  line-height: 1;
}

.wwd-pillar-detail__focus-text {
  font-size: 0.93rem;
  line-height: 1.48;
  font-weight: 600;
  color: #243447;
  display: flex;
  align-items: center;
}

.wwd-pillar-detail__cta-bar {
  margin-top: 1.35rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(13, 122, 79, 0.1);
}

.wwd-pillar-detail__cta-label {
  margin: 0 0 0.75rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.wwd-pillar-detail__cta-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem 0.75rem;
}

body.theme-acep .wwd-pillar-detail__title,
body.theme-acep .wwd-pillar-detail__programme-title,
body.theme-acep .wwd-pillar-detail__focus-text,
body.theme-acep .wwd-pillar-detail__quickfact {
  font-family: var(--font-ui, var(--font-sans));
}

.wwd-showcase-hero {
  position: relative;
  overflow: hidden;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  border-bottom: none !important;
}

.wwd-showcase-hero.section--surface {
  background: transparent;
}

.wwd-showcase-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse 80% 70% at 20% 20%, rgba(13, 122, 79, 0.35), transparent 55%),
    radial-gradient(ellipse 60% 50% at 85% 60%, rgba(21, 101, 192, 0.18), transparent 50%),
    linear-gradient(145deg, #041a12 0%, #0a3d28 38%, #0d5c3a 72%, #052e20 100%);
}

.wwd-showcase-hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.4;
  background-image:
    linear-gradient(115deg, rgba(255, 255, 255, 0.05) 22%, transparent 22.5%),
    linear-gradient(295deg, rgba(255, 255, 255, 0.04) 22%, transparent 22.5%);
  background-size: 56px 96px, 56px 96px;
  background-position:
    0 0,
    28px 48px;
  pointer-events: none;
}

.wwd-showcase-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 40rem;
  padding: clamp(2.75rem, 8vw, 4.25rem) 0 clamp(3rem, 8vw, 4.5rem);
  color: #fff;
}

.wwd-showcase-hero__eyebrow {
  margin: 0 0 0.45rem;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(196, 255, 220, 0.95);
}

.wwd-showcase-hero__title {
  margin: 0 0 0.85rem;
  font-size: clamp(2.1rem, 6vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.08;
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.2);
}

.wwd-showcase-hero__title--ruled::after {
  content: "";
  display: block;
  width: 2.85rem;
  height: 3px;
  margin-top: 0.45rem;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(167, 243, 208, 0.95) 0%, rgba(255, 255, 255, 0.3) 100%);
}

.wwd-showcase-hero__micro {
  margin: -0.25rem 0 0.75rem;
  font-size: 0.94rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.8);
  max-width: 40rem;
}

.wwd-showcase-hero__lead {
  margin: 0 0 1.5rem;
  font-size: clamp(1.02rem, 2.2vw, 1.14rem);
  line-height: 1.62;
  color: rgba(255, 255, 255, 0.92);
}

.wwd-showcase-hero__link {
  color: #a8f5c8;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.wwd-showcase-hero__link:hover,
.wwd-showcase-hero__link:focus-visible {
  color: #fff;
}

.wwd-showcase-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1rem;
}

.wwd-showcase-hero__actions .btn--primary {
  background: linear-gradient(180deg, #f97316 0%, #ea580c 100%);
  border: none;
  color: #fff;
  font-weight: 700;
  box-shadow: 0 4px 20px rgba(234, 88, 12, 0.35);
}

.wwd-showcase-hero__actions .btn--primary:hover,
.wwd-showcase-hero__actions .btn--primary:focus-visible {
  filter: brightness(1.06);
}

.wwd-showcase-hero__actions .btn:not(.btn--primary) {
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  border: 2px solid rgba(255, 255, 255, 0.55);
}

.wwd-showcase-hero__actions .btn:not(.btn--primary):hover,
.wwd-showcase-hero__actions .btn:not(.btn--primary):focus-visible {
  background: rgba(255, 255, 255, 0.22);
  border-color: #fff;
}

.wwd-showcase-mosaic__intro {
  max-width: 44rem;
}

.wwd-showcase-mosaic__grid {
  list-style: none;
  margin: 1.5rem 0 0;
  padding: 0;
  display: grid;
  gap: 1.35rem;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
}

.wwd-showcase-tile {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
  background: var(--color-surface);
  border-radius: calc(var(--radius) + 2px);
  border: 1px solid rgba(13, 122, 79, 0.1);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  transition:
    transform 0.28s var(--ease-out),
    box-shadow 0.28s ease,
    border-color 0.2s ease;
}

.wwd-showcase-tile:hover,
.wwd-showcase-tile:focus-visible {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(13, 122, 79, 0.22);
}

.wwd-showcase-tile:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.wwd-showcase-tile__media {
  aspect-ratio: 16 / 10;
  background: #e0ebe6;
  overflow: hidden;
}

.wwd-showcase-tile__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s var(--ease-out);
}

.wwd-showcase-tile:hover .wwd-showcase-tile__media img,
.wwd-showcase-tile:focus-visible .wwd-showcase-tile__media img {
  transform: scale(1.05);
}

.wwd-showcase-tile__body {
  padding: 1.15rem 1.2rem 1.3rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.wwd-showcase-tile__title {
  margin: 0 0 0.45rem;
  font-size: 1.08rem;
  font-weight: 700;
  line-height: 1.28;
  color: var(--color-accent-dark);
}

.wwd-showcase-tile__sum {
  margin: 0 0 0.75rem;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--color-muted);
  flex: 1;
}

.wwd-showcase-tile__cta {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--color-accent);
}

.wwd-showcase-tile:hover .wwd-showcase-tile__cta,
.wwd-showcase-tile:focus-visible .wwd-showcase-tile__cta {
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.wwd-showcase-placeholder-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 200px), 1fr));
  margin: 1.25rem 0 1rem;
}

.wwd-showcase-placeholder {
  border-radius: var(--radius);
  min-height: 140px;
  padding: 1.1rem 1rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.35rem;
  color: #fff;
  font-weight: 700;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.25);
}

.wwd-showcase-placeholder__num {
  font-size: 1.75rem;
  font-weight: 800;
  opacity: 0.9;
  line-height: 1;
}

.wwd-showcase-placeholder__label {
  font-size: 0.82rem;
  line-height: 1.35;
}

.wwd-showcase-placeholder--awareness {
  background: linear-gradient(135deg, #0d7a4f 0%, #063d28 100%);
}

.wwd-showcase-placeholder--capacity {
  background: linear-gradient(135deg, #1565c0 0%, #0d3d7a 100%);
}

.wwd-showcase-placeholder--policy {
  background: linear-gradient(135deg, #6a1b9a 0%, #3d0d5c 100%);
}

.wwd-showcase-placeholder--networking {
  background: linear-gradient(135deg, #ef6c00 0%, #a34b00 100%);
}

.wwd-showcase-placeholder--pilots {
  background: linear-gradient(135deg, #00838f 0%, #004d56 100%);
}

.wwd-showcase-empty {
  margin: 0;
  padding: 1rem 1.15rem;
  background: var(--color-accent-soft);
  border-radius: var(--radius);
  font-size: 0.98rem;
}

.wwd-pillar-visual-grid {
  list-style: none;
  margin: 1.5rem 0 0;
  padding: 0;
  display: grid;
  gap: 1.15rem;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
}

.wwd-pillar-visual-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1.35rem 1.3rem 1.4rem;
  border-radius: calc(var(--radius) + 2px);
  text-decoration: none;
  color: #fff;
  box-shadow: var(--shadow-md);
  border: 1px solid rgba(255, 255, 255, 0.12);
  transition:
    transform 0.26s var(--ease-out),
    box-shadow 0.26s ease;
}

.wwd-pillar-visual-card:hover,
.wwd-pillar-visual-card:focus-visible {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}

.wwd-pillar-visual-card:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

.wwd-pillar-visual-card__num {
  font-size: 2rem;
  font-weight: 800;
  opacity: 0.92;
  line-height: 1;
  margin-bottom: 0.65rem;
}

.wwd-pillar-visual-card__title {
  margin: 0 0 0.55rem;
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.3;
}

.wwd-pillar-visual-card__sum {
  margin: 0 0 0.85rem;
  font-size: 0.9rem;
  line-height: 1.5;
  opacity: 0.95;
  flex: 1;
}

.wwd-pillar-visual-card__more {
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.95;
}

.wwd-pillar-visual-card--awareness {
  background: linear-gradient(155deg, #0e8f5f 0%, #054530 100%);
}

.wwd-pillar-visual-card--capacity {
  background: linear-gradient(155deg, #1976d2 0%, #0d4175 100%);
}

.wwd-pillar-visual-card--policy {
  background: linear-gradient(155deg, #7b1fa2 0%, #43106e 100%);
}

.wwd-pillar-visual-card--networking {
  background: linear-gradient(155deg, #f57c00 0%, #a34d00 100%);
}

.wwd-pillar-visual-card--pilots {
  background: linear-gradient(155deg, #0097a7 0%, #005662 100%);
}

.wwd-showcase-strip {
  border-top: 1px solid rgba(13, 122, 79, 0.1);
}

.wwd-showcase-strip__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem 2rem;
}

.wwd-showcase-strip__text {
  flex: 1 1 280px;
  max-width: 40rem;
}

.wwd-showcase-strip__text h2,
.wwd-showcase-strip__title {
  margin: 0 0 0.6rem;
  font-size: clamp(1.2rem, 2.5vw, 1.45rem);
  font-weight: 800;
  color: var(--color-accent-dark);
  letter-spacing: -0.02em;
}

.wwd-showcase-strip__text p {
  margin: 0;
  color: var(--color-muted);
  line-height: 1.6;
}

.wwd-showcase-strip__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 0.85rem;
}

body.theme-acep .wwd-showcase-hero__title,
body.theme-acep .wwd-pillar-visual-card__title,
body.theme-acep .wwd-showcase-strip__title {
  font-family: var(--font-ui, var(--font-sans));
}

/* -------------------------------------------------------------------------
 On-site visual assistant (floating chat)
   ------------------------------------------------------------------------- */
.ghna-assistant {
  position: fixed;
  z-index: 9990;
  right: max(1rem, env(safe-area-inset-right));
  bottom: max(1rem, env(safe-area-inset-bottom));
  font-family: var(--font-sans);
  font-size: 0.95rem;
  line-height: 1.45;
}

.ghna-assistant__fab {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 1rem 0.55rem 0.65rem;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  color: #fff;
  background: linear-gradient(145deg, #0d9488 0%, var(--color-accent) 45%, var(--color-accent-dark) 100%);
  box-shadow:
    0 4px 18px rgba(13, 122, 79, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.12) inset;
  transition:
    transform 0.2s var(--ease-out),
    box-shadow 0.2s ease;
}

.ghna-assistant__fab:hover,
.ghna-assistant__fab:focus-visible {
  transform: translateY(-2px);
  box-shadow:
    0 8px 28px rgba(13, 122, 79, 0.5),
    0 0 0 1px rgba(255, 255, 255, 0.18) inset;
  outline: none;
}

.ghna-assistant__fab:focus-visible {
  box-shadow:
    0 0 0 3px #fff,
    0 0 0 5px var(--color-accent),
    0 8px 28px rgba(13, 122, 79, 0.45);
}

.ghna-assistant__fab-icon {
  display: flex;
  width: 2rem;
  height: 2rem;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 50%;
}

.ghna-assistant__fab-label {
  font-weight: 700;
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  padding-right: 0.15rem;
}

.ghna-assistant--open .ghna-assistant__fab {
  opacity: 0;
  pointer-events: none;
  transform: scale(0.9);
}

.ghna-assistant__panel {
  position: absolute;
  right: 0;
  bottom: 0;
  width: min(calc(100vw - 2rem), 22.5rem);
  max-height: min(32rem, calc(100vh - 6rem));
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border-radius: 16px;
  border: 1px solid rgba(13, 122, 79, 0.14);
  box-shadow:
    0 -4px 40px rgba(15, 36, 24, 0.12),
    0 24px 56px rgba(15, 36, 24, 0.18);
  overflow: hidden;
}

.ghna-assistant__panel[hidden] {
  display: none !important;
}

.ghna-assistant--open .ghna-assistant__panel {
  display: flex !important;
}

.ghna-assistant__head {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.75rem 0.85rem;
  background: linear-gradient(105deg, rgba(13, 122, 79, 0.1) 0%, rgba(21, 101, 192, 0.06) 100%);
  border-bottom: 1px solid rgba(13, 122, 79, 0.1);
}

.ghna-assistant__avatar {
  flex-shrink: 0;
}

.ghna-assistant__head-text {
  flex: 1 1 auto;
  min-width: 0;
}

.ghna-assistant__title {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1.2;
  color: var(--color-accent-dark);
  letter-spacing: -0.02em;
}

.ghna-assistant__subtitle {
  margin: 0.15rem 0 0;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.ghna-assistant__close {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border: none;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.65);
  color: var(--color-text);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s ease;
}

.ghna-assistant__close:hover,
.ghna-assistant__close:focus-visible {
  background: rgba(13, 122, 79, 0.12);
  outline: none;
}

.ghna-assistant__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 0.85rem;
  background: linear-gradient(180deg, #f8faf9 0%, #fff 40%);
  min-height: 11rem;
}

.ghna-assistant__msg {
  margin-bottom: 0.85rem;
}

.ghna-assistant__msg p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--color-text);
}

.ghna-assistant__msg--user p {
  margin-left: 2rem;
  padding: 0.55rem 0.75rem;
  background: rgba(13, 122, 79, 0.12);
  border-radius: 12px 12px 4px 12px;
  color: var(--color-accent-dark);
  font-weight: 500;
}

.ghna-assistant__msg--bot p {
  padding: 0.55rem 0.75rem;
  background: #fff;
  border: 1px solid rgba(13, 122, 79, 0.1);
  border-radius: 12px 12px 12px 4px;
  box-shadow: 0 2px 8px rgba(15, 36, 24, 0.05);
}

.ghna-assistant__msg--error p {
  padding: 0.55rem 0.75rem;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 10px;
  color: #991b1b;
  font-size: 0.85rem;
}

.ghna-assistant__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.55rem;
}

.ghna-assistant__chip {
  padding: 0.28rem 0.55rem;
  font-size: 0.75rem;
  font-weight: 600;
  border: 1px solid rgba(13, 122, 79, 0.25);
  border-radius: 999px;
  background: #fff;
  color: var(--color-accent-dark);
  cursor: pointer;
  transition:
    background 0.15s ease,
    border-color 0.15s ease;
}

.ghna-assistant__chip:hover,
.ghna-assistant__chip:focus-visible {
  background: var(--color-accent-soft);
  border-color: var(--color-accent);
  outline: none;
}

.ghna-assistant__links {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-top: 0.55rem;
}

.ghna-assistant__link {
  display: block;
  padding: 0.45rem 0.65rem;
  font-size: 0.82rem;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
  color: #fff;
  background: var(--color-accent);
  border-radius: 8px;
  transition: filter 0.15s ease;
}

.ghna-assistant__link:hover,
.ghna-assistant__link:focus-visible {
  filter: brightness(1.08);
  outline: none;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--color-accent);
}

.ghna-assistant__form {
  display: flex;
  gap: 0.45rem;
  align-items: flex-end;
  padding: 0.65rem 0.75rem;
  border-top: 1px solid rgba(13, 122, 79, 0.1);
  background: var(--color-surface);
}

.ghna-assistant__input {
  flex: 1 1 auto;
  min-height: 2.5rem;
  max-height: 7.5rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid rgba(13, 122, 79, 0.2);
  border-radius: 10px;
  font: inherit;
  resize: none;
  line-height: 1.4;
}

.ghna-assistant__input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(13, 122, 79, 0.12);
}

.ghna-assistant__send {
  flex-shrink: 0;
  padding: 0.55rem 0.85rem;
  border: none;
  border-radius: 10px;
  font-weight: 700;
  font-size: 0.82rem;
  cursor: pointer;
  color: #fff;
  background: var(--color-accent-dark);
  transition: filter 0.15s ease;
}

.ghna-assistant__send:hover:not(:disabled),
.ghna-assistant__send:focus-visible:not(:disabled) {
  filter: brightness(1.1);
  outline: none;
}

.ghna-assistant__send:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.ghna-assistant__fineprint {
  margin: 0;
  padding: 0.4rem 0.75rem 0.65rem;
  font-size: 0.68rem;
  line-height: 1.4;
  color: var(--color-muted);
  background: #f4f7f5;
  border-top: 1px solid rgba(13, 122, 79, 0.08);
}

.ghna-assistant__fineprint a {
  color: var(--color-accent-dark);
  font-weight: 600;
}

@media (max-width: 480px) {
  .ghna-assistant {
    right: 0.65rem;
    bottom: 0.65rem;
    left: 0.65rem;
  }

  .ghna-assistant__panel {
    width: 100%;
    max-height: min(70vh, 28rem);
  }

  .ghna-assistant__fab-label {
    display: none;
  }

  .ghna-assistant__fab {
    padding: 0.55rem;
    border-radius: 50%;
    width: 3.35rem;
    height: 3.35rem;
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ghna-assistant__fab,
  .ghna-assistant--open .ghna-assistant__fab {
    transition: none;
    transform: none;
  }
}

@media print {
  .ghna-assistant {
    display: none !important;
  }
}
