/* ===== generated design system ===== */
:root {
  --c-primary: #00401C;
  --c-primary-dark: #002d13;
  --c-primary-light: #005a28;
  --c-sage-tint: #E8F2EC;
  --c-navy: #1A2B4A;
  --c-navy-dark: #111d33;
  --c-gold: #C9A84C;
  --c-gold-light: #d9bc72;
  --c-gold-dark: #a8883a;
  --c-off-white: #F8F9FA;
  --c-silver: #E1E1E1;
  --c-slate: #6B7280;
  --c-charcoal: #1C1C1C;
  --c-leaf: #2D7A4F;
  --c-alert: #C0392B;
  --c-amber: #E67E22;
  --c-sky: #2980B9;
  --c-white: #FFFFFF;
  --c-black: #000000;

  --c-text-primary: #1C1C1C;
  --c-text-secondary: #6B7280;
  --c-text-inverse: #FFFFFF;
  --c-text-muted: #9CA3AF;
  --c-text-link: #00401C;
  --c-text-link-hover: #2D7A4F;

  --c-bg-body: #F8F9FA;
  --c-bg-card: #FFFFFF;
  --c-bg-section-alt: #E8F2EC;
  --c-bg-dark: #1A2B4A;

  --c-border: #E1E1E1;
  --c-border-focus: #00401C;
  --c-border-error: #C0392B;
  --c-border-success: #2D7A4F;

  --c-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.05);
  --c-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.10), 0 2px 6px rgba(0, 0, 0, 0.06);
  --c-shadow-lg: 0 10px 30px rgba(0, 0, 0, 0.12), 0 4px 12px rgba(0, 0, 0, 0.08);
  --c-shadow-xl: 0 20px 50px rgba(0, 0, 0, 0.15), 0 8px 20px rgba(0, 0, 0, 0.10);
  --c-shadow-gold: 0 4px 20px rgba(201, 168, 76, 0.30);
  --c-shadow-primary: 0 4px 20px rgba(0, 64, 28, 0.30);

  --font-display: 'Merienda', Georgia, 'Times New Roman', serif;
  --font-body: Tahoma, Verdana, Geneva, sans-serif;
  --font-mono: 'Courier New', Courier, monospace;

  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-md: 1.0625rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;
  --text-6xl: 3.75rem;

  --leading-tight: 1.2;
  --leading-snug: 1.35;
  --leading-normal: 1.6;
  --leading-relaxed: 1.75;

  --tracking-tight: -0.02em;
  --tracking-normal: 0em;
  --tracking-wide: 0.04em;
  --tracking-wider: 0.08em;
  --tracking-widest: 0.12em;

  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-extrabold: 800;

  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-7: 1.75rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-14: 3.5rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-full: 9999px;
  --radius-octagon: 8px;

  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 400ms ease;
  --transition-bounce: 300ms cubic-bezier(0.34, 1.56, 0.64, 1);

  --container-max: 1180px;
  --container-padding: var(--space-6);

  --z-base: 0;
  --z-raised: 10;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-overlay: 300;
  --z-modal: 400;
  --z-toast: 500;
  --z-tooltip: 600;

  --nav-height: 72px;
  --announcement-height: 40px;
  --utility-height: 36px;
}

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

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  tab-size: 4;
  hanging-punctuation: first last;
}

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--fw-regular);
  line-height: var(--leading-normal);
  color: var(--c-text-primary);
  background-color: var(--c-bg-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  min-height: 100vh;
}

:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

:focus:not(:focus-visible) {
  outline: none;
}

::selection {
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

img {
  font-style: italic;
  background-repeat: no-repeat;
  background-size: cover;
  shape-margin: 1rem;
}

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

button {
  cursor: pointer;
  border: none;
  background: none;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
  hyphens: auto;
}

p {
  max-width: 72ch;
}

ul,
ol {
  list-style: none;
}

a {
  color: var(--c-text-link);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--c-text-link-hover);
  text-decoration: underline;
  text-underline-offset: 3px;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  border: none;
  border-top: 1px solid var(--c-border);
  margin: var(--space-8) 0;
}

blockquote {
  border-left: 4px solid var(--c-gold);
  padding-left: var(--space-6);
  margin: var(--space-8) 0;
  font-style: italic;
  color: var(--c-slate);
}

code {
  font-family: var(--font-mono);
  font-size: 0.875em;
  background-color: var(--c-sage-tint);
  padding: 0.15em 0.4em;
  border-radius: var(--radius-sm);
}

pre {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  background-color: var(--c-charcoal);
  color: var(--c-off-white);
  padding: var(--space-6);
  border-radius: var(--radius-md);
  overflow-x: auto;
  line-height: var(--leading-relaxed);
}

pre code {
  background: none;
  padding: 0;
  font-size: inherit;
}

fieldset {
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-6);
}

legend {
  font-weight: var(--fw-semibold);
  padding: 0 var(--space-2);
  color: var(--c-primary);
}

details > summary {
  cursor: pointer;
  list-style: none;
}

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

[hidden] {
  display: none !important;
}

[disabled],
[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.55;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--c-charcoal);
}

h1 {
  font-size: clamp(var(--text-3xl), 5vw, var(--text-6xl));
  line-height: 1.1;
  letter-spacing: -0.03em;
}

h2 {
  font-size: clamp(var(--text-2xl), 3.5vw, var(--text-5xl));
  line-height: 1.15;
}

h3 {
  font-size: clamp(var(--text-xl), 2.5vw, var(--text-4xl));
  line-height: 1.2;
}

h4 {
  font-size: clamp(var(--text-lg), 2vw, var(--text-3xl));
  line-height: 1.25;
}

h5 {
  font-size: clamp(var(--text-base), 1.5vw, var(--text-2xl));
  line-height: 1.3;
}

h6 {
  font-size: clamp(var(--text-sm), 1.2vw, var(--text-xl));
  line-height: 1.35;
}

.display-1 {
  font-family: var(--font-display);
  font-size: clamp(var(--text-4xl), 6vw, 4.5rem);
  font-weight: var(--fw-extrabold);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.display-2 {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5vw, var(--text-6xl));
  font-weight: var(--fw-bold);
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.section-heading {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 3vw, var(--text-4xl));
  font-weight: var(--fw-bold);
  color: var(--c-navy);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
}

.section-subheading {
  font-family: var(--font-body);
  font-size: clamp(var(--text-base), 1.5vw, var(--text-lg));
  font-weight: var(--fw-regular);
  color: var(--c-slate);
  line-height: var(--leading-relaxed);
  max-width: 60ch;
}

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--c-gold);
}

.lead {
  font-size: clamp(var(--text-lg), 2vw, var(--text-xl));
  line-height: var(--leading-relaxed);
  color: var(--c-slate);
  max-width: 68ch;
}

.text-xs { font-size: var(--text-xs); }
.text-sm { font-size: var(--text-sm); }
.text-base { font-size: var(--text-base); }
.text-lg { font-size: var(--text-lg); }
.text-xl { font-size: var(--text-xl); }
.text-2xl { font-size: var(--text-2xl); }
.text-3xl { font-size: var(--text-3xl); }

.font-display { font-family: var(--font-display); }
.font-body { font-family: var(--font-body); }
.font-regular { font-weight: var(--fw-regular); }
.font-medium { font-weight: var(--fw-medium); }
.font-semibold { font-weight: var(--fw-semibold); }
.font-bold { font-weight: var(--fw-bold); }

.text-primary-color { color: var(--c-primary); }
.text-navy { color: var(--c-navy); }
.text-gold { color: var(--c-gold); }
.text-slate { color: var(--c-slate); }
.text-charcoal { color: var(--c-charcoal); }
.text-inverse { color: var(--c-text-inverse); }
.text-muted { color: var(--c-text-muted); }
.text-alert { color: var(--c-alert); }
.text-amber { color: var(--c-amber); }

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }
.uppercase { text-transform: uppercase; }
.capitalize { text-transform: capitalize; }
.italic { font-style: italic; }
.underline { text-decoration: underline; text-underline-offset: 3px; }
.no-underline { text-decoration: none; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

.container-sm {
  width: 100%;
  max-width: 768px;
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

.container-lg {
  width: 100%;
  max-width: 1400px;
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

.container-fluid {
  width: 100%;
  padding-inline: var(--container-padding);
}

@media (max-width: 640px) {
  .container,
  .container-sm,
  .container-lg,
  .container-fluid {
    padding-inline: var(--space-4);
  }
}

@media (min-width: 641px) and (max-width: 1024px) {
  .container,
  .container-sm,
  .container-lg,
  .container-fluid {
    padding-inline: var(--space-8);
  }
}

.section {
  padding-block: var(--space-20);
}

.section-sm {
  padding-block: var(--space-12);
}

.section-lg {
  padding-block: var(--space-32);
}

.section-header {
  margin-bottom: var(--space-12);
}

.section-header--center {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.section-header--left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3);
}

.section-divider {
  width: 64px;
  height: 3px;
  background: linear-gradient(90deg, var(--c-gold), var(--c-primary));
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.section-divider--center {
  margin-inline: auto;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.75rem 1.75rem;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: var(--radius-octagon);
  clip-path: polygon(
    12px 0%,
    calc(100% - 12px) 0%,
    100% 12px,
    100% calc(100% - 12px),
    calc(100% - 12px) 100%,
    12px 100%,
    0% calc(100% - 12px),
    0% 12px
  );
  transition:
    background-color var(--transition-base),
    color var(--transition-base),
    border-color var(--transition-base),
    box-shadow var(--transition-base),
    transform var(--transition-bounce);
  position: relative;
  overflow: hidden;
  min-height: 44px;
  min-width: 44px;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  vertical-align: middle;
  isolation: isolate;
}

.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0);
  transition: background var(--transition-fast);
  z-index: -1;
}

.btn:hover::before {
  background: rgba(255, 255, 255, 0.08);
}

.btn:active {
  transform: scale(0.97);
}

.btn:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 3px;
}

.btn svg,
.btn img {
  width: 1em;
  height: 1em;
  flex-shrink: 0;
}

.btn--primary {
  background-color: var(--c-primary);
  color: var(--c-white);
  border-color: var(--c-primary);
  box-shadow: var(--c-shadow-primary);
}

.btn--primary:hover {
  background-color: var(--c-primary-light);
  border-color: var(--c-primary-light);
  box-shadow: 0 6px 24px rgba(0, 64, 28, 0.40);
  color: var(--c-white);
  text-decoration: none;
  transform: translateY(-1px);
}

.btn--primary:active {
  background-color: var(--c-primary-dark);
  border-color: var(--c-primary-dark);
  transform: translateY(0) scale(0.97);
  box-shadow: var(--c-shadow-sm);
}

.btn--secondary {
  background-color: var(--c-gold);
  color: var(--c-charcoal);
  border-color: var(--c-gold);
  box-shadow: var(--c-shadow-gold);
}

.btn--secondary:hover {
  background-color: var(--c-gold-light);
  border-color: var(--c-gold-light);
  box-shadow: 0 6px 24px rgba(201, 168, 76, 0.45);
  color: var(--c-charcoal);
  text-decoration: none;
  transform: translateY(-1px);
}

.btn--secondary:active {
  background-color: var(--c-gold-dark);
  border-color: var(--c-gold-dark);
  transform: translateY(0) scale(0.97);
  box-shadow: var(--c-shadow-sm);
}

.btn--ghost {
  background-color: transparent;
  color: var(--c-primary);
  border-color: var(--c-primary);
  box-shadow: none;
}

.btn--ghost:hover {
  background-color:var(--c-sage-tint);
  color: var(--c-primary);
  border-color: var(--c-primary);
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: var(--c-shadow-sm);
}

.btn--ghost:active {
  background-color: var(--c-sage-tint);
  transform: translateY(0) scale(0.97);
}

.btn--ghost-inverse {
  background-color: transparent;
  color: var(--c-white);
  border-color: var(--c-white);
  box-shadow: none;
}

.btn--ghost-inverse:hover {
  background-color: rgba(255, 255, 255, 0.12);
  color: var(--c-white);
  border-color: var(--c-white);
  text-decoration: none;
  transform: translateY(-1px);
}

.btn--ghost-inverse:active {
  background-color: rgba(255, 255, 255, 0.20);
  transform: translateY(0) scale(0.97);
}

.btn--navy {
  background-color: var(--c-navy);
  color: var(--c-white);
  border-color: var(--c-navy);
  box-shadow: 0 4px 20px rgba(26, 43, 74, 0.30);
}

.btn--navy:hover {
  background-color: var(--c-navy-dark);
  border-color: var(--c-navy-dark);
  color: var(--c-white);
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(26, 43, 74, 0.40);
}

.btn--navy:active {
  transform: translateY(0) scale(0.97);
  box-shadow: var(--c-shadow-sm);
}

.btn--amber {
  background-color: var(--c-amber);
  color: var(--c-white);
  border-color: var(--c-amber);
  box-shadow: 0 4px 20px rgba(230, 126, 34, 0.30);
}

.btn--amber:hover {
  background-color: #d4711e;
  border-color: #d4711e;
  color: var(--c-white);
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(230, 126, 34, 0.40);
}

.btn--amber:active {
  background-color: #bf6419;
  transform: translateY(0) scale(0.97);
  box-shadow: var(--c-shadow-sm);
}

.btn--sm {
  padding: 0.5rem 1.25rem;
  font-size: var(--text-xs);
  min-height: 36px;
  clip-path: polygon(
    8px 0%,
    calc(100% - 8px) 0%,
    100% 8px,
    100% calc(100% - 8px),
    calc(100% - 8px) 100%,
    8px 100%,
    0% calc(100% - 8px),
    0% 8px
  );
}

.btn--lg {
  padding: 1rem 2.5rem;
  font-size: var(--text-base);
  min-height: 52px;
  clip-path: polygon(
    16px 0%,
    calc(100% - 16px) 0%,
    100% 16px,
    100% calc(100% - 16px),
    calc(100% - 16px) 100%,
    16px 100%,
    0% calc(100% - 16px),
    0% 16px
  );
}

.btn--xl {
  padding: 1.125rem 3rem;
  font-size: var(--text-lg);
  min-height: 60px;
  letter-spacing: var(--tracking-wider);
  clip-path: polygon(
    18px 0%,
    calc(100% - 18px) 0%,
    100% 18px,
    100% calc(100% - 18px),
    calc(100% - 18px) 100%,
    18px 100%,
    0% calc(100% - 18px),
    0% 18px
  );
}

.btn--full {
  width: 100%;
}

.btn--pill {
  clip-path: none;
  border-radius: var(--radius-full);
}

.btn--icon-only {
  padding: 0.75rem;
  aspect-ratio: 1;
}

.btn--icon-only.btn--sm {
  padding: 0.5rem;
}

.btn--icon-only.btn--lg {
  padding: 1rem;
}

.btn-group {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.btn-group--center {
  justify-content: center;
}

.btn-group--stack {
  flex-direction: column;
  align-items: stretch;
}

@media (max-width: 480px) {
  .btn-group--stack-mobile {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  .btn-group--stack-mobile .btn {
    width: 100%;
    justify-content: center;
  }
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}

.form-group:last-child {
  margin-bottom: 0;
}

.form-label {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--c-charcoal);
  line-height: 1.4;
  cursor: pointer;
}

.form-label--required::after {
  content: ' *';
  color: var(--c-alert);
  font-weight: var(--fw-bold);
}

.form-label--optional::after {
  content: ' (optional)';
  color: var(--c-text-muted);
  font-weight: var(--fw-regular);
  font-size: var(--text-xs);
}

.form-hint {
  font-size: var(--text-xs);
  color: var(--c-slate);
  line-height: 1.5;
  margin-top: var(--space-1);
}

.form-error {
  font-size: var(--text-xs);
  color: var(--c-alert);
  font-weight: var(--fw-medium);
  line-height: 1.5;
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-1);
}

.form-error::before {
  content: '';
  display: inline-block;
  width: 12px;
  height: 12px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Ccircle cx='6' cy='6' r='5.5' stroke='%23C0392B' fill='none'/%3E%3Cpath d='M6 3.5v3M6 8v.5' stroke='%23C0392B' stroke-width='1.2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  flex-shrink: 0;
}

.form-success-msg {
  font-size: var(--text-xs);
  color: var(--c-leaf);
  font-weight: var(--fw-medium);
  line-height: 1.5;
  margin-top: var(--space-1);
}

.form-control {
  display: block;
  width: 100%;
  padding: 0.6875rem 1rem;
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--fw-regular);
  line-height: var(--leading-normal);
  color: var(--c-charcoal);
  background-color: var(--c-white);
  background-clip: padding-box;
  border: 1.5px solid var(--c-border);
  border-radius: var(--radius-md);
  appearance: none;
  -webkit-appearance: none;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background-color var(--transition-fast);
  min-height: 44px;
  outline: none;
}

.form-control::placeholder {
  color: var(--c-text-muted);
  opacity: 1;
}

.form-control:hover:not(:disabled):not([readonly]) {
  border-color: var(--c-slate);
}

.form-control:focus {
  border-color: var(--c-border-focus);
  box-shadow: 0 0 0 3px rgba(0, 64, 28, 0.12);
  background-color: var(--c-white);
  outline: none;
}

.form-control:disabled {
  background-color: var(--c-silver);
  color: var(--c-text-muted);
  cursor: not-allowed;
  border-color: var(--c-border);
}

.form-control[readonly] {
  background-color: var(--c-off-white);
  color: var(--c-slate);
  cursor: default;
}

.form-control.is-invalid,
.form-control[aria-invalid="true"] {
  border-color: var(--c-border-error);
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.10);
}

.form-control.is-invalid:focus,
.form-control[aria-invalid="true"]:focus {
  border-color: var(--c-border-error);
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.18);
}

.form-control.is-valid {
  border-color: var(--c-border-success);
  box-shadow: 0 0 0 3px rgba(45, 122, 79, 0.10);
}

.form-control.is-valid:focus {
  border-color: var(--c-border-success);
  box-shadow: 0 0 0 3px rgba(45, 122, 79, 0.18);
}

textarea.form-control {
  resize: vertical;
  min-height: 120px;
  line-height: var(--leading-relaxed);
}

textarea.form-control--fixed {
  resize: none;
}

select.form-control {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.875rem center;
  background-size: 16px 16px;
  padding-right: 2.75rem;
  cursor: pointer;
}

select.form-control:focus {
  border-color: var(--c-border-focus);
  box-shadow: 0 0 0 3px rgba(0, 64, 28, 0.12);
}

select.form-control[multiple] {
  background-image: none;
  padding-right: 1rem;
  height: auto;
}

.form-control--sm {
  padding: 0.4375rem 0.75rem;
  font-size: var(--text-sm);
  min-height: 36px;
  border-radius: var(--radius-sm);
}

.form-control--lg {
  padding: 0.875rem 1.25rem;
  font-size: var(--text-lg);
  min-height: 52px;
  border-radius: var(--radius-lg);
}

.form-check {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  cursor: pointer;
  min-height: 44px;
  padding-block: var(--space-1);
}

.form-check-input {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  min-width: 20px;
  border: 2px solid var(--c-border);
  border-radius: var(--radius-sm);
  background-color: var(--c-white);
  cursor: pointer;
  transition:
    border-color var(--transition-fast),
    background-color var(--transition-fast),
    box-shadow var(--transition-fast);
  position: relative;
  margin-top: 2px;
  flex-shrink: 0;
}

.form-check-input[type="radio"] {
  border-radius: 50%;
}

.form-check-input:hover:not(:disabled) {
  border-color: var(--c-primary);
}

.form-check-input:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
  box-shadow: none;
}

.form-check-input:checked {
  background-color: var(--c-primary);
  border-color: var(--c-primary);
}

.form-check-input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%) rotate(45deg);
  width: 5px;
  height: 9px;
  border: 2px solid var(--c-white);
  border-top: none;
  border-left: none;
}

.form-check-input[type="radio"]:checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--c-white);
}

.form-check-input:disabled {
  background-color: var(--c-silver);
  border-color: var(--c-border);
  cursor: not-allowed;
}

.form-check-input:disabled:checked {
  background-color: var(--c-slate);
  border-color: var(--c-slate);
}

.form-check-label {
  font-size: var(--text-sm);
  color: var(--c-charcoal);
  line-height: 1.5;
  cursor: pointer;
}

.form-check-input:disabled + .form-check-label {
  color: var(--c-text-muted);
  cursor: not-allowed;
}

.form-input-group {
  display: flex;
  align-items: stretch;
  width: 100%;
}

.form-input-group .form-control {
  flex: 1 1 auto;
  min-width: 0;
}

.form-input-group .form-control:not(:first-child) {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-left: none;
}

.form-input-group .form-control:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.form-input-group .btn {
  clip-path: none;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  flex-shrink: 0;
}

.form-input-addon {
  display: inline-flex;
  align-items: center;
  padding: 0 1rem;
  background-color: var(--c-off-white);
  border: 1.5px solid var(--c-border);
  color: var(--c-slate);
  font-size: var(--text-sm);
  white-space: nowrap;
  flex-shrink: 0;
}

.form-input-addon:first-child {
  border-right: none;
  border-radius: var(--radius-md) 0 0 var(--radius-md);
}

.form-input-addon:last-child {
  border-left: none;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.form-input-icon {
  position: relative;
}

.form-input-icon .form-control {
  padding-left: 2.75rem;
}

.form-input-icon .form-control--icon-right {
  padding-left: 1rem;
  padding-right: 2.75rem;
}

.form-input-icon__icon {
  position: absolute;
  top: 50%;
  left: 0.875rem;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--c-slate);
  pointer-events: none;
  flex-shrink: 0;
}

.form-input-icon__icon--right {
  left: auto;
  right: 0.875rem;
}

.form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
  gap: var(--space-5);
}

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

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

@media (max-width: 640px) {
  .form-row--2,
  .form-row--3 {
    grid-template-columns: 1fr;
  }
}

.form-fieldset {
  border: 1.5px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-6);
}

.form-fieldset legend {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  color: var(--c-primary);
  padding: 0 var(--space-3);
  letter-spacing: var(--tracking-normal);
}

.form-actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-8);
  flex-wrap: wrap;
}

.form-actions--center {
  justify-content: center;
}

.form-actions--right {
  justify-content: flex-end;
}

.form-actions--stack {
  flex-direction: column;
  align-items: stretch;
}

.form-actions--stack .btn {
  width: 100%;
  justify-content: center;
}

.form--card {
  background-color: var(--c-white);
  border-radius: var(--radius-xl);
  padding: var(--space-10);
  box-shadow: var(--c-shadow-lg);
  border: 1px solid var(--c-border);
}

@media (max-width: 640px) {
  .form--card {
    padding: var(--space-6);
    border-radius: var(--radius-lg);
  }
}

.form--inline {
  display: flex;
  align-items: flex-end;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.form--inline .form-group {
  flex: 1 1 200px;
  margin-bottom: 0;
}

.form--inline .form-actions {
  margin-top: 0;
  flex-shrink: 0;
}

.form-progress {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
  counter-reset: step;
}

.form-progress__step {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex: 1;
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: var(--c-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.form-progress__step::before {
  counter-increment: step;
  content: counter(step);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  min-width: 28px;
  border-radius: 50%;
  background-color: var(--c-silver);
  color: var(--c-slate);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  transition: background-color var(--transition-base), color var(--transition-base);
}

.form-progress__step.is-active {
  color: var(--c-primary);
}

.form-progress__step.is-active::before {
  background-color: var(--c-primary);
  color: var(--c-white);
}

.form-progress__step.is-complete {
  color: var(--c-leaf);
}

.form-progress__step.is-complete::before {
  background-color: var(--c-leaf);
  color: var(--c-white);
  content: '✓';
}

.form-progress__connector {
  flex: 1;
  height: 2px;
  background-color: var(--c-silver);
  border-radius: var(--radius-full);
  transition: background-color var(--transition-base);
}

.form-progress__connector.is-complete {
  background-color: var(--c-leaf);
}

.m-0 { margin: 0; }
.m-1 { margin: var(--space-1); }
.m-2 { margin: var(--space-2); }
.m-3 { margin: var(--space-3); }
.m-4 { margin: var(--space-4); }
.m-5 { margin: var(--space-5); }
.m-6 { margin: var(--space-6); }
.m-8 { margin: var(--space-8); }
.m-10 { margin: var(--space-10); }
.m-12 { margin: var(--space-12); }
.m-16 { margin: var(--space-16); }
.m-auto { margin: auto; }

.mx-0 { margin-inline: 0; }
.mx-1 { margin-inline: var(--space-1); }
.mx-2 { margin-inline: var(--space-2); }
.mx-3 { margin-inline: var(--space-3); }
.mx-4 { margin-inline: var(--space-4); }
.mx-5 { margin-inline: var(--space-5); }
.mx-6 { margin-inline: var(--space-6); }
.mx-8 { margin-inline: var(--space-8); }
.mx-auto { margin-inline: auto; }

.my-0 { margin-block: 0; }
.my-1 { margin-block: var(--space-1); }
.my-2 { margin-block: var(--space-2); }
.my-3 { margin-block: var(--space-3); }
.my-4 { margin-block: var(--space-4); }
.my-5 { margin-block: var(--space-5); }
.my-6 { margin-block: var(--space-6); }
.my-8 { margin-block: var(--space-8); }
.my-10 { margin-block: var(--space-10); }
.my-12 { margin-block: var(--space-12); }
.my-16 { margin-block: var(--space-16); }
.my-auto { margin-block: auto; }

.mt-0 { margin-top: 0; }
.mt-1 { margin-top: var(--space-1); }
.mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }
.mt-5 { margin-top: var(--space-5); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }
.mt-10 { margin-top: var(--space-10); }
.mt-12 { margin-top: var(--space-12); }
.mt-16 { margin-top: var(--space-16); }
.mt-20 { margin-top: var(--space-20); }
.mt-auto { margin-top: auto; }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--space-1); }
.mb-2 { margin-bottom: var(--space-2); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-8 { margin-bottom: var(--space-8); }
.mb-10 { margin-bottom: var(--space-10); }
.mb-12 { margin-bottom: var(--space-12); }
.mb-16 { margin-bottom: var(--space-16); }
.mb-20 { margin-bottom: var(--space-20); }
.mb-auto { margin-bottom: auto; }

.ml-0 { margin-left: 0; }
.ml-1 { margin-left: var(--space-1); }
.ml-2 { margin-left: var(--space-2); }
.ml-3 { margin-left: var(--space-3); }
.ml-4 { margin-left: var(--space-4); }
.ml-5 { margin-left: var(--space-5); }
.ml-6 { margin-left: var(--space-6); }
.ml-8 { margin-left: var(--space-8); }
.ml-auto { margin-left: auto; }

.mr-0 { margin-right: 0; }
.mr-1 { margin-right: var(--space-1); }
.mr-2 { margin-right: var(--space-2); }
.mr-3 { margin-right: var(--space-3); }
.mr-4 { margin-right: var(--space-4); }
.mr-5 { margin-right: var(--space-5); }
.mr-6 { margin-right: var(--space-6); }
.mr-8 { margin-right: var(--space-8); }
.mr-auto { margin-right: auto; }

.p-0 { padding: 0; }
.p-1 { padding: var(--space-1); }
.p-2 { padding: var(--space-2); }
.p-3 { padding: var(--space-3); }
.p-4 { padding: var(--space-4); }
.p-5 { padding: var(--space-5); }
.p-6 { padding: var(--space-6); }
.p-8 { padding: var(--space-8); }
.p-10 { padding: var(--space-10); }
.p-12 { padding: var(--space-12); }
.p-16 { padding: var(--space-16); }

.px-0 { padding-inline: 0; }
.px-1 { padding-inline: var(--space-1); }
.px-2 { padding-inline: var(--space-2); }
.px-3 { padding-inline: var(--space-3); }
.px-4 { padding-inline: var(--space-4); }
.px-5 { padding-inline: var(--space-5); }
.px-6 { padding-inline: var(--space-6); }
.px-8 { padding-inline: var(--space-8); }
.px-10 { padding-inline: var(--space-10); }
.px-12 { padding-inline: var(--space-12); }

.py-0 { padding-block: 0; }
.py-1 { padding-block: var(--space-1); }
.py-2 { padding-block: var(--space-2); }
.py-3 { padding-block: var(--space-3); }
.py-4 { padding-block: var(--space-4); }
.py-5 { padding-block: var(--space-5); }
.py-6 { padding-block: var(--space-6); }
.py-8 { padding-block: var(--space-8); }
.py-10 { padding-block: var(--space-10); }
.py-12 { padding-block: var(--space-12); }
.py-16 { padding-block: var(--space-16); }
.py-20 { padding-block: var(--space-20); }

.pt-0 { padding-top: 0; }
.pt-1 { padding-top: var(--space-1); }
.pt-2 { padding-top: var(--space-2); }
.pt-3 { padding-top: var(--space-3); }
.pt-4 { padding-top: var(--space-4); }
.pt-5 { padding-top: var(--space-5); }
.pt-6 { padding-top: var(--space-6); }
.pt-8 { padding-top: var(--space-8); }
.pt-10 { padding-top: var(--space-10); }
.pt-12 { padding-top: var(--space-12); }
.pt-16 { padding-top: var(--space-16); }
.pt-20 { padding-top: var(--space-20); }

.pb-0 { padding-bottom: 0; }
.pb-1 { padding-bottom: var(--space-1); }
.pb-2 { padding-bottom: var(--space-2); }
.pb-3 { padding-bottom: var(--space-3); }
.pb-4 { padding-bottom: var(--space-4); }
.pb-5 { padding-bottom: var(--space-5); }
.pb-6 { padding-bottom: var(--space-6); }
.pb-8 { padding-bottom: var(--space-8); }
.pb-10 { padding-bottom: var(--space-10); }
.pb-12 { padding-bottom: var(--space-12); }
.pb-16 { padding-bottom: var(--space-16); }
.pb-20 { padding-bottom: var(--space-20); }

.pl-0 { padding-left: 0; }
.pl-1 { padding-left: var(--space-1); }
.pl-2 { padding-left: var(--space-2); }
.pl-3 { padding-left: var(--space-3); }
.pl-4 { padding-left: var(--space-4); }
.pl-5 { padding-left: var(--space-5); }
.pl-6 { padding-left: var(--space-6); }
.pl-8 { padding-left: var(--space-8); }

.pr-0 { padding-right: 0; }
.pr-1 { padding-right: var(--space-1); }
.pr-2 { padding-right: var(--space-2); }
.pr-3 { padding-right: var(--space-3); }
.pr-4 { padding-right: var(--space-4); }
.pr-5 { padding-right: var(--space-5); }
.pr-6 { padding-right: var(--space-6); }
.pr-8 { padding-right: var(--space-8); }

.gap-0 { gap: 0; }
.gap-1 { gap: var(--space-1); }
.gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.gap-5 { gap: var(--space-5); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }
.gap-10 { gap: var(--space-10); }
.gap-12 { gap: var(--space-12); }
.gap-16 { gap: var(--space-16); }

.gap-x-0 { column-gap: 0; }
.gap-x-2 { column-gap: var(--space-2); }
.gap-x-4 { column-gap: var(--space-4); }
.gap-x-6 { column-gap: var(--space-6); }
.gap-x-8 { column-gap: var(--space-8); }

.gap-y-0 { row-gap: 0; }
.gap-y-2 { row-gap: var(--space-2); }
.gap-y-4 { row-gap: var(--space-4); }
.gap-y-6 { row-gap: var(--space-6); }
.gap-y-8 { row-gap: var(--space-8); }

.d-none { display: none; }
.d-block { display: block; }
.d-inline { display: inline; }
.d-inline-block { display: inline-block; }
.d-flex { display: flex; }
.d-inline-flex { display: inline-flex; }
.d-grid { display: grid; }
.d-inline-grid { display: inline-grid; }

.flex-row { flex-direction: row; }
.flex-col { flex-direction: column; }
.flex-row-reverse { flex-direction: row-reverse; }
.flex-col-reverse { flex-direction: column-reverse; }
.flex-wrap { flex-wrap: wrap; }
.flex-nowrap { flex-wrap: nowrap; }
.flex-1 { flex: 1 1 0%; }
.flex-auto { flex: 1 1 auto; }
.flex-none { flex: none; }
.flex-shrink-0 { flex-shrink: 0; }
.flex-grow-1 { flex-grow: 1; }

.items-start { align-items: flex-start; }
.items-center { align-items: center; }
.items-end { align-items: flex-end; }
.items-stretch { align-items: stretch; }
.items-baseline { align-items: baseline; }

.justify-start { justify-content: flex-start; }
.justify-center { justify-content: center; }
.justify-end { justify-content: flex-end; }
.justify-between { justify-content: space-between; }
.justify-around { justify-content: space-around; }
.justify-evenly { justify-content: space-evenly; }

.self-start { align-self: flex-start; }
.self-center { align-self: center; }
.self-end { align-self: flex-end; }
.self-stretch { align-self: stretch; }

.grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
.grid-cols-5 { grid-template-columns: repeat(5, 1fr); }
.grid-cols-6 { grid-template-columns: repeat(6, 1fr); }
.grid-cols-auto { grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr)); }
.grid-cols-auto-sm { grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr)); }
.grid-cols-auto-lg { grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr)); }

.col-span-1 { grid-column: span 1; }
.col-span-2 { grid-column: span 2; }
.col-span-3 { grid-column: span 3; }
.col-span-4 { grid-column: span 4; }
.col-span-full { grid-column: 1 / -1; }

.row-span-1 { grid-row: span 1; }
.row-span-2 { grid-row: span 2; }
.row-span-3 { grid-row: span 3; }
.row-span-full { grid-row: 1 / -1; }

@media (max-width: 640px) {
  .sm\:d-none { display: none; }
  .sm\:d-block { display: block; }
  .sm\:d-flex { display: flex; }
  .sm\:flex-col { flex-direction: column; }
  .sm\:grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
  .sm\:text-center { text-align: center; }
  .sm\:mx-auto { margin-inline: auto; }
  .sm\:px-4 { padding-inline: var(--space-4); }
  .sm\:py-8 { padding-block: var(--space-8); }
  .sm\:col-span-full { grid-column: 1 / -1; }
}

@media (min-width: 641px) and (max-width: 1024px) {
  .md\:d-none { display: none; }
  .md\:d-block { display: block; }
  .md\:d-flex { display: flex; }
  .md\:flex-col { flex-direction: column; }
  .md\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .md\:text-center { text-align: center; }
  .md\:col-span-full { grid-column: 1 / -1; }
}

@media (min-width: 1025px) {
  .lg\:d-none { display: none; }
  .lg\:d-block { display: block; }
  .lg\:d-flex { display: flex; }
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
  .lg\:col-span-2 { grid-column: span 2; }
}

.w-full { width: 100%; }
.w-auto { width: auto; }
.w-fit { width: fit-content; }
.w-screen { width: 100vw; }
.h-full { height: 100%; }
.h-auto { height: auto; }
.h-fit { height: fit-content; }
.h-screen { height: 100vh; }
.min-h-screen { min-height: 100vh; }
.min-w-0 { min-width: 0; }
.max-w-full { max-width: 100%; }
.max-w-prose { max-width: 72ch; }
.max-w-sm { max-width: 480px; }
.max-w-md { max-width: 640px; }
.max-w-lg { max-width: 768px; }
.max-w-xl { max-width: 960px; }
.max-w-container { max-width: var(--container-max); }

.overflow-hidden { overflow: hidden; }
.overflow-auto { overflow: auto; }
.overflow-x-auto { overflow-x: auto; }
.overflow-y-auto { overflow-y: auto; }
.overflow-visible { overflow: visible; }

.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }
.sticky { position: sticky; }
.static { position: static; }

.inset-0 { inset: 0; }
.top-0 { top: 0; }
.bottom-0 { bottom: 0; }
.left-0 { left: 0; }
.right-0 { right: 0; }

.z-base { z-index: var(--z-base); }
.z-raised { z-index: var(--z-raised); }
.z-dropdown { z-index: var(--z-dropdown); }
.z-sticky { z-index: var(--z-sticky); }
.z-overlay { z-index: var(--z-overlay); }
.z-modal { z-index: var(--z-modal); }

.rounded-sm { border-radius: var(--radius-sm); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-2xl { border-radius: var(--radius-2xl); }
.rounded-full { border-radius: var(--radius-full); }
.rounded-none { border-radius: 0; }

.border { border: 1px solid var(--c-border); }
.border-2 { border: 2px solid var(--c-border); }
.border-primary { border-color: var(--c-primary); }
.border-gold { border-color: var(--c-gold); }
.border-navy { border-color: var(--c-navy); }
.border-none { border: none; }
.border-t { border-top: 1px solid var(--c-border); }
.border-b { border-bottom: 1px solid var(--c-border); }
.border-l { border-left: 1px solid var(--c-border); }
.border-r { border-right: 1px solid var(--c-border); }
.border-l-primary { border-left: 4px solid var(--c-primary); }
.border-l-gold { border-left: 4px solid var(--c-gold); }

.shadow-sm { box-shadow: var(--c-shadow-sm); }
.shadow-md { box-shadow: var(--c-shadow-md); }
.shadow-lg { box-shadow: var(--c-shadow-lg); }
.shadow-xl { box-shadow: var(--c-shadow-xl); }
.shadow-none { box-shadow: none; }
.shadow-gold { box-shadow: var(--c-shadow-gold); }
.shadow-primary { box-shadow: var(--c-shadow-primary); }

.bg-white { background-color: var(--c-white); }
.bg-off-white { background-color: var(--c-off-white); }
.bg-sage { background-color: var(--c-sage-tint); }
.bg-primary { background-color: var(--c-primary); }
.bg-navy { background-color: var(--c-navy); }
.bg-gold { background-color: var(--c-gold); }
.bg-charcoal { background-color: var(--c-charcoal); }
.bg-silver { background-color: var(--c-silver); }
.bg-amber { background-color: var(--c-amber); }
.bg-alert { background-color: var(--c-alert); }
.bg-leaf { background-color: var(--c-leaf); }
.bg-transparent { background-color: transparent; }

.bg-gradient-primary {
  background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-leaf) 100%);
}

.bg-gradient-navy {
  background: linear-gradient(135deg, var(--c-navy) 0%, var(--c-primary) 100%);
}

.bg-gradient-gold {
  background: linear-gradient(135deg, var(--c-gold-dark) 0%, var(--c-gold-light) 100%);
}

.bg-gradient-hero {
  background: linear-gradient(
    160deg,
    var(--c-navy) 0%,
    var(--c-primary) 50%,
    var(--c-leaf) 100%
  );
}

.bg-gradient-overlay {
  background: linear-gradient(
    to bottom,
    rgba(26, 43, 74, 0) 0%,
    rgba(26, 43, 74, 0.7) 60%,
    rgba(26, 43, 74, 0.95) 100%
  );
}

.opacity-0 { opacity: 0; }.opacity-25 { opacity: 0.25; }
.opacity-50 { opacity: 0.50; }
.opacity-75 { opacity: 0.75; }
.opacity-100 { opacity: 1; }

.pointer-events-none { pointer-events: none; }
.pointer-events-auto { pointer-events: auto; }
.cursor-pointer { cursor: pointer; }
.cursor-default { cursor: default; }
.cursor-not-allowed { cursor: not-allowed; }

.select-none { user-select: none; }
.select-text { user-select: text; }
.select-all { user-select: all; }

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

.not-sr-only {
  position: static;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
}

.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-4);
  z-index: 9999;
  padding: var(--space-3) var(--space-6);
  background-color: var(--c-primary);
  color: var(--c-white);
  font-weight: var(--fw-semibold);
  font-size: var(--text-sm);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  text-decoration: none;
  transition: top var(--transition-fast);
}

.skip-link:focus {
  top: 0;
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
}

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

.aspect-square { aspect-ratio: 1 / 1; }
.aspect-video { aspect-ratio: 16 / 9; }
.aspect-portrait { aspect-ratio: 3 / 4; }
.aspect-landscape { aspect-ratio: 4 / 3; }
.aspect-wide { aspect-ratio: 21 / 9; }

.object-cover { object-fit: cover; }
.object-contain { object-fit: contain; }
.object-fill { object-fit: fill; }
.object-center { object-position: center; }
.object-top { object-position: top; }
.object-bottom { object-position: bottom; }

.img-fluid {
  max-width: 100%;
  height: auto;
  display: block;
}

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

.img-lazy {
  background-color: var(--c-silver);
  transition: opacity var(--transition-slow);
}

.img-lazy[data-loaded="false"] {
  opacity: 0;
}

.img-lazy[data-loaded="true"] {
  opacity: 1;
}

.transition-none { transition: none; }
.transition-fast { transition: all var(--transition-fast); }
.transition-base { transition: all var(--transition-base); }
.transition-slow { transition: all var(--transition-slow); }

.animate-fade-in {
  animation: fadeIn var(--transition-slow) ease forwards;
}

.animate-slide-up {
  animation: slideUp 0.5s ease forwards;
}

.animate-slide-down {
  animation: slideDown 0.4s ease forwards;
}

.animate-scale-in {
  animation: scaleIn 0.35s var(--transition-bounce) forwards;
}

.animate-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

.animate-spin {
  animation: spin 1s linear infinite;
}

.animate-bounce-subtle {
  animation: bounceSlight 2s ease-in-out infinite;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.92);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

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

@keyframes countUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.scroll-fade {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.6s ease,
    transform 0.6s ease;
}

.scroll-fade.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.scroll-fade--left {
  opacity: 0;
  transform: translateX(-24px);
  transition:
    opacity 0.6s ease,
    transform 0.6s ease;
}

.scroll-fade--left.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.scroll-fade--right {
  opacity: 0;
  transform: translateX(24px);
  transition:
    opacity 0.6s ease,
    transform 0.6s ease;
}

.scroll-fade--right.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.scroll-fade--scale {
  opacity: 0;
  transform: scale(0.95);
  transition:
    opacity 0.6s ease,
    transform 0.6s ease;
}

.scroll-fade--scale.is-visible {
  opacity: 1;
  transform: scale(1);
}

.stagger-children > * {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 0.5s ease,
    transform 0.5s ease;
}

.stagger-children.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.stagger-children.is-visible > *:nth-child(2) { transition-delay: 80ms; }
.stagger-children.is-visible > *:nth-child(3) { transition-delay: 160ms; }
.stagger-children.is-visible > *:nth-child(4) { transition-delay: 240ms; }
.stagger-children.is-visible > *:nth-child(5) { transition-delay: 320ms; }
.stagger-children.is-visible > *:nth-child(6) { transition-delay: 400ms; }
.stagger-children.is-visible > *:nth-child(7) { transition-delay: 480ms; }
.stagger-children.is-visible > *:nth-child(8) { transition-delay: 560ms; }

.stagger-children.is-visible > * {
  opacity: 1;
  transform: translateY(0);
}

.skeleton {
  background: linear-gradient(
    90deg,
    var(--c-silver) 25%,
    var(--c-off-white) 50%,
    var(--c-silver) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--radius-md);
}

.skeleton--text {
  height: 1em;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-2);
}

.skeleton--heading {
  height: 1.5em;
  width: 60%;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-4);
}

.skeleton--avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  flex-shrink: 0;
}

.skeleton--card {
  height: 240px;
  border-radius: var(--radius-lg);
}

.skeleton--image {
  width: 100%;
  padding-top: 56.25%;
  border-radius: var(--radius-md);
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: 0.25rem 0.625rem;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  line-height: 1;
  border-radius: var(--radius-full);
  white-space: nowrap;
  vertical-align: middle;
}

.badge--primary {
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
  border: 1px solid rgba(0, 64, 28, 0.20);
}

.badge--gold {
  background-color: rgba(201, 168, 76, 0.15);
  color: var(--c-gold-dark);
  border: 1px solid rgba(201, 168, 76, 0.35);
}

.badge--navy {
  background-color: rgba(26, 43, 74, 0.10);
  color: var(--c-navy);
  border: 1px solid rgba(26, 43, 74, 0.20);
}

.badge--amber {
  background-color: rgba(230, 126, 34, 0.12);
  color: #b8621a;
  border: 1px solid rgba(230, 126, 34, 0.30);
}

.badge--alert {
  background-color: rgba(192, 57, 43, 0.10);
  color: var(--c-alert);
  border: 1px solid rgba(192, 57, 43, 0.25);
}

.badge--leaf {
  background-color: rgba(45, 122, 79, 0.12);
  color: var(--c-leaf);
  border: 1px solid rgba(45, 122, 79, 0.25);
}

.badge--solid-primary {
  background-color: var(--c-primary);
  color: var(--c-white);
  border: 1px solid var(--c-primary);
}

.badge--solid-gold {
  background-color: var(--c-gold);
  color: var(--c-charcoal);
  border: 1px solid var(--c-gold);
}

.badge--solid-navy {
  background-color: var(--c-navy);
  color: var(--c-white);
  border: 1px solid var(--c-navy);
}

.badge--new::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: currentColor;
  flex-shrink: 0;
}

.tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0.3125rem 0.75rem;
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--c-slate);
  background-color: var(--c-off-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-full);
  transition:
    background-color var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast);
  cursor: default;
  white-space: nowrap;
}

.tag--interactive {
  cursor: pointer;
}

.tag--interactive:hover {
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
  border-color: var(--c-primary);
}

.tag--active {
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
  border-color: var(--c-primary);
  font-weight: var(--fw-semibold);
}

.divider {
  border: none;
  border-top: 1px solid var(--c-border);
  margin-block: var(--space-8);
}

.divider--thick {
  border-top-width: 2px;
}

.divider--primary {
  border-color: var(--c-primary);
}

.divider--gold {
  border-color: var(--c-gold);
}

.divider--dashed {
  border-top-style: dashed;
}

.divider--with-text {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  border: none;
  margin-block: var(--space-8);
}

.divider--with-text::before,
.divider--with-text::after {
  content: '';
  flex: 1;
  height: 1px;
  background-color: var(--c-border);
}

.divider--with-text span {
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: var(--c-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  white-space: nowrap;
}

.card {
  background-color: var(--c-bg-card);
  border-radius: var(--radius-xl);
  border: 1px solid var(--c-border);
  overflow: hidden;
  transition:
    box-shadow var(--transition-base),
    transform var(--transition-base),
    border-color var(--transition-base);
}

.card--hover:hover {
  box-shadow: var(--c-shadow-lg);
  transform: translateY(-3px);
  border-color: rgba(0, 64, 28, 0.15);
}

.card--shadow {
  box-shadow: var(--c-shadow-md);
  border-color: transparent;
}

.card--shadow:hover {
  box-shadow: var(--c-shadow-xl);
  transform: translateY(-3px);
}

.card--primary {
  background-color: var(--c-primary);
  color: var(--c-white);
  border-color: var(--c-primary);
}

.card--navy {
  background-color: var(--c-navy);
  color: var(--c-white);
  border-color: var(--c-navy);
}

.card--gold-accent {
  border-top: 4px solid var(--c-gold);
}

.card--primary-accent {
  border-top: 4px solid var(--c-primary);
}

.card__image {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: center;
  display: block;
}

.card__image--square {
  aspect-ratio: 1 / 1;
}

.card__image--portrait {
  aspect-ratio: 3 / 4;
}

.card__body {
  padding: var(--space-6);
}

.card__body--sm {
  padding: var(--space-4);
}

.card__body--lg {
  padding: var(--space-8);
}

.card__header {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--c-border);
}

.card__footer {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--c-border);
  background-color: var(--c-off-white);
}

.card__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--c-navy);
  line-height: var(--leading-snug);
  margin-bottom: var(--space-2);
}

.card__subtitle {
  font-size: var(--text-sm);
  color: var(--c-slate);
  margin-bottom: var(--space-3);
}

.card__text {
  font-size: var(--text-sm);
  color: var(--c-slate);
  line-height: var(--leading-relaxed);
}

.card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  margin-bottom: var(--space-3);
  flex-wrap: wrap;
}

.card__meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.card__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-5);
  flex-wrap: wrap;
}

.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-lg);
  border: 1px solid transparent;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.alert__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 1px;
}

.alert__content {
  flex: 1;
  min-width: 0;
}

.alert__title {
  font-weight: var(--fw-semibold);
  margin-bottom: var(--space-1);
  font-size: var(--text-sm);
}

.alert__dismiss {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  color: currentColor;
  opacity: 0.6;
  transition: opacity var(--transition-fast);
  flex-shrink: 0;
  line-height: 1;
  font-size: 1.25rem;
}

.alert__dismiss:hover {
  opacity: 1;
}

.alert--info {
  background-color: rgba(41, 128, 185, 0.08);
  border-color: rgba(41, 128, 185, 0.25);
  color: #1a5f8a;
}

.alert--success {
  background-color: rgba(45, 122, 79, 0.08);
  border-color: rgba(45, 122, 79, 0.25);
  color: #1e5c3a;
}

.alert--warning {
  background-color: rgba(230, 126, 34, 0.08);
  border-color: rgba(230, 126, 34, 0.25);
  color: #8a4a10;
}

.alert--error {
  background-color: rgba(192, 57, 43, 0.08);
  border-color: rgba(192, 57, 43, 0.25);
  color: #8b1a10;
}

.alert--primary {
  background-color: var(--c-sage-tint);
  border-color: rgba(0, 64, 28, 0.20);
  color: var(--c-primary-dark);
}

.alert--gold {
  background-color: rgba(201, 168, 76, 0.10);
  border-color: rgba(201, 168, 76, 0.30);
  color: var(--c-gold-dark);
}

.tooltip {
  position: relative;
  display: inline-flex;
}

.tooltip__content {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--c-charcoal);
  color: var(--c-white);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--transition-fast);
  z-index: var(--z-tooltip);
  max-width: 240px;
  white-space: normal;
  text-align: center;
  line-height: 1.4;
}

.tooltip__content::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--c-charcoal);
}

.tooltip:hover .tooltip__content,
.tooltip:focus-within .tooltip__content {
  opacity: 1;
}

.spinner {
  display: inline-block;
  width: 24px;
  height: 24px;
  border: 3px solid var(--c-silver);
  border-top-color: var(--c-primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  flex-shrink: 0;
}

.spinner--sm {
  width: 16px;
  height: 16px;
  border-width: 2px;
}

.spinner--lg {
  width: 36px;
  height: 36px;
  border-width: 4px;
}

.spinner--xl {
  width: 48px;
  height: 48px;
  border-width: 4px;
}

.spinner--gold {
  border-color: rgba(201, 168, 76, 0.25);
  border-top-color: var(--c-gold);
}

.spinner--white {
  border-color: rgba(255, 255, 255, 0.25);
  border-top-color: var(--c-white);
}

.spinner--navy {
  border-color: rgba(26, 43, 74, 0.15);
  border-top-color: var(--c-navy);
}

.progress-bar {
  width: 100%;
  height: 8px;
  background-color: var(--c-silver);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.progress-bar__fill {
  height: 100%;
  background: linear-gradient(90deg, var(--c-primary), var(--c-leaf));
  border-radius: var(--radius-full);
  transition: width 0.6s ease;
  min-width: 0;
}

.progress-bar--sm {
  height: 4px;
}

.progress-bar--lg {
  height: 12px;
}

.progress-bar--gold .progress-bar__fill {
  background: linear-gradient(90deg, var(--c-gold-dark), var(--c-gold-light));
}

.progress-bar--navy .progress-bar__fill {
  background: linear-gradient(90deg, var(--c-navy), var(--c-sky));
}

.progress-bar--striped .progress-bar__fill {
  background-image: repeating-linear-gradient(
    45deg,
    rgba(255, 255, 255, 0.15) 0px,
    rgba(255, 255, 255, 0.15) 10px,
    transparent 10px,
    transparent 20px
  );
  background-color: var(--c-primary);
  background-size: 28px 28px;
  animation: shimmer 1s linear infinite;
}

.avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  overflow: hidden;
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
  font-weight: var(--fw-semibold);
  font-size: var(--text-sm);
  flex-shrink: 0;
  width: 40px;
  height: 40px;
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.avatar--xs { width: 24px; height: 24px; font-size: var(--text-xs); }
.avatar--sm { width: 32px; height: 32px; font-size: var(--text-xs); }
.avatar--md { width: 40px; height: 40px; font-size: var(--text-sm); }
.avatar--lg { width: 56px; height: 56px; font-size: var(--text-base); }
.avatar--xl { width: 72px; height: 72px; font-size: var(--text-xl); }
.avatar--2xl { width: 96px; height: 96px; font-size: var(--text-2xl); }

.avatar--primary {
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
}

.avatar--navy {
  background-color: rgba(26, 43, 74, 0.12);
  color: var(--c-navy);
}

.avatar--gold {
  background-color: rgba(201, 168, 76, 0.15);
  color: var(--c-gold-dark);
}

.avatar--ring {
  box-shadow: 0 0 0 3px var(--c-white), 0 0 0 5px var(--c-primary);
}

.avatar--ring-gold {
  box-shadow: 0 0 0 3px var(--c-white), 0 0 0 5px var(--c-gold);
}

.avatar-group {
  display: flex;
  align-items: center;
}

.avatar-group .avatar {
  margin-left: -10px;
  border: 2px solid var(--c-white);
  transition: transform var(--transition-fast), z-index var(--transition-fast);
  position: relative;
}

.avatar-group .avatar:first-child {
  margin-left: 0;
}

.avatar-group .avatar:hover {
  transform: translateY(-3px);
  z-index: var(--z-raised);
}

.avatar-group__count {
  margin-left: -10px;
  border: 2px solid var(--c-white);
  background-color: var(--c-silver);
  color: var(--c-slate);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
}

.icon-box {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
  flex-shrink: 0;
  width: 48px;
  height: 48px;
}

.icon-box--sm { width: 36px; height: 36px; border-radius: var(--radius-md); }
.icon-box--md { width: 48px; height: 48px; }
.icon-box--lg { width: 64px; height: 64px; border-radius: var(--radius-xl); }
.icon-box--xl { width: 80px; height: 80px; border-radius: var(--radius-xl); }

.icon-box--primary {
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
}

.icon-box--primary-solid {
  background-color: var(--c-primary);
  color: var(--c-white);
}

.icon-box--gold {
  background-color: rgba(201, 168, 76, 0.15);
  color: var(--c-gold-dark);
}

.icon-box--gold-solid {
  background-color: var(--c-gold);
  color: var(--c-charcoal);
}

.icon-box--navy {
  background-color: rgba(26, 43, 74, 0.10);
  color: var(--c-navy);
}

.icon-box--navy-solid {
  background-color: var(--c-navy);
  color: var(--c-white);
}

.icon-box--leaf {
  background-color: rgba(45, 122, 79, 0.12);
  color: var(--c-leaf);
}

.icon-box--amber {
  background-color: rgba(230, 126, 34, 0.12);
  color: var(--c-amber);
}

.icon-box--circle {
  border-radius: 50%;
}

.stat-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-8);
  gap: var(--space-2);
}

.stat-card__number {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
  font-weight: var(--fw-extrabold);
  color: var(--c-primary);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
}

.stat-card__number--gold {
  color: var(--c-gold);
}

.stat-card__number--navy {
  color: var(--c-navy);
}

.stat-card__label {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--c-slate);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  line-height: 1.4;
}

.stat-card__suffix {
  font-size: 0.6em;
  font-weight: var(--fw-bold);
  vertical-align: super;
  line-height: 1;
}

.stat-card__description {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  line-height: 1.5;
  max-width: 20ch;
}

.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1);
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: var(--text-sm);
}

.breadcrumb__item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  color: var(--c-slate);
}

.breadcrumb__item::after {
  content: '/';
  color: var(--c-text-muted);
  font-weight: var(--fw-regular);
}

.breadcrumb__item:last-child::after {
  display: none;
}

.breadcrumb__item:last-child {
  color: var(--c-charcoal);
  font-weight: var(--fw-semibold);
}

.breadcrumb__link {
  color: var(--c-slate);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.breadcrumb__link:hover {
  color: var(--c-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.breadcrumb--inverse .breadcrumb__item {
  color: rgba(255, 255, 255, 0.7);
}

.breadcrumb--inverse .breadcrumb__item:last-child {
  color: var(--c-white);
}

.breadcrumb--inverse .breadcrumb__link {
  color: rgba(255, 255, 255, 0.7);
}

.breadcrumb--inverse .breadcrumb__link:hover {
  color: var(--c-white);
}

.breadcrumb--inverse .breadcrumb__item::after {
  color: rgba(255, 255, 255, 0.4);
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.pagination__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--c-slate);
  background-color: var(--c-white);
  border: 1px solid var(--c-border);
  cursor: pointer;
  transition:
    background-color var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast);
  text-decoration: none;
  min-width: 44px;
  min-height: 44px;
}

.pagination__item:hover:not(.is-active):not(.is-disabled) {
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
  border-color: var(--c-primary);
}

.pagination__item.is-active {
  background-color: var(--c-primary);
  color: var(--c-white);
  border-color: var(--c-primary);
  font-weight: var(--fw-bold);
  cursor: default;
}

.pagination__item.is-disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.pagination__ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: var(--c-text-muted);
  font-size: var(--text-sm);
}

.tabs {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.tabs__list {
  display: flex;
  align-items: flex-end;
  border-bottom: 2px solid var(--c-border);
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.tabs__list::-webkit-scrollbar {
  display: none;
}

.tabs__trigger {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--c-slate);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  white-space: nowrap;
  transition:
    color var(--transition-fast),
    border-color var(--transition-fast);
  min-height: 44px;
}

.tabs__trigger:hover {
  color: var(--c-primary);
}

.tabs__trigger.is-active {
  color: var(--c-primary);
  border-bottom-color: var(--c-primary);
  font-weight: var(--fw-semibold);
}

.tabs__trigger:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: -3px;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.tabs__panel {
  padding-top: var(--space-6);
}

.tabs__panel[hidden] {
  display: none;
}

.tabs--pills .tabs__list {
  border-bottom: none;
  gap: var(--space-2);
  padding: var(--space-1);
  background-color: var(--c-off-white);
  border-radius: var(--radius-lg);
  align-items: center;
}

.tabs--pills .tabs__trigger {
  border-bottom: none;
  margin-bottom: 0;
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-4);
}

.tabs--pills .tabs__trigger.is-active {
  background-color: var(--c-white);
  color: var(--c-primary);
  box-shadow: var(--c-shadow-sm);
}

.tabs--pills .tabs__panel {
  padding-top: var(--space-6);
}

.accordion {
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.accordion__item {
  border-bottom: 1px solid var(--c-border);
}

.accordion__item:last-child {
  border-bottom: none;
}

.accordion__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  width: 100%;
  padding: var(--space-5) var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  color: var(--c-charcoal);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  transition:
    background-color var(--transition-fast),
    color var(--transition-fast);
  min-height: 44px;
}

.accordion__trigger:hover {
  background-color: var(--c-off-white);
  color: var(--c-primary);
}

.accordion__trigger.is-open {
  color: var(--c-primary);
  background-color: var(--c-sage-tint);
}

.accordion__trigger:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: -3px;
}

.accordion__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: var(--c-slate);
  transition: transform var(--transition-base);
}

.accordion__trigger.is-open .accordion__icon {
  transform: rotate(180deg);
  color: var(--c-primary);
}

.accordion__content {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.35s ease, padding 0.35s ease;
}

.accordion__content.is-open {
  max-height: 2000px;
}

.accordion__body {
  padding: 0 var(--space-6) var(--space-5);
  font-size: var(--text-sm);
  color: var(--c-slate);
  line-height: var(--leading-relaxed);
}

.accordion--flush {
  border: none;
  border-radius: 0;
}

.accordion--flush .accordion__item {
  border-bottom: 1px solid var(--c-border);
}

.accordion--flush .accordion__trigger {
  padding-inline: 0;
}

.accordion--flush .accordion__body {
  padding-inline: 0;
}

.accordion--primary .accordion__trigger.is-open {
  background-color: var(--c-primary);
  color: var(--c-white);
}

.accordion--primary .accordion__trigger.is-open .accordion__icon {
  color: var(--c-white);
}

.accordion--primary .accordion__content.is-open {
  background-color: var(--c-sage-tint);
}

.modal-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(26, 43, 74, 0.65);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-base);
}

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

.modal {
  background-color: var(--c-white);
  border-radius: var(--radius-2xl);
  box-shadow: var(--c-shadow-xl);
  width: 100%;
  max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
  transform: scale(0.94) translateY(12px);
  transition: transform var(--transition-bounce);
  position: relative;
}

.modal-overlay.is-open .modal {
  transform: scale(1) translateY(0);
}

.modal--sm { max-width: 420px; }
.modal--md { max-width: 560px; }
.modal--lg { max-width: 720px; }
.modal--xl { max-width: 960px; }
.modal--full { max-width: calc(100vw - 2rem); max-height: calc(100vh - 2rem); }

.modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-8);
  border-bottom: 1px solid var(--c-border);
}

.modal__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--c-navy);
  line-height: var(--leading-snug);
}

.modal__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--c-slate);
  font-size: 1.25rem;
  line-height: 1;
  transition:
    background-color var(--transition-fast),
    color var(--transition-fast);
  flex-shrink: 0;
}

.modal__close:hover {
  background-color: var(--c-off-white);
  color: var(--c-charcoal);
}

.modal__body {
  padding: var(--space-6) var(--space-8);
}

.modal__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-8);
  border-top: 1px solid var(--c-border);
  background-color: var(--c-off-white);
  border-radius: 0 0 var(--radius-2xl) var(--radius-2xl);
  flex-wrap: wrap;
}

@media (max-width: 640px) {
  .modal__header,
  .modal__body,
  .modal__footer {
    padding-inline: var(--space-5);
  }

  .modal__footer {
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .modal__footer .btn {
    width: 100%;
    justify-content: center;
  }
}

.table-wrapper {
  width: 100%;
  overflow-x: auto;
  border-radius: var(--radius-lg);
  border: 1px solid var(--c-border);
  box-shadow: var(--c-shadow-sm);
}

.table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  min-width: 480px;
}

.table thead {
  background-color: var(--c-navy);
  color: var(--c-white);
}

.table thead th {
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  text-align: left;
  white-space: nowrap;
  border-bottom: 2px solid rgba(255, 255, 255, 0.15);
}

.table thead th:first-child {
  border-radius: var(--radius-lg) 0 0 0;
}

.table thead th:last-child {
  border-radius: 0 var(--radius-lg) 0 0;
}

.table tbody tr {
  border-bottom: 1px solid var(--c-border);
  transition: background-color var(--transition-fast);
}

.table tbody tr:last-child {
  border-bottom: none;
}

.table tbody tr:hover {
  background-color: var(--c-sage-tint);
}

.table tbody td {
  padding: var(--space-4) var(--space-5);
  color: var(--c-charcoal);
  vertical-align: middle;
  line-height: var(--leading-normal);
}

.table tfoot {
  background-color: var(--c-off-white);
  border-top: 2px solid var(--c-border);
}

.table tfoot td {
  padding: var(--space-4) var(--space-5);
  font-weight: var(--fw-semibold);
  color: var(--c-charcoal);
}

.table--striped tbody tr:nth-child(even) {
  background-color: var(--c-off-white);
}

.table--striped tbody tr:nth-child(even):hover {
  background-color: var(--c-sage-tint);
}

.table--bordered td,
.table--bordered th {
  border: 1px solid var(--c-border);
}

.table--compact thead th,
.table--compact tbody td,
.table--compact tfoot td {
  padding: var(--space-2) var(--space-4);
}

.table--fees thead {
  background: linear-gradient(135deg, var(--c-navy), var(--c-primary));
}

.table--fees tbody tr:nth-child(even) {
  background-color: var(--c-sage-tint);
}

.table--fees tbody td:last-child {
  font-weight: var(--fw-semibold);
  color: var(--c-primary);
}

.table--fees tfoot {
  background-color: var(--c-sage-tint);
  border-top: 2px solid var(--c-primary);
}

.table--fees tfoot td {
  color: var(--c-primary);
  font-weight: var(--fw-bold);
}

.list-styled {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.list-styled li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--c-slate);
  line-height: var(--leading-relaxed);
}

.list-styled li::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  min-width: 8px;
  border-radius: 50%;
  background-color: var(--c-gold);
  margin-top: 0.45em;
  flex-shrink: 0;
}

.list-styled--primary li::before {
  background-color: var(--c-primary);
}

.list-styled--check li::before {
  content: '';
  width: 18px;
  height: 18px;
  min-width: 18px;
  border-radius: 50%;
  background-color: var(--c-sage-tint);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' viewBox='0 0 10 8'%3E%3Cpath d='M1 4l3 3 5-6' stroke='%2300401C' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 10px 8px;
  margin-top: 0.1em;
}

.list-styled--cross li::before {
  content: '×';
  width: 18px;
  height: 18px;
  min-width: 18px;
  border-radius: 50%;
  background-color: rgba(192, 57, 43, 0.10);
  color: var(--c-alert);
  font-size: 14px;
  font-weight: var(--fw-bold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.1em;
}

.list-styled--lg li {
  font-size: var(--text-base);
  gap: var(--space-4);
}

.list-styled--lg li::before {
  width: 10px;
  height: 10px;
  min-width: 10px;
  margin-top: 0.5em;
}

.list-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}

.list-inline--divided li:not(:last-child)::after {
  content: '·';
  margin-left: var(--space-2);
  color: var(--c-text-muted);
}

.notice-bar {
  background-color: var(--c-amber);
  color: var(--c-white);
  padding: var(--space-2) 0;
  position: relative;
  z-index: calc(var(--z-sticky) + 1);
}

.notice-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.notice-bar__scroll {
  flex: 1;
  overflow: hidden;
  white-space: nowrap;
}

.notice-bar__text {
  display: inline-block;
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  animation: marquee 30s linear infinite;
  padding-right: var(--space-16);
}

.notice-bar__text a {
  color: var(--c-white);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.notice-bar__dismiss {
  background: none;
  border: none;
  color: var(--c-white);
  cursor: pointer;
  padding: var(--space-1);
  opacity: 0.8;
  transition: opacity var(--transition-fast);
  flex-shrink: 0;
  font-size: 1.25rem;
  line-height: 1;
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.notice-bar__dismiss:hover {
  opacity: 1;
}

@keyframes marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@media (min-width: 641px) {
  .notice-bar__text {
    animation: none;
  }

  .notice-bar__scroll {
    overflow: visible;
    white-space: normal;
    text-align: center;
  }
}

.utility-strip {
  background-color: var(--c-off-white);
  border-bottom: 1px solid var(--c-border);
  padding-block: var(--space-2);
}

.utility-strip__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.utility-strip__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--c-slate);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition:
    color var(--transition-fast),
    background-color var(--transition-fast);
  white-space: nowrap;
  min-height: 28px;
}

.utility-strip__link:hover {
  color: var(--c-primary);
  background-color: var(--c-sage-tint);
  text-decoration: none;
}

.utility-strip__divider {
  width: 1px;
  height: 14px;
  background-color: var(--c-border);
  flex-shrink: 0;
}

.hero {
  position: relative;
  overflow: hidden;
  min-height: 100svh;
  display: flex;
  align-items: center;
  background-color: var(--c-navy);
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    160deg,
    rgba(26, 43, 74, 0.82) 0%,
    rgba(0, 64, 28, 0.70) 50%,
    rgba(26, 43, 74, 0.88) 100%
  );
  z-index: 1;
}

.hero__illustrated-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0.08;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cg fill='none' stroke='%23C9A84C' stroke-width='0.5' opacity='0.6'%3E%3Cpolygon points='30,2 58,16 58,44 30,58 2,44 2,16'/%3E%3Cpolygon points='30,10 50,20 50,40 30,50 10,40 10,20'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 60px 60px;
}

.hero__content {
  position: relative;
  z-index: 3;
  width: 100%;
  padding-block: var(--space-24);
}

.hero__eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--c-gold);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.hero__eyebrow::before {
  content: '';
  display: inline-block;
  width: 32px;
  height: 2px;
  background-color: var(--c-gold);
  flex-shrink: 0;
}

.hero__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5.5vw, 4.25rem);
  font-weight: var(--fw-extrabold);
  color: var(--c-white);
  line-height: 1.08;
  letter-spacing: -0.03em;
  margin-bottom: var(--space-6);
  max-width: 18ch;
}

.hero__title em {
  font-style: normal;
  color: var(--c-gold);
}

.hero__subtitle {
  font-size: clamp(var(--text-base), 1.8vw, var(--text-xl));
  color: rgba(255, 255, 255, 0.82);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-10);
  max-width: 52ch;
}

.hero__actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-12);
}

.hero__trust-strip {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  flex-wrap: wrap;
  padding-top: var(--space-8);
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.hero__trust-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.hero__trust-number {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--fw-extrabold);
  color: var(--c-gold);
  line-height: 1;
}

.hero__trust-label {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.65);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  font-weight: var(--fw-medium);
}

.hero__scroll-cue {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: rgba(255, 255, 255, 0.5);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  animation: bounceSlight 2s ease-in-out infinite;
}

.hero__scroll-cue svg {
  width: 20px;
  height: 20px;
}

@media (max-width: 640px) {
  .hero__title {
    max-width: 100%;
  }

  .hero__subtitle {
    max-width: 100%;
  }

  .hero__trust-strip {
    gap: var(--space-4);
  }

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

  .hero__actions .btn {
    width: 100%;
    justify-content: center;
  }
}

.whatsapp-fab {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: var(--z-overlay);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background-color: #25D366;
  color: var(--c-white);
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.45);
  text-decoration: none;
  transition:
    transform var(--transition-bounce),
    box-shadow var(--transition-base);
  border: none;
  cursor: pointer;
}

.whatsapp-fab:hover {
  transform: scale(1.08) translateY(-2px);
  box-shadow: 0 8px 28px rgba(37, 211, 102, 0.55);
  color: var(--c-white);
  text-decoration: none;
}

.whatsapp-fab:active {
  transform: scale(0.96);
}

.whatsapp-fab svg {
  width: 28px;
  height: 28px;
}

.whatsapp-fab__pulse {
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background-color: rgba(37, 211, 102, 0.35);
  animation: pulse 2s ease-in-out infinite;
  z-index: -1;
}

.chatbot-widget {
  position: fixed;
  bottom: calc(var(--space-6) + 64px);
  right: var(--space-6);
  z-index: var(--z-overlay);
}

.chatbot-widget__trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-primary), var(--c-leaf));
  color: var(--c-white);
  box-shadow: var(--c-shadow-primary);
  border: none;
  cursor: pointer;
  transition:
    transform var(--transition-bounce),
    box-shadow var(--transition-base);
}

.chatbot-widget__trigger:hover {
  transform: scale(1.08) translateY(-2px);
  box-shadow: 0 8px 28px rgba(0, 64, 28, 0.45);
}

.chatbot-widget__trigger svg {
  width: 24px;
  height: 24px;
}

.exit-popup-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(26, 43, 74, 0.70);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-base);
}

.exit-popup-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}

.exit-popup {
  background-color: var(--c-white);
  border-radius: var(--radius-2xl);
  box-shadow: var(--c-shadow-xl);
  width: 100%;
  max-width: 520px;
  overflow: hidden;
  transform: scale(0.92) translateY(16px);
  transition: transform var(--transition-bounce);
  position: relative;
}

.exit-popup-overlay.is-open .exit-popup {
  transform: scale(1) translateY(0);
}

.exit-popup__header {
  background: linear-gradient(135deg, var(--c-navy), var(--c-primary));
  padding: var(--space-8) var(--space-8) var(--space-6);
  text-align: center;
  position: relative;
}

.exit-popup__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background-color: var(--c-gold);
  color: var(--c-charcoal);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  padding: var(--space-1) var(--space-4);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
}

.exit-popup__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--fw-extrabold);
  color: var(--c-white);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-2);
}

.exit-popup__subtitle {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.75);
  line-height: var(--leading-relaxed);
}

.exit-popup__close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.15);
  border: none;
  color: var(--c-white);
  cursor: pointer;
  font-size: 1.125rem;
  line-height: 1;
  transition: background-color var(--transition-fast);
}

.exit-popup__close:hover {
  background: rgba(255, 255, 255, 0.25);
}

.exit-popup__body {
  padding: var(--space-6) var(--space-8) var(--space-8);
}

.exit-popup__body .form-group {
  margin-bottom: var(--space-4);
}

.exit-popup__disclaimer {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  text-align: center;
  margin-top: var(--space-4);
  line-height: 1.5;
}

.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-toast);
  background-color: var(--c-navy);
  color: var(--c-white);
  padding: var(--space-4) 0;
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.20);
  transform: translateY(100%);
  transition: transform var(--transition-slow);
}

.cookie-banner.is-visible {
  transform: translateY(0);
}

.cookie-banner__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.cookie-banner__text {
  flex: 1;
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.85);
  line-height: var(--leading-relaxed);

/* ===== */

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

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

img,
video,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

img {
  object-fit: cover;
  font-style: italic;
  background-repeat: no-repeat;
  background-size: cover;
  shape-margin: 1rem;
}

img[loading="lazy"] {
  opacity: 0;
  transition: opacity 0.4s ease;
}

img[loading="lazy"].loaded,
img.lazyloaded {
  opacity: 1;
}

.img-placeholder {
  background-color: var(--c-silver);
  min-height: 200px;
  display: block;
  width: 100%;
}

.img-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.img-contain {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.img-rounded {
  border-radius: var(--radius-lg);
}

.img-circle {
  border-radius: var(--radius-full);
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

picture {
  display: block;
}

figure {
  display: block;
  margin: 0;
}

figcaption {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--c-text-secondary);
  margin-top: var(--space-2);
  line-height: var(--leading-normal);
}

.announcement-bar {
  background-color: var(--c-amber);
  color: var(--c-white);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  line-height: var(--leading-normal);
  padding: var(--space-2) var(--space-4);
  position: relative;
  z-index: 1001;
  overflow: hidden;
  white-space: nowrap;
}

.announcement-bar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  overflow: hidden;
}

.announcement-bar__text {
  display: inline-block;
  white-space: nowrap;
}

.announcement-bar__dismiss {
  position: absolute;
  right: var(--space-4);
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: var(--c-white);
  cursor: pointer;
  font-size: var(--text-lg);
  line-height: 1;
  padding: var(--space-1) var(--space-2);
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  transition: background-color 0.2s ease;
  flex-shrink: 0;
}

.announcement-bar__dismiss:hover,
.announcement-bar__dismiss:focus-visible {
  background-color: rgba(0, 0, 0, 0.15);
  outline: 2px solid var(--c-white);
  outline-offset: 2px;
}

.announcement-bar.is-dismissed {
  display: none;
}

@media (max-width: 767px) {
  .announcement-bar__inner {
    justify-content: flex-start;
    animation: marquee-scroll 22s linear infinite;
    width: max-content;
  }

  @keyframes marquee-scroll {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-50%);
    }
  }

  .announcement-bar {
    padding-right: 3rem;
  }
}

.header {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  width: 100%;
  background-color: transparent;
  transition: background-color 0.35s ease, box-shadow 0.35s ease;
  font-family: var(--font-body);
}

.header.is-scrolled {
  background-color: var(--c-white);
  box-shadow: var(--c-shadow-md);
}

.header.nav-open {
  background-color: var(--c-white);
  box-shadow: var(--c-shadow-md);
}

.header__main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-6);
  max-width: 1440px;
  margin: 0 auto;
  min-height: 72px;
  gap: var(--space-4);
}

.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: var(--space-6);
}

.logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  flex-shrink: 0;
  min-height: 44px;
}

.logo__img {
  height: 52px;
  width: auto;
  object-fit: contain;
  display: block;
}

.logo__wordmark {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.logo__name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--fw-bold);
  color: var(--c-primary);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  white-space: nowrap;
}

.header.is-scrolled .logo__name,
.header.nav-open .logo__name {
  color: var(--c-primary);
}

.logo__tagline {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-regular);
  color: var(--c-slate);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  white-space: nowrap;
}

.nav-primary {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
  justify-content: center;
}

.nav-primary > li {
  position: relative;
}

.nav-primary > li > a,
.nav-primary > li > button {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--c-charcoal);
  text-decoration: none;
  background: transparent;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-wide);
  transition: color 0.2s ease;
  min-height: 44px;
  border-radius: var(--radius-sm);
  position: relative;
}

.header:not(.is-scrolled):not(.nav-open) .nav-primary > li > a,
.header:not(.is-scrolled):not(.nav-open) .nav-primary > li > button {
  color: var(--c-white);
}

.nav-primary > li > a::after,
.nav-primary > li > button::after {
  content: '';
  position: absolute;
  bottom: 6px;
  left: var(--space-4);
  right: var(--space-4);
  height: 2px;
  background-color: var(--c-gold);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.25s ease;
  border-radius: var(--radius-full);
}

.nav-primary > li > a:hover::after,
.nav-primary > li > button:hover::after,
.nav-primary > li > a:focus-visible::after,
.nav-primary > li > button:focus-visible::after,
.nav-primary > li.is-active > a::after,
.nav-primary > li.is-active > button::after {
  transform: scaleX(1);
}

.nav-primary > li > a:hover,
.nav-primary > li > button:hover,
.nav-primary > li > a:focus-visible,
.nav-primary > li > button:focus-visible {
  color: var(--c-primary);
  outline: none;
}

.header:not(.is-scrolled):not(.nav-open) .nav-primary > li > a:hover,
.header:not(.is-scrolled):not(.nav-open) .nav-primary > li > button:hover {
  color: var(--c-gold-light);
}

.nav-primary > li > a:focus-visible,
.nav-primary > li > button:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 2px;
}

.nav-chevron {
  width: 12px;
  height: 12px;
  display: inline-block;
  flex-shrink: 0;
  transition: transform 0.25s ease;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.nav-primary > li.is-open > button .nav-chevron {
  transform: rotate(180deg);
}

.mega-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 520px;
  background-color: var(--c-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--c-shadow-xl);
  border: 1px solid var(--c-border);
  padding: var(--space-6);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-4);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
  z-index: 999;
}

.mega-menu::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 12px;
  height: 12px;
  background-color: var(--c-white);
  border-left: 1px solid var(--c-border);
  border-top: 1px solid var(--c-border);
  transform: translateX(-50%) rotate(45deg);
}

.nav-primary > li.is-open .mega-menu,
.nav-primary > li:hover .mega-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.mega-menu__group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.mega-menu__heading {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--c-primary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  padding: var(--space-1) 0 var(--space-2);
  border-bottom: 1px solid var(--c-border);
  margin-bottom: var(--space-1);
}

.mega-menu__link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-regular);
  color: var(--c-charcoal);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: background-color 0.18s ease, color 0.18s ease, padding-left 0.18s ease;
  min-height: 44px;
  line-height: var(--leading-normal);
}

.mega-menu__link:hover,
.mega-menu__link:focus-visible {
  background-color: var(--c-sage-tint);
  color: var(--c-primary);
  padding-left: var(--space-3);
  outline: none;
}

.mega-menu__link:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 2px;
}

.mega-menu__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background-color: var(--c-primary);
  color: var(--c-white);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  text-decoration: none;
  clip-path: polygon(8px 0%, calc(100% - 8px) 0%, 100% 8px, 100% calc(100% - 8px), calc(100% - 8px) 100%, 8px 100%, 0% calc(100% - 8px), 0% 8px);
  transition: background-color 0.2s ease, transform 0.2s ease;
  min-height: 44px;
  margin-top: var(--space-2);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.mega-menu__cta:hover,
.mega-menu__cta:focus-visible {
  background-color: var(--c-primary-light);
  transform: translateY(-1px);
  outline: none;
}

.mega-menu__cta:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 3px;
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}

.nav-portal-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--c-primary);
  text-decoration: none;
  border: 1.5px solid var(--c-primary);
  border-radius: var(--radius-full);
  transition: background-color 0.2s ease, color 0.2s ease;
  min-height: 44px;
  white-space: nowrap;
  letter-spacing: var(--tracking-wide);
}

.header:not(.is-scrolled):not(.nav-open) .nav-portal-link {
  color: var(--c-white);
  border-color: rgba(255, 255, 255, 0.7);
}

.nav-portal-link:hover,
.nav-portal-link:focus-visible {
  background-color: var(--c-primary);
  color: var(--c-white);
  outline: none;
}

.nav-portal-link:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 3px;
}

.btn-apply-nav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  background-color: var(--c-primary);
  color: var(--c-white);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  text-decoration: none;
  clip-path: polygon(10px 0%, calc(100% - 10px) 0%, 100% 10px, 100% calc(100% - 10px), calc(100% - 10px) 100%, 10px 100%, 0% calc(100% - 10px), 0% 10px);
  transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  min-height: 44px;
  white-space: nowrap;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  cursor: pointer;
  border: none;
}

.btn-apply-nav:hover,
.btn-apply-nav:focus-visible {
  background-color: var(--c-primary-light);
  transform: translateY(-2px);
  box-shadow: var(--c-shadow-primary);
  outline: none;
}

.btn-apply-nav:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 3px;
}

.btn-apply-nav:active {
  transform: translateY(0);
}

.nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: transparent;
  border: 1.5px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  padding: var(--space-2);
  transition: border-color 0.2s ease, background-color 0.2s ease;
  flex-shrink: 0;
  position: relative;
  z-index: 1001;
}

.nav-toggle:hover,
.nav-toggle:focus-visible {
  border-color: var(--c-primary);
  background-color: var(--c-sage-tint);
  outline: none;
}

.nav-toggle:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 2px;
}

.nav-toggle__icon {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 22px;
  height: 16px;
  position: relative;
}

.nav-toggle__bar {
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--c-charcoal);
  border-radius: var(--radius-full);
  transition: transform 0.3s ease, opacity 0.3s ease, width 0.3s ease;
  transform-origin: center;
}

.header:not(.is-scrolled):not(.nav-open) .nav-toggle__bar {
  background-color: var(--c-white);
}

.header.nav-open .nav-toggle__bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.header.nav-open .nav-toggle__bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.header.nav-open .nav-toggle__bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.header__utility {
  background-color: var(--c-sage-tint);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  padding: 0 var(--space-6);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.header__utility::-webkit-scrollbar {
  display: none;
}

.header__utility-list {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  white-space: nowrap;
}

.header__utility-list li {
  display: flex;
  align-items: center;
}

.header__utility-list li + li::before {
  content: '';
  display: inline-block;
  width: 1px;
  height: 14px;
  background-color: var(--c-border);
  margin: 0 var(--space-1);
}

.header__utility-list a {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--c-slate);
  text-decoration: none;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  min-height: 36px;
  transition: color 0.2s ease;
  border-radius: var(--radius-sm);
}

.header__utility-list a:hover,
.header__utility-list a:focus-visible {
  color: var(--c-primary);
  outline: none;
}

.header__utility-list a:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 2px;
}

.header.is-scrolled .header__utility,
.header.nav-open .header__utility {
  display: none;
}

.nav-mobile {
  display: none;
  flex-direction: column;
  background-color: var(--c-white);
  border-top: 1px solid var(--c-border);
  padding: var(--space-4) var(--space-6) var(--space-6);
  max-height: calc(100vh - 72px);
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: var(--c-silver) transparent;
}

.header.nav-open .nav-mobile {
  display: flex;
}

.nav-mobile__priority {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-bottom: var(--space-4);
  border-bottom: 2px solid var(--c-primary);
  margin-bottom: var(--space-4);
}

.nav-mobile__priority-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  text-decoration: none;
  min-height: 44px;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  transition: background-color 0.2s ease, color 0.2s ease;
}

.nav-mobile__priority-link--apply {
  background-color: var(--c-primary);
  color: var(--c-white);
  clip-path: polygon(10px 0%, calc(100% - 10px) 0%, 100% 10px, 100% calc(100% - 10px), calc(100% - 10px) 100%, 10px 100%, 0% calc(100% - 10px), 0% 10px);
}

.nav-mobile__priority-link--apply:hover,
.nav-mobile__priority-link--apply:focus-visible {
  background-color: var(--c-primary-light);
  outline: none;
}

.nav-mobile__priority-link--portal {
  background-color: transparent;
  color: var(--c-primary);
  border: 1.5px solid var(--c-primary);
}

.nav-mobile__priority-link--portal:hover,
.nav-mobile__priority-link--portal:focus-visible {
  background-color: var(--c-sage-tint);
  outline: none;
}

.nav-mobile__priority-link:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 3px;
}

.nav-mobile__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.nav-mobile__item {
  border-bottom: 1px solid var(--c-border);
}

.nav-mobile__item:last-child {
  border-bottom: none;
}

.nav-mobile__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  color: var(--c-charcoal);
  text-decoration: none;
  min-height: 44px;
  transition: color 0.2s ease;
  background: transparent;
  border: none;
  width: 100%;
  cursor: pointer;
  text-align: left;
  letter-spacing: var(--tracking-normal);
}

.nav-mobile__link:hover,
.nav-mobile__link:focus-visible {
  color: var(--c-primary);
  outline: none;
}

.nav-mobile__link:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.nav-mobile__sub {
  list-style: none;
  margin: 0;
  padding: 0 0 var(--space-3) var(--space-4);
  display: none;
  flex-direction: column;
  gap: 0;
}

.nav-mobile__item.is-open .nav-mobile__sub {
  display: flex;
}

.nav-mobile__sub-link {
  display: block;
  padding: var(--space-3) var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-regular);
  color: var(--c-slate);
  text-decoration: none;
  min-height: 44px;
  display: flex;
  align-items: center;
  border-radius: var(--radius-sm);
  transition: color 0.2s ease, background-color 0.2s ease;
}

.nav-mobile__sub-link:hover,
.nav-mobile__sub-link:focus-visible {
  color: var(--c-primary);
  background-color: var(--c-sage-tint);
  outline: none;
}

.nav-mobile__sub-link:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 2px;
}

@media (max-width: 1199px) {
  .nav-primary > li > a,
  .nav-primary > li > button {
    padding: var(--space-3) var(--space-3);
    font-size: var(--text-xs);
  }

  .header__main {
    padding: var(--space-3) var(--space-4);
  }
}

@media (max-width: 1023px) {
  .nav-primary {
    display: none;
  }

  .nav-actions {
    display: none;
  }

  .nav-toggle {
    display: flex;
  }

  .header__utility {
    display: none;
  }

  .logo__tagline {
    display: none;
  }
}

@media (max-width: 767px) {
  .header__main {
    padding: var(--space-3) var(--space-4);
    min-height: 64px;
  }

  .logo__img {
    height: 40px;
  }

  .logo__name {
    font-size: var(--text-base);
  }

  .nav-mobile {
    padding: var(--space-4) var(--space-4) var(--space-6);
  }
}

@media (min-width: 1024px) {
  .nav-mobile {
    display: none !important;
  }
}

.hero {
  position: relative;
  width: 100%;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background-color: var(--c-primary-dark);
}

.hero--short {
  min-height: 60vh;
}

.hero--medium {
  min-height: 75vh;
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transform: scale(1.05);
  animation: hero-ken-burns 18s ease-in-out infinite alternate;
}

@keyframes hero-ken-burns {
  0% {
    transform: scale(1.05) translateX(0) translateY(0);
  }
  100% {
    transform: scale(1.12) translateX(-1.5%) translateY(-1%);
  }
}

.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    135deg,
    rgba(0, 40, 18, 0.82) 0%,
    rgba(0, 40, 18, 0.65) 40%,
    rgba(26, 43, 74, 0.55) 70%,
    rgba(26, 43, 74, 0.72) 100%
  );
}

.hero__illustrated-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  overflow: hidden;
}

.hero__illustrated-overlay svg,
.hero__illustrated-overlay img {
  position: absolute;
  opacity: 0.08;
  animation: hero-float 8s ease-in-out infinite;
}

.hero__illustrated-overlay .overlay-element--1 {
  top: 10%;
  right: 5%;
  width: clamp(200px, 30vw, 480px);
  animation-delay: 0s;
}

.hero__illustrated-overlay .overlay-element--2 {
  bottom: 5%;
  left: 2%;
  width: clamp(120px, 18vw, 280px);
  animation-delay: 2.5s;
  animation-direction: alternate-reverse;
}

.hero__illustrated-overlay .overlay-element--3 {
  top: 50%;
  right: 15%;
  width: clamp(80px, 10vw, 160px);
  animation-delay: 1.2s;
  opacity: 0.05;
}

@keyframes hero-float {
  0%, 100% {
    transform: translateY(0px) rotate(0deg);
  }
  50% {
    transform: translateY(-16px) rotate(1.5deg);
  }
}

.hero__parallax-layer {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  will-change: transform;
}

.hero__content {
  position: relative;
  z-index: 3;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding: var(--space-32) var(--space-6) var(--space-20);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.hero__content--centered {
  grid-template-columns: 1fr;
  text-align: center;
  justify-items: center;
  max-width: 900px;
}

.hero__text {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--c-gold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  padding: var(--space-2) var(--space-4);
  background-color: rgba(201, 168, 76, 0.15);
  border: 1px solid rgba(201, 168, 76, 0.35);
  border-radius: var(--radius-full);
  width: fit-content;
}

.hero__eyebrow::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  background-color: var(--c-gold);
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.hero__heading {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5vw, var(--text-6xl));
  font-weight: var(--fw-bold);
  color: var(--c-white);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin: 0;
}

.hero__heading mark {
  background: none;
  color: var(--c-gold);
  position: relative;
  display: inline;
}

.hero__heading mark::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-gold), var(--c-gold-light));
  border-radius: var(--radius-full);
  opacity: 0.6;
}

.hero__subheading {
  font-family: var(--font-body);
  font-size: clamp(var(--text-base), 2vw, var(--text-xl));
  font-weight: var(--fw-regular);
  color: rgba(255, 255, 255, 0.85);
  line-height: var(--leading-relaxed);
  margin: 0;
  max-width: 56ch;
}

.hero__actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-2);
}

.hero__trust {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  flex-wrap: wrap;
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.hero__trust-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.hero__trust-number {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--c-gold);
  line-height: 1;
}

.hero__trust-label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.hero__visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero__visual-card {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--c-shadow-xl);
  aspect-ratio: 4 / 5;
  width: 100%;
  max-width: 480px;
}

.hero__scroll-cue {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  animation: scroll-cue-bounce 2.2s ease-in-out infinite;
}

.hero__scroll-cue-label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
}

.hero__scroll-cue-arrow {
  width: 24px;
  height: 24px;
  border-right: 2px solid rgba(255, 255, 255, 0.5);
  border-bottom: 2px solid rgba(255, 255, 255, 0.5);
  transform: rotate(45deg);
}

@keyframes scroll-cue-bounce {
  0%, 100% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(8px);
  }
}

@media (max-width: 1023px) {
  .hero__content {
    grid-template-columns: 1fr;
    padding: var(--space-24) var(--space-6) var(--space-16);
    gap: var(--space-8);
  }

  .hero__visual {
    display: none;
  }

  .hero__content {
    text-align: left;
  }
}

@media (max-width: 767px) {
  .hero {
    min-height: 90svh;
  }

  .hero--short {
    min-height: 55vh;
  }

  .hero--medium {
    min-height: 70vh;
  }

  .hero__content {
    padding: var(--space-20) var(--space-4) var(--space-16);
  }

  .hero__actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .hero__trust {
    gap: var(--space-4);
  }
}

.section {
  width: 100%;
  padding: var(--space-20) var(--space-6);
}

.section--sm {
  padding: var(--space-12) var(--space-6);
}

.section--lg {
  padding: var(--space-32) var(--space-6);
}

.section--flush {
  padding-top: 0;
  padding-bottom: 0;
}

.section--flush-top {
  padding-top: 0;
}

.section--flush-bottom {
  padding-bottom: 0;
}

.section--white {
  background-color: var(--c-white);
}

.section--off-white {
  background-color: var(--c-off-white);
}

.section--sage {
  background-color: var(--c-sage-tint);
}

.section--navy {
  background-color: var(--c-navy);
}

.section--primary {
  background-color: var(--c-primary);
}

.section--charcoal {
  background-color: var(--c-charcoal);
}

.section--alt:nth-of-type(odd) {
  background-color: var(--c-white);
}

.section--alt:nth-of-type(even) {
  background-color: var(--c-sage-tint);
}

.section__inner {
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
}

.section__inner--wide {
  max-width: 1440px;
}

.section__inner--narrow {
  max-width: 860px;
}

.section__inner--text {
  max-width: 720px;
}

.section__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-bottom: var(--space-12);
}

.section__header--center {
  align-items: center;
  text-align: center;
}

.section__header--left {
  align-items: flex-start;
  text-align: left;
}

.section__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--c-primary);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  padding: var(--space-1) var(--space-3);
  background-color: var(--c-sage-tint);
  border-left: 3px solid var(--c-gold);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  width: fit-content;
}

.section--navy .section__eyebrow,
.section--primary .section__eyebrow,
.section--charcoal .section__eyebrow {
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--c-gold);
  border-left-color: var(--c-gold);
}

.section__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
  font-weight: var(--fw-bold);
  color: var(--c-charcoal);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin: 0;
}

.section--navy .section__title,
.section--primary .section__title,
.section--charcoal .section__title {
  color: var(--c-white);
}

.section__title mark {
  background: none;
  color: var(--c-primary);
}

.section--navy .section__title mark,
.section--primary .section__title mark,
.section--charcoal .section__title mark {
  color: var(--c-gold);
}

.section__subtitle {
  font-family: var(--font-body);
  font-size: clamp(var(--text-base), 2vw, var(--text-lg));
  font-weight: var(--fw-regular);
  color: var(--c-text-secondary);
  line-height: var(--leading-relaxed);
  margin: 0;
  max-width: 64ch;
}

.section--navy .section__subtitle,
.section--primary .section__subtitle,
.section--charcoal .section__subtitle {
  color: rgba(255, 255, 255, 0.75);
}

.section__divider {
  width: 56px;
  height: 4px;
  background: linear-gradient(90deg, var(--c-gold), var(--c-gold-light));
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.section__header--center .section__divider {
  align-self: center;
}

@media (max-width: 767px) {
  .section {
    padding: var(--space-16) var(--space-4);
  }

  .section--sm {
    padding: var(--space-10) var(--space-4);
  }

  .section--lg {
    padding: var(--space-20) var(--space-4);
  }

  .section__header {
    margin-bottom: var(--space-8);
  }
}

.grid {
  display: grid;
  gap: var(--space-6);
}

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

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

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

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

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

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

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

.grid--auto-fill-sm {
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}

.grid--auto-fill-md {
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.grid--auto-fill-lg {
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
}

.grid--auto-fit-sm {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.grid--auto-fit-md {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.grid--auto-fit-lg {
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
}

.grid--gap-sm {
  gap: var(--space-4);
}

.grid--gap-md {
  gap: var(--space-6);
}

.grid--gap-lg {
  gap: var(--space-8);
}

.grid--gap-xl {
  gap: var(--space-12);
}

.grid--align-start {
  align-items: start;
}

.grid--align-center {
  align-items: center;
}

.grid--align-end {
  align-items: end;
}

.grid--align-stretch {
  align-items: stretch;
}

.col-span-2 {
  grid-column: span 2;
}

.col-span-3 {
  grid-column: span 3;
}

.col-span-4 {
  grid-column: span 4;
}

.col-span-full {
  grid-column: 1 / -1;
}

.row-span-2 {
  grid-row: span 2;
}

.row-span-3 {
  grid-row: span 3;
}

@media (max-width: 1199px) {
  .grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }

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

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

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

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

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

  .col-span-2,
  .col-span-3,
  .col-span-4 {
    grid-column: span 1;
  }
}

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

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

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

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

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

  .grid--auto-fill-sm,
  .grid--auto-fill-md,
  .grid--auto-fill-lg,
  .grid--auto-fit-sm,
  .grid--auto-fit-md,
  .grid--auto-fit-lg {
    grid-template-columns: 1fr;
  }

  .grid--gap-lg {
    gap: var(--space-6);
  }

  .grid--gap-xl {
    gap: var(--space-8);
  }
}

@media (min-width: 480px) and (max-width: 767px) {
  .grid--auto-fill-sm,
  .grid--auto-fit-sm {
    grid-template-columns: repeat(2, 1fr);
  }
}

.card {
  background-color: var(--c-bg-card);
  border-radius: var(--radius-xl);
  border: 1px solid var(--c-border);
  box-shadow: var(--c-shadow-sm);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.28s cubic-bezier(0.34, 1.56, 0.64, 1),
              box-shadow 0.28s ease,
              border-color 0.28s ease;
  position: relative;
  will-change: transform;
}

.card:hover {
  transform: translateY(-6px);
  box-shadow: var(--c-shadow-lg);
  border-color: var(--c-primary);
}

.card:focus-within {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 3px;
}

.card--flat {
  box-shadow: none;
  border: 1px solid var(--c-border);
}

.card--flat:hover {
  box-shadow: var(--c-shadow-md);
  transform: translateY(-4px);
}

.card--elevated {
  box-shadow: var(--c-shadow-md);
  border: none;
}

.card--elevated:hover {
  box-shadow: var(--c-shadow-xl);
  transform: translateY(-8px);
}

.card--gold {
  border-top: 3px solid var(--c-gold);
}

.card--gold:hover {
  border-color: var(--c-gold);
  box-shadow: var(--c-shadow-gold);
}

.card--primary {
  border-top: 3px solid var(--c-primary);
}

.card--navy {
  background-color: var(--c-navy);
  border-color: rgba(255, 255, 255, 0.1);
  color: var(--c-white);
}

.card--navy:hover {
  border-color: var(--c-gold);
  box-shadow: var(--c-shadow-gold);
}

.card--sage {
  background-color: var(--c-sage-tint);
  border-color: rgba(0, 64, 28, 0.12);
}

.card--sage:hover {
  border-color: var(--c-primary);
  box-shadow: var(--c-shadow-primary);
}

.card--no-hover {
  transition: none;
}

.card--no-hover:hover {
  transform: none;
  box-shadow: var(--c-shadow-sm);
  border-color: var(--c-border);
}

.card--link {
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.card--link:hover .card__title {
  color: var(--c-primary);
}

.card__media {
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}

.card__media--square {
  aspect-ratio: 1 / 1;
}

.card__media--landscape {
  aspect-ratio: 16 / 9;
}

.card__media--portrait {
  aspect-ratio: 3 / 4;
}

.card__media--wide {
  aspect-ratio: 21 / 9;
}

.card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.45s ease;
}

.card:hover .card__media img {
  transform: scale(1.06);
}

.card__media-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 40%,
    rgba(0, 40, 18, 0.65) 100%
  );
  pointer-events: none;
}

.card__badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  border-radius: var(--radius-full);
  line-height: 1;
  z-index: 1;
}

.card__badge--gold {
  background-color: var(--c-gold);
  color: var(--c-charcoal);
}

.card__badge--primary {
  background-color: var(--c-primary);
  color: var(--c-white);
}

.card__badge--amber {
  background-color: var(--c-amber);
  color: var(--c-white);
}

.card__badge--navy {
  background-color: var(--c-navy);
  color: var(--c-white);
}

.card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}

.card__body--sm {
  padding: var(--space-4);
}

.card__body--lg {
  padding: var(--space-8);
}

.card__eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--c-primary);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  line-height: 1;
}

.card--navy .card__eyebrow {
  color: var(--c-gold);
}

.card__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--c-charcoal);
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight);
  margin: 0;
  transition: color 0.2s ease;
}

.card--navy .card__title {
  color: var(--c-white);
}

.card__title--sm {
  font-size: var(--text-lg);
}

.card__title--lg {
  font-size: var(--text-2xl);
}

.card__excerpt {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-regular);
  color: var(--c-text-secondary);
  line-height: var(--leading-relaxed);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card--navy .card__excerpt {
  color: rgba(255, 255, 255, 0.7);
}

.card__excerpt--unclamped {
  display: block;
  overflow: visible;
  -webkit-line-clamp: unset;
}

.card__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--c-text-muted);
  letter-spacing: var(--tracking-wide);
}

.card__meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.card__meta-item svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  stroke: currentColor;
  fill: none;
}

.card__footer {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--c-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-shrink: 0;
}

.card--navy .card__footer {
  border-top-color: rgba(255, 255, 255, 0.1);
}

.card__footer--sm {
  padding: var(--space-3) var(--space-4);
}

.card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--c-primary);
  text-decoration: none;
  letter-spacing: var(--tracking-wide);
  transition: gap 0.2s ease, color 0.2s ease;
  min-height: 44px;
}

.card__link:hover,
.card__link:focus-visible {
  color: var(--c-leaf);
  gap: var(--space-3);
  outline: none;
}

.card__link:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.card__link svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  stroke: currentColor;
  fill: none;
  transition: transform 0.2s ease;
}

.card__link:hover svg {
  transform: translateX(3px);
}

.card--navy .card__link {
  color: var(--c-gold);
}

.card--navy .card__link:hover {
  color: var(--c-gold-light);
}

.card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
  background-color: var(--c-sage-tint);
  flex-shrink: 0;
  transition: background-color 0.25s ease, transform 0.25s ease;
}

.card__icon svg {
  width: 28px;
  height: 28px;
  stroke: var(--c-primary);
  fill: none;
  flex-shrink: 0;
}

.card:hover .card__icon {
  background-color: var(--c-primary);
  transform: scale(1.08);
}

.card:hover .card__icon svg {
  stroke: var(--c-white);
}

.card--navy .card__icon {
  background-color: rgba(255, 255, 255, 0.1);
}

.card--navy .card__icon svg {
  stroke: var(--c-gold);
}

.card--navy:hover .card__icon {
  background-color: var(--c-gold);
}

.card--navy:hover .card__icon svg {
  stroke: var(--c-charcoal);
}

.card__icon--sm {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
}

.card__icon--sm svg {
  width: 22px;
  height: 22px;
}

.card__icon--lg {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-xl);
}

.card__icon--lg svg {
  width: 36px;
  height: 36px;
}

.card__icon--gold {
  background-color: rgba(201, 168, 76, 0.15);
}

.card__icon--gold svg {
  stroke: var(--c-gold-dark);
}

.card:hover .card__icon--gold {
  background-color: var(--c-gold);
}

.card:hover .card__icon--gold svg {
  stroke: var(--c-white);
}

.card__divider {
  width: 40px;
  height: 3px;
  background: linear-gradient(90deg, var(--c-gold), var(--c-gold-light));
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.card__tag {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--c-primary);
  background-color: var(--c-sage-tint);
  border: 1px solid rgba(0, 64, 28, 0.15);
  border-radius: var(--radius-full);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  line-height: 1;
  white-space: nowrap;
}

.card--navy .card__tag {
  color: var(--c-gold);
  background-color: rgba(201, 168, 76, 0.12);
  border-color: rgba(201, 168, 76, 0.25);
}

@media (max-width: 767px) {
  .card__body {
    padding: var(--space-5);
  }

  .card__body--lg {
    padding: var(--space-6);
  }

  .card__footer {
    padding: var(--space-4) var(--space-5);
  }
}

.footer {
  background-color: var(--c-navy);
  color: var(--c-white);
  font-family: var(--font-body);
  width: 100%;
}

.footer__top {
  padding: var(--space-20) var(--space-6) var(--space-16);
  max-width: 1440px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: var(--space-10);
  align-items: start;
}

.footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.footer__logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  width: fit-content;
}

.footer__logo-img {
  height: 52px;
  width: auto;
  object-fit: contain;
  display: block;
  filter: brightness(0) invert(1);
}

.footer__logo-name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--fw-bold);
  color: var(--c-white);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
}

.footer__tagline {
  font-size: var(--text-sm);
  font-weight: var(--fw-regular);
  color: rgba(255, 255, 255, 0.65);
  line-height: var(--leading-relaxed);
  max-width: 32ch;
}

.footer__affiliation {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background-color: rgba(201, 168, 76, 0.12);
  border: 1px solid rgba(201, 168, 76, 0.25);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: var(--c-gold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  width: fit-content;
}

.footer__affiliation::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  background-color: var(--c-gold);
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.footer__col-heading {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--c-gold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  margin: 0 0 var(--space-5) 0;
  padding-bottom: var(--space-3);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  position: relative;
}

.footer__col-heading::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 32px;
  height: 2px;
  background-color: var(--c-gold);
  border-radius: var(--radius-full);
}

.footer__nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.footer__nav-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
  font-weight: var(--fw-regular);
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  line-height: var(--leading-normal);
  transition: color 0.2s ease, padding-left 0.2s ease;
  min-height: 44px;
  border-radius: var(--radius-sm);
}

.footer__nav-link::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 4px;
  background-color: var(--c-gold);
  border-radius: var(--radius-full);
  flex-shrink: 0;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.footer__nav-link:hover,
.footer__nav-link:focus-visible { color: var(--c-white);
  padding-left: var(--space-2);
  outline: none;
}

.footer__nav-link:hover::before,
.footer__nav-link:focus-visible::before {
  opacity: 1;
}

.footer__nav-link:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 2px;
}

.footer__contact-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer__contact-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.footer__contact-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background-color: rgba(201, 168, 76, 0.12);
  border: 1px solid rgba(201, 168, 76, 0.2);
  border-radius: var(--radius-md);
  flex-shrink: 0;
  margin-top: 2px;
}

.footer__contact-icon svg {
  width: 16px;
  height: 16px;
  stroke: var(--c-gold);
  fill: none;
  flex-shrink: 0;
}

.footer__contact-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.footer__contact-label {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--c-gold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  line-height: 1;
}

.footer__contact-value {
  font-size: var(--text-sm);
  font-weight: var(--fw-regular);
  color: rgba(255, 255, 255, 0.75);
  line-height: var(--leading-normal);
  text-decoration: none;
  transition: color 0.2s ease;
}

a.footer__contact-value:hover,
a.footer__contact-value:focus-visible {
  color: var(--c-white);
  outline: none;
}

a.footer__contact-value:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.footer__map-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: var(--c-gold);
  text-decoration: none;
  border: 1px solid rgba(201, 168, 76, 0.3);
  border-radius: var(--radius-md);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  transition: background-color 0.2s ease, color 0.2s ease;
  min-height: 44px;
  width: fit-content;
}

.footer__map-link:hover,
.footer__map-link:focus-visible {
  background-color: rgba(201, 168, 76, 0.15);
  color: var(--c-gold-light);
  outline: none;
}

.footer__map-link:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 2px;
}

.footer__map-link svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  fill: none;
  flex-shrink: 0;
}

.footer__social {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer__social-label {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: rgba(255, 255, 255, 0.5);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
}

.footer__social-icons {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background-color: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.footer__social-link svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  flex-shrink: 0;
}

.footer__social-link:hover,
.footer__social-link:focus-visible {
  background-color: var(--c-gold);
  border-color: var(--c-gold);
  color: var(--c-charcoal);
  transform: translateY(-3px);
  outline: none;
}

.footer__social-link:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 3px;
}

.footer__social-link--facebook:hover {
  background-color: #1877F2;
  border-color: #1877F2;
  color: var(--c-white);
}

.footer__social-link--instagram:hover {
  background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
  border-color: #dc2743;
  color: var(--c-white);
}

.footer__social-link--youtube:hover {
  background-color: #FF0000;
  border-color: #FF0000;
  color: var(--c-white);
}

.footer__social-link--linkedin:hover {
  background-color: #0A66C2;
  border-color: #0A66C2;
  color: var(--c-white);
}

.footer__mid {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding: var(--space-8) var(--space-6);
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.footer__accreditation {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer__accreditation-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: rgba(255, 255, 255, 0.65);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  white-space: nowrap;
}

.footer__accreditation-badge svg {
  width: 16px;
  height: 16px;
  stroke: var(--c-gold);
  fill: none;
  flex-shrink: 0;
}

.footer__newsletter {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.footer__newsletter-label {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: rgba(255, 255, 255, 0.8);
  white-space: nowrap;
}

.footer__newsletter-form {
  display: flex;
  align-items: center;
  gap: 0;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-md);
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0.05);
  transition: border-color 0.2s ease;
}

.footer__newsletter-form:focus-within {
  border-color: var(--c-gold);
}

.footer__newsletter-input {
  flex: 1;
  min-width: 200px;
  padding: var(--space-3) var(--space-4);
  background: transparent;
  border: none;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--c-white);
  outline: none;
  min-height: 44px;
}

.footer__newsletter-input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.footer__newsletter-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3) var(--space-5);
  background-color: var(--c-gold);
  color: var(--c-charcoal);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  min-height: 44px;
  white-space: nowrap;
  transition: background-color 0.2s ease;
  flex-shrink: 0;
}

.footer__newsletter-btn:hover,
.footer__newsletter-btn:focus-visible {
  background-color: var(--c-gold-light);
  outline: none;
}

.footer__newsletter-btn:focus-visible {
  outline: 2px solid var(--c-white);
  outline-offset: 2px;
}

.footer__bottom {
  background-color: var(--c-navy-dark);
  padding: var(--space-5) var(--space-6);
}

.footer__bottom-inner {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer__copyright {
  font-size: var(--text-xs);
  font-weight: var(--fw-regular);
  color: rgba(255, 255, 255, 0.5);
  line-height: var(--leading-normal);
}

.footer__copyright strong {
  color: rgba(255, 255, 255, 0.75);
  font-weight: var(--fw-semibold);
}

.footer__legal-links {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap;
}

.footer__legal-links li {
  display: flex;
  align-items: center;
}

.footer__legal-links li + li::before {
  content: '';
  display: inline-block;
  width: 1px;
  height: 12px;
  background-color: rgba(255, 255, 255, 0.2);
  margin: 0 var(--space-2);
}

.footer__legal-link {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-2);
  font-size: var(--text-xs);
  font-weight: var(--fw-regular);
  color: rgba(255, 255, 255, 0.45);
  text-decoration: none;
  transition: color 0.2s ease;
  min-height: 44px;
  border-radius: var(--radius-sm);
}

.footer__legal-link:hover,
.footer__legal-link:focus-visible {
  color: var(--c-gold);
  outline: none;
}

.footer__legal-link:focus-visible {
  outline: 2px solid var(--c-gold);
  outline-offset: 2px;
}

.footer__cookie-notice {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.35);
  line-height: var(--leading-normal);
}

@media (max-width: 1199px) {
  .footer__top {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }

  .footer__brand {
    grid-column: 1 / -1;
    flex-direction: row;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: var(--space-8);
  }

  .footer__tagline {
    max-width: 48ch;
  }
}

@media (max-width: 767px) {
  .footer__top {
    grid-template-columns: 1fr;
    padding: var(--space-12) var(--space-4) var(--space-10);
    gap: var(--space-8);
  }

  .footer__brand {
    flex-direction: column;
    gap: var(--space-4);
  }

  .footer__mid {
    flex-direction: column;
    align-items: flex-start;
    padding: var(--space-6) var(--space-4);
    gap: var(--space-5);
  }

  .footer__newsletter {
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
  }

  .footer__newsletter-form {
    width: 100%;
  }

  .footer__newsletter-input {
    min-width: 0;
    flex: 1;
  }

  .footer__bottom {
    padding: var(--space-4);
  }

  .footer__bottom-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .footer__legal-links {
    gap: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .hero__bg-img {
    animation: none;
    transform: none;
  }

  .hero__illustrated-overlay svg,
  .hero__illustrated-overlay img {
    animation: none;
  }

  .hero__scroll-cue {
    animation: none;
  }

  .announcement-bar__inner {
    animation: none;
  }

  .card {
    transition: box-shadow 0.01ms, border-color 0.01ms;
  }

  .card:hover {
    transform: none;
  }

  img[loading="lazy"] {
    opacity: 1;
    transition: none;
  }
}

@media (prefers-color-scheme: dark) {
  .card {
    background-color: var(--c-bg-card);
  }
}

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

.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-4);
  z-index: 9999;
  display: inline-flex;
  align-items: center;
  padding: var(--space-3) var(--space-6);
  background-color: var(--c-primary);
  color: var(--c-white);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  text-decoration: none;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  transition: top 0.2s ease;
  min-height: 44px;
}

.skip-link:focus {
  top: 0;
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
}

:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 3px;
}

:focus:not(:focus-visible) {
  outline: none;
}

/* ===== */

:root {
  --c-primary: #00401C;
  --c-primary-dark: #002d13;
  --c-primary-light: #005a28;
  --c-sage-tint: #E8F2EC;
  --c-navy: #1A2B4A;
  --c-navy-dark: #111d33;
  --c-gold: #C9A84C;
  --c-gold-light: #d9bc72;
  --c-gold-dark: #a8883a;
  --c-off-white: #F8F9FA;
  --c-silver: #E1E1E1;
  --c-slate: #6B7280;
  --c-charcoal: #1C1C1C;
  --c-leaf: #2D7A4F;
  --c-alert: #C0392B;
  --c-amber: #E67E22;
  --c-sky: #2980B9;
  --c-white: #FFFFFF;
  --c-black: #000000;
  --c-text-primary: #1C1C1C;
  --c-text-secondary: #6B7280;
  --c-text-inverse: #FFFFFF;
  --c-text-muted: #9CA3AF;
  --c-text-link: #00401C;
  --c-text-link-hover: #2D7A4F;
  --c-bg-body: #F8F9FA;
  --c-bg-card: #FFFFFF;
  --c-bg-section-alt: #E8F2EC;
  --c-bg-dark: #1A2B4A;
  --c-border: #E1E1E1;
  --c-border-focus: #00401C;
  --c-border-error: #C0392B;
  --c-border-success: #2D7A4F;
  --c-shadow-sm: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.05);
  --c-shadow-md: 0 4px 12px rgba(0,0,0,0.10), 0 2px 6px rgba(0,0,0,0.06);
  --c-shadow-lg: 0 10px 30px rgba(0,0,0,0.12), 0 4px 12px rgba(0,0,0,0.08);
  --c-shadow-xl: 0 20px 50px rgba(0,0,0,0.15), 0 8px 20px rgba(0,0,0,0.10);
  --c-shadow-gold: 0 4px 20px rgba(201,168,76,0.30);
  --c-shadow-primary: 0 4px 20px rgba(0,64,28,0.30);
  --font-display: 'Merienda', Georgia, 'Times New Roman', serif;
  --font-body: Tahoma, Verdana, Geneva, sans-serif;
  --font-mono: 'Courier New', Courier, monospace;
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-md: 1.0625rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;
  --text-6xl: 3.75rem;
  --leading-tight: 1.2;
  --leading-snug: 1.35;
  --leading-normal: 1.6;
  --leading-relaxed: 1.75;
  --tracking-tight: -0.02em;
  --tracking-normal: 0em;
  --tracking-wide: 0.04em;
  --tracking-wider: 0.08em;
  --tracking-widest: 0.12em;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-extrabold: 800;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-7: 1.75rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-14: 3.5rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-full: 9999px;
}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   FOCUS-VISIBLE ACCESSIBILITY
   ============================================================ */

*:focus {
  outline: none;
}

*:focus-visible {
  outline: 3px solid var(--c-border-focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
  box-shadow: 0 0 0 5px rgba(0, 64, 28, 0.18);
  transition: outline-offset 0.1s ease, box-shadow 0.1s ease;
}

a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid var(--c-border-focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
  box-shadow: 0 0 0 5px rgba(0, 64, 28, 0.18);
}

.btn:focus-visible,
.cta-btn:focus-visible,
.btn-primary:focus-visible,
.btn-secondary:focus-visible,
.btn-ghost:focus-visible,
.btn-gold:focus-visible,
.nav-cta:focus-visible,
[class*="btn-oct"]:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 4px;
  box-shadow: 0 0 0 6px rgba(201, 168, 76, 0.28);
}

.nav-link:focus-visible,
.mega-link:focus-visible,
.footer-link:focus-visible,
.utility-link:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
  box-shadow: 0 0 0 5px rgba(201, 168, 76, 0.22);
  text-decoration: underline;
}

input[type="text"]:focus-visible,
input[type="email"]:focus-visible,
input[type="tel"]:focus-visible,
input[type="number"]:focus-visible,
input[type="password"]:focus-visible,
input[type="search"]:focus-visible,
input[type="date"]:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--c-border-focus);
  outline-offset: 0;
  border-color: var(--c-border-focus);
  box-shadow: 0 0 0 4px rgba(0, 64, 28, 0.15);
  border-radius: var(--radius-md);
}

input[type="checkbox"]:focus-visible,
input[type="radio"]:focus-visible {
  outline: 3px solid var(--c-border-focus);
  outline-offset: 2px;
  box-shadow: 0 0 0 5px rgba(0, 64, 28, 0.18);
}

.card:focus-visible,
.program-card:focus-visible,
.news-card:focus-visible,
.gallery-item:focus-visible,
.testimonial-card:focus-visible {
  outline: 3px solid var(--c-border-focus);
  outline-offset: 4px;
  box-shadow: var(--c-shadow-primary);
  border-radius: var(--radius-lg);
}

.skip-link:focus-visible {
  position: fixed;
  top: var(--space-4);
  left: var(--space-4);
  z-index: 9999;
  padding: var(--space-3) var(--space-6);
  background: var(--c-primary);
  color: var(--c-white);
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  border-radius: var(--radius-md);
  outline: 3px solid var(--c-gold);
  outline-offset: 3px;
  box-shadow: var(--c-shadow-lg);
  text-decoration: none;
}

.announcement-bar a:focus-visible {
  outline: 2px solid var(--c-white);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
  box-shadow: none;
}

.social-icon:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 3px;
  border-radius: var(--radius-full);
  box-shadow: 0 0 0 5px rgba(201, 168, 76, 0.22);
}

.accordion-trigger:focus-visible {
  outline: 3px solid var(--c-border-focus);
  outline-offset: 2px;
  border-radius: var(--radius-md);
  box-shadow: 0 0 0 5px rgba(0, 64, 28, 0.15);
}

.tab-btn:focus-visible,
[role="tab"]:focus-visible {
  outline: 3px solid var(--c-border-focus);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
  box-shadow: 0 0 0 5px rgba(0, 64, 28, 0.15);
}

.slider-prev:focus-visible,
.slider-next:focus-visible,
.carousel-btn:focus-visible,
[class*="swiper-button"]:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 3px;
  border-radius: var(--radius-full);
  box-shadow: 0 0 0 5px rgba(201, 168, 76, 0.22);
}

.nav-toggle:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
  box-shadow: 0 0 0 5px rgba(201, 168, 76, 0.22);
}

/* ============================================================
   MOBILE NAV TOGGLE — BASE STATE (hidden above breakpoints)
   ============================================================ */

.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  background: transparent;
  border: 2px solid var(--c-primary);
  border-radius: var(--radius-md);
  cursor: pointer;
  padding: var(--space-2);
  flex-shrink: 0;
  transition: background 0.2s ease, border-color 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}

.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--c-primary);
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease, width 0.3s ease;
  transform-origin: center;
}

.nav-toggle:hover {
  background: var(--c-sage-tint);
  border-color: var(--c-primary-dark);
}

header.nav-open .nav-toggle span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

header.nav-open .nav-toggle span:nth-child(2) {
  opacity: 0;
  width: 0;
}

header.nav-open .nav-toggle span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ============================================================
   1024px — TABLET LANDSCAPE / SMALL DESKTOP
   ============================================================ */

@media (max-width: 1024px) {

  /* --- Typography Scale --- */
  :root {
    --text-6xl: 3rem;
    --text-5xl: 2.5rem;
    --text-4xl: 2rem;
    --text-3xl: 1.625rem;
    --text-2xl: 1.375rem;
    --text-xl: 1.1875rem;
  }

  /* --- Spacing Adjustments --- */
  :root {
    --space-32: 6rem;
    --space-24: 5rem;
    --space-20: 4rem;
    --space-16: 3.5rem;
  }

  /* --- Navigation --- */
  .nav-toggle {
    display: flex;
  }

  .site-nav,
  .nav-primary,
  .nav-menu,
  nav.main-nav {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100dvh;
    background: var(--c-white);
    z-index: 9990;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 80px var(--space-6) var(--space-8);
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    transform: translateX(100%);
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1),
                opacity 0.35s ease;
    opacity: 0;
    -webkit-overflow-scrolling: touch;
  }

  header.nav-open .site-nav,
  header.nav-open .nav-primary,
  header.nav-open .nav-menu,
  header.nav-open nav.main-nav {
    display: flex;
    transform: translateX(0);
    opacity: 1;
  }

  .nav-item,
  .nav-primary > li,
  .nav-menu > li {
    border-bottom: 1px solid var(--c-border);
    width: 100%;
  }

  .nav-link,
  .nav-primary > li > a,
  .nav-menu > li > a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4) var(--space-2);
    font-size: var(--text-lg);
    font-weight: var(--fw-semibold);
    color: var(--c-text-primary);
    text-decoration: none;
    min-height: 44px;
    width: 100%;
  }

  .nav-link:hover,
  .nav-primary > li > a:hover {
    color: var(--c-primary);
    background: var(--c-sage-tint);
    padding-left: var(--space-4);
  }

  /* Mega menus hidden on mobile/tablet */
  .mega-menu,
  .dropdown-menu,
  .nav-dropdown,
  [class*="mega-"] {
    display: none !important;
  }

  /* Mobile nav priority items */
  .nav-mobile-admissions,
  .nav-mobile-portal {
    order: -1;
  }

  .nav-cta-wrap,
  .nav-actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-6) var(--space-2) var(--space-4);
    width: 100%;
  }

  .nav-cta,
  .btn-apply-now {
    width: 100%;
    text-align: center;
    justify-content: center;
    min-height: 48px;
    font-size: var(--text-base);
  }

  .parents-portal-link {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-3) var(--space-4);
    background: var(--c-sage-tint);
    color: var(--c-primary);
    font-weight: var(--fw-semibold);
    border-radius: var(--radius-md);
    min-height: 44px;
    text-decoration: none;
    width: 100%;
  }

  /* Utility strip collapses */
  .utility-strip,
  .nav-utility {
    display: none;
  }

  /* Header layout */
  .site-header,
  header.site-header {
    padding: 0 var(--space-4);
  }

  .header-inner,
  .nav-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 68px;
    gap: var(--space-3);
  }

  .site-logo img,
  .logo img {
    max-height: 52px;
    width: auto;
  }

  /* Announcement bar */
  .announcement-bar {
    font-size: var(--text-xs);
    padding: var(--space-2) var(--space-4);
  }

  /* --- Grids --- */
  .grid-4,
  .grid-cols-4,
  [class*="col-4"] {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  .grid-3,
  .grid-cols-3,
  [class*="col-3"] {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  .grid-5,
  .grid-cols-5 {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
  }

  .footer-grid,
  .footer-columns {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8) var(--space-6);
  }

  /* --- Hero --- */
  .hero-section,
  .hero {
    min-height: 80vh;
    padding: var(--space-20) var(--space-6) var(--space-16);
  }

  .hero-content,
  .hero-text {
    max-width: 600px;
  }

  .hero-title,
  .hero h1 {
    font-size: var(--text-5xl);
  }

  .hero-subtitle,
  .hero-desc {
    font-size: var(--text-lg);
  }

  /* --- Stats Band --- */
  .stats-band,
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  /* --- Sections --- */
  .section-pad,
  .section {
    padding-top: var(--space-16);
    padding-bottom: var(--space-16);
  }

  .container,
  .container-xl {
    padding-left: var(--space-6);
    padding-right: var(--space-6);
  }

  /* --- Cards --- */
  .card-grid,
  .cards-row {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  /* --- Two-col layouts --- */
  .two-col,
  .split-layout,
  .content-media {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }

  /* --- Gallery --- */
  .gallery-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
  }

  /* --- Testimonials --- */
  .testimonial-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  /* --- Programs / Academics --- */
  .programs-grid,
  .academics-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  /* --- Fee Table --- */
  .fee-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* --- Chatbot --- */
  .chatbot-widget {
    bottom: var(--space-4);
    right: var(--space-4);
  }

  /* --- Exit Intent / Popup --- */
  .exit-popup,
  .modal-dialog {
    max-width: 90vw;
    margin: var(--space-4) auto;
  }
}

/* ============================================================
   768px — TABLET PORTRAIT
   ============================================================ */

@media (max-width: 768px) {

  /* --- Typography Scale --- */
  :root {
    --text-6xl: 2.5rem;
    --text-5xl: 2.125rem;
    --text-4xl: 1.75rem;
    --text-3xl: 1.5rem;
    --text-2xl: 1.25rem;
    --text-xl: 1.125rem;
    --text-lg: 1.0625rem;
    --text-md: 1rem;
  }

  /* --- Spacing --- */
  :root {
    --space-32: 5rem;
    --space-24: 4rem;
    --space-20: 3.5rem;
    --space-16: 3rem;
    --space-14: 2.75rem;
    --space-12: 2.5rem;
  }

  /* --- Header --- */
  .site-header,
  header.site-header {
    padding: 0 var(--space-4);
  }

  .header-inner,
  .nav-container {
    height: 62px;
    gap: var(--space-2);
  }

  .site-logo img,
  .logo img {
    max-height: 46px;
    width: auto;
  }

  /* --- Announcement Bar --- */
  .announcement-bar {
    font-size: var(--text-xs);
    padding: var(--space-1) var(--space-3);
    white-space: nowrap;
    overflow: hidden;
  }

  .announcement-bar .announcement-text {
    display: inline-block;
    animation: marquee-scroll 28s linear infinite;
    white-space: nowrap;
    padding-left: 100%;
  }

  @keyframes marquee-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-100%); }
  }

  .announcement-bar .dismiss-btn {
    flex-shrink: 0;
    min-width: 44px;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* --- Navigation --- */
  .site-nav,
  .nav-primary,
  .nav-menu,
  nav.main-nav {
    padding: 70px var(--space-5) var(--space-8);
  }

  .nav-link,
  .nav-primary > li > a,
  .nav-menu > li > a {
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-2);
  }

  /* --- Container --- */
  .container,
  .container-xl,
  .container-lg {
    padding-left: var(--space-5);
    padding-right: var(--space-5);
    max-width: 100%;
  }

  /* --- Sections --- */
  .section-pad,
  .section {
    padding-top: var(--space-14);
    padding-bottom: var(--space-14);
  }

  .section-header,
  .section-title-wrap {
    margin-bottom: var(--space-8);
    text-align: center;
  }

  .section-eyebrow,
  .eyebrow {
    font-size: var(--text-xs);
    letter-spacing: var(--tracking-widest);
  }

  .section-title,
  .section h2 {
    font-size: var(--text-3xl);
  }

  .section-subtitle,
  .section-desc {
    font-size: var(--text-base);
    max-width: 100%;
  }

  /* --- Hero --- */
  .hero-section,
  .hero {
    min-height: 70vh;
    padding: var(--space-16) var(--space-5) var(--space-12);
    text-align: center;
    align-items: center;
  }

  .hero-content,
  .hero-text {
    max-width: 100%;
    text-align: center;
  }

  .hero-title,
  .hero h1 {
    font-size: var(--text-4xl);
    line-height: var(--leading-tight);
  }

  .hero-subtitle,
  .hero-desc {
    font-size: var(--text-base);
    max-width: 540px;
    margin-left: auto;
    margin-right: auto;
  }

  .hero-cta-group,
  .hero-actions {
    flex-direction: column;
    align-items: center;
    gap: var(--space-3);
    width: 100%;
  }

  .hero-cta-group .btn,
  .hero-actions .btn,
  .hero-cta-group .cta-btn,
  .hero-actions .cta-btn {
    width: 100%;
    max-width: 320px;
    justify-content: center;
    text-align: center;
  }

  .hero-badge,
  .hero-trust-badge {
    margin-left: auto;
    margin-right: auto;
  }

  /* Hero illustrated overlay parallax */
  .hero-overlay-illustration,
  .hero-animated-overlay {
    opacity: 0.18;
    pointer-events: none;
  }

  /* --- Stats Band --- */
  .stats-band,
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
    padding: var(--space-10) var(--space-5);
  }

  .stat-item {
    padding: var(--space-5) var(--space-4);
  }

  .stat-number,
  .count-up {
    font-size: var(--text-4xl);
  }

  .stat-label {
    font-size: var(--text-sm);
  }

  /* --- Grids --- */
  .grid-4,
  .grid-cols-4,
  [class*="col-4"] {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
  }

  .grid-3,
  .grid-cols-3,
  [class*="col-3"] {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

  .grid-5,
  .grid-cols-5 {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }

  .grid-2,
  .grid-cols-2,
  [class*="col-2"] {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

  /* --- Two-col / Split layouts --- */
  .two-col,
  .split-layout,
  .content-media,
  .about-split,
  .feature-split {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .two-col .media-col,
  .split-layout .media-col,
  .content-media .media-col {
    order: -1;
  }

  .two-col img,
  .split-layout img,
  .content-media img,
  .feature-split img {
    width: 100%;
    height: auto;
    max-height: 380px;
    object-fit: cover;
    border-radius: var(--radius-lg);
  }

  /* --- Cards --- */
  .card-grid,
  .cards-row {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

  .card,
  .program-card,
  .news-card,
  .feature-card {
    width: 100%;
  }

  /* --- Programs / Academics --- */
  .programs-grid,
  .academics-grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

  .program-card {
    display: grid;
    grid-template-columns: 80px 1fr;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-5);
  }

  .program-card .card-icon {
    width: 64px;
    height: 64px;
    flex-shrink: 0;
  }

  /* --- Testimonials --- */
  .testimonial-grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

  .testimonial-slider,
  .testimonial-carousel {
    overflow: hidden;
  }

  .testimonial-track {
    display: flex;
    transition: transform 0.4s ease;
  }

  .testimonial-card {
    flex: 0 0 100%;
    width: 100%;
  }

  /* --- Gallery --- */
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-2);
  }

  .gallery-item.featured,
  .gallery-item.span-2 {
    grid-column: span 2;
  }

  /* --- Footer --- */
  .footer-grid,
  .footer-columns {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8) var(--space-5);
  }

  .footer-col:last-child {
    grid-column: span 2;
  }

  .footer-bottom,
  .footer-bar {
    flex-direction: column;
    gap: var(--space-3);
    text-align: center;
  }

  .footer-legal-links {
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-3);
  }

  .footer-map-embed {
    height: 200px;
    width: 100%;
  }

  .footer-map-embed iframe {
    width: 100%;
    height: 100%;
    border-radius: var(--radius-md);
  }

  /* --- Accordion --- */
  .accordion-item {
    border-radius: var(--radius-md);
  }

  .accordion-trigger {
    padding: var(--space-4) var(--space-5);
    font-size: var(--text-base);
    min-height: 44px;
  }

  .accordion-body {
    padding: 0 var(--space-5) var(--space-4);
    font-size: var(--text-sm);
  }

  /* --- Tabs --- */
  .tabs-nav,
  .tab-list {
    flex-wrap: wrap;
    gap: var(--space-2);
    justify-content: center;
  }

  .tab-btn,
  [role="tab"] {
    font-size: var(--text-sm);
    padding: var(--space-2) var(--space-4);
    min-height: 44px;
  }

  /* --- Fee Table --- */
  .fee-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: var(--radius-md);
    box-shadow: var(--c-shadow-sm);
  }

  .fee-table {
    min-width: 560px;
    font-size: var(--text-sm);
  }

  .fee-table th,
  .fee-table td {
    padding: var(--space-3) var(--space-4);
  }

  /* --- Forms --- */
  .form-grid,
  .form-row {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .form-group {
    width: 100%;
  }

  .form-input,
  .form-select,
  .form-textarea {
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-4);
    min-height: 44px;
    width: 100%;
  }

  .form-submit,
  .form-cta {
    width: 100%;
    min-height: 52px;
    font-size: var(--text-base);
    justify-content: center;
  }

  /* --- Admission Steps --- */
  .steps-grid,
  .admission-steps {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

  .step-connector,
  .steps-line {
    display: none;
  }

  /* --- Principal / Leadership --- */
  .principal-layout,
  .leadership-grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    text-align: center;
  }

  .principal-photo,
  .leader-photo {
    margin: 0 auto;
    max-width: 240px;
  }

  /* --- Awards / Badges --- */
  .awards-grid,
  .badges-row {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }

  /* --- Blog / News --- */
  .blog-grid,
  .news-grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .blog-card,
  .news-card {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: var(--space-4);
    align-items: start;
  }

  .blog-card .card-thumb,
  .news-card .card-thumb {
    width: 120px;
    height: 90px;
    object-fit: cover;
    border-radius: var(--radius-md);
    flex-shrink: 0;
  }

  /* --- WhatsApp / CTA floats --- */
  .whatsapp-float,
  .whatsapp-cta {
    bottom: var(--space-16);
    right: var(--space-4);
    width: 52px;
    height: 52px;
  }

  .chatbot-widget {
    bottom: var(--space-4);
    right: var(--space-4);
  }

  /* --- Exit Intent Popup --- */
  .exit-popup,
  .modal-dialog {
    max-width: 94vw;
    padding: var(--space-6);
    margin: var(--space-4) auto;
    border-radius: var(--radius-xl);
  }

  .exit-popup .popup-title {
    font-size: var(--text-2xl);
  }

  .exit-popup .popup-form {
    flex-direction: column;
    gap: var(--space-3);
  }

  .exit-popup .popup-form input,
  .exit-popup .popup-form .btn {
    width: 100%;
  }

  /* --- Cookie Banner --- */
  .cookie-banner {
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    text-align: center;
  }

  .cookie-banner .cookie-actions {
    flex-direction: row;
    justify-content: center;
    gap: var(--space-3);
    width: 100%;
  }

  /* --- Utility Strip (hidden at 768) --- */
  .utility-strip,
  .nav-utility {
    display: none;
  }

  /* --- Reveal stagger delay reduction --- */
  .reveal:nth-child(2) { transition-delay: 0.05s; }
  .reveal:nth-child(3) { transition-delay: 0.10s; }
  .reveal:nth-child(4) { transition-delay: 0.15s; }
  .reveal:nth-child(n+5) { transition-delay: 0.18s; }
}

/* ============================================================
   480px — MOBILE PORTRAIT
   ============================================================ */

@media (max-width: 480px) {

  /* --- Typography Scale --- */
  :root {
    --text-6xl: 2rem;
    --text-5xl: 1.875rem;
    --text-4xl: 1.625rem;
    --text-3xl: 1.375rem;
    --text-2xl: 1.1875rem;
    --text-xl: 1.0625rem;
    --text-lg: 1rem;
    --text-md: 0.9375rem;
    --text-base: 0.9375rem;
    --text-sm: 0.8125rem;
  }

  /* --- Spacing --- */
  :root {
    --space-32: 4rem;
    --space-24: 3.5rem;
    --space-20: 3rem;
    --space-16: 2.5rem;
    --space-14: 2.25rem;
    --space-12: 2rem;
    --space-10: 2rem;
  }

  /* --- Container --- */
  .container,
  .container-xl,
  .container-lg {
    padding-left: var(--space-4);
    padding-right: var(--space-4);
  }

  /* --- Header --- */
  .site-header,
  header.site-header {
    padding: 0 var(--space-3);
  }

  .header-inner,
  .nav-container {
    height: 58px;
    gap: var(--space-2);
  }

  .site-logo img,
  .logo img {
    max-height: 40px;
    width: auto;
  }

  /* --- Announcement Bar --- */
  .announcement-bar {
    font-size: 0.6875rem;
    padding: var(--space-1) var(--space-3);
    line-height: 1.4;
  }

  /* --- Navigation --- */
  .site-nav,
  .nav-primary,
  .nav-menu,
  nav.main-nav {
    padding: 66px var(--space-4) var(--space-8);
  }

  .nav-link,
  .nav-primary > li > a,
  .nav-menu > li > a {
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-1);
    min-height: 48px;
  }

  .nav-toggle {
    width: 44px;
    height: 44px;
  }

  /* --- Sections --- */
  .section-pad,
  .section {
    padding-top: var(--space-12);
    padding-bottom: var(--space-12);
  }

  .section-title,
  .section h2 {
    font-size: var(--text-2xl);
    line-height: var(--leading-snug);
  }

  .section-subtitle,
  .section-desc {
    font-size: var(--text-sm);
  }

  /* --- Hero --- */
  .hero-section,
  .hero {
    min-height: 88vh;
    min-height: 88dvh;
    padding: var(--space-14) var(--space-4) var(--space-10);
    text-align: center;
  }

  .hero-title,
  .hero h1 {
    font-size: var(--text-3xl);
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
  }

  .hero-subtitle,
  .hero-desc {
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
  }

  .hero-cta-group,
  .hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
  }

  .hero-cta-group .btn,
  .hero-actions .btn,
  .hero-cta-group .cta-btn,
  .hero-actions .cta-btn {
    width: 100%;
    max-width: 100%;
    min-height: 52px;
    font-size: var(--text-base);
  }

  /* --- Stats Band --- */
  .stats-band,
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
    padding: var(--space-8) var(--space-4);
  }

  .stat-item {
    padding: var(--space-4) var(--space-3);
    text-align: center;
  }

  .stat-number,
  .count-up {
    font-size: var(--text-3xl);
    line-height: 1;
  }

  .stat-label {
    font-size: var(--text-xs);
    margin-top: var(--space-1);
  }

  /* --- Grids --- */
  .grid-4,
  .grid-cols-4,
  [class*="col-4"],
  .grid-3,
  .grid-cols-3,
  [class*="col-3"],
  .grid-2,
  .grid-cols-2,
  [class*="col-2"],
  .grid-5,
  .grid-cols-5 {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  /* --- Cards --- */
  .card,
  .program-card,
  .news-card,
  .feature-card,
  .testimonial-card {
    padding: var(--space-5) var(--space-4);
    border-radius: var(--radius-lg);
  }

  .program-card {
    grid-template-columns: 60px 1fr;
    gap: var(--space-3);
    padding: var(--space-4);
  }

  .program-card .card-icon {
    width: 52px;
    height: 52px;
  }

  /* --- Gallery --- */
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-2);
  }

  .gallery-item.featured,
  .gallery-item.span-2 {
    grid-column: span 2;
  }

  .gallery-item img {
    aspect-ratio: 4/3;
    object-fit: cover;
    width: 100%;
    border-radius: var(--radius-md);
  }

  /* --- Footer --- */
  .footer-grid,
  .footer-columns {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .footer-col:last-child {
    grid-column: span 1;
  }

  .footer-col h3,
  .footer-col .footer-heading {
    font-size: var(--text-base);
    margin-bottom: var(--space-3);
  }

  .footer-links li,
  .footer-col ul li {
    margin-bottom: var(--space-2);
  }

  .footer-links a,
  .footer-col ul li a {
    font-size: var(--text-sm);
    min-height: 44px;
    display: flex;
    align-items: center;
  }

  .footer-bottom,
  .footer-bar {
    flex-direction: column;
    gap: var(--space-2);
    text-align: center;
    font-size: var(--text-xs);
    padding: var(--space-4) var(--space-4);
  }

  .footer-legal-links {
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-2) var(--space-3);
  }

  .footer-legal-links a {
    font-size: var(--text-xs);
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }

  .footer-social-icons {
    display: flex;
    gap: var(--space-3);
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .social-icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-full);
    min-width: 44px;
    min-height: 44px;
  }

  .footer-map-embed {
    height: 180px;
    width: 100%;
    border-radius: var(--radius-md);
    overflow: hidden;
  }

  .footer-map-embed iframe {
    width: 100%;
    height: 100%;
    border: none;
  }

  /* --- Accordion --- */
  .accordion-trigger {
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    min-height: 48px;
    gap: var(--space-3);
  }

  .accordion-trigger .accordion-icon {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
  }

  .accordion-body {
    padding: 0 var(--space-4) var(--space-4);
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
  }

  /* --- Tabs --- */
  .tabs-nav,
  .tab-list {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-2);
  }

  .tab-btn,
  [role="tab"] {
    width: 100%;
    text-align: center;
    justify-content: center;
    font-size: var(--text-sm);
    min-height: 48px;
    border-radius: var(--radius-md);
  }

  /* --- Fee Table --- */
  .fee-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-left: calc(-1 * var(--space-4));
    margin-right: calc(-1 * var(--space-4));
    padding-left: var(--space-4);
    padding-right: var(--space-4);
    border-radius: 0;
  }

  .fee-table {
    min-width: 480px;
    font-size: var(--text-xs);
  }

  .fee-table th,
  .fee-table td {
    padding: var(--space-2) var(--space-3);
    white-space: nowrap;
  }

  .fee-table th {
    font-size: var(--text-xs);
    letter-spacing: var(--tracking-wide);
  }

  /* --- Forms --- */
  .form-grid,
  .form-row {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .form-input,
  .form-select,
  .form-textarea {
    font-size: var(--text-base);
    padding: var(--space-3) var(--space-4);
    min-height: 48px;
    border-radius: var(--radius-md);
    width: 100%;
    -webkit-appearance: none;
    appearance: none;
  }

  .form-label {
    font-size: var(--text-sm);
    margin-bottom: var(--space-1);
    display: block;
  }

  .form-submit,
  .form-cta {
    width: 100%;
    min-height: 52px;
    font-size: var(--text-base);
    font-weight: var(--fw-semibold);
    justify-content: center;
    text-align: center;
  }

  .form-helper,
  .form-error {
    font-size: var(--text-xs);
    margin-top: var(--space-1);
  }

  /* --- Buttons --- */
  .btn,
  .cta-btn,
  .btn-primary,
  .btn-secondary,
  .btn-ghost,
  .btn-gold,
  [class*="btn-oct"] {
    min-height: 48px;
    font-size: var(--text-sm);
    padding: var(--space-3) var(--space-5);
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .btn-sm {
    min-height: 40px;
    font-size: var(--text-xs);
    padding: var(--space-2) var(--space-4);
    width: auto;
  }

  .btn-inline,
  .btn-text {
    width: auto;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }

  /* --- Blog / News --- */
  .blog-card,
  .news-card {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .blog-card .card-thumb,
  .news-card .card-thumb {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: var(--radius-md);
  }

  .blog-card .card-body,
  .news-card .card-body {
    padding: var(--space-3) 0 0;
  }

  .blog-card .card-title,
  .news-card .card-title {
    font-size: var(--text-base);
    line-height: var(--leading-snug);
  }

  .blog-card .card-excerpt,
  .news-card .card-excerpt {
    font-size: var(--text-sm);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  /* --- Testimonials --- */
  .testimonial-card {
    padding: var(--space-5) var(--space-4);
  }

  .testimonial-quote {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
  }

  .testimonial-author {
    gap: var(--space-3);
    margin-top: var(--space-4);
  }

  .testimonial-avatar {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    border-radius: var(--radius-full);
  }

  .testimonial-name {
    font-size: var(--text-sm);
    font-weight: var(--fw-semibold);
  }

  .testimonial-role {
    font-size: var(--text-xs);
    color: var(--c-text-secondary);
  }

  .slider-controls,
  .carousel-controls {
    display: flex;
    justify-content: center;
    gap: var(--space-3);
    margin-top: var(--space-5);
  }

  .slider-prev,
  .slider-next,
  .carousel-btn {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* --- Awards / Badges --- */
  .awards-grid,
  .badges-row {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
  }

  .award-item,
  .badge-item {
    padding: var(--space-4) var(--space-3);
    text-align: center;
  }

  .award-item img,
  .badge-item img {
    max-height: 56px;
    width: auto;
    margin: 0 auto var(--space-2);
  }

  /* --- Admission Steps --- */
  .steps-grid,
  .admission-steps {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .step-item {
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: var(--space-3);
    align-items: start;
    padding: var(--space-4);
    border-radius: var(--radius-lg);
  }

  .step-number {
    width: 44px;
    height: 44px;
    min-width: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-full);
    font-size: var(--text-base);
    font-weight: var(--fw-bold);
    flex-shrink: 0;
  }

  .step-title {
    font-size: var(--text-base);
    font-weight: var(--fw-semibold);
    margin-bottom: var(--space-1);
  }

  .step-desc {
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
  }

  /* --- Principal / Leadership --- */
  .principal-layout,
  .leadership-grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
    text-align: center;
  }

  .principal-photo,
  .leader-photo {
    max-width: 200px;
    margin: 0 auto;
    border-radius: var(--radius-xl);
  }

  .principal-quote,
  .leader-message {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
  }

  .principal-name,
  .leader-name {
    font-size: var(--text-xl);
  }

  .principal-title,
  .leader-title {
    font-size: var(--text-sm);
  }

  /* --- Trust Strip / Logos --- */
  .trust-strip,
  .partner-logos,
  .affiliation-logos {
    gap: var(--space-5);
    flex-wrap: wrap;
    justify-content: center;
    padding: var(--space-6) var(--space-4);
  }

  .trust-logo,
  .partner-logo,
  .affiliation-logo {
    max-height: 40px;
    width: auto;
    flex-shrink: 0;
  }

  /* --- Notice Board --- */
  .notice-board,
  .notices-list {
    padding: var(--space-4);
    border-radius: var(--radius-lg);
  }

  .notice-item {
    padding: var(--space-3) 0;
    font-size: var(--text-sm);
    border-bottom: 1px solid var(--c-border);
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
  }

  .notice-date {
    font-size: var(--text-xs);
    color: var(--c-text-secondary);
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* --- Contact Page --- */
  .contact-grid,
  .contact-layout {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .contact-info-block {
    padding: var(--space-5) var(--space-4);
    border-radius: var(--radius-lg);
  }

  .contact-info-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-3) 0;
    border-bottom: 1px solid var(--c-border);
    font-size: var(--text-sm);
  }

  .contact-info-icon {
    width: 40px;
    height: 40px;
    min-width: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    flex-shrink: 0;
  }

  .contact-map {
    height: 240px;
    border-radius: var(--radius-lg);
    overflow: hidden;
  }

  .contact-map iframe {
    width: 100%;
    height: 100%;
    border: none;
  }

  /* --- Click-to-call / WhatsApp --- */
  .click-to-call,
  a[href^="tel"] {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    min-height: 44px;
    font-size: var(--text-base);
    font-weight: var(--fw-semibold);
    color: var(--c-primary);
    text-decoration: none;
    -webkit-tap-highlight-color: transparent;
  }

  .whatsapp-float,
  .whatsapp-cta {
    bottom: calc(var(--space-16) + var(--space-4));
    right: var(--space-3);
    width: 50px;
    height: 50px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--c-shadow-lg);
    z-index: 9980;
  }

  .chatbot-widget {
    bottom: var(--space-4);
    right: var(--space-3);
    z-index: 9970;
  }

  /* --- Exit Intent Popup --- */
  .exit-popup,
  .modal-dialog {
    max-width: 96vw;
    width: 96vw;
    padding: var(--space-5) var(--space-4);
    margin: var(--space-3) auto;
    border-radius: var(--radius-xl);
    max-height: 90dvh;
    overflow-y: auto;
  }

  .exit-popup .popup-title {
    font-size: var(--text-xl);
    line-height: var(--leading-snug);
  }

  .exit-popup .popup-subtitle {
    font-size: var(--text-sm);
  }

  .exit-popup .popup-form {
    flex-direction: column;
    gap: var(--space-3);
  }

  .exit-popup .popup-form input {
    width: 100%;
    min-height: 48px;
    font-size: var(--text-base);
    -webkit-appearance: none;
    appearance: none;
  }

  .exit-popup .popup-form .btn {
    width: 100%;
    min-height: 52px;
  }

  .exit-popup .popup-close,
  .modal-close {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-full);
    position: absolute;
    top: var(--space-3);
    right: var(--space-3);
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
  }

  /* --- Cookie Banner --- */
  .cookie-banner {
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-4);
    text-align: center;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 9960;
  }

  .cookie-banner p {
    font-size: var(--text-xs);
    line-height: var(--leading-relaxed);
  }

  .cookie-banner .cookie-actions {
    flex-direction: row;
    justify-content: center;
    gap: var(--space-2);
    flex-wrap: wrap;
  }

  .cookie-banner .btn {
    min-height: 44px;
    font-size: var(--text-xs);
    padding: var(--space-2) var(--space-4);
    width: auto;
    flex: 1;
    max-width: 160px;
  }

  /* --- Breadcrumbs --- */
  .breadcrumb,
  .breadcrumbs {
    font-size: var(--text-xs);
    flex-wrap: wrap;
    gap: var(--space-1);
    padding: var(--space-2) 0;
  }

  .breadcrumb-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);
  }

  /* --- Page Hero / Inner Pages --- */
  .page-hero,
  .inner-hero {
    padding: var(--space-12) var(--space-4) var(--space-10);
    min-height: 220px;
    text-align: center;
  }

  .page-hero h1,
  .inner-hero h1 {
    font-size: var(--text-3xl);
    line-height: var(--leading-tight);
  }

  .page-hero p,
  .inner-hero p {
    font-size: var(--text-sm);
  }

  /* --- Reveal stagger — minimal on small screens --- */
  .reveal:nth-child(2) { transition-delay: 0.03s; }
  .reveal:nth-child(3) { transition-delay: 0.06s; }
  .reveal:nth-child(4) { transition-delay: 0.09s; }
  .reveal:nth-child(n+5) { transition-delay: 0.10s; }

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

    .announcement-bar .announcement-text {
      animation: none;
      padding-left: 0;
    }

    .hero-animated-overlay,
    .hero-overlay-illustration {
      animation: none;
    }

    *,
    *::before,
    *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
      scroll-behavior: auto !important;
    }
  }
}

/* ============================================================
   REDUCED MOTION — GLOBAL (outside breakpoint, applies always)
   ============================================================ */

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

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .announcement-bar .announcement-text {
    animation: none;
    padding-left: 0;
    white-space: normal;
  }
}