@import url("https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@400;500;600;700&family=Sora:wght@400;500;600;700;800&display=swap");

:root {
  --bg: #fffef7;
  --bg-alt: #fff8e6;
  --surface: rgba(255, 255, 255, 0.96);
  --surface-strong: #ffffff;
  --surface-muted: #fff7dc;
  --ink: #2f2f2f;
  --ink-soft: #66604d;
  --line: rgba(47, 47, 47, 0.1);
  --brand: #f4cf43;
  --brand-deep: #b88f08;
  --brand-soft: #fff2b9;
  --accent: #0f7a69;
  --accent-soft: #deefea;
  --warning: #ce5331;
  --shadow-lg: 0 28px 80px rgba(41, 39, 28, 0.08);
  --shadow-md: 0 16px 42px rgba(41, 39, 28, 0.07);
  --shadow-sm: 0 10px 28px rgba(41, 39, 28, 0.05);
  --radius-xl: 30px;
  --radius-lg: 22px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --content: 1220px;
  --nav-height: 84px;
  --focus-ring: rgba(12, 123, 106, 0.28);
  --page-bg:
    radial-gradient(circle at top left, rgba(244, 207, 67, 0.18), transparent 30%),
    radial-gradient(circle at right 10% top 8%, rgba(15, 122, 105, 0.08), transparent 26%),
    linear-gradient(180deg, #fffef7 0%, #fffaf0 100%);
  --page-shell-overlay:
    radial-gradient(circle at 85% 12%, rgba(244, 207, 67, 0.12), transparent 14%),
    radial-gradient(circle at 12% 22%, rgba(15, 122, 105, 0.07), transparent 18%);
  --scroll-behavior: smooth;
}

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

html {
  scroll-behavior: var(--scroll-behavior);
  scroll-padding-top: calc(var(--nav-height) + 1.5rem);
}

body {
  margin: 0;
  font-family: "Instrument Sans", sans-serif;
  background: var(--page-bg);
  color: var(--ink);
  line-height: 1.68;
  overflow-x: hidden;
}

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

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

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

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 3px;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

main {
  display: block;
}

.page-shell {
  min-height: 100vh;
  filter: var(--a11y-content-filter, none);
}

.page-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background: var(--page-shell-overlay);
  z-index: -1;
}

.container {
  width: min(calc(100% - 2.6rem), var(--content));
  margin: 0 auto;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.55rem 0.85rem;
  margin-bottom: 1.2rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(12, 123, 106, 0.14);
  color: var(--brand-deep);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.eyebrow::before {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), var(--accent));
}

h1,
h2,
h3,
h4 {
  font-family: "Sora", sans-serif;
  margin: 0 0 0.9rem;
  line-height: 1.08;
  letter-spacing: -0.03em;
  text-wrap: balance;
}

h1 {
  font-size: clamp(2.5rem, 5vw, 5.1rem);
}

h2 {
  font-size: clamp(1.8rem, 2.8vw, 2.65rem);
}

h3 {
  font-size: clamp(1.25rem, 2.4vw, 1.7rem);
}

h4 {
  font-size: 1.08rem;
}

p {
  margin: 0 0 1rem;
  color: var(--ink-soft);
}

main p a,
main li a {
  color: var(--brand-deep);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.16em;
}

ul,
ol {
  margin: 0;
  padding-left: 1.15rem;
  color: var(--ink-soft);
}

strong {
  color: var(--ink);
}

.kicker {
  display: block;
  margin-bottom: 0.95rem;
  color: var(--brand-deep);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.section {
  padding: 4.25rem 0;
}

.section-lg {
  padding: 6.5rem 0;
}

.page-hero + .section,
.section + .section,
.section + .section-lg,
.section-lg + .section {
  padding-top: 1.25rem;
}

.section-intro {
  display: grid;
  gap: 1rem;
  margin-bottom: 2.75rem;
}

.section-intro--split {
  grid-template-columns: 1.15fr 0.85fr;
  align-items: end;
}

.section-intro--split .actions {
  justify-content: flex-end;
  margin-left: auto;
}

.section-intro > p:last-child {
  margin-bottom: 0;
}

.section-intro--wide .page-copy {
  max-width: none;
}

body[data-page="home"] .page-copy {
  max-width: none;
  width: 100%;
}

.actions,
.hero-actions,
.card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
}

.button,
.button-secondary,
.button-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.95rem 1.25rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 700;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease;
}

.button {
  background: linear-gradient(135deg, #f7d94f, var(--brand));
  color: #4d3d08;
  box-shadow: 0 10px 24px rgba(244, 207, 67, 0.22);
}

.button-secondary {
  background: linear-gradient(135deg, var(--accent), #0b6154);
  color: #fff;
  box-shadow: 0 10px 24px rgba(15, 122, 105, 0.18);
}

.button-ghost {
  background: rgba(255, 255, 255, 0.88);
  color: var(--ink);
  border-color: rgba(47, 47, 47, 0.09);
}

.button:hover,
.button-secondary:hover,
.button-ghost:hover {
  transform: translateY(-3px);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(18px);
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: 0.75rem;
  z-index: 140;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  background: #0b6154;
  color: #fff;
  font-weight: 700;
  transform: translateY(-180%);
  transition: transform 180ms ease;
}

.skip-link:focus-visible {
  transform: translateY(0);
}

html[data-a11y-size="default"] {
  font-size: 100%;
}

html[data-a11y-size="large"] {
  font-size: 106.25%;
}

html[data-a11y-size="larger"] {
  font-size: 112.5%;
}

html[data-a11y-size="largest"] {
  font-size: 118.75%;
}

html[data-a11y-links="on"] a:not(.button):not(.button-secondary):not(.button-ghost):not(.logo-link):not(.back-to-top) {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

html[data-a11y-spacing="light"] p,
html[data-a11y-spacing="light"] li,
html[data-a11y-spacing="light"] label,
html[data-a11y-spacing="light"] input,
html[data-a11y-spacing="light"] textarea,
html[data-a11y-spacing="light"] select,
html[data-a11y-spacing="light"] figcaption {
  letter-spacing: 0.01em;
  word-spacing: 0.05em;
}

html[data-a11y-spacing="moderate"] p,
html[data-a11y-spacing="moderate"] li,
html[data-a11y-spacing="moderate"] label,
html[data-a11y-spacing="moderate"] input,
html[data-a11y-spacing="moderate"] textarea,
html[data-a11y-spacing="moderate"] select,
html[data-a11y-spacing="moderate"] figcaption {
  letter-spacing: 0.015em;
  word-spacing: 0.08em;
}

html[data-a11y-spacing="heavy"] p,
html[data-a11y-spacing="heavy"] li,
html[data-a11y-spacing="heavy"] label,
html[data-a11y-spacing="heavy"] input,
html[data-a11y-spacing="heavy"] textarea,
html[data-a11y-spacing="heavy"] select,
html[data-a11y-spacing="heavy"] figcaption {
  letter-spacing: 0.03em;
  word-spacing: 0.13em;
}

html[data-a11y-line-height="relaxed"] body,
html[data-a11y-line-height="relaxed"] p,
html[data-a11y-line-height="relaxed"] li,
html[data-a11y-line-height="relaxed"] blockquote,
html[data-a11y-line-height="relaxed"] figcaption {
  line-height: 1.9;
}

html[data-a11y-line-height="wide"] body,
html[data-a11y-line-height="wide"] p,
html[data-a11y-line-height="wide"] li,
html[data-a11y-line-height="wide"] blockquote,
html[data-a11y-line-height="wide"] figcaption {
  line-height: 2.15;
}

html[data-a11y-align="left"] main p,
html[data-a11y-align="left"] main li,
html[data-a11y-align="left"] main blockquote,
html[data-a11y-align="left"] main figcaption,
html[data-a11y-align="left"] .detail-card,
html[data-a11y-align="left"] .quote-card {
  text-align: left;
}

html[data-a11y-align="center"] main p,
html[data-a11y-align="center"] main li,
html[data-a11y-align="center"] main blockquote,
html[data-a11y-align="center"] main figcaption,
html[data-a11y-align="center"] .detail-card,
html[data-a11y-align="center"] .quote-card {
  text-align: center;
}

html[data-a11y-align="right"] main p,
html[data-a11y-align="right"] main li,
html[data-a11y-align="right"] main blockquote,
html[data-a11y-align="right"] main figcaption,
html[data-a11y-align="right"] .detail-card,
html[data-a11y-align="right"] .quote-card {
  text-align: right;
}

html[data-a11y-align="justify"] main p,
html[data-a11y-align="justify"] main li,
html[data-a11y-align="justify"] main blockquote,
html[data-a11y-align="justify"] main figcaption,
html[data-a11y-align="justify"] .detail-card,
html[data-a11y-align="justify"] .quote-card {
  text-align: justify;
}

html[data-a11y-contrast="light"] {
  --bg: #ffffff;
  --bg-alt: #ffffff;
  --surface: #ffffff;
  --surface-strong: #ffffff;
  --surface-muted: #f4f7fb;
  --ink: #111111;
  --ink-soft: #232323;
  --line: rgba(17, 17, 17, 0.22);
  --brand: #f0c600;
  --brand-deep: #3d2d00;
  --brand-soft: #fff2b3;
  --accent: #005fcc;
  --accent-soft: #e5efff;
  --shadow-lg: 0 20px 44px rgba(17, 17, 17, 0.12);
  --shadow-md: 0 16px 32px rgba(17, 17, 17, 0.1);
  --shadow-sm: 0 12px 24px rgba(17, 17, 17, 0.08);
  --focus-ring: rgba(0, 95, 204, 0.45);
  --page-bg: linear-gradient(180deg, #ffffff 0%, #ffffff 100%);
  --page-shell-overlay: none;
}

html[data-a11y-contrast="dark"] {
  --bg: #0e1115;
  --bg-alt: #121722;
  --surface: rgba(17, 23, 34, 0.96);
  --surface-strong: #1a2330;
  --surface-muted: #16202a;
  --ink: #f6f7fb;
  --ink-soft: #dae0ea;
  --line: rgba(255, 255, 255, 0.14);
  --brand: #ffd75c;
  --brand-deep: #ffe9a3;
  --brand-soft: rgba(255, 215, 92, 0.16);
  --accent: #64d7c1;
  --accent-soft: rgba(100, 215, 193, 0.16);
  --shadow-lg: 0 24px 56px rgba(0, 0, 0, 0.36);
  --shadow-md: 0 18px 36px rgba(0, 0, 0, 0.28);
  --shadow-sm: 0 12px 24px rgba(0, 0, 0, 0.22);
  --focus-ring: rgba(100, 215, 193, 0.42);
  --page-bg: linear-gradient(180deg, #0e1115 0%, #121722 100%);
  --page-shell-overlay: none;
}

html[data-a11y-contrast="invert"] {
  --bg: #03060c;
  --bg-alt: #07111f;
  --surface: rgba(10, 15, 24, 0.96);
  --surface-strong: #101a29;
  --surface-muted: #0d1621;
  --ink: #f9fcff;
  --ink-soft: #dce8ff;
  --line: rgba(255, 255, 255, 0.18);
  --brand: #67e5ff;
  --brand-deep: #d6fbff;
  --brand-soft: rgba(103, 229, 255, 0.18);
  --accent: #ffd86a;
  --accent-soft: rgba(255, 216, 106, 0.18);
  --shadow-lg: 0 28px 64px rgba(0, 0, 0, 0.42);
  --shadow-md: 0 18px 38px rgba(0, 0, 0, 0.32);
  --shadow-sm: 0 12px 24px rgba(0, 0, 0, 0.26);
  --focus-ring: rgba(103, 229, 255, 0.44);
  --page-bg: linear-gradient(180deg, #03060c 0%, #07111f 100%);
  --page-shell-overlay:
    radial-gradient(circle at 84% 12%, rgba(103, 229, 255, 0.14), transparent 16%),
    radial-gradient(circle at 12% 24%, rgba(255, 216, 106, 0.1), transparent 20%);
}

html[data-a11y-smart-contrast="on"] {
  --line: rgba(17, 17, 17, 0.24);
  --focus-ring: rgba(0, 95, 204, 0.5);
}

html:not([data-a11y-contrast="dark"])[data-a11y-smart-contrast="on"] {
  --ink-soft: #2b2b2b;
}

html[data-a11y-contrast="dark"][data-a11y-smart-contrast="on"] {
  --line: rgba(255, 255, 255, 0.2);
  --ink-soft: #e7edf5;
  --focus-ring: rgba(100, 215, 193, 0.5);
}

html[data-a11y-contrast="invert"][data-a11y-smart-contrast="on"] {
  --line: rgba(255, 255, 255, 0.24);
  --ink-soft: #edf5ff;
  --focus-ring: rgba(103, 229, 255, 0.52);
}

html[data-a11y-contrast="dark"] .button,
html[data-a11y-contrast="invert"] .button,
html[data-a11y-contrast="light"] .button {
  background: #111111;
  color: #ffffff;
  box-shadow: none;
}

html[data-a11y-contrast="invert"] .button {
  background: #ffffff;
  color: #05070c;
}

html[data-a11y-contrast="dark"] .button-secondary,
html[data-a11y-contrast="light"] .button-secondary {
  background: #005fcc;
  color: #ffffff;
  box-shadow: none;
}

html[data-a11y-contrast="invert"] .button-secondary {
  background: #67e5ff;
  color: #071018;
  box-shadow: none;
}

html[data-a11y-contrast="dark"] .button-ghost,
html[data-a11y-contrast="light"] .button-ghost {
  background: #ffffff;
  border-color: rgba(17, 17, 17, 0.3);
  color: #111111;
}

html[data-a11y-contrast="dark"] .button-ghost {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.22);
  color: #ffffff;
}

html[data-a11y-contrast="invert"] .button-ghost {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.22);
  color: #ffffff;
}

html[data-a11y-contrast="dark"] .nav-link:hover,
html[data-a11y-contrast="dark"] .nav-link.is-current,
html[data-a11y-contrast="dark"] .nav-item.is-current > .nav-link,
html[data-a11y-contrast="light"] .nav-link:hover,
html[data-a11y-contrast="light"] .nav-link.is-current,
html[data-a11y-contrast="light"] .nav-item.is-current > .nav-link {
  background: rgba(0, 95, 204, 0.12);
  color: #003b7a;
}

html[data-a11y-contrast="dark"] .nav-link:hover,
html[data-a11y-contrast="dark"] .nav-link.is-current,
html[data-a11y-contrast="dark"] .nav-item.is-current > .nav-link {
  color: #ffffff;
}

html[data-a11y-contrast="dark"] .media-launch__note,
html[data-a11y-contrast="dark"] .hero-caption,
html[data-a11y-contrast="invert"] .media-launch__note,
html[data-a11y-contrast="invert"] .hero-caption,
html[data-a11y-contrast="light"] .media-launch__note,
html[data-a11y-contrast="light"] .hero-caption {
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

html[data-a11y-contrast="invert"] .eyebrow {
  background: rgba(103, 229, 255, 0.12);
  border-color: rgba(103, 229, 255, 0.22);
  color: var(--brand-deep);
}

html[data-a11y-contrast="invert"] .chip {
  background: rgba(103, 229, 255, 0.14);
  color: var(--brand-deep);
}

html[data-a11y-contrast="invert"] .tag {
  background: rgba(255, 216, 106, 0.18);
  color: #fff1bd;
}

html[data-a11y-contrast="dark"] .header-nav,
html[data-a11y-contrast="dark"] .site-header.is-scrolled .header-nav {
  background: rgba(14, 17, 21, 0.94);
  border-color: rgba(255, 255, 255, 0.08);
}

html[data-a11y-contrast="dark"] .nav-menu,
html[data-a11y-contrast="dark"] .nav-children,
html[data-a11y-contrast="dark"] .nav-subitem--group > .nav-grandmenu,
html[data-a11y-contrast="dark"] .nav-granditem--group > .nav-grandmenu--nested {
  background: rgba(17, 23, 34, 0.98);
  border-color: rgba(255, 255, 255, 0.12);
}

html[data-a11y-contrast="dark"] .nav-group__toggle,
html[data-a11y-contrast="dark"] .nav-subtoggle,
html[data-a11y-contrast="dark"] .nav-toggle,
html[data-a11y-contrast="dark"] .back-to-top,
html[data-a11y-contrast="dark"] .a11y-trigger {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.16);
  color: var(--ink);
}

html[data-a11y-contrast="dark"] .nav-link:hover,
html[data-a11y-contrast="dark"] .nav-link.is-current,
html[data-a11y-contrast="dark"] .nav-item.is-current > .nav-link,
html[data-a11y-contrast="dark"] .nav-sublink:hover,
html[data-a11y-contrast="dark"] .nav-sublink.is-current,
html[data-a11y-contrast="dark"] .nav-grandlink:hover,
html[data-a11y-contrast="dark"] .nav-grandlink.is-current,
html[data-a11y-contrast="dark"] .nav-links a:hover,
html[data-a11y-contrast="dark"] .nav-links a[aria-current="page"],
html[data-a11y-contrast="dark"] .nav-group__toggle:hover,
html[data-a11y-contrast="dark"] .nav-group__toggle:focus-visible,
html[data-a11y-contrast="dark"] .nav-item.is-current .nav-group__toggle,
html[data-a11y-contrast="dark"] .nav-item--group.is-open .nav-group__toggle,
html[data-a11y-contrast="dark"] .nav-subtoggle:hover,
html[data-a11y-contrast="dark"] .nav-subtoggle:focus-visible,
html[data-a11y-contrast="dark"] .nav-subitem--group.is-open > .nav-subgroup__head .nav-subtoggle,
html[data-a11y-contrast="dark"] .nav-subitem--group.is-current > .nav-subgroup__head .nav-subtoggle,
html[data-a11y-contrast="dark"] .slider-control:hover,
html[data-a11y-contrast="dark"] .slider-control:focus-visible,
html[data-a11y-contrast="dark"] .back-to-top:hover,
html[data-a11y-contrast="dark"] .back-to-top:focus-visible {
  background: rgba(255, 215, 92, 0.16);
  border-color: rgba(255, 215, 92, 0.34);
  color: var(--ink);
}

html[data-a11y-contrast="dark"] .hero-standard .page-hero__grid,
html[data-a11y-contrast="dark"] .testimonial-panel,
html[data-a11y-contrast="dark"] .testimonial-slide,
html[data-a11y-contrast="dark"] .cta-banner {
  background:
    radial-gradient(circle at right top, rgba(255, 215, 92, 0.14), transparent 30%),
    linear-gradient(135deg, rgba(18, 23, 34, 0.98), rgba(12, 17, 26, 0.98));
  border-color: rgba(255, 255, 255, 0.1);
}

html[data-a11y-contrast="dark"] .metric-pill,
html[data-a11y-contrast="dark"] .hero-caption,
html[data-a11y-contrast="dark"] .floating-card,
html[data-a11y-contrast="dark"] .impact-chip,
html[data-a11y-contrast="dark"] .media-launch__play,
html[data-a11y-contrast="dark"] .stat-item,
html[data-a11y-contrast="dark"] .slider-control,
html[data-a11y-contrast="dark"] .field input:not([type="checkbox"]):not([type="radio"]),
html[data-a11y-contrast="dark"] .field select,
html[data-a11y-contrast="dark"] .field textarea,
html[data-a11y-contrast="dark"] .checkbox-item,
html[data-a11y-contrast="dark"] .form-feedback,
html[data-a11y-contrast="dark"] .footer-panel,
html[data-a11y-contrast="dark"] .footer-socials a,
html[data-a11y-contrast="dark"] .a11y-panel,
html[data-a11y-contrast="dark"] .a11y-panel__close,
html[data-a11y-contrast="dark"] .a11y-chip,
html[data-a11y-contrast="dark"] .a11y-action,
html[data-a11y-contrast="dark"] .a11y-choice,
html[data-a11y-contrast="dark"] .a11y-switch,
html[data-a11y-contrast="dark"] .a11y-structure,
html[data-a11y-contrast="dark"] .a11y-dictionary,
html[data-a11y-contrast="dark"] .a11y-structure__link,
html[data-a11y-contrast="dark"] .lightbox__panel,
html[data-a11y-contrast="dark"] .lightbox__caption,
html[data-a11y-contrast="dark"] .legal-status-card {
  background: rgba(17, 23, 34, 0.96);
  border-color: rgba(255, 255, 255, 0.12);
}

html[data-a11y-contrast="dark"] .hero-standard .image-frame,
html[data-a11y-contrast="dark"] .hero-standard .hero-caption,
html[data-a11y-contrast="dark"] .gallery-card--plain img {
  background: linear-gradient(180deg, rgba(22, 30, 42, 0.98), rgba(12, 17, 26, 0.98));
}

html[data-a11y-contrast="dark"] .hero-standard .hero-caption,
html[data-a11y-contrast="dark"] .lightbox__caption,
html[data-a11y-contrast="dark"] .footer-bottom {
  border-color: rgba(255, 255, 255, 0.12);
}

html[data-a11y-contrast="dark"] .field input:not([type="checkbox"]):not([type="radio"]),
html[data-a11y-contrast="dark"] .field select,
html[data-a11y-contrast="dark"] .field textarea {
  color: var(--ink);
  caret-color: var(--brand);
}

html[data-a11y-contrast="dark"] .field input:not([type="checkbox"]):not([type="radio"])::placeholder,
html[data-a11y-contrast="dark"] .field textarea::placeholder {
  color: rgba(231, 237, 245, 0.68);
}

html[data-a11y-contrast="dark"] .form-feedback.is-success {
  background: rgba(15, 122, 105, 0.16);
  border-color: rgba(100, 215, 193, 0.26);
}

html[data-a11y-contrast="dark"] .form-feedback.is-error,
html[data-a11y-contrast="dark"] .field--invalid .checkbox-item {
  background: rgba(206, 83, 49, 0.14);
  border-color: rgba(255, 160, 136, 0.3);
}

html[data-a11y-contrast="dark"] .cta-banner .button-ghost {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.16);
  color: var(--ink);
}

html[data-a11y-contrast="dark"] .footer-socials a,
html[data-a11y-contrast="dark"] .footer-links a,
html[data-a11y-contrast="dark"] .footer-contact a,
html[data-a11y-contrast="dark"] .footer-bottom {
  color: var(--ink-soft);
}

html[data-a11y-contrast="dark"] .footer-links a:hover,
html[data-a11y-contrast="dark"] .footer-contact a:hover,
html[data-a11y-contrast="dark"] .footer-socials a:hover,
html[data-a11y-contrast="dark"] .footer-credit:hover,
html[data-a11y-contrast="dark"] .footer-credit:focus-visible {
  color: var(--ink);
}

html[data-a11y-contrast="dark"] .a11y-helper,
html[data-a11y-contrast="dark"] .a11y-control__label,
html[data-a11y-contrast="dark"] .a11y-switch__state,
html[data-a11y-contrast="dark"] .a11y-dictionary__result {
  color: var(--ink-soft);
}

html[data-a11y-contrast="dark"] .a11y-switch__state {
  background: rgba(255, 255, 255, 0.08);
}

html[data-a11y-contrast="dark"] .a11y-choice.is-active,
html[data-a11y-contrast="dark"] .a11y-switch.is-active,
html[data-a11y-contrast="dark"] .a11y-chip.is-active,
html[data-a11y-contrast="dark"] .a11y-action.is-active {
  background: rgba(100, 215, 193, 0.18);
  border-color: rgba(100, 215, 193, 0.34);
  color: var(--ink);
}

html[data-a11y-contrast="dark"] .a11y-switch.is-active .a11y-switch__state {
  background: rgba(100, 215, 193, 0.18);
  color: var(--ink);
}

html[data-a11y-contrast="invert"] .header-nav,
html[data-a11y-contrast="invert"] .site-header.is-scrolled .header-nav {
  background: rgba(3, 6, 12, 0.94);
  border-color: rgba(255, 255, 255, 0.08);
}

html[data-a11y-contrast="invert"] .nav-menu,
html[data-a11y-contrast="invert"] .nav-children,
html[data-a11y-contrast="invert"] .nav-subitem--group > .nav-grandmenu,
html[data-a11y-contrast="invert"] .nav-granditem--group > .nav-grandmenu--nested {
  background: rgba(10, 15, 24, 0.98);
  border-color: rgba(255, 255, 255, 0.12);
}

html[data-a11y-contrast="invert"] .nav-group__toggle,
html[data-a11y-contrast="invert"] .nav-subtoggle,
html[data-a11y-contrast="invert"] .nav-toggle,
html[data-a11y-contrast="invert"] .back-to-top,
html[data-a11y-contrast="invert"] .a11y-trigger,
html[data-a11y-contrast="invert"] .slider-control {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.16);
  color: var(--ink);
}

html[data-a11y-contrast="invert"] .nav-link:hover,
html[data-a11y-contrast="invert"] .nav-link.is-current,
html[data-a11y-contrast="invert"] .nav-item.is-current > .nav-link,
html[data-a11y-contrast="invert"] .nav-sublink:hover,
html[data-a11y-contrast="invert"] .nav-sublink.is-current,
html[data-a11y-contrast="invert"] .nav-grandlink:hover,
html[data-a11y-contrast="invert"] .nav-grandlink.is-current,
html[data-a11y-contrast="invert"] .nav-links a:hover,
html[data-a11y-contrast="invert"] .nav-links a[aria-current="page"],
html[data-a11y-contrast="invert"] .nav-group__toggle:hover,
html[data-a11y-contrast="invert"] .nav-group__toggle:focus-visible,
html[data-a11y-contrast="invert"] .nav-item.is-current .nav-group__toggle,
html[data-a11y-contrast="invert"] .nav-item--group.is-open .nav-group__toggle,
html[data-a11y-contrast="invert"] .nav-subtoggle:hover,
html[data-a11y-contrast="invert"] .nav-subtoggle:focus-visible,
html[data-a11y-contrast="invert"] .nav-subitem--group.is-open > .nav-subgroup__head .nav-subtoggle,
html[data-a11y-contrast="invert"] .nav-subitem--group.is-current > .nav-subgroup__head .nav-subtoggle,
html[data-a11y-contrast="invert"] .slider-control:hover,
html[data-a11y-contrast="invert"] .slider-control:focus-visible,
html[data-a11y-contrast="invert"] .back-to-top:hover,
html[data-a11y-contrast="invert"] .back-to-top:focus-visible {
  background: rgba(103, 229, 255, 0.16);
  border-color: rgba(103, 229, 255, 0.34);
  color: var(--ink);
}

html[data-a11y-contrast="invert"] .hero-standard .page-hero__grid,
html[data-a11y-contrast="invert"] .testimonial-panel,
html[data-a11y-contrast="invert"] .testimonial-slide,
html[data-a11y-contrast="invert"] .cta-banner {
  background:
    radial-gradient(circle at right top, rgba(103, 229, 255, 0.18), transparent 30%),
    linear-gradient(135deg, rgba(7, 13, 22, 0.98), rgba(3, 8, 14, 0.98));
  border-color: rgba(255, 255, 255, 0.1);
}

html[data-a11y-contrast="invert"] .metric-pill,
html[data-a11y-contrast="invert"] .hero-caption,
html[data-a11y-contrast="invert"] .floating-card,
html[data-a11y-contrast="invert"] .impact-chip,
html[data-a11y-contrast="invert"] .media-launch__play,
html[data-a11y-contrast="invert"] .stat-item,
html[data-a11y-contrast="invert"] .field input:not([type="checkbox"]):not([type="radio"]),
html[data-a11y-contrast="invert"] .field select,
html[data-a11y-contrast="invert"] .field textarea,
html[data-a11y-contrast="invert"] .checkbox-item,
html[data-a11y-contrast="invert"] .form-feedback,
html[data-a11y-contrast="invert"] .footer-panel,
html[data-a11y-contrast="invert"] .footer-socials a,
html[data-a11y-contrast="invert"] .a11y-panel,
html[data-a11y-contrast="invert"] .a11y-panel__close,
html[data-a11y-contrast="invert"] .a11y-chip,
html[data-a11y-contrast="invert"] .a11y-action,
html[data-a11y-contrast="invert"] .a11y-choice,
html[data-a11y-contrast="invert"] .a11y-switch,
html[data-a11y-contrast="invert"] .a11y-structure,
html[data-a11y-contrast="invert"] .a11y-dictionary,
html[data-a11y-contrast="invert"] .a11y-structure__link,
html[data-a11y-contrast="invert"] .lightbox__panel,
html[data-a11y-contrast="invert"] .lightbox__caption,
html[data-a11y-contrast="invert"] .legal-status-card {
  background: rgba(10, 15, 24, 0.96);
  border-color: rgba(255, 255, 255, 0.12);
}

html[data-a11y-contrast="invert"] .hero-standard .image-frame,
html[data-a11y-contrast="invert"] .hero-standard .hero-caption,
html[data-a11y-contrast="invert"] .gallery-card--plain img {
  background: linear-gradient(180deg, rgba(12, 18, 28, 0.98), rgba(5, 9, 16, 0.98));
}

html[data-a11y-contrast="invert"] .hero-standard .hero-caption,
html[data-a11y-contrast="invert"] .lightbox__caption,
html[data-a11y-contrast="invert"] .footer-bottom {
  border-color: rgba(255, 255, 255, 0.12);
}

html[data-a11y-contrast="invert"] .field input:not([type="checkbox"]):not([type="radio"]),
html[data-a11y-contrast="invert"] .field select,
html[data-a11y-contrast="invert"] .field textarea {
  color: var(--ink);
  caret-color: var(--brand);
}

html[data-a11y-contrast="invert"] .field input:not([type="checkbox"]):not([type="radio"])::placeholder,
html[data-a11y-contrast="invert"] .field textarea::placeholder {
  color: rgba(220, 232, 255, 0.68);
}

html[data-a11y-contrast="invert"] .form-feedback.is-success {
  background: rgba(103, 229, 255, 0.16);
  border-color: rgba(103, 229, 255, 0.28);
}

html[data-a11y-contrast="invert"] .form-feedback.is-error,
html[data-a11y-contrast="invert"] .field--invalid .checkbox-item {
  background: rgba(206, 83, 49, 0.14);
  border-color: rgba(255, 160, 136, 0.3);
}

html[data-a11y-contrast="invert"] .cta-banner .button-ghost {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.16);
  color: var(--ink);
}

html[data-a11y-contrast="invert"] .footer-socials a,
html[data-a11y-contrast="invert"] .footer-links a,
html[data-a11y-contrast="invert"] .footer-contact a,
html[data-a11y-contrast="invert"] .footer-bottom {
  color: var(--ink-soft);
}

html[data-a11y-contrast="invert"] .footer-links a:hover,
html[data-a11y-contrast="invert"] .footer-contact a:hover,
html[data-a11y-contrast="invert"] .footer-socials a:hover,
html[data-a11y-contrast="invert"] .footer-credit:hover,
html[data-a11y-contrast="invert"] .footer-credit:focus-visible {
  color: var(--ink);
}

html[data-a11y-contrast="invert"] .a11y-helper,
html[data-a11y-contrast="invert"] .a11y-control__label,
html[data-a11y-contrast="invert"] .a11y-switch__state,
html[data-a11y-contrast="invert"] .a11y-dictionary__result {
  color: var(--ink-soft);
}

html[data-a11y-contrast="invert"] .a11y-switch__state {
  background: rgba(255, 255, 255, 0.08);
}

html[data-a11y-contrast="invert"] .a11y-choice.is-active,
html[data-a11y-contrast="invert"] .a11y-switch.is-active,
html[data-a11y-contrast="invert"] .a11y-chip.is-active,
html[data-a11y-contrast="invert"] .a11y-action.is-active {
  background: rgba(103, 229, 255, 0.2);
  border-color: rgba(103, 229, 255, 0.34);
  color: var(--ink);
}

html[data-a11y-contrast="invert"] .a11y-switch.is-active .a11y-switch__state {
  background: rgba(103, 229, 255, 0.18);
  color: var(--ink);
}

html[data-a11y-dyslexia-font="on"] body,
html[data-a11y-dyslexia-font="on"] button,
html[data-a11y-dyslexia-font="on"] input,
html[data-a11y-dyslexia-font="on"] select,
html[data-a11y-dyslexia-font="on"] textarea {
  font-family: "OpenDyslexic", "Comic Sans MS", "Trebuchet MS", sans-serif;
}

html[data-a11y-dyslexia-font="on"] h1,
html[data-a11y-dyslexia-font="on"] h2,
html[data-a11y-dyslexia-font="on"] h3,
html[data-a11y-dyslexia-font="on"] h4 {
  font-family: "OpenDyslexic", "Comic Sans MS", "Trebuchet MS", sans-serif;
  letter-spacing: 0;
}

html[data-a11y-legible-font="on"] body,
html[data-a11y-legible-font="on"] button,
html[data-a11y-legible-font="on"] input,
html[data-a11y-legible-font="on"] select,
html[data-a11y-legible-font="on"] textarea {
  font-family: Arial, Verdana, Tahoma, sans-serif;
}

html[data-a11y-legible-font="on"] h1,
html[data-a11y-legible-font="on"] h2,
html[data-a11y-legible-font="on"] h3,
html[data-a11y-legible-font="on"] h4 {
  font-family: Arial, Verdana, Tahoma, sans-serif;
  letter-spacing: 0;
}

html[data-a11y-big-cursor="on"],
html[data-a11y-big-cursor="on"] * {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36'%3E%3Ccircle cx='16' cy='16' r='10' fill='%23f4cf43' stroke='%230f7a69' stroke-width='3'/%3E%3Cpath d='M24 24l8 8' stroke='%230f7a69' stroke-width='4' stroke-linecap='round'/%3E%3C/svg%3E") 16 16, auto !important;
}

html[data-a11y-hide-images="on"] main img,
html[data-a11y-hide-images="on"] main video,
html[data-a11y-hide-images="on"] .page-hero__media,
html[data-a11y-hide-images="on"] .story-split__media,
html[data-a11y-hide-images="on"] .testimonial-slide__media {
  display: none !important;
}

html[data-a11y-hide-images="on"] .page-hero__grid,
html[data-a11y-hide-images="on"] .story-split,
html[data-a11y-hide-images="on"] .testimonial-slide {
  grid-template-columns: 1fr !important;
}

.header-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.header-nav {
  border-bottom: 1px solid rgba(47, 47, 47, 0.06);
  background: rgba(255, 255, 255, 0.92);
}

.site-header.is-scrolled .header-nav {
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-sm);
}

.logo-link {
  display: inline-flex;
  align-items: center;
  gap: 0;
  min-height: var(--nav-height);
  flex: 0 0 auto;
}

.brand-logo {
  width: clamp(176px, 17vw, 220px);
  height: auto;
  max-height: 50px;
  object-fit: contain;
}

.footer-brand .logo-link {
  min-height: auto;
  margin-bottom: 0.85rem;
}

.header-nav__inner {
  position: relative;
}

.nav-menu {
  margin-left: auto;
  margin-right: 0;
  min-width: 0;
}

.nav-list,
.nav-submenu {
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-grandmenu {
  list-style: none;
  margin: 0.2rem 0 0;
  padding: 0.35rem 0 0 0.9rem;
  border-left: 1px solid rgba(47, 47, 47, 0.08);
  display: grid;
  gap: 0.12rem;
}

.nav-list {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.nav-item {
  position: relative;
}

.nav-group__head {
  display: flex;
  align-items: center;
  gap: 0.18rem;
}

.nav-link,
.nav-sublink {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  border: 0;
  background: transparent;
  color: var(--ink-soft);
  font: inherit;
  text-align: left;
  transition: background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.nav-link {
  font-weight: 600;
  padding: 0.78rem 0.92rem;
  border-radius: 999px;
  font-size: 0.93rem;
  line-height: 1.1;
  white-space: nowrap;
}

.nav-link:hover,
.nav-link.is-current,
.nav-item.is-current > .nav-link {
  background: rgba(244, 207, 67, 0.2);
  color: #5e4a07;
}

.nav-caret {
  width: 0.55rem;
  height: 0.55rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transition: transform 180ms ease;
}

.nav-group__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 50%;
  border: 1px solid rgba(47, 47, 47, 0.08);
  background: rgba(255, 255, 255, 0.84);
  color: var(--ink-soft);
  cursor: pointer;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.nav-group__toggle:hover,
.nav-group__toggle:focus-visible,
.nav-item.is-current .nav-group__toggle,
.nav-item--group.is-open .nav-group__toggle {
  background: rgba(244, 207, 67, 0.18);
  border-color: rgba(244, 207, 67, 0.45);
  color: #5e4a07;
}

.nav-item--group:hover > .nav-group__head .nav-caret,
.nav-item--group:focus-within > .nav-group__head .nav-caret,
.nav-item--group.is-open > .nav-group__head .nav-caret {
  transform: rotate(-135deg) translateY(-1px);
}

.nav-children {
  position: absolute;
  top: calc(100% + 0.2rem);
  left: 0;
  min-width: 18.75rem;
  max-width: min(22rem, calc(100vw - 2rem));
  padding: 0.75rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.985);
  border: 1px solid rgba(47, 47, 47, 0.08);
  box-shadow: var(--shadow-md);
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity 180ms ease, transform 180ms ease;
  z-index: 40;
  overflow: visible;
}

.nav-children::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -0.7rem;
  height: 0.7rem;
}

.nav-item:nth-last-child(-n + 2) .nav-children {
  left: auto;
  right: 0;
}

.nav-item--group:hover > .nav-children,
.nav-item--group:focus-within > .nav-children,
.nav-item--group.is-open > .nav-children {
  opacity: 1;
  pointer-events: auto;
  transform: none;
}

.nav-submenu {
  display: grid;
  gap: 0.2rem;
}

.nav-subgroup__head,
.nav-grandgroup__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.35rem;
  align-items: center;
}

.nav-sublink {
  width: 100%;
  padding: 0.86rem 1rem;
  border-radius: 16px;
  font-weight: 500;
}

.nav-subtoggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.3rem;
  height: 2.3rem;
  border-radius: 50%;
  border: 1px solid rgba(47, 47, 47, 0.08);
  background: rgba(255, 255, 255, 0.84);
  color: var(--ink-soft);
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease,
    transform 180ms ease;
}

.nav-subtoggle:hover,
.nav-subtoggle:focus-visible,
.nav-subitem--group.is-open > .nav-subgroup__head .nav-subtoggle,
.nav-subitem--group.is-current > .nav-subgroup__head .nav-subtoggle {
  background: rgba(244, 207, 67, 0.18);
  border-color: rgba(244, 207, 67, 0.45);
  color: #5e4a07;
}

.nav-grandlink {
  display: block;
  width: 100%;
  padding: 0.72rem 0.9rem;
  border-radius: 14px;
  color: var(--ink-soft);
  font-weight: 500;
  font-size: 0.9rem;
  line-height: 1.35;
  transition: background 180ms ease, color 180ms ease;
}

.nav-sublink:hover,
.nav-sublink.is-current,
.nav-grandlink:hover,
.nav-grandlink.is-current {
  background: rgba(244, 207, 67, 0.16);
  color: #5e4a07;
}

.nav-sublink.is-current,
.nav-grandlink.is-current {
  font-weight: 700;
}

.nav-subitem--group > .nav-sublink,
.nav-subitem--group > .nav-subgroup__head > .nav-sublink {
  color: var(--ink-soft);
  font-weight: 500;
}

.nav-subitem--group.is-current > .nav-sublink,
.nav-subitem--group.is-current > .nav-subgroup__head > .nav-sublink {
  color: var(--ink);
  font-weight: 700;
}

.nav-subitem--group > .nav-grandmenu,
.nav-granditem--group > .nav-grandmenu--nested {
  display: none;
}

.nav-subitem--group:hover > .nav-grandmenu,
.nav-subitem--group:focus-within > .nav-grandmenu,
.nav-subitem--group.is-open > .nav-grandmenu,
.nav-subitem--group.is-current > .nav-grandmenu,
.nav-granditem--group:hover > .nav-grandmenu--nested,
.nav-granditem--group:focus-within > .nav-grandmenu--nested,
.nav-granditem--group.is-open > .nav-grandmenu--nested,
.nav-granditem--group.is-current > .nav-grandmenu--nested {
  display: grid;
}

.nav-grandmenu--nested {
  margin-top: 0.35rem;
}

@media (min-width: 1041px) {
  .nav-subitem--group,
  .nav-granditem--group {
    position: relative;
  }

  .nav-subitem--group > .nav-grandmenu,
  .nav-granditem--group > .nav-grandmenu--nested {
    position: absolute;
    top: 0;
    left: calc(100% - 0.2rem);
    min-width: 18rem;
    margin: 0;
    padding: 0.75rem;
    border-radius: 22px;
    border: 1px solid rgba(47, 47, 47, 0.08);
    background: rgba(255, 255, 255, 0.99);
    box-shadow: var(--shadow-md);
    z-index: 46;
  }

  .nav-subitem--group > .nav-grandmenu::before,
  .nav-granditem--group > .nav-grandmenu--nested::before {
    content: "";
    position: absolute;
    left: -0.95rem;
    top: 0;
    bottom: 0;
    width: 1rem;
  }

  .nav-item:nth-last-child(-n + 2) .nav-subitem--group > .nav-grandmenu,
  .nav-item:nth-last-child(-n + 2) .nav-granditem--group > .nav-grandmenu--nested {
    left: auto;
    right: calc(100% - 0.2rem);
  }

  .nav-item:nth-last-child(-n + 2) .nav-subitem--group > .nav-grandmenu::before,
  .nav-item:nth-last-child(-n + 2) .nav-granditem--group > .nav-grandmenu--nested::before {
    left: auto;
    right: -0.95rem;
  }
}

.nav-toggle {
  display: none;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.85);
  align-items: center;
  justify-content: center;
  color: var(--ink);
}

.nav-toggle span,
.nav-toggle span::before,
.nav-toggle span::after {
  display: block;
  width: 18px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  transition: transform 180ms ease, opacity 180ms ease;
  content: "";
}

.nav-toggle span::before {
  transform: translateY(-6px);
}

.nav-toggle span::after {
  transform: translateY(4px);
}

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

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

.nav-toggle[aria-expanded="true"] span::after {
  transform: rotate(-45deg) translate(1px, -1px);
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-left: auto;
  margin-right: 1rem;
}

.nav-links a {
  padding: 0.75rem 0.95rem;
  border-radius: 999px;
  color: var(--ink-soft);
  font-weight: 600;
  transition: background 180ms ease, color 180ms ease;
}

.nav-links a:hover,
.nav-links a[aria-current="page"] {
  background: rgba(12, 123, 106, 0.1);
  color: var(--brand-deep);
}

.page-hero {
  padding: 4.4rem 0 5.7rem;
}

.page-hero__grid {
  display: grid;
  gap: 3rem;
  grid-template-columns: 1.1fr 0.9fr;
  align-items: center;
}

.hero-standard .page-hero__grid {
  position: relative;
  align-items: stretch;
  padding: 2rem;
  border-radius: 38px;
  background:
    radial-gradient(circle at right top, rgba(244, 207, 67, 0.14), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 253, 250, 0.96));
  border: 1px solid rgba(47, 47, 47, 0.06);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.hero-standard .page-hero__grid::before {
  content: "";
  position: absolute;
  width: 14rem;
  height: 14rem;
  right: -3rem;
  top: -3rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(15, 122, 105, 0.1), transparent 66%);
  pointer-events: none;
}

.page-hero__copy {
  display: grid;
  gap: 1.55rem;
  align-content: center;
}

.page-hero__copy h1 {
  max-width: 18ch;
  text-wrap: balance;
}

.page-hero__copy p {
  font-size: 1.08rem;
  max-width: 62ch;
}

.hero-standard .page-hero__copy {
  align-content: start;
  padding-block: 0.4rem;
}

.page-hero__meta {
  display: grid;
  gap: 0.9rem;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  align-items: stretch;
}

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

.metric-pill {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  justify-content: space-between;
  min-width: 0;
  height: 100%;
  padding: 1rem 1.05rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(47, 47, 47, 0.07);
  box-shadow: 0 10px 20px rgba(41, 39, 28, 0.04);
}

.metric-pill strong {
  font-family: "Sora", sans-serif;
  font-size: 1.2rem;
  line-height: 1.2;
}

.page-hero__media {
  position: relative;
  display: flex;
  align-items: center;
  align-self: center;
  height: 100%;
  min-width: 0;
}

.page-hero__media .image-frame {
  width: 100%;
}

.image-frame {
  position: relative;
  overflow: hidden;
  border-radius: 34px;
  background: #d3ddd9;
  box-shadow: var(--shadow-lg);
}

main img {
  cursor: zoom-in;
}

main .logo-link img,
main .footer-link img,
main .footer-contact-link img,
main .footer-social img {
  cursor: default;
}

.image-frame::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 45%;
  background: linear-gradient(180deg, transparent, rgba(15, 24, 20, 0.45));
}

.image-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.image-frame video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-caption,
.floating-card,
.impact-chip {
  position: absolute;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(47, 47, 47, 0.06);
  box-shadow: var(--shadow-md);
}

.hero-caption {
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 22px;
  color: var(--ink);
}

.floating-card {
  top: -1rem;
  right: -1rem;
  padding: 1rem 1.15rem;
  border-radius: 20px;
  max-width: 230px;
}

.floating-card strong,
.impact-chip strong {
  display: block;
  font-family: "Sora", sans-serif;
  font-size: 1.25rem;
  margin-bottom: 0.2rem;
}

.impact-chip {
  left: -1rem;
  bottom: 2rem;
  padding: 0.85rem 1rem;
  border-radius: 20px;
}

.hero-home .image-frame {
  aspect-ratio: 0.94;
}

.hero-slider {
  isolation: isolate;
}

.hero-slider__viewport,
.hero-slider__track,
.hero-slider__slide {
  height: 100%;
}

.hero-slider__viewport {
  overflow: hidden;
}

.hero-slider__track {
  display: flex;
  transition: transform 620ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.hero-slider__slide {
  position: relative;
  flex: 0 0 100%;
  min-width: 100%;
  margin: 0;
}

.hero-slider__slide img {
  display: block;
}

.hero-slider__controls {
  position: absolute;
  z-index: 3;
  right: 1rem;
  top: 1rem;
  display: inline-flex;
  gap: 0.45rem;
}

.hero-slider__control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.55rem;
  height: 2.55rem;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
}

.hero-slider__control::before {
  content: "";
  width: 0.56rem;
  height: 0.56rem;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.hero-slider__control--prev::before {
  transform: rotate(225deg);
}

.hero-slider__dots {
  position: absolute;
  z-index: 3;
  left: 1.2rem;
  top: 1.2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.hero-slider__dot {
  width: 0.62rem;
  height: 0.62rem;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 0 0 1px rgba(15, 24, 20, 0.1);
  cursor: pointer;
}

.hero-slider__dot.is-active {
  width: 1.55rem;
  border-radius: 999px;
  background: var(--brand);
}

.hero-standard .image-frame {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  min-height: 100%;
  aspect-ratio: auto;
  background: linear-gradient(180deg, rgba(239, 246, 243, 0.98), rgba(255, 255, 255, 0.98));
}

.hero-standard .image-frame::after {
  display: none;
}

.hero-standard .page-hero__media {
  align-self: stretch;
}

.hero-standard .image-frame img {
  min-height: 360px;
}

body[data-page="about-founder"] .hero-standard .page-hero__media {
  align-self: start;
}

body[data-page="about-founder"] .hero-standard .image-frame {
  display: block;
  min-height: 0;
}

body[data-page="about-founder"] .hero-standard .image-frame img {
  width: 100%;
  height: auto;
  min-height: 0;
  object-fit: contain;
}

.media-launch {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
}

.media-launch .image-frame {
  cursor: pointer;
}

.media-launch .image-frame::after {
  height: 100%;
  background: linear-gradient(
    180deg,
    rgba(9, 13, 12, 0.14),
    rgba(9, 13, 12, 0.58)
  );
}

.media-launch__play {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.85rem 1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
  font-weight: 700;
  box-shadow: var(--shadow-sm);
  transform: translate(-50%, -50%);
}

.media-launch__play::before {
  content: "";
  width: 0;
  height: 0;
  border-top: 0.45rem solid transparent;
  border-bottom: 0.45rem solid transparent;
  border-left: 0.7rem solid currentColor;
}

.media-launch__note {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 1;
  color: #fff;
  font-weight: 600;
  line-height: 1.45;
}

.story-split__media .media-launch {
  max-width: 22rem;
  margin-inline: auto;
}

.story-split__media .media-launch .image-frame {
  aspect-ratio: 1.08;
}

.section > .container > .media-launch {
  max-width: 28rem;
  margin-inline: auto;
}

.section > .container > .media-launch .image-frame {
  aspect-ratio: 1.22;
}

.page-hero__media > .media-launch {
  max-width: 24rem;
  margin-left: auto;
}

.page-hero__media > .media-launch .image-frame {
  aspect-ratio: 0.98;
}

.media-launch__play {
  padding: 0.72rem 0.92rem;
  font-size: 0.94rem;
}

.hero-standard .hero-caption {
  position: static;
  left: auto;
  right: auto;
  bottom: auto;
  margin: 0;
  padding: 1.05rem 1.15rem 1.15rem;
  border-radius: 0;
  border: 0;
  border-top: 1px solid rgba(47, 47, 47, 0.08);
  box-shadow: none;
  background: linear-gradient(180deg, rgba(255, 248, 230, 0.98), rgba(255, 255, 255, 0.98));
}

.section-surface,
.surface-panel,
.stat-band,
.quote-card,
.timeline-card,
.news-card,
.program-card,
.support-card,
.team-card,
.detail-card,
.contact-card,
.form-card,
.cta-banner,
.value-card,
.initiative-stat,
.recognition-card {
  background: var(--surface);
  border: 1px solid rgba(47, 47, 47, 0.06);
  box-shadow: var(--shadow-sm);
}

.section-surface {
  border-radius: var(--radius-xl);
  padding: 3rem;
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  color: var(--ink-soft);
  font-size: 0.92rem;
}

.breadcrumb a {
  color: var(--brand-deep);
}

.page-copy {
  max-width: 100%;
}

.article-detail__body {
  margin: 0;
}

.contact-lines {
  display: grid;
  gap: 0.7rem;
  margin: 0.35rem 0 1rem;
}

.contact-line {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  width: fit-content;
  color: var(--ink);
}

.contact-line__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 50%;
  background: var(--accent-soft);
  color: var(--accent);
  flex: 0 0 auto;
}

.contact-line__icon svg {
  width: 1.2rem;
  height: 1.2rem;
}

.grid {
  display: grid;
  gap: 1.7rem;
}

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

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

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

.value-card,
.program-card,
.recognition-card,
.initiative-stat,
.support-card,
.contact-card,
.team-card,
.news-card,
.quote-card,
.timeline-card,
.detail-card {
  border-radius: 24px;
  padding: 1.85rem;
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.value-card,
.recognition-card,
.initiative-stat,
.support-card,
.contact-card,
.quote-card,
.timeline-card,
.detail-card {
  display: grid;
  align-content: start;
  gap: 0.8rem;
  min-height: 100%;
}

.detail-card {
  min-height: auto;
}

.icon-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: 2.8rem;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--brand-soft), rgba(214, 147, 58, 0.18));
  color: var(--brand-deep);
}

.icon-badge svg {
  width: 1.35rem;
  height: 1.35rem;
}

.program-card {
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  padding: 0;
}

.news-card {
  display: grid;
  grid-template-rows: auto 1fr;
  align-items: start;
  overflow: hidden;
  padding: 0;
}

.program-card img,
.team-card img,
.news-card img,
.story-split__media img {
  width: 100%;
  aspect-ratio: 1.2;
  object-fit: cover;
  transition: transform 700ms ease;
}

.program-card__body,
.team-card__body {
  display: grid;
  align-content: start;
  gap: 0.8rem;
  padding: 1.35rem;
  min-height: 100%;
}

.news-card__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  align-self: stretch;
  gap: 0.85rem;
  padding: 1.35rem;
  min-height: 100%;
  height: 100%;
}

.news-card__body > * {
  width: 100%;
}

.program-card__body p:last-child,
.team-card__body p:last-child,
.news-card__body p:last-child {
  margin-bottom: 0;
}

.program-card__body .card-actions,
.news-card__body .card-actions,
.detail-card .card-actions,
.support-card .card-actions {
  margin-top: auto;
}

.chip-row,
.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.chip,
.tag {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.5rem 0.8rem;
  border-radius: 999px;
  background: rgba(12, 123, 106, 0.08);
  color: var(--brand-deep);
  font-size: 0.9rem;
  font-weight: 600;
}

.tag {
  background: rgba(214, 147, 58, 0.12);
  color: #9f621b;
}

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

.page-intro-panel {
  display: grid;
  gap: 0.9rem;
  width: 100%;
  max-width: 100%;
}

.page-intro-panel h1 {
  margin-bottom: 0;
}

.page-intro-panel p:last-child {
  margin-bottom: 0;
}

.story-split--flush {
  margin-bottom: 0;
}

.card-actions--top-offset,
.actions--top-offset,
.copy-top-offset {
  margin-top: 1rem;
}

.grid--section-gap {
  margin-bottom: 2rem;
}

.section-surface--offset {
  margin-bottom: 2.2rem;
}

.archive-stack {
  display: grid;
  gap: 2rem;
}

.archive-year {
  display: grid;
  gap: 1.15rem;
}

.archive-year__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.45rem;
  align-items: start;
}

.archive-year__head p {
  margin: 0;
  color: var(--ink-soft);
  grid-column: 1 / -1;
}

.archive-year__head .button-ghost {
  justify-self: end;
  align-self: start;
}

.activity-stack {
  display: grid;
  gap: 1.4rem;
}

.activity-card {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 1.35rem;
  padding: 1.2rem;
  align-items: stretch;
}

.activity-card__media {
  min-width: 0;
}

.activity-card__media img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  border-radius: 20px;
  aspect-ratio: 1.08;
  object-fit: cover;
}

.activity-card__content {
  display: grid;
  align-content: start;
  gap: 0.8rem;
  min-width: 0;
}

.activity-card__content p:last-child {
  margin-bottom: 0;
}

.gallery-card {
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
  overflow: hidden;
  border-radius: 24px;
  background: var(--surface);
  border: 1px solid rgba(47, 47, 47, 0.06);
  box-shadow: var(--shadow-sm);
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.gallery-card--button {
  appearance: none;
  width: 100%;
  padding: 0;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.gallery-card img {
  width: 100%;
  aspect-ratio: 1.22;
  height: clamp(220px, 28vw, 300px);
  object-fit: cover;
}

.gallery-card__body {
  display: grid;
  align-content: start;
  gap: 0.35rem;
  min-height: 100%;
  padding: 1rem 1.15rem 1.2rem;
}

.gallery-card--plain {
  display: block;
  position: relative;
}

.gallery-card--plain img {
  aspect-ratio: auto;
  height: auto;
  max-height: 420px;
  object-fit: contain;
  background: rgba(247, 244, 232, 0.92);
}

.gallery-card__play {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.65rem 0.9rem;
  border-radius: 999px;
  background: rgba(15, 14, 10, 0.74);
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  z-index: 1;
}

.gallery-card__play::before {
  content: "";
  width: 0;
  height: 0;
  border-top: 0.35rem solid transparent;
  border-bottom: 0.35rem solid transparent;
  border-left: 0.55rem solid currentColor;
}

.image-strip {
  display: grid;
  gap: 1.25rem;
  overflow: hidden;
}

.image-strip .section-intro {
  margin-bottom: 0;
}

.image-strip__controls {
  display: inline-flex;
  gap: 0.55rem;
  justify-self: end;
  align-self: end;
}

.image-strip__control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border: 1px solid rgba(47, 47, 47, 0.08);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.94);
  color: var(--ink);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: transform 180ms ease, background 180ms ease, opacity 180ms ease;
}

.image-strip__control::before {
  content: "";
  width: 0.6rem;
  height: 0.6rem;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.image-strip__control--prev::before {
  transform: rotate(225deg);
}

.image-strip__control:hover,
.image-strip__control:focus-visible {
  background: var(--brand-soft);
  transform: translateY(-2px);
}

.image-strip__control:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

.image-strip__viewport {
  overflow: hidden;
  padding: 0.2rem 0.1rem 0.8rem;
}

.image-strip__track {
  --image-strip-visible: 4;
  display: flex;
  gap: 1rem;
  transition: transform 560ms cubic-bezier(0.2, 0.8, 0.2, 1);
  will-change: transform;
}

.image-strip__item {
  appearance: none;
  display: block;
  flex: 0 0 calc((100% - 3rem) / 4);
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(47, 47, 47, 0.06);
  border-radius: 24px;
  background: var(--surface-muted);
  box-shadow: 0 12px 26px rgba(41, 39, 28, 0.07);
  cursor: zoom-in;
}

.image-strip__item img {
  display: block;
  width: 100%;
  height: clamp(210px, 24vw, 300px);
  object-fit: cover;
  transition: transform 220ms ease;
}

.image-strip__item:hover img,
.image-strip__item:focus-visible img {
  transform: scale(1.04);
}

.stat-band {
  border-radius: 30px;
  padding: 2.35rem;
}

.stat-band .grid {
  gap: 1rem;
  align-items: stretch;
}

.stat-item {
  display: grid;
  gap: 0.35rem;
  align-content: start;
  height: 100%;
  padding: 1.4rem 1.25rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(47, 47, 47, 0.06);
  box-shadow: 0 10px 22px rgba(41, 39, 28, 0.04);
}

.stat-item strong {
  font-family: "Sora", sans-serif;
  font-size: clamp(1.4rem, 2vw, 2rem);
  line-height: 1.22;
}

.stat-item span {
  color: var(--ink-soft);
}

.story-split {
  display: grid;
  gap: 2.6rem;
  grid-template-columns: 0.92fr 1.08fr;
  align-items: center;
  margin-bottom: 2.2rem;
}

.story-split:nth-child(even) {
  grid-template-columns: 1.08fr 0.92fr;
}

.story-split:nth-child(even) .story-split__media {
  order: 2;
}

.story-split__media .image-frame {
  aspect-ratio: 1.03;
}

.story-split__content {
  display: grid;
  gap: 1rem;
}

.story-split__content p:last-of-type {
  margin-bottom: 0;
}

.mini-list {
  display: grid;
  gap: 0.75rem;
  padding: 0;
  list-style: none;
}

.mini-list li {
  position: relative;
  padding-left: 1.25rem;
}

.mini-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7rem;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), var(--accent));
}

.quote-card {
  display: grid;
  gap: 1rem;
}

.quote-card blockquote {
  margin: 0;
  color: var(--ink);
  font-size: 1.02rem;
}

.quote-card cite {
  font-style: normal;
  color: var(--ink-soft);
}

.testimonial-panel {
  display: grid;
  gap: 1.35rem;
  margin-top: 1.6rem;
  padding: 1.4rem;
  border-radius: 34px;
  background:
    radial-gradient(circle at right top, rgba(244, 207, 67, 0.16), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(248, 253, 250, 0.96));
  border: 1px solid rgba(47, 47, 47, 0.06);
}

.slider-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  justify-content: flex-end;
}

.slider-control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  border: 1px solid rgba(47, 47, 47, 0.08);
  background: rgba(255, 255, 255, 0.9);
  color: var(--ink);
  transition: transform 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease;
}

.slider-control:hover,
.slider-control:focus-visible {
  background: rgba(244, 207, 67, 0.18);
  border-color: rgba(244, 207, 67, 0.45);
  color: #5e4a07;
  transform: translateY(-2px);
}

.slider-control__arrow {
  width: 0.72rem;
  height: 0.72rem;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.slider-control__arrow--left {
  transform: rotate(-135deg);
}

.testimonial-slider {
  display: grid;
  gap: 1rem;
}

.testimonial-slider__viewport {
  overflow: hidden;
}

.testimonial-slider__track {
  display: flex;
  transition: transform 420ms ease;
  will-change: transform;
}

.testimonial-slide {
  min-width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 104px) minmax(0, 1fr);
  gap: 1.35rem;
  align-items: start;
  padding: 1.85rem;
  border-radius: 32px;
  background:
    radial-gradient(circle at top right, rgba(244, 207, 67, 0.22), transparent 28%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 253, 250, 0.98));
  border: 1px solid rgba(47, 47, 47, 0.06);
  box-shadow: var(--shadow-sm);
}

.testimonial-slide__media {
  position: relative;
  width: min(100%, 104px);
  justify-self: start;
}

.testimonial-slide__media img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
}

.testimonial-avatar {
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 1;
  border-radius: 16px;
  background:
    radial-gradient(circle at top right, rgba(244, 207, 67, 0.35), transparent 32%),
    linear-gradient(135deg, rgba(15, 84, 72, 0.92), rgba(47, 47, 47, 0.92));
  color: #fff8e6;
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  box-shadow: var(--shadow-sm);
}

.testimonial-slide__badge {
  display: none;
}

.testimonial-slide__content {
  display: grid;
  gap: 1rem;
  position: relative;
  padding-top: 0.5rem;
}

.testimonial-slide__content::before {
  content: '"';
  position: absolute;
  top: -0.9rem;
  left: -0.1rem;
  color: rgba(244, 207, 67, 0.4);
  font-family: "Sora", sans-serif;
  font-size: 4.6rem;
  line-height: 1;
}

.testimonial-slide__content blockquote {
  margin: 0;
  font-family: "Sora", sans-serif;
  font-size: clamp(1rem, 1.3vw, 1.18rem);
  line-height: 1.65;
}

.testimonial-slide__person {
  display: grid;
  gap: 0.2rem;
}

.testimonial-slide__person strong {
  font-size: 1rem;
}

.testimonial-slide__person span {
  color: var(--ink-soft);
}

.testimonial-slide__meta {
  font-size: 0.92rem;
  line-height: 1.55;
}

.slider-dots {
  display: flex;
  gap: 0.55rem;
  align-items: center;
  justify-content: center;
}

.slider-dot {
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 999px;
  border: 0;
  background: rgba(47, 47, 47, 0.14);
  transition: width 180ms ease, background 180ms ease;
}

.slider-dot.is-active {
  width: 2rem;
  background: var(--accent);
}

.recognition-card {
  display: grid;
  gap: 0.6rem;
}

.recognition-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 16px;
  margin-bottom: 0.15rem;
}

.recognition-card strong {
  font-size: 1rem;
}

.timeline {
  display: grid;
  gap: 1rem;
}

.timeline-card {
  position: relative;
  padding-left: 1.55rem;
}

.timeline-card::before {
  content: "";
  position: absolute;
  left: 0.55rem;
  top: 1.25rem;
  bottom: -1rem;
  width: 1px;
  background: rgba(12, 123, 106, 0.2);
}

.timeline-card:last-child::before {
  display: none;
}

.timeline-card::after {
  content: "";
  position: absolute;
  left: 0.2rem;
  top: 1.2rem;
  width: 0.7rem;
  height: 0.7rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), var(--accent));
}

.meta-line {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: center;
  color: var(--ink-soft);
  font-size: 0.92rem;
}

.meta-line span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.detail-card,
.support-card,
.contact-card,
.form-card {
  border-radius: 28px;
}

.detail-card strong,
.support-card strong,
.contact-card strong,
.form-card strong {
  font-family: "Sora", sans-serif;
}

.pricing-grid {
  display: grid;
  gap: 1.35rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.support-card {
  display: grid;
  gap: 1rem;
}

.support-card__price {
  font-family: "Sora", sans-serif;
  font-size: 1.9rem;
  color: var(--accent);
}

.support-card.highlight {
  background: linear-gradient(135deg, rgba(255, 243, 193, 0.96), rgba(255, 255, 255, 0.98));
  color: var(--ink);
  border-color: rgba(244, 207, 67, 0.45);
}

.support-card.highlight p,
.support-card.highlight li,
.support-card.highlight .support-card__caption {
  color: var(--ink-soft);
}

.support-card.highlight .chip {
  background: rgba(15, 122, 105, 0.1);
  color: var(--accent);
}

.support-card__caption {
  font-size: 0.95rem;
}

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

.team-card img {
  aspect-ratio: 0.92;
}

.team-list {
  display: grid;
  gap: 1.15rem;
  margin-inline: auto;
  max-width: 980px;
}

.team-card--profile {
  align-items: center;
  display: grid;
  gap: 1.2rem;
  grid-template-columns: 150px minmax(0, 1fr);
  padding: 1.25rem;
}

.team-card--profile img {
  width: 150px;
  aspect-ratio: 1;
  border-radius: 22px;
}

.team-card--profile .team-card__body {
  padding: 0;
  text-align: left;
}

.team-card--profile .tag {
  justify-self: start;
}

.team-card--profile h2 {
  font-size: clamp(1.05rem, 1.7vw, 1.3rem);
}

.team-role {
  color: var(--brand-deep);
  font-size: 0.92rem;
  font-weight: 700;
}

.contact-layout {
  display: grid;
  gap: 2rem;
  grid-template-columns: 0.85fr 1.15fr;
}

.contact-grid {
  display: grid;
  gap: 1rem;
}

.contact-card {
  display: grid;
  gap: 0.45rem;
}

.contact-card a {
  color: var(--brand-deep);
  font-weight: 600;
}

.form-card {
  padding: 2rem;
}

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

.form-grid .full {
  grid-column: 1 / -1;
}

.field {
  display: grid;
  gap: 0.45rem;
}

.field label {
  font-size: 0.92rem;
  color: var(--ink);
  font-weight: 600;
}

.field input:not([type="checkbox"]):not([type="radio"]),
.field select,
.field textarea {
  width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(24, 51, 41, 0.12);
  background: rgba(255, 255, 255, 0.8);
  padding: 1rem 1rem;
  color: var(--ink);
  transition: border-color 180ms ease, box-shadow 180ms ease;
}

.field textarea {
  min-height: 150px;
  resize: vertical;
}

.field input:not([type="checkbox"]):not([type="radio"]):focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-color: rgba(12, 123, 106, 0.55);
  box-shadow: 0 0 0 4px rgba(12, 123, 106, 0.12);
}

.field input[type="checkbox"],
.field input[type="radio"],
.checkbox-item input {
  width: 1rem;
  height: 1rem;
  margin: 0.18rem 0 0;
  accent-color: var(--accent);
}

.checkbox-grid {
  display: grid;
  gap: 0.8rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.checkbox-item {
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr);
  gap: 0.8rem;
  align-items: start;
  cursor: pointer;
  padding: 1rem 1.1rem;
  border-radius: 16px;
  border: 1px solid rgba(47, 47, 47, 0.08);
  background: rgba(255, 255, 255, 0.84);
}

.checkbox-item input {
  margin-top: 0.22rem;
}

.checkbox-item span {
  display: block;
  color: var(--ink-soft);
}

.form-note {
  color: var(--ink-soft);
  font-size: 0.92rem;
}

.form-note a {
  color: var(--brand-deep);
  font-weight: 700;
}

.form-feedback {
  margin: 0 0 1rem;
  padding: 0.95rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(47, 47, 47, 0.08);
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink);
}

.form-feedback[hidden] {
  display: none;
}

.form-feedback.is-success {
  border-color: rgba(15, 122, 105, 0.28);
  background: rgba(222, 239, 234, 0.75);
}

.form-feedback.is-error {
  border-color: rgba(206, 83, 49, 0.28);
  background: rgba(255, 239, 233, 0.82);
}

.field--invalid label {
  color: var(--warning);
}

.field--invalid input:not([type="checkbox"]):not([type="radio"]),
.field--invalid select,
.field--invalid textarea {
  border-color: rgba(206, 83, 49, 0.55);
  box-shadow: 0 0 0 4px rgba(206, 83, 49, 0.12);
}

.field--invalid .checkbox-item {
  border-color: rgba(206, 83, 49, 0.38);
  background: rgba(255, 247, 244, 0.92);
}

.field-error {
  margin: 0;
  color: var(--warning);
  font-size: 0.88rem;
  font-weight: 600;
}

.field--hidden {
  display: none !important;
}

.button[disabled],
.button-secondary[disabled],
.button-ghost[disabled] {
  cursor: wait;
  opacity: 0.72;
  transform: none;
}

.cta-banner {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1.18fr 0.82fr;
  align-items: center;
  padding: 2.6rem;
  border-radius: 34px;
  background:
    radial-gradient(circle at top right, rgba(244, 207, 67, 0.25), transparent 34%),
    linear-gradient(135deg, rgba(255, 250, 229, 0.98), rgba(247, 253, 250, 0.98));
  color: var(--ink);
  border: 1px solid rgba(244, 207, 67, 0.4);
}

.cta-banner p,
.cta-banner li {
  color: var(--ink-soft);
}

.cta-banner > :first-child {
  min-width: 0;
}

.cta-banner .eyebrow {
  margin-bottom: 1.15rem;
}

.cta-banner h2 {
  margin-bottom: 0.75rem;
  text-wrap: balance;
}

.cta-banner .actions {
  justify-content: flex-end;
  align-items: center;
  margin-left: auto;
  align-self: end;
}

.cta-banner .button-ghost {
  background: rgba(255, 255, 255, 0.9);
  color: var(--ink);
  border-color: rgba(47, 47, 47, 0.09);
}

.cta-banner .button-secondary {
  box-shadow: none;
}

.report-viewer {
  display: grid;
  gap: 1.8rem;
}

.report-viewer__head {
  display: grid;
  gap: 1.35rem;
  padding-bottom: 1.35rem;
  border-bottom: 1px solid var(--line);
}

.report-viewer__copy {
  display: grid;
  gap: 0.9rem;
  max-width: 48rem;
}

.report-viewer__copy .eyebrow {
  justify-self: start;
  margin-bottom: 0;
}

.report-viewer__copy h2,
.report-viewer__copy p {
  margin: 0;
}

.report-viewer__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem;
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(244, 207, 67, 0.1), transparent 28%),
    linear-gradient(180deg, var(--surface), var(--surface-strong));
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}

.report-viewer__toolbar > * {
  flex: 0 0 auto;
}

.report-viewer__jump {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.45rem 0.55rem 0.45rem 0.8rem;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}

.report-viewer__jump-label {
  color: var(--ink-soft);
  font-size: 0.9rem;
  font-weight: 700;
}

.report-viewer__jump-input {
  width: 4.35rem;
  padding: 0.35rem 0.2rem;
  border: 0;
  background: transparent;
  color: var(--ink);
  font-weight: 700;
  text-align: center;
}

.report-viewer__jump-input:focus {
  outline: none;
}

.report-viewer__status {
  margin: 0;
  padding: 0.8rem 1rem;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--ink);
  font-weight: 700;
  box-shadow: var(--shadow-sm);
}

.report-viewer__frame {
  position: relative;
  min-height: clamp(34rem, 82vh, 78rem);
  border-radius: 0;
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(244, 207, 67, 0.12), transparent 30%),
    linear-gradient(180deg, var(--surface-muted), var(--surface-strong));
  border: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
  isolation: isolate;
}

.report-viewer__frame:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 4px;
}

.report-viewer__frame.is-loading::after {
  content: "Loading report page...";
  position: absolute;
  right: 1rem;
  top: 1rem;
  z-index: 3;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  background: rgba(17, 23, 34, 0.82);
  color: #ffffff;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.report-viewer__paper {
  position: relative;
  display: grid;
  place-items: center;
  min-height: inherit;
  width: 100%;
  padding: clamp(1rem, 2vw, 1.6rem);
  overflow: hidden;
}

.report-viewer__embed-shell,
.report-viewer__flip-sheet {
  display: block;
  width: min(100%, 1040px);
  border-radius: 0;
  background: #ffffff;
  box-shadow: 0 24px 60px rgba(17, 15, 8, 0.18);
}

.report-viewer__embed-shell {
  position: relative;
  z-index: 1;
  height: clamp(30rem, 74vh, 70rem);
  overflow: hidden;
}

.report-viewer__embed {
  display: block;
  width: calc(100% + 20px);
  height: calc(100% + 20px);
  border: 0;
  margin-right: -20px;
  margin-bottom: -20px;
  background: #ffffff;
}

.report-viewer__flip-sheet {
  position: absolute;
  top: clamp(1rem, 2vw, 1.6rem);
  bottom: clamp(1rem, 2vw, 1.6rem);
  width: min(52%, 540px);
  opacity: 0;
  pointer-events: none;
  z-index: 2;
  backface-visibility: hidden;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.98) 0%,
    rgba(255, 251, 240, 0.94) 46%,
    rgba(214, 193, 150, 0.34) 100%
  );
}

.report-viewer__frame.is-flipping-next .report-viewer__flip-sheet {
  right: clamp(1rem, 2vw, 1.6rem);
  transform-origin: left center;
  animation: reportPageFlipNext 680ms cubic-bezier(0.33, 0.02, 0.2, 1);
}

.report-viewer__frame.is-flipping-prev .report-viewer__flip-sheet {
  left: clamp(1rem, 2vw, 1.6rem);
  transform-origin: right center;
  background: linear-gradient(
    270deg,
    rgba(255, 255, 255, 0.98) 0%,
    rgba(255, 251, 240, 0.94) 46%,
    rgba(214, 193, 150, 0.34) 100%
  );
  animation: reportPageFlipPrev 680ms cubic-bezier(0.33, 0.02, 0.2, 1);
}

.report-viewer__empty {
  max-width: 32rem;
  margin: 0;
  padding: 1rem 1.1rem;
  border-radius: 20px;
  background: rgba(17, 23, 34, 0.86);
  color: #ffffff;
  text-align: center;
  font-weight: 600;
}

.report-viewer__note {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.92rem;
}

@media (min-width: 980px) {
  .report-viewer__toolbar {
    justify-content: flex-start;
  }
}

.site-footer {
  padding: 0 0 2rem;
}

.footer-panel {
  padding: 1.7rem 1.85rem;
  border-radius: 32px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(47, 47, 47, 0.06);
  box-shadow: var(--shadow-sm);
}

.footer-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1.18fr 0.85fr 0.97fr;
}

.footer-grid h4 {
  margin: 0 0 1rem;
  font-family: "Sora", sans-serif;
  font-size: 1rem;
}

.footer-brand p,
.footer-grid p {
  max-width: 42ch;
  font-size: 0.96rem;
}

.footer-links {
  display: grid;
  gap: 0.5rem;
}

.footer-links--columns {
  grid-template-columns: 1fr;
  gap: 0.5rem;
}

.footer-contact {
  display: grid;
  gap: 0.56rem;
  margin-bottom: 0.8rem;
}

.footer-links a,
.footer-contact a {
  color: var(--ink-soft);
  transition: color 180ms ease, transform 180ms ease;
}

.footer-link,
.footer-contact-link,
.footer-social {
  display: inline-flex;
  align-items: center;
  gap: 0.58rem;
  width: fit-content;
}

.footer-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  color: var(--accent);
  flex: 0 0 auto;
}

.footer-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.footer-links a:hover,
.footer-contact a:hover {
  color: var(--ink);
  transform: translateX(2px);
}

.footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.8rem;
}

.footer-socials a {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.6rem;
  padding: 0.46rem 0.78rem;
  border-radius: 999px;
  background: rgba(255, 248, 230, 0.95);
  border: 1px solid rgba(47, 47, 47, 0.08);
  color: var(--ink-soft);
  font-size: 0.92rem;
}

.footer-bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1.25rem;
  padding-top: 0.9rem;
  border-top: 1px solid rgba(24, 51, 41, 0.08);
  color: var(--ink-soft);
  font-size: 0.92rem;
}

.footer-credit {
  color: var(--brand-deep);
  font-weight: 700;
}

.footer-credit:hover,
.footer-credit:focus-visible {
  color: var(--ink);
}

.back-to-top {
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  z-index: 120;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.4rem;
  height: 3.4rem;
  border-radius: 50%;
  border: 1px solid rgba(47, 47, 47, 0.1);
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
  box-shadow: var(--shadow-md);
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition: opacity 180ms ease, transform 180ms ease, background 180ms ease, color 180ms ease;
  text-decoration: none;
}

.back-to-top:hover,
.back-to-top:focus-visible {
  background: rgba(244, 207, 67, 0.18);
  color: #5e4a07;
}

.back-to-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: none;
}

.back-to-top__icon {
  width: 0.8rem;
  height: 0.8rem;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
  transform: rotate(45deg) translate(1px, 1px);
}

.a11y-tools {
  position: fixed;
  right: 1.25rem;
  bottom: 5.45rem;
  z-index: 170;
  display: grid;
  gap: 0.85rem;
  justify-items: end;
}

.a11y-trigger {
  display: inline-grid;
  place-items: center;
  width: 3.45rem;
  height: 3.45rem;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(47, 47, 47, 0.1);
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
  box-shadow: var(--shadow-md);
}

.a11y-trigger__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.45rem;
  height: 2.45rem;
  color: var(--accent);
  line-height: 1;
}

.a11y-trigger__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.a11y-panel {
  width: min(29rem, calc(100vw - 2rem));
  max-height: min(78vh, 760px);
  overflow: auto;
  padding: 1.2rem;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(47, 47, 47, 0.1);
  box-shadow: var(--shadow-lg);
}

.a11y-panel[hidden] {
  display: none;
}

.a11y-panel__head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.1rem;
}

.a11y-panel__head h2 {
  font-size: 1.2rem;
  margin-bottom: 0.2rem;
}

.a11y-panel__subhead {
  display: flex;
  align-items: start;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.8rem;
  margin-bottom: 0.7rem;
}

.a11y-panel__eyebrow {
  margin: 0 0 0.3rem;
  color: var(--brand-deep);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.a11y-panel__close {
  width: 2.4rem;
  height: 2.4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(47, 47, 47, 0.08);
  background: rgba(255, 255, 255, 0.9);
  color: var(--ink);
  font-size: 1.2rem;
}

.a11y-panel__group + .a11y-panel__group {
  margin-top: 1rem;
}

.a11y-panel__label {
  margin: 0 0 0.65rem;
  color: var(--ink);
  font-size: 0.92rem;
  font-weight: 700;
}

.a11y-grid {
  display: grid;
  gap: 0.55rem;
}

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

.a11y-chip,
.a11y-action,
.a11y-segment {
  font-size: 0.9rem;
}

.a11y-chip,
.a11y-action,
.a11y-choice,
.a11y-switch {
  border: 1px solid rgba(47, 47, 47, 0.08);
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink);
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
}

.a11y-chip,
.a11y-action {
  min-height: 2.75rem;
  padding: 0.7rem 0.85rem;
  border-radius: 18px;
  font-weight: 700;
}

.a11y-action {
  max-width: 100%;
  white-space: normal;
}

.a11y-control + .a11y-control,
.a11y-control + .a11y-switches,
.a11y-switches + .a11y-control,
.a11y-switches + .a11y-helper,
.a11y-helper + .a11y-dictionary,
.a11y-switches + .a11y-structure {
  margin-top: 0.75rem;
}

.a11y-control__label {
  display: block;
  margin-bottom: 0.45rem;
  color: var(--ink-soft);
  font-size: 0.86rem;
  font-weight: 700;
}

.a11y-segment {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(5.1rem, 1fr));
  gap: 0.55rem;
}

.a11y-choice {
  min-height: 3rem;
  padding: 0.7rem 0.72rem;
  border-radius: 18px;
  font-weight: 700;
}

.a11y-switches {
  display: grid;
  gap: 0.6rem;
}

.a11y-switch {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  padding: 0.9rem 1rem;
  border-radius: 18px;
  text-align: left;
}

.a11y-switch__label {
  font-weight: 700;
}

.a11y-switch__state {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3.2rem;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(47, 47, 47, 0.08);
  color: var(--ink-soft);
  font-size: 0.84rem;
  font-weight: 700;
}

.a11y-helper {
  margin: 0;
  color: var(--ink-soft);
  font-size: 0.84rem;
}

.a11y-structure,
.a11y-dictionary {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.8rem;
  padding: 0.9rem;
  border-radius: 20px;
  background: rgba(250, 251, 255, 0.92);
  border: 1px solid rgba(47, 47, 47, 0.08);
}

.a11y-structure__list {
  display: grid;
  gap: 0.45rem;
}

.a11y-structure__link {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.65rem;
  align-items: start;
  padding: 0.65rem 0.78rem;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--ink);
  font-size: 0.9rem;
  font-weight: 600;
}

.a11y-structure__link span:first-child {
  color: var(--brand-deep);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
}

.a11y-structure__link--level-2 {
  padding-left: 1rem;
}

.a11y-structure__link--level-3,
.a11y-structure__link--level-4,
.a11y-structure__link--level-5,
.a11y-structure__link--level-6 {
  padding-left: 1.25rem;
}

.a11y-dictionary__word {
  font-family: "Sora", sans-serif;
  font-size: 0.96rem;
}

.a11y-dictionary__result {
  margin: 0;
}

.a11y-choice.is-active,
.a11y-switch.is-active,
.a11y-chip.is-active,
.a11y-action.is-active {
  border-color: rgba(15, 122, 105, 0.34);
  background: rgba(222, 239, 234, 0.9);
  box-shadow: 0 12px 28px rgba(15, 122, 105, 0.08);
}

.a11y-choice.is-active,
.a11y-switch.is-active .a11y-switch__state,
.a11y-chip.is-active,
.a11y-action.is-active {
  color: var(--ink);
}

.a11y-switch.is-active .a11y-switch__state {
  background: rgba(15, 122, 105, 0.14);
}

.a11y-trigger:hover,
.a11y-trigger:focus-visible,
.a11y-chip:hover,
.a11y-chip:focus-visible,
.a11y-action:hover,
.a11y-action:focus-visible,
.a11y-choice:hover,
.a11y-choice:focus-visible,
.a11y-switch:hover,
.a11y-switch:focus-visible,
.a11y-panel__close:hover,
.a11y-panel__close:focus-visible {
  transform: translateY(-2px);
}

.a11y-panel__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 1.15rem;
}

.a11y-reading-guide,
.a11y-reading-mask,
.a11y-tooltip {
  position: fixed;
  z-index: 190;
  pointer-events: none;
}

.a11y-reading-guide {
  left: 0;
  right: 0;
  height: 3px;
  background: rgba(15, 122, 105, 0.88);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.3);
}

.a11y-reading-mask {
  left: 0;
  right: 0;
  height: 168px;
  background: rgba(255, 255, 255, 0.02);
  box-shadow: 0 0 0 9999px rgba(14, 17, 21, 0.56);
}

.a11y-tooltip {
  max-width: min(20rem, calc(100vw - 2rem));
  padding: 0.75rem 0.85rem;
  border-radius: 16px;
  background: rgba(17, 23, 34, 0.96);
  color: #ffffff;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.24);
  font-size: 0.84rem;
  line-height: 1.5;
}

.lightbox-open {
  overflow: hidden;
}

.lightbox {
  position: fixed;
  inset: 0;
  z-index: 220;
  display: grid;
  place-items: center;
  padding: 1.5rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease;
  filter: var(--a11y-content-filter, none);
}

.lightbox[hidden] {
  display: none;
}

.lightbox.is-open {
  opacity: 1;
  pointer-events: auto;
}

.lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 14, 10, 0.76);
  backdrop-filter: blur(4px);
}

.lightbox__panel {
  --lightbox-media-max-height: calc(88vh - 8.5rem);
  position: relative;
  z-index: 1;
  width: min(92vw, 1080px);
  max-height: min(88vh, 940px);
  margin: 0;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  border-radius: 30px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: 0 32px 80px rgba(17, 15, 8, 0.34);
}

.lightbox__media {
  display: grid;
  place-items: center;
  min-width: 0;
  min-height: min(56vh, 720px);
  padding: 1.25rem;
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.08), transparent 40%),
    #0d0d0d;
  overflow: hidden;
}

.lightbox__image {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: var(--lightbox-media-max-height);
  object-fit: contain;
}

.lightbox__video {
  display: block;
  width: min(100%, 1000px);
  max-height: var(--lightbox-media-max-height);
  background: #111;
}

.lightbox__caption {
  padding: 1rem 1.35rem 1.2rem;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.98);
  border-top: 1px solid rgba(24, 51, 41, 0.08);
}

.lightbox__caption[hidden] {
  display: none;
}

.lightbox__nav {
  position: absolute;
  top: 50%;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.35rem;
  height: 3.35rem;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 50%;
  background: rgba(15, 14, 10, 0.72);
  color: #fff;
  box-shadow: 0 16px 34px rgba(17, 15, 8, 0.26);
  cursor: pointer;
  transform: translateY(-50%);
  transition: background 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.lightbox__nav[hidden] {
  display: none;
}

.lightbox__nav--prev {
  left: 1rem;
}

.lightbox__nav--next {
  right: 1rem;
}

.lightbox__nav::before {
  content: "";
  width: 0.72rem;
  height: 0.72rem;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.lightbox__nav--prev::before {
  transform: rotate(225deg);
}

.lightbox__nav:hover,
.lightbox__nav:focus-visible {
  background: rgba(15, 122, 105, 0.92);
  transform: translateY(-50%) scale(1.04);
  box-shadow: 0 20px 38px rgba(17, 15, 8, 0.32);
}

.lightbox__nav:focus-visible {
  outline: 3px solid rgba(255, 243, 193, 0.9);
  outline-offset: 2px;
}

.legal-status-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.legal-status-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 1.15rem 1.2rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(47, 47, 47, 0.07);
  box-shadow: 0 10px 24px rgba(41, 39, 28, 0.05);
}

.legal-status-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 5rem;
  height: 5rem;
  overflow: hidden;
  padding: 0.45rem;
  border-radius: 20px;
  background: #fff;
  border: 1px solid rgba(47, 47, 47, 0.08);
  box-shadow: inset 0 0 0 1px rgba(47, 47, 47, 0.03);
}

.legal-status-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  border-radius: 14px;
}

.legal-status-card p {
  margin: 0;
}

.lightbox__close {
  position: absolute;
  top: 0.9rem;
  right: 0.9rem;
  z-index: 2;
  width: 3rem;
  height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(15, 14, 10, 0.72);
  color: #fff;
  box-shadow: 0 12px 26px rgba(17, 15, 8, 0.22);
  transition: transform 180ms ease, background 180ms ease, box-shadow 180ms ease;
}

.lightbox__close svg {
  width: 1.1rem;
  height: 1.1rem;
  display: block;
}

.lightbox__close:hover,
.lightbox__close:focus-visible {
  background: rgba(15, 122, 105, 0.92);
  transform: translateY(-1px);
  box-shadow: 0 16px 28px rgba(17, 15, 8, 0.28);
}

.lightbox__close:focus-visible {
  outline: 3px solid rgba(255, 243, 193, 0.9);
  outline-offset: 2px;
}

.reveal-on-scroll {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 500ms ease, transform 500ms ease;
}

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

html[data-a11y-motion="reduced"] {
  --scroll-behavior: auto;
}

html[data-a11y-motion="reduced"] *,
html[data-a11y-motion="reduced"] *::before,
html[data-a11y-motion="reduced"] *::after {
  animation-duration: 0.01ms !important;
  animation-iteration-count: 1 !important;
  transition-duration: 0.01ms !important;
  scroll-behavior: auto !important;
}

html[data-a11y-motion="reduced"] .reveal-on-scroll {
  opacity: 1;
  transform: none;
}

html[data-a11y-motion="reduced"] .hero-slider__track {
  transition: none;
}

html[data-a11y-motion="reduced"] .image-strip__track {
  transition: none;
}

.program-card:hover,
.gallery-card:hover,
.value-card:hover,
.detail-card:hover,
.recognition-card:hover,
.support-card:hover,
.team-card:hover,
.news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(41, 39, 28, 0.08);
}

.program-card:hover img,
.team-card:hover img,
.news-card:hover img,
.story-split__media:hover img,
.gallery-card:hover img {
  transform: scale(1.04);
}

.hero-home .image-frame img {
  animation: softZoom 18s ease-in-out infinite alternate;
}

.floating-card,
.impact-chip {
  animation: driftFloat 8s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  :root {
    --scroll-behavior: auto;
  }

  .reveal-on-scroll {
    opacity: 1;
    transform: none;
  }

  .hero-home .image-frame img,
  .floating-card,
  .impact-chip {
    animation: none;
  }

  .testimonial-slider__track {
    transition: none;
  }

  .hero-slider__track {
    transition: none;
  }
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

@media (max-width: 1080px) {
  .page-hero__grid,
  .story-split,
  .story-split:nth-child(even),
  .section-intro--split,
  .testimonial-slide,
  .contact-layout,
  .cta-banner {
    grid-template-columns: 1fr;
  }

  .section-intro--split .actions,
  .slider-actions {
    margin-left: 0;
    justify-content: flex-start;
  }

  .cta-banner .actions {
    margin-left: 0;
    justify-content: flex-start;
    align-self: start;
  }

  .hero-standard .page-hero__grid {
    padding: 1.6rem;
  }

  .section-intro {
    gap: 0.95rem;
    margin-bottom: 2.3rem;
  }

  .activity-card {
    grid-template-columns: 1fr;
  }

  .story-split:nth-child(even) .story-split__media {
    order: 0;
  }

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

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

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

  .image-strip__track {
    --image-strip-visible: 3;
  }

  .image-strip__item {
    flex-basis: calc((100% - 2rem) / 3);
  }

}

@media (max-width: 1180px) {
  .brand-logo {
    width: clamp(160px, 18vw, 190px);
  }

  .nav-link {
    font-size: 0.89rem;
    padding-inline: 0.8rem;
  }

  .nav-group__toggle {
    width: 2.2rem;
    height: 2.2rem;
  }
}

@media (max-width: 1040px) {
  :root {
    --nav-height: 72px;
  }

  .nav-toggle {
    display: inline-flex;
  }

  .nav-menu {
    position: absolute;
    left: 1rem;
    right: 1rem;
    top: calc(100% + 0.75rem);
    padding: 1rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(24, 51, 41, 0.08);
    box-shadow: var(--shadow-md);
    flex-direction: column;
    align-items: stretch;
    margin: 0;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity 180ms ease, transform 180ms ease;
    display: block;
    max-height: calc(100vh - 7rem);
    overflow-y: auto;
  }

  .nav-menu.is-open {
    opacity: 1;
    pointer-events: auto;
    transform: none;
  }

  .nav-list {
    flex-direction: column;
    align-items: stretch;
  }

  .nav-group__head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.5rem;
    align-items: stretch;
  }

  .nav-link,
  .nav-sublink {
    width: 100%;
    justify-content: flex-start;
    padding: 1rem 1rem;
  }

  .nav-group__toggle {
    width: 3rem;
    height: auto;
    min-height: 3rem;
  }

  .nav-item--group .nav-children {
    position: static;
    min-width: 0;
    margin-top: 0.25rem;
    padding: 0 0 0 0.6rem;
    border: 0;
    box-shadow: none;
    background: transparent;
    border-radius: 0;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    display: none;
  }

  .nav-item--group.is-open .nav-children,
  .nav-item--group.is-current .nav-children {
    display: block;
  }

  .nav-submenu {
    gap: 0.15rem;
  }

  .nav-sublink {
    padding-left: 0.5rem;
  }

  .nav-grandmenu {
    margin-top: 0;
    padding: 0.25rem 0 0 0.7rem;
  }

  .nav-grandlink {
    padding-left: 0.5rem;
  }

  .nav-subtoggle {
    width: 3rem;
    min-height: 3rem;
  }

  .nav-subitem--group > .nav-grandmenu,
  .nav-granditem--group > .nav-grandmenu--nested {
    display: none;
  }

  .nav-subitem--group.is-open > .nav-grandmenu,
  .nav-subitem--group.is-current > .nav-grandmenu,
  .nav-granditem--group.is-open > .nav-grandmenu--nested,
  .nav-granditem--group.is-current > .nav-grandmenu--nested {
    display: grid;
  }

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

  .grid-3,
  .grid-2,
  .pricing-grid,
  .form-grid,
  .checkbox-grid,
  .gallery-grid,
  .legal-status-grid {
    grid-template-columns: 1fr;
  }

  .footer-links--columns {
    grid-template-columns: 1fr;
  }

  .page-hero {
    padding-top: 2.5rem;
  }

  .hero-standard .page-hero__grid {
    padding: 1.25rem;
  }

  .team-card--profile {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }

  .team-card--profile .team-card__body {
    text-align: center;
  }

  .team-card--profile .tag {
    justify-self: center;
  }

  .story-split {
    gap: 1.9rem;
  }

  .floating-card,
  .impact-chip {
    position: static;
    margin-top: 1rem;
  }

  .hero-caption {
    position: static;
    margin: 1rem;
  }

  .hero-standard .hero-caption {
    margin: 0;
  }

  .page-hero__meta {
    gap: 0.65rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .report-viewer__frame {
    min-height: clamp(28rem, 72vh, 56rem);
  }
}

@media (max-width: 560px) {
  .container {
    width: min(calc(100% - 1.3rem), var(--content));
  }

  .section,
  .section-lg,
  .page-hero {
    padding-bottom: 2.75rem;
  }

  .section-surface,
  .testimonial-panel,
  .footer-panel,
  .cta-banner,
  .form-card,
  .testimonial-slide {
    padding: 1.55rem;
  }

  .section-intro {
    gap: 0.9rem;
    margin-bottom: 1.9rem;
  }

  .story-split {
    gap: 1.45rem;
    margin-bottom: 1.8rem;
  }

  .activity-card {
    gap: 1rem;
    padding: 1rem;
  }

  .hero-actions,
  .actions,
  .card-actions {
    gap: 0.75rem;
  }

  .page-hero__meta {
    grid-template-columns: 1fr;
  }

  .report-viewer__toolbar {
    align-items: stretch;
  }

  .report-viewer__toolbar > * {
    width: 100%;
  }

  .hero-slider__controls {
    display: none;
  }

  .hero-slider__dots {
    left: 1rem;
    right: 1rem;
    top: 1rem;
  }

  .image-strip__track {
    --image-strip-visible: 1;
  }

  .image-strip__item {
    flex-basis: 100%;
  }

  .image-strip__controls {
    justify-self: start;
  }

  .report-viewer__jump {
    width: 100%;
    justify-content: space-between;
  }

  .report-viewer__jump-input {
    width: 100%;
    max-width: 6rem;
  }

  .report-viewer__status {
    text-align: center;
  }

  .report-viewer__frame {
    min-height: 24rem;
  }

  .report-viewer__paper {
    padding: 0.8rem;
  }

  .brand-logo {
    width: min(56vw, 180px);
    max-height: 42px;
  }

  .page-hero__copy p {
    font-size: 1rem;
  }

  .page-hero__copy h1 {
    max-width: none;
  }

  .testimonial-slide__media {
    width: min(100%, 92px);
  }

  .testimonial-slide__content::before {
    top: -0.5rem;
    font-size: 3.6rem;
  }

  .testimonial-slide__content blockquote {
    font-size: 1rem;
  }

  .footer-links--columns {
    grid-template-columns: 1fr;
  }

  .back-to-top {
    right: 0.85rem;
    bottom: 0.9rem;
    width: 3rem;
    height: 3rem;
  }

  .a11y-tools {
    left: auto;
    right: 0.85rem;
    bottom: 4.55rem;
    justify-items: end;
  }

  .a11y-trigger {
    width: 3.25rem;
    height: 3.25rem;
  }

  .a11y-panel {
    width: min(calc(100vw - 1.7rem), 24rem);
    max-height: min(74vh, 700px);
  }

  .lightbox {
    padding: 1rem;
  }

  .lightbox__panel {
    width: min(94vw, 1080px);
    border-radius: 24px;
    --lightbox-media-max-height: calc(84vh - 7.5rem);
  }

  .lightbox__media {
    min-height: min(48vh, 520px);
    padding: 0.9rem;
  }

  .lightbox__close {
    top: 0.7rem;
    right: 0.7rem;
    width: 2.8rem;
    height: 2.8rem;
  }

  .lightbox__nav {
    width: 2.75rem;
    height: 2.75rem;
  }

  .lightbox__nav--prev {
    left: 0.55rem;
  }

  .lightbox__nav--next {
    right: 0.55rem;
  }
}

@keyframes driftFloat {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}

@keyframes softZoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.06);
  }
}

@keyframes reportPageFlipNext {
  0% {
    opacity: 0;
    transform: perspective(1800px) rotateY(92deg);
  }
  14% {
    opacity: 1;
  }
  50% {
    opacity: 1;
    transform: perspective(1800px) rotateY(8deg);
  }
  100% {
    opacity: 0;
    transform: perspective(1800px) rotateY(-92deg);
  }
}

@keyframes reportPageFlipPrev {
  0% {
    opacity: 0;
    transform: perspective(1800px) rotateY(-92deg);
  }
  14% {
    opacity: 1;
  }
  50% {
    opacity: 1;
    transform: perspective(1800px) rotateY(-8deg);
  }
  100% {
    opacity: 0;
    transform: perspective(1800px) rotateY(92deg);
  }
}
