/* ==========================================================================
   01. Global Design Tokens
   Core palette, spacing, typography, and shared custom properties.
   ========================================================================== */
:root {
  color-scheme: light;
  --mint-050: #d8f3dc;
  --mint-100: #b7e4c7;
  --mint-200: #95d5b2;
  --mint-300: #74c69d;
  --mint-400: #52b788;
  --mint-500: #40916c;
  --mint-600: #2d6a4f;
  --mint-700: #1b4332;
  --carbon-900: #081c15;
  --cream-000: #fffaf2;
  --cream-050: #f7f0e4;
  --cream-100: #efe3cf;
  --logo-gold: #c89832;
  --logo-gold-rgb: 200, 152, 50;
  --logo-gold-soft: color-mix(in srgb, var(--logo-gold) 42%, white);
  --logo-gold-deep: color-mix(in srgb, var(--logo-gold) 76%, black);
  --icon-gold: var(--logo-gold);
  --gold-100: var(--logo-gold-soft);
  --gold-300: var(--logo-gold);
  --gold-500: var(--logo-gold);
  --gold-700: var(--logo-gold-deep);
  --plum-100: #efe7fb;
  --plum-300: #c7b0e8;
  --plum-500: #7c5aa6;
  --plum-700: #4f2d69;
  --apricot-200: #f5caa3;
  --apricot-400: #e79a52;
  --orange-500: #cd6c28;
  --surface-base: #fbf3e3;
  --surface-raised: rgba(252, 246, 235, 0.94);
  --surface-glass: rgba(252, 247, 238, 0.82);
  --surface-strong: #fef9ef;
  --surface-dark: var(--carbon-900);
  --surface-dark-soft: rgba(8, 28, 21, 0.86);
  --surface-card-start: rgba(244, 250, 240, 0.98);
  --surface-card-end: rgba(226, 239, 222, 0.95);
  --surface-card-solid: rgba(237, 247, 233, 0.96);
  --surface-card-contrast: rgba(248, 252, 246, 0.98);
  --nav-surface-top: rgba(8, 28, 21, 0.96);
  --nav-surface-bottom: rgba(22, 58, 42, 0.96);
  --panel-surface: rgba(239, 247, 235, 0.96);
  --banner-surface: rgba(9, 31, 22, 0.94);
  --footer-surface-top: #123627;
  --footer-surface-bottom: #081c15;
  --text-main: #10251d;
  --text-muted: rgba(16, 37, 29, 0.74);
  --text-soft: rgba(16, 37, 29, 0.58);
  --text-inverse: #f5fff7;
  --heading-color: #0d221b;
  --border-soft: rgba(27, 67, 50, 0.11);
  --border-strong: rgba(27, 67, 50, 0.22);
  --shadow-xs: 0 10px 22px rgba(8, 28, 21, 0.05);
  --shadow-sm: 0 18px 38px rgba(8, 28, 21, 0.08);
  --shadow-md: 0 30px 60px rgba(8, 28, 21, 0.12);
  --shadow-lg: 0 48px 96px rgba(8, 28, 21, 0.16);
  --radius-xs: 0.95rem;
  --radius-sm: 1.2rem;
  --radius-md: 1.55rem;
  --radius-lg: 2rem;
  --radius-pill: 999px;
  --container-width: 1880px;
  --reading-width: 72ch;
  --utility-bar-height: 0px;
  --main-nav-height: 0px;
  --sticky-stack-height: calc(var(--utility-bar-height) + var(--main-nav-height));
  --text-scale: 1;
  --font-display-default: "Iowan Old Style", "Georgia Pro", "Palatino Linotype", "Book Antiqua", serif;
  --font-body-default: "Avenir Next", "Segoe UI Variable", "Aptos", "Segoe UI", sans-serif;
  --font-label-default: "Franklin Gothic Medium", "Arial Narrow", "Aptos Narrow", sans-serif;
  --font-display: var(--font-display-default);
  --font-body: var(--font-body-default);
  --font-label: var(--font-label-default);
  --font-mono: "SFMono-Regular", ui-monospace, monospace;
  --navbar-toggler-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23c89832' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
  --accent: var(--mint-400);
  --accent-strong: var(--mint-700);
  --accent-soft: rgba(116, 198, 157, 0.1);
  --accent-wash: rgba(216, 243, 220, 0.24);
  --accent-contrast: #f7fff9;
  --secondary-accent: var(--gold-500);
  --secondary-soft: rgba(183, 228, 199, 0.22);
  --sun-accent: var(--orange-500);
  --hero-top: rgba(4, 14, 10, 0.34);
  --hero-bottom: rgba(4, 14, 10, 0.68);
  --hero-side-left: rgba(4, 14, 10, 0.58);
  --hero-side-right: rgba(4, 14, 10, 0.3);
  --hero-glow: rgba(231, 154, 82, 0.24);
  --content-stage-surface: transparent;
  --content-stage-border: transparent;
  --content-stage-shadow: none;
}

/* ==========================================================================
   02. Route Family Accent Tokens
   Section-specific accent tuning used across heroes and emphasis blocks.
   ========================================================================== */
body.family-foundation {
  --accent: var(--mint-400);
  --accent-strong: var(--mint-700);
  --accent-soft: rgba(116, 198, 157, 0.1);
  --accent-wash: rgba(216, 243, 220, 0.24);
  --hero-top: rgba(4, 14, 10, 0.32);
  --hero-bottom: rgba(4, 14, 10, 0.66);
}

body.family-services {
  --accent: var(--mint-600);
  --accent-strong: var(--mint-700);
  --accent-soft: rgba(116, 198, 157, 0.1);
  --accent-wash: rgba(216, 243, 220, 0.24);
  --hero-top: rgba(4, 14, 10, 0.36);
  --hero-bottom: rgba(4, 14, 10, 0.7);
}

body.family-process {
  --accent: var(--gold-500);
  --accent-strong: #7b521c;
  --accent-soft: rgba(116, 198, 157, 0.1);
  --accent-wash: rgba(216, 243, 220, 0.24);
  --hero-top: rgba(22, 12, 4, 0.34);
  --hero-bottom: rgba(22, 12, 4, 0.68);
}

body.family-brazil {
  --accent: var(--mint-500);
  --accent-strong: var(--mint-700);
  --accent-soft: rgba(116, 198, 157, 0.1);
  --accent-wash: rgba(216, 243, 220, 0.24);
  --hero-top: rgba(4, 14, 10, 0.34);
  --hero-bottom: rgba(4, 14, 10, 0.66);
}

body.family-about {
  --accent: var(--gold-500);
  --accent-strong: #7b521c;
  --accent-soft: rgba(116, 198, 157, 0.1);
  --accent-wash: rgba(216, 243, 220, 0.24);
  --hero-top: rgba(22, 12, 4, 0.42);
  --hero-bottom: rgba(22, 12, 4, 0.76);
}

body.family-insights {
  --accent: var(--orange-500);
  --accent-strong: #8e4312;
  --accent-soft: rgba(116, 198, 157, 0.1);
  --accent-wash: rgba(216, 243, 220, 0.24);
  --hero-top: rgba(28, 14, 8, 0.36);
  --hero-bottom: rgba(28, 14, 8, 0.7);
}

body.family-legal {
  --accent: var(--mint-700);
  --accent-strong: var(--carbon-900);
  --accent-soft: rgba(116, 198, 157, 0.1);
  --accent-wash: rgba(216, 243, 220, 0.24);
  --hero-top: rgba(4, 14, 10, 0.38);
  --hero-bottom: rgba(4, 14, 10, 0.72);
}

/* ==========================================================================
   03. Theme Token Overrides
   Dark mode tokens are the default unless `theme-light` is explicitly present.
   ========================================================================== */
body.theme-dark,
body:not(.theme-light) {
  color-scheme: dark;
  --surface-base: #071711;
  --surface-raised: rgba(10, 28, 20, 0.9);
  --surface-glass: rgba(10, 32, 23, 0.72);
  --surface-strong: #10261d;
  --surface-dark: #030d09;
  --surface-dark-soft: rgba(3, 13, 9, 0.92);
  --surface-card-start: rgba(18, 40, 30, 0.94);
  --surface-card-end: rgba(8, 21, 16, 0.9);
  --surface-card-solid: rgba(10, 24, 18, 0.92);
  --surface-card-contrast: rgba(16, 36, 27, 0.96);
  --nav-surface-top: rgba(12, 31, 23, 0.94);
  --nav-surface-bottom: rgba(7, 20, 15, 0.94);
  --panel-surface: rgba(10, 29, 21, 0.96);
  --banner-surface: rgba(8, 26, 19, 0.88);
  --footer-surface-top: #10261d;
  --footer-surface-bottom: #030d09;
  --text-main: #e7f5eb;
  --text-muted: rgba(231, 245, 235, 0.74);
  --text-soft: rgba(231, 245, 235, 0.58);
  --text-inverse: #f5fff7;
  --heading-color: #f1fbf4;
  --border-soft: rgba(183, 228, 199, 0.12);
  --border-strong: rgba(183, 228, 199, 0.2);
  --shadow-xs: 0 10px 22px rgba(0, 0, 0, 0.2);
  --shadow-sm: 0 18px 38px rgba(0, 0, 0, 0.28);
  --shadow-md: 0 30px 60px rgba(0, 0, 0, 0.34);
  --shadow-lg: 0 48px 96px rgba(0, 0, 0, 0.42);
  --accent: var(--mint-300);
  --accent-strong: var(--mint-100);
  --accent-soft: rgba(116, 198, 157, 0.18);
  --accent-wash: rgba(235, 200, 126, 0.16);
  --accent-contrast: #04110c;
  --secondary-accent: var(--gold-300);
  --secondary-soft: rgba(235, 200, 126, 0.16);
  --sun-accent: var(--apricot-200);
  --hero-top: rgba(4, 14, 10, 0.24);
  --hero-bottom: rgba(4, 14, 10, 0.74);
  --hero-glow: rgba(245, 202, 163, 0.24);
  --content-stage-surface:
    radial-gradient(circle at 14% 0%, rgba(255, 255, 255, 0.72), transparent 24%),
    radial-gradient(circle at 84% 8%, rgba(247, 232, 198, 0.22), transparent 18%),
    linear-gradient(180deg, rgba(254, 249, 239, 0.98) 0%, rgba(247, 240, 228, 0.98) 42%, rgba(239, 227, 207, 0.98) 100%);
  --content-stage-border: rgba(123, 82, 28, 0.14);
  --content-stage-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.64),
    inset 0 -1px 0 rgba(123, 82, 28, 0.06);
}

/* ==========================================================================
   04. Base Reset, Document Defaults, and Typography
   Reset, page background, ambient layers, and type scale foundation.
   ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--sticky-stack-height) + 1rem);
  font-size: calc(16px * var(--text-scale));
}

body {
  position: relative;
  margin: 0;
  overflow-x: hidden;
  color: var(--text-main);
  background:
    radial-gradient(circle at 14% 0%, rgba(255, 255, 255, 0.92), transparent 26%),
    radial-gradient(circle at 88% 10%, rgba(241, 210, 143, 0.1), transparent 20%),
    linear-gradient(180deg, #fffdf8 0%, #fbf7ef 46%, #f7f1e8 100%);
  font-family: var(--font-body);
  line-height: 1.75;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.32), transparent 34%),
    radial-gradient(circle at 16% 16%, rgba(255, 255, 255, 0.28), transparent 20%);
  opacity: 0.62;
}

/* Dark theme page background and ambient overlays. */
body.theme-dark,
body:not(.theme-light) {
  background:
    radial-gradient(circle at top left, rgba(82, 183, 136, 0.18), transparent 28%),
    radial-gradient(circle at 82% 12%, rgba(235, 200, 126, 0.12), transparent 24%),
    radial-gradient(circle at 72% 84%, rgba(245, 202, 163, 0.1), transparent 22%),
    linear-gradient(180deg, #06140f 0%, #091b14 42%, #0e261d 100%);
}

body.theme-dark::before,
body:not(.theme-light)::before {
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.05), transparent 34%),
    radial-gradient(circle at 14% 18%, rgba(255, 255, 255, 0.08), transparent 22%);
  opacity: 0.58;
}

/* Media, links, form-element inheritance, headings, and utility text styles. */
img {
  max-width: 100%;
  height: auto;
}

a {
  color: var(--accent-strong);
  text-decoration-color: var(--accent-soft);
  text-decoration-thickness: 0.1em;
  text-underline-offset: 0.18em;
}

a:hover,
a:focus-visible {
  color: var(--accent);
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
  color: var(--heading-color);
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.04em;
  text-wrap: balance;
}

h1 {
  font-size: clamp(3.25rem, 7vw, 5.6rem);
}

h2 {
  font-size: clamp(2rem, 4.4vw, 3.35rem);
}

h3 {
  font-size: clamp(1.35rem, 2.3vw, 1.92rem);
}

h4 {
  font-size: clamp(1.12rem, 1.8vw, 1.4rem);
}

h5 {
  font-size: 1rem;
}

h6 {
  font-size: 0.92rem;
}

p,
li {
  font-size: 1rem;
}

.section-title {
  display: inline-flex;
  align-items: center;
  gap: 0.72rem;
}

.section-title__icon {
  display: inline-flex;
  width: 1.12rem;
  height: 1.12rem;
  flex: 0 0 auto;
  color: var(--icon-gold);
}

.section-title__icon svg {
  width: 100%;
  height: 100%;
}

.footer-heading-icon {
  color: var(--icon-gold);
}

::selection {
  background: rgba(199, 149, 60, 0.24);
  color: var(--surface-dark);
}

.container,
.container-xl,
.container-xxl {
  width: min(var(--container-width), calc(100% - clamp(1.4rem, 2.8vw, 3.4rem)));
  margin-inline: auto;
}

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

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

/* ==========================================================================
   05. Buttons and Shared Interactive Controls
   ========================================================================== */
.btn {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  min-height: 52px;
  padding: 0.88rem 1.42rem;
  border: 1px solid rgba(18, 41, 34, 0.12);
  border-radius: calc(var(--radius-xs) + 0.05rem);
  background: linear-gradient(145deg, rgba(255, 252, 246, 0.98), rgba(244, 234, 214, 0.96));
  box-shadow:
    0 16px 32px rgba(18, 37, 29, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.72);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  line-height: 1.15;
  text-align: center;
  text-decoration: none;
  color: var(--text-main);
  cursor: pointer;
  transition:
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 220ms ease,
    background-color 220ms ease,
    border-color 220ms ease,
    color 220ms ease,
    filter 220ms ease;
}

.btn::before {
  content: "";
  position: absolute;
  inset: 1px;
  z-index: -1;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.32), transparent 58%);
}

.btn::after {
  content: "";
  position: absolute;
  top: -30%;
  bottom: -30%;
  left: -36%;
  width: 34%;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.55) 52%, transparent 100%);
  opacity: 0.7;
  pointer-events: none;
  transform: translateX(-180%) rotate(18deg);
  transition: transform 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

.btn:hover,
.btn:focus-visible {
  transform: translateY(-3px) scale(1.01);
  box-shadow:
    0 26px 48px rgba(18, 37, 29, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.78);
  border-color: var(--border-strong);
}

.btn:hover::after,
.btn:focus-visible::after {
  transform: translateX(360%) rotate(18deg);
}

.btn:active {
  transform: translateY(-1px) scale(0.99);
  box-shadow: 0 14px 26px rgba(8, 28, 21, 0.12);
}

.btn-cta,
.btn-cta:visited {
  color: #221409;
  background: linear-gradient(135deg, #fff2c7 0%, #f0ca79 30%, #d59a38 67%, #b45c3f 100%);
  border-color: rgba(156, 108, 43, 0.34);
  box-shadow:
    0 22px 40px rgba(180, 92, 63, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.btn-cta::before {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.08) 60%, transparent 100%);
}

.btn-cta:hover,
.btn-cta:focus-visible {
  color: #1b1107;
  background: linear-gradient(135deg, #fff5d7 0%, #f6d998 28%, #dfa64d 62%, #bd6437 100%);
  border-color: rgba(156, 108, 43, 0.48);
  box-shadow:
    0 30px 50px rgba(180, 92, 63, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.48);
}

.btn-secondary,
.btn-secondary:visited {
  color: #fffaf2;
  background: linear-gradient(135deg, #2f8a5e 0%, #184c43 46%, #0f2c23 100%);
  border-color: rgba(49, 142, 96, 0.36);
  box-shadow:
    0 18px 34px rgba(15, 44, 35, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.btn-secondary::before {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.03) 60%, transparent 100%);
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
  color: #fffaf2;
  background: linear-gradient(135deg, #389a68 0%, #1f6c49 40%, #123b29 100%);
  border-color: rgba(73, 169, 111, 0.52);
  box-shadow:
    0 28px 48px rgba(15, 44, 35, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.btn-sm {
  min-height: 44px;
  padding: 0.72rem 1.08rem;
  font-size: 0.78rem;
}

/* ==========================================================================
   06. Upgrade Banner / Promo Surface
   ========================================================================== */
.upgrade-banner {
  position: relative;
  overflow: hidden;
  padding: clamp(2.8rem, 6vw, 4.5rem) 0;
}

.upgrade-banner::before,
.upgrade-banner::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.upgrade-banner::before {
  inset: -5rem auto auto -4rem;
  width: 18rem;
  height: 18rem;
  background: radial-gradient(circle, rgba(235, 200, 126, 0.34), transparent 70%);
}

.upgrade-banner::after {
  inset: auto -4rem -7rem auto;
  width: 22rem;
  height: 22rem;
  background: radial-gradient(circle, rgba(82, 183, 136, 0.16), transparent 72%);
}

.upgrade-banner__shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.75fr);
  gap: 1.4rem;
  align-items: stretch;
  min-height: max(28rem, 50vh);
  padding: clamp(2rem, 4.5vw, 3.4rem);
  border: 1px solid rgba(199, 149, 60, 0.22);
  border-radius: calc(var(--radius-lg) + 0.35rem);
  background:
    linear-gradient(140deg, rgba(255, 251, 243, 0.98) 0%, rgba(246, 239, 228, 0.96) 48%, rgba(216, 243, 220, 0.86) 100%);
  box-shadow:
    0 28px 60px rgba(73, 61, 45, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.upgrade-banner__content,
.upgrade-banner__aside {
  display: grid;
}

.upgrade-banner__content {
  align-content: center;
  gap: 1.05rem;
}

.upgrade-banner__content h2 {
  max-width: 14ch;
  margin-bottom: 0;
  font-size: clamp(2.4rem, 5.5vw, 4.35rem);
  line-height: 0.95;
}

.upgrade-banner__lead {
  max-width: 60ch;
  margin: 0;
  font-size: 1.18rem;
  color: var(--text-main);
}

.upgrade-banner__content p:not(.section-kicker):not(.upgrade-banner__lead) {
  max-width: 62ch;
  margin: 0;
  color: var(--text-muted);
}

.upgrade-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  margin-top: 0.6rem;
}

.upgrade-banner__actions .btn {
  min-width: 12rem;
}

.upgrade-banner__aside {
  align-content: center;
  gap: 1rem;
}

.upgrade-banner__card {
  display: grid;
  gap: 0.45rem;
  padding: 1.25rem 1.3rem;
  border-radius: var(--radius-md);
  border: 1px solid rgba(27, 67, 50, 0.12);
  background:
    linear-gradient(145deg, rgba(255, 253, 248, 0.95), rgba(255, 247, 230, 0.9));
  box-shadow: 0 16px 34px rgba(73, 61, 45, 0.08);
}

.upgrade-banner__card span {
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #7b521c;
}

.upgrade-banner__card strong {
  color: var(--text-main);
  font-size: 1rem;
  line-height: 1.5;
}

body.theme-dark .upgrade-banner__shell {
  border-color: rgba(235, 200, 126, 0.2);
  background:
    linear-gradient(140deg, rgba(16, 38, 29, 0.96) 0%, rgba(18, 46, 34, 0.94) 52%, rgba(88, 63, 22, 0.52) 100%);
}

body.theme-dark .upgrade-banner__card {
  border-color: rgba(235, 200, 126, 0.16);
  background:
    linear-gradient(145deg, rgba(15, 35, 26, 0.96), rgba(28, 54, 40, 0.9));
}

body.theme-dark .upgrade-banner__card span {
  color: var(--gold-300);
}

body.a11y-contrast .upgrade-banner__shell,
body.a11y-contrast .upgrade-banner__card {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

/* ==========================================================================
   07. Utility Bar and Utility Actions
   ========================================================================== */
.utility-bar {
  position: sticky;
  top: 0;
  z-index: 60;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(8, 28, 21, 0.94), rgba(18, 54, 39, 0.94));
  backdrop-filter: blur(18px);
  box-shadow: 0 10px 22px rgba(3, 13, 9, 0.18);
}

body.is-scrolled .utility-bar {
  box-shadow: 0 14px 28px rgba(3, 13, 9, 0.24);
}

/* Shared shell primitives. Some selectors here are intentionally specialized
   later in the file for component-specific layouts, such as `.hero-inner`. */
.utility-inner,
.brand-inner,
.hero-inner,
.footer-bottom {
  display: flex;
  gap: 1rem;
}

.utility-inner {
  align-items: center;
  justify-content: space-between;
  padding: 0.56rem 0;
}

.utility-support {
  display: inline-flex;
  align-items: center;
  margin: 0;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.45;
  color: rgba(255, 250, 242, 0.88);
}

.utility-support__mark {
  display: none;
}

.utility-actions {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.lang-switcher--minimal {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: rgba(255, 250, 242, 0.72);
}

.lang-link,
.utility-action--text {
  min-height: auto;
  padding: 0;
  border: 0;
  background: none;
  box-shadow: none;
  color: rgba(255, 250, 242, 0.82);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  cursor: pointer;
}

.lang-link.active {
  color: #fffaf2;
  font-weight: 600;
  text-decoration: none;
  box-shadow: inset 0 -0.14rem 0 0 var(--gold-300);
}

.lang-link:hover,
.lang-link:focus-visible,
.utility-action--text:hover,
.utility-action--text:focus-visible {
  color: #fffaf2;
  transform: none;
  text-decoration: underline;
}

.lang-link[disabled] {
  opacity: 0.42;
  cursor: not-allowed;
  text-decoration: none;
}

.utility-link,
.lang-chip,
.panel-close,
.toggle-button,
.back-to-top {
  border: 0;
  background: none;
  color: var(--text-main);
  cursor: pointer;
}

.utility-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0.68rem 1rem;
  border: 1px solid var(--border-soft);
  border-radius: calc(var(--radius-xs) + 0.05rem);
  background: linear-gradient(180deg, var(--surface-card-start), var(--surface-card-end));
  box-shadow: 0 10px 24px rgba(8, 28, 21, 0.06);
  color: var(--text-main);
  font-weight: 700;
  text-decoration: none;
  transition:
    background-color 200ms ease,
    color 200ms ease,
    transform 200ms ease,
    border-color 200ms ease,
    box-shadow 200ms ease;
}

.utility-link:hover,
.utility-link:focus-visible,
.panel-close:hover,
.panel-close:focus-visible,
.toggle-button:hover,
.toggle-button:focus-visible {
  transform: translateY(-2px) scale(1.01);
  background: linear-gradient(135deg, rgba(199, 176, 232, 0.3), rgba(255, 255, 255, 0.88));
  color: var(--plum-700);
  box-shadow: 0 16px 30px rgba(79, 45, 105, 0.16);
}

.utility-link--nav {
  min-height: 42px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-inverse);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: none;
}

.utility-link--nav:hover,
.utility-link--nav:focus-visible {
  background: rgba(255, 255, 255, 0.14);
  color: var(--text-inverse);
}

.lang-switcher {
  display: inline-flex;
  gap: 0.45rem;
}

.lang-chip {
  min-height: 40px;
  padding: 0.6rem 0.9rem;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, rgba(199, 176, 232, 0.22), rgba(255, 255, 255, 0.78));
  color: var(--plum-700);
  box-shadow: inset 0 0 0 1px rgba(124, 90, 166, 0.12);
  font-weight: 800;
  transition: background-color 200ms ease, color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
}

.lang-chip.active,
.lang-chip:not([disabled]):hover,
.lang-chip:not([disabled]):focus-visible {
  transform: translateY(-2px);
  background: linear-gradient(135deg, var(--plum-300) 0%, var(--plum-500) 42%, var(--plum-700) 100%);
  color: #fffaf2;
  box-shadow: 0 16px 30px rgba(79, 45, 105, 0.2);
}

.lang-chip[disabled] {
  opacity: 0.42;
  cursor: not-allowed;
}

/* ==========================================================================
   08. Accessibility Panel
   Modal controls, reading guide, and accessibility toggles.
   ========================================================================== */
.accessibility-panel {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 1100;
  width: min(420px, 100vw);
  max-width: 100vw;
  overflow: hidden;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(100%);
  transition: transform 260ms ease;
  background: var(--panel-surface);
  backdrop-filter: blur(26px);
  box-shadow: -28px 0 80px rgba(8, 28, 21, 0.18);
}

.accessibility-panel.is-open {
  visibility: visible;
  pointer-events: auto;
  transform: translateX(0);
}

.accessibility-panel__inner {
  display: grid;
  align-content: start;
  gap: 1rem;
  height: 100%;
  padding: max(1rem, env(safe-area-inset-top)) 1rem max(1rem, env(safe-area-inset-bottom));
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
  -webkit-overflow-scrolling: touch;
}

.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0;
  position: sticky;
  top: 0;
  z-index: 1;
  padding-bottom: 0.25rem;
  background: inherit;
}

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

.panel-actions > .scale-control,
.panel-actions > .toggle-button.reset {
  grid-column: 1 / -1;
}

.scale-control,
.toggle-button,
.panel-close {
  border-radius: var(--radius-xs);
}

.scale-control {
  display: grid;
  gap: 0.72rem;
  padding: 1rem;
  background: linear-gradient(135deg, var(--secondary-soft), var(--surface-card-contrast));
}

.toggle-button,
.panel-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0.78rem 0.85rem;
  background: var(--surface-card-solid);
  font-size: 0.92rem;
  line-height: 1.25;
  text-align: center;
}

.toggle-button {
  width: 100%;
}

.toggle-button.is-active {
  background: linear-gradient(135deg, var(--plum-300), var(--plum-700));
  color: #fffaf2;
  box-shadow: 0 16px 30px rgba(79, 45, 105, 0.22);
}

.inline-actions--choices {
  gap: 0.55rem;
}

.toggle-button--choice {
  flex: 1 1 6rem;
}

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

.reading-guide {
  position: fixed;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, rgba(200, 160, 98, 0.5) 14%, rgba(200, 160, 98, 0.9) 50%, rgba(200, 160, 98, 0.5) 86%, transparent 100%);
  box-shadow: 0 0 20px rgba(200, 160, 98, 0.8);
  opacity: 0;
  pointer-events: none;
}

.reading-guide.is-active {
  opacity: 1;
}

body.is-accessibility-open {
  overflow: hidden;
}

/* ==========================================================================
   09. Brand Lockup and Identity
   ========================================================================== */
.brand-bar {
  display: none;
}

.brand-inner {
  align-items: center;
  justify-content: space-between;
  padding: 1.15rem 0;
}

.brand-lockup {
  display: inline-grid;
  gap: 0.24rem;
  color: var(--text-main);
  text-decoration: none;
}

.brand-lockup__image {
  display: inline-flex;
  width: auto;
  max-width: 100%;
  height: auto;
}

.brand-lockup__meta {
  display: block;
}

.brand-lockup__meta small {
  display: block;
  color: var(--text-muted);
  font-size: 0.67rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  line-height: 1.45;
  text-transform: uppercase;
}

.brand-wordmark {
  display: inline-flex;
  align-items: center;
  gap: 0.88rem;
}

.brand-wordmark__mark {
  display: block;
  width: 56px;
  height: 56px;
  flex: 0 0 auto;
}

.brand-wordmark__text {
  display: grid;
  gap: 0.06rem;
}

.brand-wordmark__line {
  display: block;
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 0.94;
  letter-spacing: -0.04em;
}

.brand-wordmark__line--top {
  font-size: 1.2rem;
  color: #101820;
}

.brand-wordmark__line--bottom {
  font-size: 1.2rem;
  color: var(--mint-700);
}

.brand-wordmark--inverse .brand-wordmark__line--top,
.brand-wordmark--inverse .brand-wordmark__line--bottom {
  color: var(--cream-000);
}

.brand-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.brand-note {
  display: grid;
  gap: 0.06rem;
  padding: 0.65rem 1rem;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--secondary-soft), rgba(255, 255, 255, 0.72));
}

.brand-note span {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.brand-note strong {
  font-size: 0.94rem;
  color: var(--text-main);
  line-height: 1.35;
}

/* ==========================================================================
   10. Main Navigation
   Desktop header, CTA, and primary navigation shell.
   ========================================================================== */
.main-nav {
  position: sticky;
  top: var(--utility-bar-height);
  z-index: 50;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(8, 28, 21, 0.96), rgba(18, 54, 39, 0.94));
  backdrop-filter: blur(22px);
  box-shadow: 0 18px 40px rgba(3, 13, 9, 0.24);
}

body.is-scrolled .main-nav {
  box-shadow: 0 22px 46px rgba(3, 13, 9, 0.3);
}

.main-nav .container {
  display: block;
}

.main-nav .navbar-toggler {
  margin-left: auto;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-xs);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: none;
  color: #fffaf2;
}

.main-nav .navbar-toggler-icon {
  background-image: var(--navbar-toggler-icon);
  filter: none;
  opacity: 0.92;
}

.main-nav .navbar-collapse {
  width: 100%;
}

.main-header {
  display: grid;
  gap: 0.78rem;
  padding: 0.95rem 0 1rem;
}

.main-header__upper,
.main-header__identity,
.main-header__lower,
.main-header__center,
.main-header__actions {
  display: flex;
  align-items: center;
}

.main-header__upper {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 1rem;
}

.main-header__identity {
  gap: 1rem;
  min-width: 0;
  justify-self: start;
}

.main-header__center {
  justify-self: center;
}

.main-header__lower {
  position: relative;
  justify-content: center;
  padding-top: 0.78rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.main-header__actions {
  justify-self: end;
  justify-content: flex-end;
  gap: 0.8rem;
  min-width: 0;
  flex-wrap: nowrap;
}

.main-nav .navbar-nav {
  display: flex;
  align-items: center;
  gap: 1.9rem;
  margin: 0;
}

.navbar-nav--services {
  justify-content: center;
  flex-wrap: nowrap;
}

.navbar-nav--services .nav-item {
  flex: 0 0 auto;
}

.main-nav .nav-link,
.main-nav .dropdown-toggle {
  display: inline-flex;
  align-items: center;
  min-height: auto;
  padding: 0.58rem 0;
  border: 0;
  border-bottom: 1px solid transparent;
  border-radius: 0;
  background: none;
  color: rgba(255, 250, 242, 0.76);
  font-weight: 600;
  letter-spacing: 0.01em;
  text-decoration: none;
  transition:
    color 200ms ease,
    border-color 200ms ease,
    transform 200ms ease;
}

.main-nav .nav-link:hover,
.main-nav .nav-link:focus-visible,
.main-nav .dropdown.show > .nav-link {
  color: #fffaf2;
  background: none;
  border-color: rgba(235, 200, 126, 0.62);
  transform: none;
}

.navbar-nav--services .nav-link,
.navbar-nav--services .dropdown-toggle {
  padding-inline: 0.12rem;
}

.navbar-nav--services .dropdown-toggle::after {
  margin-left: 0.42rem;
  opacity: 0.92;
  border-top-color: var(--icon-gold);
  border-top-width: 0.42em;
  border-right-width: 0.32em;
  border-left-width: 0.32em;
  transform: translateY(0);
  transform-origin: center;
  animation: nav-caret-bob 1.8s ease-in-out infinite;
  transition:
    transform 220ms ease,
    opacity 220ms ease,
    border-top-color 220ms ease;
}

.service-family-dropdown.is-active > .nav-link,
.service-family-dropdown.is-active > .dropdown-toggle,
.navbar-nav--services .nav-link.is-active,
.navbar-nav--services .dropdown-toggle.is-active,
.service-family-dropdown.show > .nav-link,
.service-family-dropdown.show > .dropdown-toggle {
  color: #fffaf2;
  border-color: rgba(235, 200, 126, 0.72);
}

.service-family-dropdown.is-active > .dropdown-toggle::after,
.service-family-dropdown.show > .dropdown-toggle::after {
  opacity: 0.9;
  border-top-color: var(--icon-gold);
}

.service-family-dropdown.show > .dropdown-toggle::after {
  animation: none;
  transform: translateY(1px) rotate(180deg);
}

@keyframes nav-caret-bob {
  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(2px);
  }
}

.main-header__home {
  display: inline-flex;
  align-items: center;
  min-height: auto;
  padding: 0.36rem 0 0.5rem;
  border: 0;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  background: transparent;
  color: rgba(255, 250, 242, 0.76);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  transition:
    color 180ms ease,
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.main-header__home:hover,
.main-header__home:focus-visible,
.main-header__home.is-active {
  color: #fffaf2;
}

.main-header__home:hover,
.main-header__home:focus-visible {
  transform: none;
  border-bottom-color: rgba(255, 255, 255, 0.2);
  background: transparent;
}

.main-header__home.is-active {
  border-bottom-color: rgba(235, 200, 126, 0.88);
  background: transparent;
  box-shadow: inset 0 -1px 0 rgba(235, 200, 126, 0.22);
}

.main-nav .brand-lockup,
.main-nav .brand-lockup__meta,
.main-nav .brand-lockup__meta small,
.main-nav .main-header__home {
  color: #fffaf2;
}

.main-nav .brand-lockup__meta,
.main-nav .brand-lockup__meta small {
  display: none;
}

.main-header__cta {
  margin-left: 0;
  gap: 0.68rem;
  padding-inline: 1.18rem 1.34rem;
  border-color: rgba(205, 108, 40, 0.62);
  animation: cta-beacon 2.8s ease-in-out infinite;
}

.main-header__cta--mobile,
.main-header__cta--mobile:visited {
  min-height: 40px;
  padding: 0.64rem 0.92rem;
  border-color: rgba(181, 124, 40, 0.42);
  background: linear-gradient(135deg, #fff1c4 0%, #efcb7a 34%, #d69b3b 72%, #bc6b3b 100%);
  color: #28170a;
  box-shadow:
    0 14px 24px rgba(65, 31, 86, 0.22),
    0 0 0 7px rgba(124, 90, 166, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
  animation:
    mobile-consult-float 3.2s ease-in-out infinite,
    mobile-consult-glow 4.4s ease-in-out infinite;
}

.main-header__cta--mobile::after {
  content: "";
  position: absolute;
  inset: -2px auto -2px -38%;
  width: 34%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  transform: skewX(-18deg);
  animation: cta-sheen 4.6s ease-in-out infinite;
}

.main-header__cta--mobile:hover,
.main-header__cta--mobile:focus-visible {
  color: #211105;
  border-color: rgba(193, 151, 84, 0.5);
  background: linear-gradient(135deg, #fff5d6 0%, #f3d894 32%, #dda34d 70%, #c77743 100%);
  box-shadow:
    0 18px 28px rgba(65, 31, 86, 0.26),
    0 0 0 9px rgba(124, 90, 166, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.main-header__cta::after {
  content: "";
  position: absolute;
  inset: -2px auto -2px -38%;
  width: 34%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.62), transparent);
  transform: skewX(-18deg);
  animation: cta-sheen 2.9s ease-in-out infinite;
}

.main-header__cta-icons {
  display: inline-flex;
  align-items: center;
  gap: 0.26rem;
  flex: 0 0 auto;
}

.main-header__cta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--icon-gold);
}

.main-header__cta-icon svg {
  width: 0.9rem;
  height: 0.9rem;
}

.main-header__cta-icon--scales svg {
  width: 0.84rem;
  height: 0.84rem;
}

.main-header__cta-label {
  position: relative;
  z-index: 1;
}

/* ==========================================================================
   11. Desktop Dropdown Menus
   Mega-menu style groupings for service families.
   ========================================================================== */
.mega .dropdown-menu {
  width: min(calc(var(--container-width) - 6rem), calc(100vw - clamp(1.4rem, 2.8vw, 3.4rem)));
  margin-top: 0.55rem;
  padding: 1.3rem;
  border: 0;
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, var(--surface-card-start), var(--surface-card-end)),
    var(--surface-card-solid);
  box-shadow: var(--shadow-lg);
  max-height: calc(100vh - 120px);
  overflow-y: auto;
}

.mega-overview {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--border-soft);
}

.mega-overview h3,
.mega-overview p {
  margin: 0;
}

.mega-label {
  display: inline-block;
  margin-bottom: 0.55rem;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.mega-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0.55rem 0.9rem;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--secondary-soft), rgba(255, 255, 255, 0.82));
  color: #7b521c;
  font-size: 0.9rem;
  font-weight: 800;
}

.mega-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.8rem;
}

.mega-grid-grouped {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.mega-section {
  display: grid;
  gap: 0.65rem;
}

.mega-section h3 {
  margin: 0;
  color: var(--accent-strong);
  font-size: 1.1rem;
}

.mega-subgrid {
  display: grid;
  gap: 0.55rem;
}

.mega-link {
  display: block;
  min-height: 100%;
  padding: 0.92rem 1rem;
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm);
  background: var(--surface-card-contrast);
  color: var(--text-main);
  text-decoration: none;
  transition:
    transform 220ms ease,
    background-color 220ms ease,
    border-color 220ms ease,
    box-shadow 220ms ease;
}

.mega-link:hover,
.mega-link:focus-visible {
  transform: translateY(-2px);
  border-color: var(--border-strong);
  background: rgba(255, 250, 244, 0.98);
  box-shadow: var(--shadow-xs);
}

.service-family-dropdown {
  position: static;
}

.main-nav .dropdown-menu {
  display: block;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 160ms ease,
    transform 160ms ease,
    visibility 160ms ease;
}

.main-nav .nav-item.show > .dropdown-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.service-family-menu {
  top: calc(100% + 0.8rem);
  left: 50%;
  width: min(calc(var(--container-width) - 8rem), calc(100vw - clamp(1.4rem, 2.8vw, 3.4rem)));
  margin-top: 0;
  padding: 1.7rem 1.85rem;
  border: 0;
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, var(--surface-card-start), var(--surface-card-end)),
    var(--surface-card-solid);
  box-shadow: var(--shadow-lg);
  max-height: calc(100vh - 140px);
  overflow-y: auto;
  transform: translate(-50%, 0.6rem);
}

.service-family-dropdown.show > .service-family-menu {
  transform: translate(-50%, 0);
}

.service-family-menu__head {
  padding-bottom: 1.05rem;
  margin-bottom: 1.05rem;
  border-bottom: 1px solid var(--border-soft);
}

.service-family-menu__head h3,
.service-family-menu__head p {
  margin: 0;
}

.service-family-menu__head h3 {
  margin-bottom: 0.35rem;
  color: var(--heading-color);
  font-size: 1.2rem;
}

.service-family-menu__head p:last-child {
  max-width: 48ch;
  color: var(--text-muted);
  font-size: 0.95rem;
}

.service-family-menu__heading {
  color: var(--heading-color);
  text-decoration: none;
}

.service-family-menu__heading:hover,
.service-family-menu__heading:focus-visible {
  color: var(--accent-strong);
}

.service-family-menu__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.65rem 1.25rem;
}

.service-family-menu__column {
  display: grid;
  gap: 0.35rem;
}

.service-family-menu__link {
  display: block;
  padding: 0.28rem 0;
  border: 0;
  background: none;
  color: var(--text-muted);
  font-size: 0.94rem;
  font-weight: 500;
  text-decoration: none;
  transition: color 180ms ease, transform 180ms ease;
}

.service-family-menu__link strong {
  font-weight: 500;
}

.service-family-menu__link:hover,
.service-family-menu__link:focus-visible {
  transform: translateX(2px);
  color: var(--text-main);
}

/* ==========================================================================
   12. Mobile Navigation
   ========================================================================== */
.mobile-nav-shell {
  width: 100%;
  padding: 1rem 0 1.25rem;
}

.mobile-nav-section + .mobile-nav-section {
  margin-top: 1rem;
}

.mobile-nav-section--secondary {
  padding-top: 0.95rem;
  border-top: 1px solid var(--border-soft);
}

.mobile-nav-shell__eyebrow {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.mobile-nav-shell__intro {
  margin: 0 0 0.85rem;
  color: var(--text-muted);
  font-size: 0.95rem;
}

.mobile-nav-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.mobile-nav-home {
  color: var(--text-muted);
  font-weight: 600;
  text-decoration: none;
}

.mobile-nav-home:hover,
.mobile-nav-home:focus-visible,
.mobile-nav-home.is-active {
  color: var(--text-main);
}

.mobile-nav-group {
  border-top: 1px solid var(--border-soft);
}

.mobile-nav-group:last-of-type {
  border-bottom: 1px solid var(--border-soft);
}

.mobile-nav-group summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 0;
  color: var(--heading-color);
  font-weight: 700;
  list-style: none;
  cursor: pointer;
}

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

.mobile-nav-group summary::after {
  content: "";
  flex: 0 0 auto;
  width: 0;
  height: 0;
  margin-left: auto;
  border-top: 0.42em solid var(--icon-gold);
  border-right: 0.32em solid transparent;
  border-left: 0.32em solid transparent;
  opacity: 0.92;
  transform: translateY(0);
  transform-origin: center;
  transition:
    transform 220ms ease,
    opacity 220ms ease,
    border-top-color 220ms ease;
}

.mobile-nav-group[open] summary::after {
  transform: translateY(1px) rotate(180deg);
  border-top-color: var(--icon-gold);
}

.mobile-nav-group__body {
  display: grid;
  gap: 0.85rem;
  padding: 0 0 1rem;
}

.mobile-nav-group__intro {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.95rem;
}

.mobile-nav-subgroup {
  display: grid;
  gap: 0.45rem;
}

.mobile-nav-subgroup h3 {
  margin: 0;
  color: var(--accent-strong);
  font-size: 0.92rem;
}

.mobile-nav-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.45rem 0.85rem;
}

.mobile-nav-links a {
  color: var(--text-main);
  text-decoration: none;
  line-height: 1.45;
}

.mobile-nav-links a:hover,
.mobile-nav-links a:focus-visible {
  color: var(--accent-strong);
  text-decoration: underline;
}

/* ==========================================================================
   13. Performance and Render Hints
   Rendering hints only. These selectors receive their visual styles later.
   Footer sections are intentionally excluded after prior visibility conflicts.
   ========================================================================== */
.content-block,
.official-resources,
.faq-block,
.related-block,
.lead-form-block,
.cta-pair,
.site-disclaimer,
.trust-marker-block,
.sidebar-card {
  content-visibility: auto;
  contain-intrinsic-size: 1px 960px;
}

@supports (content-visibility: auto) {
  .page-home-atlas > section + section {
    content-visibility: auto;
    contain-intrinsic-size: 1px 1200px;
  }
}

/* ==========================================================================
   14. Hero System
   Page hero media, overlays, lockups, proof points, and glance cards.
   ========================================================================== */
.hero {
  position: relative;
  overflow: hidden;
  padding: clamp(4rem, 8vw, 6.2rem) 0 clamp(4.6rem, 10vw, 7.2rem);
  color: var(--text-inverse);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01)),
    var(--hero-image, linear-gradient(135deg, var(--accent-strong), #d9c1a2));
  background-position: center;
  background-size: cover;
}

.hero::before,
.hero::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
}

.hero::before {
  inset: auto auto -14% -8%;
  width: 22rem;
  height: 22rem;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.12), transparent 70%);
}

.hero::after {
  inset: 7% -7% auto auto;
  width: 28rem;
  height: 28rem;
  background: radial-gradient(circle, var(--hero-glow), transparent 70%);
  animation: hero-glow 10s ease-in-out infinite;
}

.hero-media {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, var(--hero-top) 0%, rgba(4, 14, 10, 0.18) 26%, var(--hero-bottom) 100%),
    linear-gradient(104deg, var(--hero-side-left) 0%, rgba(4, 14, 10, 0.3) 42%, rgba(4, 14, 10, 0.08) 62%, var(--hero-side-right) 100%),
    radial-gradient(circle at 18% 38%, rgba(255, 255, 255, 0.05), transparent 28%);
}

.hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.75fr);
  position: relative;
  z-index: 2;
  align-items: end;
  justify-content: initial;
  gap: clamp(1.75rem, 3vw, 4.5rem);
}

.hero-copy {
  max-width: min(760px, 100%);
  padding: clamp(1.25rem, 2vw, 1.7rem);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: calc(var(--radius-lg) - 0.15rem);
  background:
    linear-gradient(145deg, rgba(4, 14, 10, 0.74), rgba(4, 14, 10, 0.28)),
    rgba(4, 14, 10, 0.4);
  box-shadow: 0 24px 44px rgba(4, 12, 8, 0.24);
  backdrop-filter: blur(14px);
  animation: hero-rise 700ms ease both;
}

.hero-copy__lead {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-bottom: 1rem;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.48);
}

.hero h1,
.hero h2,
.hero h3,
.hero h4,
.hero h5,
.hero h6,
.hero .eyebrow,
.hero-kicker {
  color: var(--text-inverse);
  text-shadow: 0 3px 18px rgba(0, 0, 0, 0.52);
}

.eyebrow,
.section-kicker {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.eyebrow {
  color: rgba(248, 244, 236, 0.82);
}

.hero-kicker {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.55rem 0.92rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(248, 244, 236, 0.92);
  font-size: 0.84rem;
  font-weight: 700;
}

.hero-summary {
  max-width: 60rem;
  margin-bottom: 1rem;
  font-size: 1.14rem;
  color: rgba(248, 244, 236, 0.88);
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.48);
}

.hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 1.25rem 0 1.4rem;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 38px;
  padding: 0.55rem 0.88rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(248, 244, 236, 0.92);
  font-size: 0.88rem;
  font-weight: 700;
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.42);
}

.hero-badge__icon {
  display: inline-flex;
  width: 0.95rem;
  height: 0.95rem;
  flex: 0 0 auto;
  color: var(--icon-gold);
}

.hero-badge__icon svg {
  width: 100%;
  height: 100%;
}

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

.hero-meta {
  display: grid;
  gap: 1rem;
  width: min(360px, 100%);
  min-width: 300px;
}

.hero-panel {
  padding: 1.15rem 1.2rem;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(145deg, rgba(4, 14, 10, 0.72), rgba(4, 14, 10, 0.26)),
    rgba(4, 14, 10, 0.42);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 40px rgba(12, 20, 32, 0.2);
}

.hero-panel--brand {
  display: grid;
  gap: 0.55rem;
  background:
    linear-gradient(145deg, rgba(4, 14, 10, 0.78), rgba(18, 54, 39, 0.42)),
    rgba(4, 14, 10, 0.56);
  border-color: rgba(255, 255, 255, 0.14);
}

.hero-brand-lockup {
  display: inline-flex;
  width: auto;
  max-width: 100%;
}

.hero-brand-lockup .brand-wordmark__mark {
  width: 64px;
  height: 64px;
}

.hero-brand-lockup .brand-wordmark__line--top,
.hero-brand-lockup .brand-wordmark__line--bottom {
  font-size: 1.34rem;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.46);
}

.hero-brand-tagline {
  display: none;
}

.hero-brand-note {
  margin: 0;
  color: rgba(248, 244, 236, 0.92);
  font-size: 0.95rem;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.42);
}

.hero-panel strong {
  display: block;
  margin-bottom: 0.55rem;
  font-size: 1rem;
  letter-spacing: 0.01em;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.42);
}

.hero-panel-list {
  display: grid;
  gap: 0.7rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hero-panel-item {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  color: rgba(248, 244, 236, 0.96);
  font-size: 0.94rem;
  font-weight: 700;
  line-height: 1.45;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.36);
}

.hero-panel-item__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  height: 1.9rem;
  flex: 0 0 1.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: var(--icon-gold);
}

.hero-panel-item__icon svg {
  width: 0.98rem;
  height: 0.98rem;
}

.hero-panel p {
  margin: 0 0 0.75rem;
  color: rgba(248, 244, 236, 0.92);
  font-size: 0.95rem;
  line-height: 1.55;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.42);
}

.hero-panel a {
  display: block;
  color: #fffaf2;
  text-decoration: none;
}

.hero-panel a + a {
  margin-top: 0.28rem;
}

.hero-proof-list {
  padding-left: 1.15rem;
  margin: 0;
  color: rgba(248, 244, 236, 0.86);
}

.hero-proof-list li + li {
  margin-top: 0.45rem;
}

.hero-glance {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: clamp(2rem, 4vw, 3rem);
}

.hero-glance-card {
  display: grid;
  gap: 0.35rem;
  padding: 1.05rem 1.15rem;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background:
    linear-gradient(145deg, rgba(4, 14, 10, 0.52), rgba(4, 14, 10, 0.16)),
    rgba(4, 14, 10, 0.24);
  backdrop-filter: blur(18px);
}

.hero-glance-card span {
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(248, 244, 236, 0.72);
}

.hero-glance-card strong {
  font-size: 0.96rem;
  line-height: 1.55;
  color: rgba(255, 250, 242, 0.92);
}

/* ==========================================================================
   15. Breadcrumbs and Main Content Stage
   Shared page chrome immediately below the hero.
   ========================================================================== */
.breadcrumbs {
  position: relative;
  z-index: 10;
  padding-top: 1rem;
}

.breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.breadcrumbs li {
  color: var(--text-soft);
}

.breadcrumbs li + li::before {
  content: "/";
  margin-right: 0.65rem;
  color: var(--border-strong);
}

.site-main {
  position: relative;
  z-index: 3;
  padding: 0 0 5rem;
  isolation: isolate;
}

.site-main::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--content-stage-surface);
  border-top: 1px solid var(--content-stage-border);
  box-shadow: var(--content-stage-shadow);
}

/* ==========================================================================
   16. Quick Scan, Journey Strip, and Page Map
   Introductory overview surfaces that sit above the main content shell.
   ========================================================================== */
.quick-scan {
  position: relative;
  z-index: 5;
  margin: -3.5rem 0 2rem;
}

.quick-scan__shell {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  gap: 1rem;
}

.quick-scan__panel,
.topic-section--frame .topic-section__shell {
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-soft);
  background:
    linear-gradient(180deg, var(--surface-card-start), var(--surface-card-end)),
    var(--surface-card-solid);
  box-shadow: var(--shadow-md);
}

.quick-scan__panel {
  padding: 1.4rem;
}

.section-head {
  margin-bottom: 1.05rem;
}

.section-head p {
  margin-bottom: 0;
  color: var(--text-muted);
}

.journey-strip {
  display: grid;
  gap: 0.8rem;
}

.journey-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.95rem;
  align-items: start;
  padding: 0.95rem 0;
  border-bottom: 1px solid var(--border-soft);
}

.journey-step:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.journey-step__meta {
  display: grid;
  gap: 0.45rem;
  justify-items: center;
}

.journey-step__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: 2.8rem;
  border-radius: 50%;
  background: rgba(255, 250, 244, 0.9);
  color: var(--icon-gold);
  box-shadow: inset 0 0 0 1px rgba(199, 149, 60, 0.18);
}

.journey-step__icon svg {
  width: 1.1rem;
  height: 1.1rem;
}

.journey-step h3,
.page-map__head h2 {
  margin-bottom: 0.25rem;
}

.journey-step p,
.page-map__head p {
  margin: 0;
  color: var(--text-muted);
}

.journey-step__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.8rem;
  min-height: 2.1rem;
  padding: 0 0.65rem;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--secondary-soft) 0%, var(--accent-wash) 100%);
  color: #7b521c;
  font-weight: 800;
}

.page-map {
  display: grid;
  gap: 0.82rem;
}

.page-map__head {
  display: grid;
  gap: 0.28rem;
}

.page-map__links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.page-map__link {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 38px;
  padding: 0.5rem 0.8rem;
  border-radius: 1rem;
  border: 1px solid var(--border-soft);
  background: var(--surface-card-contrast);
  color: var(--text-main);
  font-weight: 700;
  font-size: 0.94rem;
  line-height: 1.35;
  text-decoration: none;
  transition:
    transform 200ms ease,
    border-color 200ms ease,
    background-color 200ms ease,
    color 200ms ease,
    box-shadow 200ms ease;
}

.page-map__icon {
  display: inline-flex;
  width: 0.82rem;
  height: 0.82rem;
  flex: 0 0 auto;
  color: var(--icon-gold);
}

.page-map__icon svg {
  width: 100%;
  height: 100%;
}

.page-map__link:hover,
.page-map__link:focus-visible {
  transform: translateY(-1px);
  border-color: var(--border-strong);
  background: rgba(255, 250, 244, 0.98);
}

/* ==========================================================================
   17. Main Shell and Sticky Sidebar
   Two-column content layout used on interior pages.
   ========================================================================== */
.main-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(250px, 285px);
  gap: 1.4rem;
  align-items: start;
  margin-top: 1.4rem;
}

.main-shell--intro {
  position: relative;
  z-index: 5;
  margin-top: -3.5rem;
}

.content-column {
  min-width: 0;
}

.sidebar-column {
  position: sticky;
  top: calc(var(--sticky-stack-height) + 1rem);
  display: grid;
  gap: 0.9rem;
}

/* ==========================================================================
   18. Shared Content Surfaces
   Core card-like wrappers for content, forms, resources, and side modules.
   These selectors intentionally overlap the earlier performance-hint block.
   ========================================================================== */
.content-block,
.sidebar-card,
.official-resources,
.faq-block,
.related-block,
.lead-form-block,
.cta-pair,
.site-disclaimer,
.trust-marker-block {
  padding: 1.5rem;
  margin-bottom: 1.35rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-soft);
  background:
    linear-gradient(180deg, var(--surface-card-start), var(--surface-card-end)),
    var(--surface-card-solid);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(22px);
}

.intro-block {
  padding: 1.65rem;
}

.intro-block h2 {
  margin-bottom: 0.85rem;
}

.intro-block p {
  max-width: var(--reading-width);
}

/* ==========================================================================
   19. Asha Chat
   Localized profile-page guide that searches public site pages and nudges
   users toward WhatsApp when the question becomes case-specific.
   ========================================================================== */
.asha-chat-block {
  position: relative;
  overflow: hidden;
  border-color: rgba(199, 149, 60, 0.22);
  background:
    radial-gradient(circle at top left, rgba(231, 154, 82, 0.16), transparent 28%),
    radial-gradient(circle at 92% 12%, rgba(116, 198, 157, 0.14), transparent 18%),
    linear-gradient(180deg, rgba(248, 243, 233, 0.98), rgba(235, 227, 215, 0.96)),
    rgba(246, 238, 225, 0.96);
}

.asha-chat-block::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), transparent 42%),
    radial-gradient(circle at 78% 24%, rgba(247, 232, 198, 0.16), transparent 24%);
}

.asha-chat__shell,
.asha-chat__messages,
.asha-chat__controls,
.asha-chat__suggestions,
.asha-chat__actions {
  position: relative;
  z-index: 1;
}

.asha-chat__shell {
  display: grid;
  gap: 1.2rem;
}

.asha-chat__intro {
  display: grid;
  grid-template-columns: minmax(220px, 0.88fr) minmax(0, 1.12fr);
  gap: 1.2rem;
  align-items: stretch;
}

.asha-chat__portrait-card,
.asha-chat__messages,
.asha-chat__result,
.asha-chat__form-shell {
  border: 1px solid rgba(27, 67, 50, 0.14);
  border-radius: 1.45rem;
  background:
    linear-gradient(180deg, rgba(253, 249, 242, 0.96), rgba(240, 234, 223, 0.94)),
    rgba(247, 240, 230, 0.95);
  box-shadow: 0 18px 42px rgba(30, 28, 24, 0.1);
}

.asha-chat__portrait-card {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: 1rem;
}

.asha-chat__portrait-wrap {
  position: relative;
  width: min(100%, 250px);
  margin: 0 auto;
  aspect-ratio: 1 / 1;
  border-radius: 1.35rem;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.44), transparent 32%),
    linear-gradient(180deg, rgba(21, 43, 34, 0.96), rgba(11, 27, 21, 0.96));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 26px 56px rgba(8, 28, 21, 0.26);
  overflow: hidden;
}

.asha-chat__portrait {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.asha-chat__status {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  width: fit-content;
  max-width: 100%;
  padding: 0.45rem 0.75rem;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(199, 149, 60, 0.26);
  background: rgba(255, 248, 238, 0.84);
  color: var(--text-main);
  font-family: var(--font-label);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.asha-chat__status::before {
  content: "";
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 50%;
  background: linear-gradient(180deg, #74c69d, #2d6a4f);
  box-shadow: 0 0 0 0.25rem rgba(116, 198, 157, 0.14);
}

.asha-chat__portrait-note {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.97rem;
}

.asha-chat__messages {
  display: grid;
  gap: 0.9rem;
  padding: 1rem;
}

.asha-chat__eyebrow {
  margin: 0;
  color: var(--sun-accent);
  font-family: var(--font-label);
  font-size: 0.82rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.asha-chat__title {
  margin: 0;
}

.asha-chat__lede {
  margin: 0;
  color: var(--text-muted);
  max-width: 62ch;
}

.asha-chat__transcript {
  display: grid;
  gap: 0.8rem;
}

.asha-chat__bubble {
  width: fit-content;
  max-width: min(100%, 42rem);
  padding: 0.95rem 1rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(27, 67, 50, 0.12);
  background: rgba(254, 250, 244, 0.94);
  box-shadow: 0 14px 30px rgba(21, 42, 32, 0.08);
}

.asha-chat__bubble p {
  margin: 0;
}

.asha-chat__bubble p + p {
  margin-top: 0.55rem;
}

.asha-chat__bubble--bot {
  color: var(--text-main);
}

.asha-chat__bubble--user {
  margin-left: auto;
  text-align: right;
  border-color: rgba(199, 149, 60, 0.3);
  background:
    linear-gradient(180deg, rgba(249, 230, 205, 0.92), rgba(239, 215, 183, 0.92)),
    rgba(243, 224, 202, 0.95);
}

.asha-chat__form-shell {
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
}

.asha-chat__form-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.asha-chat__form-head label {
  margin: 0;
  color: var(--heading-color);
  font-family: var(--font-label);
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.asha-chat__public-note {
  margin: 0;
  color: var(--text-soft);
  font-size: 0.9rem;
}

.asha-chat__input-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.8rem;
}

.asha-chat__input {
  min-width: 0;
  width: 100%;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(27, 67, 50, 0.18);
  border-radius: 1rem;
  background: rgba(255, 251, 246, 0.92);
  color: var(--text-main);
  font: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.asha-chat__input::placeholder {
  color: var(--text-soft);
}

.asha-chat__input:focus-visible {
  outline: 3px solid rgba(82, 183, 136, 0.28);
  outline-offset: 2px;
  border-color: rgba(45, 106, 79, 0.38);
}

.asha-chat__submit {
  white-space: nowrap;
}

.asha-chat__suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.asha-chat__chip {
  padding: 0.62rem 0.88rem;
  border: 1px solid rgba(27, 67, 50, 0.12);
  border-radius: var(--radius-pill);
  background:
    linear-gradient(180deg, rgba(255, 250, 244, 0.96), rgba(242, 235, 223, 0.94)),
    rgba(247, 240, 228, 0.96);
  color: var(--text-main);
  cursor: pointer;
  font: inherit;
  font-size: 0.95rem;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
}

.asha-chat__chip:hover,
.asha-chat__chip:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(199, 149, 60, 0.34);
  box-shadow: 0 12px 24px rgba(30, 28, 24, 0.08);
}

.asha-chat__results {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.9rem;
}

.asha-chat__result {
  display: grid;
  gap: 0.7rem;
  padding: 1rem;
}

.asha-chat__result-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
}

.asha-chat__family,
.asha-chat__best {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.85rem;
  padding: 0.18rem 0.65rem;
  border-radius: var(--radius-pill);
  font-family: var(--font-label);
  font-size: 0.76rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.asha-chat__family {
  border: 1px solid rgba(45, 106, 79, 0.14);
  background: rgba(221, 236, 225, 0.94);
  color: var(--accent-strong);
}

.asha-chat__best {
  border: 1px solid rgba(199, 149, 60, 0.16);
  background: rgba(247, 232, 198, 0.92);
  color: #7b521c;
}

.asha-chat__result strong {
  font-size: 1.02rem;
}

.asha-chat__result strong a {
  color: var(--heading-color);
  text-decoration: none;
}

.asha-chat__result strong a:hover,
.asha-chat__result strong a:focus-visible {
  color: var(--sun-accent);
}

.asha-chat__result p {
  margin: 0;
  color: var(--text-muted);
}

.asha-chat__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

.asha-chat__trust {
  margin: 0;
  color: var(--text-soft);
  font-size: 0.92rem;
}

body.theme-dark .asha-chat-block,
body:not(.theme-light) .asha-chat-block {
  border-color: rgba(245, 202, 163, 0.18);
  background:
    radial-gradient(circle at top left, rgba(231, 154, 82, 0.18), transparent 28%),
    radial-gradient(circle at 92% 12%, rgba(116, 198, 157, 0.18), transparent 18%),
    linear-gradient(180deg, rgba(18, 32, 25, 0.98), rgba(11, 22, 18, 0.96)),
    rgba(10, 22, 17, 0.96);
}

body.theme-dark .asha-chat__portrait-card,
body.theme-dark .asha-chat__messages,
body.theme-dark .asha-chat__result,
body.theme-dark .asha-chat__form-shell,
body:not(.theme-light) .asha-chat__portrait-card,
body:not(.theme-light) .asha-chat__messages,
body:not(.theme-light) .asha-chat__result,
body:not(.theme-light) .asha-chat__form-shell {
  border-color: rgba(183, 228, 199, 0.12);
  background:
    linear-gradient(180deg, rgba(22, 39, 31, 0.96), rgba(11, 22, 17, 0.96)),
    rgba(12, 24, 19, 0.96);
}

body.theme-dark .asha-chat__status,
body.theme-dark .asha-chat__bubble,
body.theme-dark .asha-chat__chip,
body:not(.theme-light) .asha-chat__status,
body:not(.theme-light) .asha-chat__bubble,
body:not(.theme-light) .asha-chat__chip {
  background: rgba(18, 35, 28, 0.92);
}

body.theme-dark .asha-chat__bubble--user,
body:not(.theme-light) .asha-chat__bubble--user {
  background:
    linear-gradient(180deg, rgba(108, 58, 35, 0.9), rgba(72, 36, 29, 0.92)),
    rgba(86, 45, 31, 0.9);
}

body.theme-dark .asha-chat__input,
body:not(.theme-light) .asha-chat__input {
  border-color: rgba(183, 228, 199, 0.16);
  background: rgba(13, 28, 21, 0.94);
  color: var(--text-main);
}

body.theme-dark .asha-chat__family,
body:not(.theme-light) .asha-chat__family {
  background: rgba(45, 106, 79, 0.2);
}

body.theme-dark .asha-chat__best,
body:not(.theme-light) .asha-chat__best {
  background: rgba(199, 149, 60, 0.16);
  color: var(--gold-300);
}

@media (max-width: 991px) {
  .asha-chat__intro,
  .asha-chat__input-row {
    grid-template-columns: 1fr;
  }

  .asha-chat__form-head {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ==========================================================================
   20. Sidebar Variants
   Sticky navigation rail, sidebar brand treatment, and sidebar actions.
   ========================================================================== */
.sidebar-card {
  padding: 1.05rem;
  margin-bottom: 0;
}

.sidebar-card--map {
  padding: 0.92rem;
  overflow: hidden;
  max-height: calc(100vh - var(--sticky-stack-height) - 1.65rem);
  border-color: rgba(45, 106, 79, 0.15);
  background:
    linear-gradient(180deg, rgba(234, 237, 231, 0.98), rgba(220, 225, 217, 0.96)),
    rgba(226, 231, 223, 0.96);
  box-shadow: 0 24px 46px rgba(21, 42, 32, 0.12);
}

.sidebar-card--map .page-map {
  min-height: 0;
}

..sidebar-card--map .page-map__head h2 {
  color: rgba(248, 244, 236, 0.98);
  font-size: 1rem;
  line-height: 1.2;
}

.site-footer h3 {
  color: #ffffff !important;
}

.sidebar-card--map .page-map__head p {
  color: rgba(248, 244, 236, 0.92);
  font-size: 0.92rem;
}

.sidebar-card--map .page-map__title .section-title__icon,
.sidebar-card--map .page-map__icon {
  color: var(--icon-gold);
}

.sidebar-card--map .page-map__links {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.42rem;
  min-height: 0;
  max-height: min(30rem, calc(100vh - var(--sticky-stack-height) - 8.25rem));
  overflow-y: auto;
  padding-right: 0.22rem;
  align-content: start;
  scrollbar-width: thin;
  scrollbar-color: rgba(45, 106, 79, 0.34) rgba(255, 255, 255, 0.16);
}

.sidebar-card--map .page-map__links::-webkit-scrollbar {
  width: 0.46rem;
}

.sidebar-card--map .page-map__links::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.16);
  border-radius: 999px;
}

.sidebar-card--map .page-map__links::-webkit-scrollbar-thumb {
  background: rgba(45, 106, 79, 0.34);
  border-radius: 999px;
}

.sidebar-card--map .page-map__link {
  width: 100%;
  justify-content: flex-start;
  min-height: 0;
  padding: 0.5rem 0.72rem;
  border-color: rgba(45, 106, 79, 0.16);
  background: rgba(245, 247, 242, 0.92);
  color: var(--mint-700);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.64);
}

.sidebar-card--map .page-map__link:hover,
.sidebar-card--map .page-map__link:focus-visible {
  border-color: rgba(27, 67, 50, 0.3);
  background: rgba(236, 243, 235, 0.98);
  color: var(--mint-700);
  box-shadow: 0 12px 24px rgba(27, 67, 50, 0.12);
}

.sidebar-list {
  display: grid;
  gap: 0.7rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.sidebar-list li {
  display: grid;
  gap: 0.15rem;
}

.sidebar-list strong {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.sidebar-list span {
  color: var(--text-muted);
  line-height: 1.5;
}

.sidebar-card--action p {
  color: var(--text-muted);
}

.sidebar-card--brand {
  background:
    linear-gradient(145deg, rgba(10, 32, 23, 0.96), rgba(21, 58, 42, 0.96)),
    rgba(10, 32, 23, 0.94);
  border-color: rgba(255, 255, 255, 0.08);
}

.sidebar-brand {
  display: flex;
  gap: 0.95rem;
  align-items: center;
  margin-bottom: 0.85rem;
}

.sidebar-brand__mark {
  display: block;
  width: 68px;
  height: 68px;
  flex: 0 0 auto;
}

.sidebar-brand__copy {
  display: grid;
  gap: 0.16rem;
}

.sidebar-brand__copy strong {
  color: rgba(248, 244, 236, 0.98);
  font-size: 1.02rem;
  font-weight: 700;
}

.sidebar-brand__copy span {
  display: none;
}

.sidebar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.sidebar-note {
  margin-bottom: 0;
  color: rgba(248, 244, 236, 0.82);
  font-size: 0.92rem;
}

/* ==========================================================================
   20. Topic Sections and Editorial Layouts
   Flexible content section patterns for split, banded, framed, and rail styles.
   ========================================================================== */
.topic-section {
  overflow: hidden;
}

.topic-section__shell {
  display: grid;
  gap: 1.25rem;
}

.topic-section__heading {
  display: grid;
  gap: 0.4rem;
}

.section-kicker {
  color: var(--text-soft);
}

.section-strap {
  margin: 0;
  max-width: var(--reading-width);
  color: var(--text-muted);
}

.topic-section__body {
  display: grid;
  gap: 1rem;
}

.topic-section__body p {
  max-width: var(--reading-width);
  margin: 0;
}

.topic-section__aside {
  display: grid;
  gap: 0.8rem;
}

.topic-note {
  display: grid;
  gap: 0.28rem;
  padding: 0.95rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-soft);
  background: linear-gradient(135deg, var(--surface-card-contrast), var(--secondary-soft));
}

.topic-note strong {
  color: var(--text-main);
}

.topic-note span {
  color: var(--text-muted);
}

.topic-section--split .topic-section__shell,
.topic-section--rail .topic-section__shell {
  grid-template-columns: minmax(0, 1.08fr) minmax(260px, 0.62fr);
  align-items: start;
}

.topic-section--split .topic-section__heading,
.topic-section--rail .topic-section__heading {
  grid-column: 1 / -1;
}

.topic-section--split .topic-section__body,
.topic-section--rail .topic-section__body {
  grid-column: 1;
}

.topic-section--split .topic-section__aside,
.topic-section--rail .topic-section__aside {
  grid-column: 2;
}

.topic-section--band {
  background:
    linear-gradient(135deg, var(--secondary-soft) 0%, var(--surface-card-contrast) 52%, var(--accent-wash) 100%),
    var(--surface-card-solid);
}

.topic-section--band .topic-section__shell {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
}

.topic-section--band .topic-section__heading {
  grid-column: 1;
}

.topic-section--band .topic-section__body {
  grid-column: 2;
}

.topic-section--band .topic-section__aside {
  grid-column: 1 / -1;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.topic-section--frame {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.topic-section--frame .topic-section__shell {
  padding: 1.45rem;
}

.topic-section--frame .topic-section__aside {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.topic-section--rail {
  border-left: 4px solid var(--accent);
}

.highlight-block {
  background:
    linear-gradient(135deg, var(--secondary-soft) 0%, var(--surface-card-contrast) 58%, var(--accent-wash) 100%),
    var(--surface-card-solid);
}

.alert-block {
  background:
    linear-gradient(135deg, rgba(8, 28, 21, 0.04), rgba(231, 154, 82, 0.16)),
    var(--surface-card-solid);
}

.timeline-block,
.lead-form-block {
  background:
    linear-gradient(160deg, var(--secondary-soft), var(--surface-card-contrast) 56%, rgba(199, 149, 60, 0.14)),
    var(--surface-card-solid);
}

.testimonial-strip,
.related-block {
  background:
    linear-gradient(160deg, rgba(216, 243, 220, 0.34), var(--surface-card-solid)),
    var(--surface-card-solid);
}

.official-resources,
.faq-block {
  background:
    linear-gradient(180deg, var(--surface-card-start), var(--surface-card-end)),
    var(--surface-card-solid);
}

/* ==========================================================================
   21. Section Image Backdrops
   Manifest-driven background images for long-form content sections.
   ========================================================================== */
[data-section-image="true"] {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border-color: rgba(255, 255, 255, 0.14);
  background: rgba(6, 14, 12, 0.08);
  box-shadow: 0 24px 44px rgba(5, 16, 12, 0.14);
  backdrop-filter: none;
}

[data-section-image="true"]::before,
[data-section-image="true"]::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

[data-section-image="true"]::before {
  z-index: -2;
  background-image: var(--section-image), var(--section-image);
  background-position: center, center;
  background-repeat: no-repeat, no-repeat;
  background-size: contain, cover;
  background-color: rgba(6, 14, 12, 0.1);
  filter: saturate(1.03) contrast(1.02) brightness(1.05);
}

[data-section-image="true"]::after {
  z-index: -1;
  opacity: 0.68;
  background: var(
    --section-overlay,
    linear-gradient(180deg, rgba(6, 14, 12, 0.72), rgba(8, 18, 16, 0.58)),
      linear-gradient(128deg, rgba(14, 58, 52, 0.34), rgba(25, 55, 77, 0.24))
  );
}

[data-section-image="true"] > * {
  position: relative;
  z-index: 1;
}

[data-section-image="true"] h2,
[data-section-image="true"] h3,
[data-section-image="true"] p,
[data-section-image="true"] li,
[data-section-image="true"] strong,
[data-section-image="true"] span,
[data-section-image="true"] label,
[data-section-image="true"] legend,
[data-section-image="true"] .section-kicker,
[data-section-image="true"] .section-strap,
[data-section-image="true"] .section-title,
[data-section-image="true"] .section-head p {
  color: rgba(249, 245, 236, 0.96);
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.34);
}

[data-section-image="true"] .section-title__icon,
[data-section-image="true"] .page-map__icon {
  color: var(--icon-gold);
}

[data-section-image="true"] a:not(.btn) {
  color: #fff4cb;
  text-decoration-color: rgba(255, 244, 203, 0.72);
}

[data-section-image="true"] a:not(.btn):hover,
[data-section-image="true"] a:not(.btn):focus-visible {
  color: #ffffff;
  text-decoration-color: rgba(255, 255, 255, 0.88);
}

[data-section-image="true"] .topic-section__shell {
  padding: 1.45rem;
  border-radius: inherit;
  background:
    linear-gradient(102deg, rgba(5, 16, 12, 0.34), rgba(5, 16, 12, 0.22) 56%, rgba(5, 16, 12, 0.12)),
    rgba(5, 16, 12, 0.08);
  backdrop-filter: blur(1.px) saturate(1.03);
}

[data-section-image="true"].intro-block,
[data-section-image="true"].highlight-block {
  backdrop-filter: blur(1.px) saturate(1.02);
}

[data-section-image="true"] .topic-note,
[data-section-image="true"] .info-card,
[data-section-image="true"] .resource-card,
[data-section-image="true"] .related-card {
  border-color: rgba(255, 255, 255, 0.16);
  background:
    linear-gradient(145deg, rgba(6, 14, 12, 0.42), rgba(10, 24, 20, 0.18)),
    rgba(6, 14, 12, 0.2);
  box-shadow: 0 16px 32px rgba(5, 16, 12, 0.16);
  backdrop-filter: blur(1.3px) saturate(1.03);
}

[data-section-image="true"] .topic-note strong,
[data-section-image="true"] .info-card h3,
[data-section-image="true"] .resource-card h3,
[data-section-image="true"] .related-card strong {
  color: rgba(249, 245, 236, 0.98);
}

[data-section-image="true"] .topic-note span,
[data-section-image="true"] .info-card p,
[data-section-image="true"] .resource-card p,
[data-section-image="true"] .related-card span {
  color: rgba(249, 245, 236, 0.82);
}

/* ==========================================================================
   22. Card Grids and Reusable Card Surfaces
   Resource cards, related cards, testimonial cards, and info blocks.
   ========================================================================== */
.card-grid,
.resource-grid,
.quote-grid,
.related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}

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

.info-card,
.resource-card,
.quote-card,
.related-card {
  position: relative;
  display: grid;
  gap: 0.85rem;
  padding: 1.15rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-soft);
  background: var(--surface-card-contrast);
  box-shadow: 0 16px 28px rgba(8, 28, 21, 0.05);
  text-decoration: none;
  transition:
    transform 220ms ease,
    box-shadow 220ms ease,
    border-color 220ms ease,
    background-color 220ms ease;
}

.info-card:hover,
.resource-card:hover,
.quote-card:hover,
.related-card:hover,
.info-card:focus-within,
.resource-card:focus-within,
.quote-card:focus-within,
.related-card:focus-within {
  transform: translateY(-3px);
  border-color: var(--border-strong);
  background: rgba(255, 250, 244, 0.98);
  box-shadow: var(--shadow-sm);
}

.info-card h3,
.resource-card h3,
.quote-card p,
.related-card strong {
  margin-bottom: 0.55rem;
}

.related-card__media {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: calc(var(--radius-md) - 0.35rem);
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
}

.info-card p,
.resource-card p,
.related-card span {
  margin-bottom: 0;
  color: var(--text-muted);
}

.info-card .stretched-link,
.resource-card h3 a {
  color: var(--accent-strong);
  font-weight: 800;
}

.archive-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 1rem;
  margin: 1rem 0 0;
}

.archive-jump-links {
  margin-top: 1rem;
}

.archive-section__head {
  display: grid;
  gap: 0.5rem;
}

.archive-section__intro {
  max-width: var(--reading-width);
  margin-bottom: 0;
}

.archive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}

.archive-card {
  height: 100%;
}

.archive-card__media {
  display: block;
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 1rem;
  margin-bottom: 0.95rem;
}

.archive-card__meta {
  margin: 0 0 0.55rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.timeline-list {
  margin: 0;
  padding-left: 1.3rem;
  border-left: 3px solid var(--accent);
}

.timeline-list li {
  padding-left: 0.8rem;
  margin-bottom: 0.8rem;
}

.quote-card footer {
  display: flex;
  justify-content: space-between;
  gap: 0.7rem;
  margin-top: 0.85rem;
  color: var(--text-soft);
  font-size: 0.9rem;
}

.quote-grid.expanded {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.small-note {
  color: var(--text-soft);
  font-size: 0.95rem;
}

.profile-block {
  background:
    linear-gradient(160deg, var(--secondary-soft), var(--surface-card-solid)),
    var(--surface-card-solid);
}

.fact-sheet {
  display: grid;
  gap: 0.85rem;
}

.fact-sheet div {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--border-soft);
}

.fact-sheet strong {
  color: var(--text-soft);
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.fact-sheet span {
  color: var(--text-main);
  font-weight: 700;
  text-align: right;
}

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

.marker {
  padding: 1.05rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-soft);
  background: linear-gradient(135deg, var(--surface-card-contrast), var(--secondary-soft));
}

.marker strong {
  display: block;
  margin-bottom: 0.35rem;
}

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

/* ==========================================================================
   22. Forms and Search
   Lead capture forms, inline search, and result listing presentation.
   ========================================================================== */
.lead-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.15rem;
  align-items: start;
}

.lead-form label {
  display: grid;
  gap: 0.48rem;
  font-weight: 700;
  color: var(--text-main);
  align-content: start;
}

.lead-form textarea,
.lead-form input,
.lead-form select,
.search-inline-form input {
  min-height: 56px;
  padding: 0.98rem 1rem;
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-xs);
  background: var(--surface-card-contrast);
  color: var(--text-main);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
  transition: border-color 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}

.lead-form textarea::placeholder,
.lead-form input::placeholder,
.search-inline-form input::placeholder {
  color: var(--text-soft);
}

.lead-form textarea:focus,
.lead-form input:focus,
.lead-form select:focus,
.search-inline-form input:focus {
  outline: 0;
  border-color: rgba(235, 200, 126, 0.42);
  box-shadow:
    0 0 0 4px rgba(199, 149, 60, 0.14),
    0 16px 32px rgba(8, 28, 21, 0.12);
  background: var(--surface-card-solid);
}

.lead-form textarea {
  min-height: 180px;
  resize: vertical;
}

.lead-form label:has(textarea),
.lead-form-full label:has(textarea),
.form-note,
.lead-form button {
  grid-column: 1 / -1;
}

.lead-form button {
  width: 100%;
  justify-self: stretch;
}

.form-note p {
  margin: 0;
  color: var(--text-muted);
}

.search-inline-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: stretch;
  margin-bottom: 1rem;
}

.search-inline-form input {
  flex: 1 1 280px;
  font-style: italic;
}

.search-inline-form input::placeholder {
  color: var(--text-soft);
  font-style: italic;
}

.search-inline-form button {
  min-height: 50px;
  padding: 0.88rem 1.2rem;
  border: 1px solid rgba(199, 149, 60, 0.34);
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, rgba(255, 249, 239, 0.98), rgba(247, 232, 198, 0.92));
  color: #7b521c;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.52rem;
  font-weight: 800;
  box-shadow: 0 12px 26px rgba(199, 149, 60, 0.16);
  transition:
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 220ms ease,
    border-color 220ms ease,
    background-color 220ms ease,
    color 220ms ease;
}

.search-inline-form button:hover,
.search-inline-form button:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(199, 149, 60, 0.5);
  background: linear-gradient(135deg, #fff7e6, #f3dfb1);
  color: #5d3f17;
  box-shadow: 0 18px 32px rgba(199, 149, 60, 0.22);
}

.search-inline-form__submit-icon {
  display: inline-flex;
  width: 1rem;
  height: 1rem;
  color: var(--icon-gold);
}

.search-inline-form__submit-icon svg {
  width: 100%;
  height: 100%;
}

.search-result {
  padding: 1rem 0;
  border-bottom: 1px solid var(--border-soft);
}

.search-result:last-child {
  border-bottom: 0;
}

.search-result strong {
  display: block;
  margin-bottom: 0.35rem;
}

.search-result span,
.search-result p {
  color: var(--text-muted);
}

/* ==========================================================================
   23. Accordions and Disclosure Blocks
   ========================================================================== */
.accordion-item {
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm) !important;
  overflow: hidden;
  background: var(--surface-card-contrast);
  box-shadow: 0 10px 24px rgba(8, 28, 21, 0.04);
}

.accordion-item + .accordion-item {
  margin-top: 0.85rem;
}

.accordion-button {
  padding: 1rem 1.1rem;
  background: var(--surface-card-contrast);
  color: var(--text-main);
  font-weight: 800;
}

.accordion-button:not(.collapsed) {
  background: linear-gradient(135deg, var(--surface-card-contrast), var(--secondary-soft));
  color: var(--text-main);
  box-shadow: none;
}

.accordion-button:focus {
  box-shadow: inset 0 0 0 2px rgba(199, 149, 60, 0.24);
}

.accordion-body {
  color: var(--text-muted);
  background: var(--surface-card-solid);
}

/* ==========================================================================
   24. CTA and Disclaimer Blocks
   ========================================================================== */
.cta-pair {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

.site-disclaimer {
  background: linear-gradient(135deg, rgba(8, 28, 21, 0.94), rgba(18, 54, 39, 0.92));
  color: rgba(248, 244, 236, 0.88);
  font-size: 0.8rem;
  line-height: 1.65;
  letter-spacing: 0.01em;
  padding: 0.95rem 1.1rem;
}

.site-disclaimer p {
  margin: 0;
}

.site-disclaimer p + p {
  margin-top: 0.7rem;
}

/* ==========================================================================
   25. Site Footer
   Shared footer system for EN and PT partials. Keeps the eight-column desktop
   layout on large screens, relaxes to four columns on tablet, and two columns
   on mobile while letting the brand column span full width when needed.
   ========================================================================== */
/* =========================
   FOOTER LAYOUT FIX
   ========================= */

.site-footer {
  padding: 3rem 0 2rem;
  background:
    radial-gradient(circle at top, rgba(235,200,126,0.12), transparent 40%),
    linear-gradient(180deg, #062019, #02110d);
  color: rgba(248,244,236,0.85);
}

.container {
  width: min(1560px, 96%);
  margin: auto;
}

/* ROW 1: 8 COLUMNS */
.footer-grid {
  display: grid;
  grid-template-columns:
    minmax(260px, 1.5fr)
    repeat(7, minmax(120px, 1fr));
  gap: 2rem;
}

/* PANELS */
.footer-panel {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-left: 1rem;
  border-left: 1px solid rgba(255,255,255,0.08);
}

.footer-panel:first-child {
  border-left: none;
  padding-left: 0;
}

/* BRAND */
.footer-brand-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.footer-logo {
  width: 48px;
}

.footer-description {
  font-size: 0.85rem;
  color: rgba(248,244,236,0.65);
}

/* BUTTONS */
.footer-buttons {
  display: flex;
  gap: 0.5rem;
}

.btn-primary {
  background: linear-gradient(135deg, #e7c77a, #b08a3c);
  color: #1a1205;
  padding: 0.5rem 0.8rem;
  border-radius: 6px;
  font-size: 0.75rem;
  text-decoration: none;
}

.btn-outline {
  border: 1px solid rgba(255,255,255,0.2);
  padding: 0.5rem 0.8rem;
  border-radius: 6px;
  font-size: 0.75rem;
  color: white;
  text-decoration: none;
}

/* LISTS */
.footer-panel ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-panel a {
  font-size: 0.78rem;
  color: rgba(248,244,236,0.85);
  text-decoration: none;
}

.footer-panel a:hover {
  color: #fff;
}

.footer-grid.footer-grid--directory {
  grid-template-columns:
    minmax(280px, 2.15fr)
    repeat(5, minmax(0, 0.88fr))
    minmax(210px, 1.28fr);
  align-items: start;
  gap: 1.2rem;
}

.footer-panel--directory h3 {
  margin: 0 0 0.65rem;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.footer-panel--directory h3 a {
  color: #fff;
  text-decoration: none;
}

.footer-link-list {
  display: grid;
  gap: 0.34rem;
}

.footer-link-list--dense {
  gap: 0.28rem;
}

.footer-link-list--root {
  margin-bottom: 0.15rem;
}

.footer-link-list--columns,
.footer-country-list {
  display: block;
}

.footer-link-list--columns {
  columns: 2 8.75rem;
  column-gap: 1rem;
}

.footer-link-list--columns li,
.footer-country-list li {
  break-inside: avoid;
  margin-bottom: 0.42rem;
}

.footer-panel--stacked {
  gap: 0.8rem;
}

.footer-disclosure {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 0.68rem;
}

.footer-disclosure:first-of-type {
  border-top: none;
  padding-top: 0;
}

.footer-disclosure summary {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  cursor: pointer;
  list-style: none;
  color: #fff;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.footer-disclosure summary::-webkit-details-marker {
  display: none;
}

.footer-disclosure summary::after {
  content: "+";
  flex: none;
  color: var(--icon-gold);
  font-size: 1.05rem;
  line-height: 1;
}

.footer-disclosure[open] summary::after {
  content: "-";
}

.footer-disclosure__body {
  margin-top: 0.55rem;
  display: grid;
  gap: 0.72rem;
}

.footer-disclosure__body--scroll {
  max-height: 16rem;
  overflow: auto;
  padding-right: 0.3rem;
}

.footer-subgroups {
  display: grid;
  gap: 0.75rem;
}

.footer-subgroup {
  display: grid;
  gap: 0.32rem;
}

.footer-subgroup__title {
  margin: 0;
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(248,244,236,0.64);
}

.footer-subgroup__title a {
  color: inherit;
  text-decoration: none;
}

.footer-brand {
  gap: 0.9rem;
  padding-right: 0.5rem;
}

.footer-brand .footer-logo {
  width: 42px;
}

.footer-brand .footer-description {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.55;
}

.footer-brand .footer-buttons {
  flex-wrap: wrap;
}

.footer-contact {
  display: grid;
  gap: 0.36rem;
  margin-top: 0.1rem;
  padding-top: 0.7rem;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.footer-contact li {
  font-size: 0.74rem;
  line-height: 1.45;
  color: rgba(248,244,236,0.74);
}

.footer-grid.footer-grid--directory .footer-panel:not(.footer-brand) a {
  font-size: 0.72rem;
  line-height: 1.35;
}

.footer-grid.footer-grid--directory .footer-panel--stacked {
  min-width: 0;
}

.footer-country-list {
  columns: 2 10rem;
  column-gap: 1rem;
}

/* ROW 2 */
.footer-row--legal {
  margin-top: 2rem;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 1.5rem;
}

.footer-row--legal p {
  margin: 0.3rem 0;
  font-size: 0.8rem;
}

/* CTA */
.footer-main-cta {
  margin-top: 1rem;
  display: inline-block;
  padding: 0.6rem 1rem;
  background: linear-gradient(135deg, #6b4ca3, #3d255e);
  border-radius: 8px;
  color: white;
  text-decoration: none;
}

/* ROW 3 */
.footer-row--meta {
  margin-top: 1.5rem;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 1rem;
}

.footer-links {
  margin-bottom: 0.5rem;
}

.footer-links a {
  color: rgba(248,244,236,0.85);
  text-decoration: none;
}

.footer-search {
  display: inline-block;
  border: 1px solid rgba(235,200,126,0.3);
  padding: 0.3rem 0.7rem;
  border-radius: 999px;
  font-size: 0.75rem;
}

/* RESPONSIVE */
@media (max-width: 1200px) {
  .footer-grid {
    grid-template-columns: repeat(3, 1fr);
  }

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

  .footer-grid.footer-grid--directory .footer-brand {
    grid-column: span 3;
  }

  .footer-grid.footer-grid--directory .footer-panel--stacked {
    grid-column: span 2;
  }
}

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

  .footer-panel {
    border-left: none;
    padding-left: 0;
  }

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

  .footer-grid.footer-grid--directory .footer-brand,
  .footer-grid.footer-grid--directory .footer-panel--stacked {
    grid-column: auto;
  }

  .footer-link-list--columns,
  .footer-country-list {
    columns: 1;
  }
}

/* ==========================================================================
   26. Floating Utilities and Cookie Banner
   Persistent global controls layered above page content.
   ========================================================================== */
.floating-whatsapp,
.back-to-top {
  position: fixed;
  right: 1rem;
  z-index: 1050;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  min-height: 58px;
  padding: 0;
  border-radius: var(--radius-pill);
  backdrop-filter: blur(18px);
  transition:
    transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 220ms ease,
    border-color 220ms ease,
    background-color 220ms ease,
    opacity 220ms ease;
}

.floating-whatsapp {
  bottom: 5.6rem;
  border: 1px solid rgba(37, 211, 102, 0.62);
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.18), transparent 42%),
    linear-gradient(180deg, rgba(17, 55, 38, 0.98), rgba(9, 28, 20, 0.96));
  color: #ffffff;
  text-decoration: none;
  box-shadow:
    0 0 0 10px rgba(124, 90, 166, 0.14),
    0 0 28px rgba(124, 90, 166, 0.28),
    0 18px 34px rgba(8, 28, 21, 0.28),
    inset 0 0 0 1px rgba(255, 255, 255, 0.06);
  animation: whatsapp-beacon 2.1s ease-in-out infinite;
}

.floating-whatsapp::before {
  content: "";
  position: absolute;
  inset: -0.32rem;
  pointer-events: none;
  border-radius: inherit;
  border: 1px solid rgba(37, 211, 102, 0.24);
  opacity: 0;
  transform: scale(0.88);
  animation: whatsapp-ring 2.1s ease-out infinite;
}

.floating-whatsapp::after {
  content: "";
  position: absolute;
  inset: -0.55rem;
  z-index: -1;
  pointer-events: none;
  border-radius: inherit;
  background: radial-gradient(circle, rgba(124, 90, 166, 0.42) 0%, rgba(124, 90, 166, 0.18) 38%, rgba(124, 90, 166, 0) 72%);
  filter: blur(10px);
  opacity: 0.92;
  transform: scale(0.96);
  animation: whatsapp-plum-glow 2.1s ease-in-out infinite;
}

.floating-whatsapp__icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.3rem;
  height: 2.3rem;
  animation: whatsapp-logo-pop 1.55s ease-in-out infinite;
}

.floating-whatsapp__logo {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: linear-gradient(180deg, #25d366, #1eba57);
  color: var(--icon-gold);
  box-shadow:
    0 0 0 0.22rem rgba(255, 255, 255, 0.08),
    0 12px 24px rgba(37, 211, 102, 0.24);
}

.floating-whatsapp__logo svg {
  width: 1.4rem;
  height: 1.4rem;
  display: block;
}

/* Legacy partial fallback: if an older pill-style WhatsApp partial is served
   briefly after deploy, keep the layout compact and hide stale copy instead of
   letting the text collapse into a broken vertical stack. */
.floating-whatsapp .floating-whatsapp__avatar-wrap,
.floating-whatsapp .floating-whatsapp__content {
  display: none;
}

.floating-whatsapp .floating-whatsapp__badge {
  position: static;
  width: auto;
  height: auto;
  border: 0;
  background: transparent;
  color: var(--icon-gold);
  box-shadow: none;
}

.floating-whatsapp .floating-whatsapp__badge svg {
  width: 1.22rem;
  height: 1.22rem;
}

.floating-whatsapp:not(:has(.floating-whatsapp__icon)) {
  overflow: hidden;
}

.floating-whatsapp:not(:has(.floating-whatsapp__icon))::before {
  animation: none;
  opacity: 0;
}

.floating-whatsapp:hover,
.floating-whatsapp:focus-visible {
  transform: translateY(-3px) scale(1.01);
  border-color: rgba(37, 211, 102, 0.82);
  color: #ffffff;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.22), transparent 42%),
    linear-gradient(180deg, rgba(24, 73, 50, 0.98), rgba(9, 28, 20, 0.98));
  box-shadow:
    0 0 0 12px rgba(124, 90, 166, 0.18),
    0 0 34px rgba(124, 90, 166, 0.32),
    0 26px 46px rgba(8, 28, 21, 0.34),
    0 0 0 6px rgba(37, 211, 102, 0.1);
}

.back-to-top {
  bottom: 1rem;
  border: 1px solid rgba(235, 200, 126, 0.62);
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(255, 250, 242, 0.18), transparent 42%), linear-gradient(180deg, rgba(16, 37, 29, 0.98), rgba(12, 28, 22, 0.94));
  color: var(--icon-gold);
  box-shadow:
    0 18px 34px rgba(8, 28, 21, 0.28),
    inset 0 0 0 1px rgba(255, 255, 255, 0.08);
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
}

.back-to-top.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  animation: back-to-top-pulse 3.4s ease-in-out infinite;
}

.back-to-top__icon {
  display: inline-flex;
  width: 1.35rem;
  height: 1.35rem;
  animation: back-to-top-arrow 2.4s ease-in-out infinite;
}

.back-to-top__icon svg {
  width: 100%;
  height: 100%;
}

.back-to-top:hover,
.back-to-top:focus-visible {
  transform: translateY(-3px) scale(1.01);
  border-color: rgba(235, 200, 126, 0.84);
  background: radial-gradient(circle at 30% 30%, rgba(255, 250, 242, 0.22), transparent 42%), linear-gradient(180deg, rgba(22, 47, 37, 0.98), rgba(12, 28, 22, 0.98));
  color: var(--icon-gold);
  box-shadow: 0 26px 46px rgba(8, 28, 21, 0.34);
}

.cookie-banner {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  left: auto;
  z-index: 1090;
  width: min(34rem, calc(100vw - 1.5rem));
}

.cookie-banner__inner {
  display: grid;
  gap: 1rem;
  padding: 1.15rem 1.2rem;
  border-radius: var(--radius-md);
  background: var(--surface-dark-soft);
  color: #fffaf2;
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
}

.cookie-banner__inner p {
  margin-bottom: 0;
  color: rgba(248, 244, 236, 0.76);
}

.cookie-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

/* ==========================================================================
   27. Dark Theme Component Overrides
   Component-level dark surface adjustments layered after shared components.
   ========================================================================== */
body.theme-dark .utility-link,
body.theme-dark .toggle-button,
body.theme-dark .panel-close,
body.theme-dark .page-map__link,
body.theme-dark .mega-link,
body.theme-dark .journey-step__icon,
body.theme-dark .info-card,
body.theme-dark .resource-card,
body.theme-dark .quote-card,
body.theme-dark .related-card,
body.theme-dark .lead-form textarea,
body.theme-dark .lead-form input,
body.theme-dark .lead-form select,
body.theme-dark .search-inline-form input,
body.theme-dark .accordion-item,
body.theme-dark .accordion-button {
  background: var(--surface-card-contrast);
  color: var(--text-main);
}

body.theme-dark .utility-link--nav {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-inverse);
}

body.theme-dark .utility-link:hover,
body.theme-dark .utility-link:focus-visible,
body.theme-dark .toggle-button:hover,
body.theme-dark .toggle-button:focus-visible,
body.theme-dark .page-map__link:hover,
body.theme-dark .page-map__link:focus-visible,
body.theme-dark .mega-link:hover,
body.theme-dark .mega-link:focus-visible,
body.theme-dark .info-card:hover,
body.theme-dark .resource-card:hover,
body.theme-dark .quote-card:hover,
body.theme-dark .related-card:hover,
body.theme-dark .info-card:focus-within,
body.theme-dark .resource-card:focus-within,
body.theme-dark .quote-card:focus-within,
body.theme-dark .related-card:focus-within {
  background: rgba(22, 48, 36, 0.98);
}

body.theme-dark .utility-link:hover,
body.theme-dark .utility-link:focus-visible,
body.theme-dark .toggle-button:hover,
body.theme-dark .toggle-button:focus-visible,
body.theme-dark .panel-close:hover,
body.theme-dark .panel-close:focus-visible {
  background: linear-gradient(135deg, rgba(199, 176, 232, 0.22), rgba(16, 36, 27, 0.96));
  color: var(--gold-100);
}

body.theme-dark .btn::before {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 58%);
}

body.theme-dark .section-title__icon,
body.theme-dark .journey-step__icon,
body.theme-dark .page-map__icon {
  color: var(--icon-gold);
}

body.theme-dark .sidebar-card--map,
body:not(.theme-light) .sidebar-card--map {
  border-color: rgba(149, 213, 178, 0.14);
  background:
    linear-gradient(180deg, rgba(27, 38, 33, 0.98), rgba(17, 25, 21, 0.96)),
    rgba(17, 25, 21, 0.96);
  box-shadow: 0 26px 48px rgba(0, 0, 0, 0.3);
}

body.theme-dark .sidebar-card--map .page-map__head p,
body:not(.theme-light) .sidebar-card--map .page-map__head p {
  color: rgba(231, 245, 235, 0.72);
}

body.theme-dark .sidebar-card--map .page-map__title .section-title__icon,
body.theme-dark .sidebar-card--map .page-map__icon,
body:not(.theme-light) .sidebar-card--map .page-map__title .section-title__icon,
body:not(.theme-light) .sidebar-card--map .page-map__icon {
  color: var(--icon-gold);
}

body.theme-dark .sidebar-card--map .page-map__link,
body:not(.theme-light) .sidebar-card--map .page-map__link {
  border-color: rgba(149, 213, 178, 0.14);
  background: rgba(14, 34, 26, 0.94);
  color: var(--mint-100);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.theme-dark .sidebar-card--map .page-map__link:hover,
body.theme-dark .sidebar-card--map .page-map__link:focus-visible,
body:not(.theme-light) .sidebar-card--map .page-map__link:hover,
body:not(.theme-light) .sidebar-card--map .page-map__link:focus-visible {
  border-color: rgba(149, 213, 178, 0.3);
  background: rgba(21, 51, 39, 0.98);
  color: var(--mint-050);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.24);
}

body.theme-dark .search-inline-form button {
  background: linear-gradient(135deg, rgba(247, 232, 198, 0.92), rgba(199, 149, 60, 0.82));
  color: #2f1b0b;
}

body.theme-dark .search-inline-form input::placeholder {
  color: rgba(231, 245, 235, 0.44);
}

/* ==========================================================================
   28. Motion and Reveal Helpers
   ========================================================================== */
@keyframes hero-rise {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes hero-glow {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(-2%, -3%, 0) scale(1.04);
  }
}

@keyframes cta-beacon {
  0%,
  100% {
    transform: translateY(0);
    box-shadow: 0 20px 38px rgba(205, 108, 40, 0.22);
  }
  50% {
    transform: translateY(-2px);
    box-shadow: 0 28px 48px rgba(205, 108, 40, 0.3);
  }
}

@keyframes cta-sheen {
  0%,
  14% {
    transform: translateX(-165%) skewX(-18deg);
    opacity: 0;
  }
  20%,
  58% {
    opacity: 0.82;
  }
  100% {
    transform: translateX(370%) skewX(-18deg);
    opacity: 0;
  }
}

@keyframes mobile-consult-float {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-1px) scale(1.01);
  }
}

@keyframes mobile-consult-glow {
  0%,
  100% {
    box-shadow:
      0 14px 24px rgba(65, 31, 86, 0.22),
      0 0 0 7px rgba(124, 90, 166, 0.14),
      inset 0 1px 0 rgba(255, 255, 255, 0.38);
  }
  50% {
    box-shadow:
      0 17px 27px rgba(65, 31, 86, 0.24),
      0 0 0 10px rgba(124, 90, 166, 0.18),
      inset 0 1px 0 rgba(255, 255, 255, 0.42);
  }
}

@keyframes back-to-top-pulse {
  0%,
  100% {
    box-shadow:
      0 18px 34px rgba(8, 28, 21, 0.28),
      inset 0 0 0 1px rgba(255, 255, 255, 0.08);
  }
  50% {
    box-shadow:
      0 21px 38px rgba(8, 28, 21, 0.31),
      0 0 0 4px rgba(235, 200, 126, 0.08),
      inset 0 0 0 1px rgba(255, 255, 255, 0.12);
  }
}

@keyframes back-to-top-arrow {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-1px);
  }
}

@keyframes back-to-top-aura {
  0%,
  100% {
    opacity: 0.72;
    filter: saturate(1) brightness(1);
  }
  50% {
    opacity: 0.96;
    filter: saturate(1.08) brightness(1.08);
  }
}

@keyframes back-to-top-core {
  0%,
  100% {
    opacity: 0.98;
    transform: translateY(0) scale(1);
  }
  50% {
    opacity: 1;
    transform: translateY(-1px) scale(1.015);
  }
}

@keyframes back-to-top-arrow-site {
  0%,
  100% {
    transform: translateY(0);
  }
  45% {
    transform: translateY(-1px);
  }
  62% {
    transform: translateY(-3px);
  }
}

@keyframes whatsapp-beacon {
  0%,
  100% {
    transform: translateY(0) scale(1);
    box-shadow:
      0 0 0 10px rgba(124, 90, 166, 0.14),
      0 0 28px rgba(124, 90, 166, 0.28),
      0 18px 34px rgba(8, 28, 21, 0.28),
      inset 0 0 0 1px rgba(255, 255, 255, 0.06);
  }
  50% {
    transform: translateY(-2px) scale(1.035);
    box-shadow:
      0 0 0 14px rgba(124, 90, 166, 0.18),
      0 0 42px rgba(124, 90, 166, 0.38),
      0 24px 44px rgba(8, 28, 21, 0.34),
      0 0 0 6px rgba(37, 211, 102, 0.12),
      inset 0 0 0 1px rgba(255, 255, 255, 0.12);
  }
}

@keyframes whatsapp-ring {
  0%,
  100% {
    opacity: 0;
    transform: scale(0.9);
  }
  22% {
    opacity: 0.58;
  }
  68% {
    opacity: 0;
    transform: scale(1.26);
  }
}

@keyframes whatsapp-logo-pop {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  18% {
    transform: translateY(-1px) scale(1.08);
  }
  34% {
    transform: translateY(0) scale(1);
  }
  52% {
    transform: translateY(-1px) scale(1.07);
  }
}

@keyframes whatsapp-plum-glow {
  0%,
  100% {
    opacity: 0.84;
    transform: scale(0.94);
    filter: blur(10px);
  }
  50% {
    opacity: 1;
    transform: scale(1.08);
    filter: blur(14px);
  }
}

/* Shared reveal helper. Keep footer-specific sections out of this system to
   avoid opacity-related clipping or hidden content after runtime injection. */
.reveal {
  opacity: 0;
  transition: opacity 160ms ease-out;
}

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

/* ==========================================================================
   29. Accessibility Mode Overrides
   These rules are intentionally forceful and rely on `!important` so they can
   win against component-specific styling when an accessibility mode is active.
   ========================================================================== */
body.a11y-contrast {
  --surface-base: #ffffff;
  --surface-raised: #ffffff;
  --surface-glass: #ffffff;
  --surface-strong: #ffffff;
  --surface-dark: #000000;
  --surface-dark-soft: #000000;
  --text-main: #000000;
  --text-muted: rgba(0, 0, 0, 0.9);
  --text-soft: rgba(0, 0, 0, 0.78);
  --text-inverse: #ffffff;
  --border-soft: rgba(0, 0, 0, 0.32);
  --border-strong: rgba(0, 0, 0, 0.8);
  --accent: #000000;
  --accent-strong: #000000;
  --accent-soft: rgba(0, 0, 0, 0.08);
  --accent-wash: rgba(0, 0, 0, 0.08);
  --accent-contrast: #ffffff;
  background: #ffffff;
  color: #000000;
}

body.a11y-contrast .utility-bar,
body.a11y-contrast .main-nav,
body.a11y-contrast .service-family-menu,
body.a11y-contrast .accessibility-panel,
body.a11y-contrast .content-block,
body.a11y-contrast .official-resources,
body.a11y-contrast .faq-block,
body.a11y-contrast .related-block,
body.a11y-contrast .lead-form-block,
body.a11y-contrast .cta-pair,
body.a11y-contrast .site-disclaimer,
body.a11y-contrast .trust-marker-block,
body.a11y-contrast .sidebar-card,
body.a11y-contrast .hero-panel,
body.a11y-contrast .hero-glance-card,
body.a11y-contrast .hero-badge,
body.a11y-contrast .hero-kicker,
body.a11y-contrast .footer-panel,
body.a11y-contrast .footer-bottom,
body.a11y-contrast .footer-meta,
body.a11y-contrast .cookie-banner__inner,
body.a11y-contrast .resource-card,
body.a11y-contrast .related-card,
body.a11y-contrast .info-card,
body.a11y-contrast .marker,
body.a11y-contrast .quick-scan__panel {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

body.a11y-contrast .cookie-badge {
  background: transparent !important;
  color: #000000 !important;
  border-color: #000000 !important;
}

body.a11y-contrast .hero {
  background: #ffffff !important;
  color: #000000 !important;
}

body.a11y-contrast .hero-overlay,
body.a11y-contrast .hero::before,
body.a11y-contrast .hero::after {
  display: none !important;
}

body.a11y-contrast [data-section-image="true"]::before,
body.a11y-contrast [data-section-image="true"]::after {
  display: none !important;
}

body.a11y-contrast .hero-summary,
body.a11y-contrast .hero h1,
body.a11y-contrast .hero h2,
body.a11y-contrast .hero h3,
body.a11y-contrast .hero h4,
body.a11y-contrast .hero h5,
body.a11y-contrast .hero h6,
body.a11y-contrast .hero-panel p,
body.a11y-contrast .hero-proof-list,
body.a11y-contrast .hero-glance-card span,
body.a11y-contrast .hero-glance-card strong,
body.a11y-contrast .eyebrow,
body.a11y-contrast .hero-panel a,
body.a11y-contrast .footer-meta,
body.a11y-contrast .footer-meta a,
body.a11y-contrast .footer-panel__group a,
body.a11y-contrast .footer-contact-list a {
  color: #000000 !important;
}

body.a11y-contrast a {
  color: #000000 !important;
  text-decoration: underline;
}

body.a11y-contrast .btn {
  background: #000000 !important;
  color: #ffffff !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

body.a11y-contrast .btn-secondary,
body.a11y-contrast .utility-link,
body.a11y-contrast .footer-actions a,
body.a11y-contrast .footer-search-trigger,
body.a11y-contrast .service-family-menu__heading,
body.a11y-contrast .service-family-menu__link,
body.a11y-contrast .main-nav .nav-link,
body.a11y-contrast .main-nav .dropdown-toggle {
  background: transparent !important;
  color: #000000 !important;
  border-color: #000000 !important;
}

body.a11y-contrast .utility-support,
body.a11y-contrast .lang-switcher--minimal,
body.a11y-contrast .lang-link,
body.a11y-contrast .utility-action--text,
body.a11y-contrast .main-nav .brand-lockup,
body.a11y-contrast .main-nav .brand-lockup__meta,
body.a11y-contrast .main-nav .brand-lockup__meta small,
body.a11y-contrast .main-nav .main-header__home {
  color: #000000 !important;
}

body.a11y-contrast .main-nav .navbar-toggler {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

body.a11y-contrast .main-nav .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23000000' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
  filter: none !important;
}

body.a11y-contrast input,
body.a11y-contrast select,
body.a11y-contrast textarea {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: #000000 !important;
}

body.a11y-contrast .floating-whatsapp,
body.a11y-contrast .back-to-top {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

body.a11y-contrast .footer-search-trigger__hint,
body.a11y-contrast .floating-whatsapp__logo {
  color: #000000 !important;
}

body.a11y-contrast .sidebar-card--map .page-map__head h2,
body.a11y-contrast .sidebar-card--map .page-map__head p,
body.a11y-contrast .sidebar-card--map .page-map__links a {
  color: #f8f4ec !important;
}

body.a11y-contrast .floating-whatsapp__logo {
  background: #ffffff !important;
  box-shadow: none !important;
}

body.a11y-contrast .floating-whatsapp .floating-whatsapp__badge {
  color: #000000 !important;
}

body.a11y-contrast .floating-whatsapp::before {
  display: none !important;
}

body.a11y-contrast .back-to-top::before,
body.a11y-contrast .back-to-top::after {
  display: none !important;
}

body.a11y-invert {
  filter: invert(1) hue-rotate(180deg);
}

body.a11y-grayscale {
  filter: grayscale(1);
}

body.a11y-dyslexia {
  --font-display: var(--dyslexia-font, var(--font-body-default));
  --font-body: var(--dyslexia-font, var(--font-body-default));
  --font-label: var(--dyslexia-font, var(--font-body-default));
  font-family: var(--font-body);
  word-spacing: 0.05em;
}

body.a11y-dyslexia h1,
body.a11y-dyslexia h2,
body.a11y-dyslexia h3,
body.a11y-dyslexia h4,
body.a11y-dyslexia h5,
body.a11y-dyslexia h6,
body.a11y-dyslexia .brand-wordmark__line {
  letter-spacing: 0.01em;
  line-height: 1.12;
}

body.a11y-links a {
  outline: 2px solid rgba(200, 160, 98, 0.86);
  outline-offset: 2px;
  text-decoration-thickness: 0.2em;
  text-underline-offset: 0.16em;
}

body.a11y-headings h1,
body.a11y-headings h2,
body.a11y-headings h3,
body.a11y-headings h4,
body.a11y-headings h5,
body.a11y-headings h6 {
  background: rgba(200, 160, 98, 0.18);
  border-radius: 0.45rem;
  padding-inline: 0.25rem;
}

body.a11y-hide-images img,
body.a11y-hide-images picture {
  display: none !important;
}

body.a11y-hide-images .hero {
  background: #ffffff !important;
  color: var(--text-main) !important;
}

body.a11y-hide-images .hero-overlay,
body.a11y-hide-images .hero::before,
body.a11y-hide-images .hero::after {
  display: none !important;
}

body.a11y-hide-images [data-section-image="true"]::before,
body.a11y-hide-images [data-section-image="true"]::after {
  display: none !important;
}

body.a11y-hide-images [data-section-image="true"] {
  background:
    linear-gradient(180deg, var(--surface-card-start), var(--surface-card-end)),
    var(--surface-card-solid) !important;
}

body.a11y-hide-images .eyebrow,
body.a11y-hide-images .hero h1,
body.a11y-hide-images .hero h2,
body.a11y-hide-images .hero h3,
body.a11y-hide-images .hero h4,
body.a11y-hide-images .hero h5,
body.a11y-hide-images .hero h6,
body.a11y-hide-images .hero-summary,
body.a11y-hide-images .hero-panel p,
body.a11y-hide-images .hero-panel a,
body.a11y-hide-images .hero-proof-list,
body.a11y-hide-images .hero-glance-card span,
body.a11y-hide-images .hero-glance-card strong {
  color: var(--text-main) !important;
}

body.a11y-hide-images .hero-kicker,
body.a11y-hide-images .hero-badge,
body.a11y-hide-images .hero-panel,
body.a11y-hide-images .hero-glance-card {
  background: #ffffff !important;
  border-color: var(--border-strong) !important;
  box-shadow: none !important;
}

/* ==========================================================================
   30. Motion Preferences
   ========================================================================== */
body.reduced-motion *,
body.reduced-motion *::before,
body.reduced-motion *::after {
  animation: none !important;
  transition-duration: 0.01ms !important;
  scroll-behavior: auto !important;
}

/* ==========================================================================
   31. Responsive Breakpoints
   Ordered from broader desktop adjustments down to very small screens.
   ========================================================================== */
@media (max-width: 1199px) {
  .main-header {
    padding: 0.88rem 0;
  }

  .main-nav .navbar-collapse.show,
  .main-nav .navbar-collapse.collapsing {
    padding-top: 0.9rem;
    padding-bottom: 1rem;
    border-top: 1px solid var(--border-soft);
  }

  .brand-lockup__image .brand-wordmark__mark {
    width: 50px;
    height: 50px;
  }

  .brand-lockup__image .brand-wordmark__line--top,
  .brand-lockup__image .brand-wordmark__line--bottom {
    font-size: 1.08rem;
  }

  .brand-lockup__meta small {
    font-size: 0.62rem;
  }
}

/* Large desktop tightening for dense primary nav labels. */
@media (max-width: 1399px) {
  .navbar-nav--services .nav-link,
  .navbar-nav--services .dropdown-toggle {
    font-size: 0.93rem;
  }
}

/* Footer wraps sooner here to protect the right-most columns from clipping. */
@media (max-width: 1279px) {
  .footer-grid,
  .footer-grid--simple {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* Tablet and small laptop stack transitions. */
@media (max-width: 1024px) {
  .hero-inner,
  .brand-inner,
  .upgrade-banner__shell,
  .quick-scan__shell,
  .main-shell,
  .topic-section--split .topic-section__shell,
  .topic-section--rail .topic-section__shell,
  .topic-section--band .topic-section__shell,
  .hero-glance,
  .trust-marker-block {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .hero {
    padding-bottom: 4rem;
  }

  .upgrade-banner__shell {
    min-height: auto;
  }

  .upgrade-banner__content h2 {
    max-width: 100%;
  }

  .quick-scan {
    margin-top: 1.25rem;
  }

  .main-shell--intro {
    margin-top: 1.25rem;
  }

  .sidebar-column {
    position: static;
  }

  .sidebar-card--map {
    max-height: none;
  }

  .sidebar-card--map .page-map__links {
    max-height: none;
    overflow: visible;
  }

}

/* Phone layout adjustments for spacing, buttons, and stacked controls. */
@media (max-width: 767px) {
  .container,
  .container-xl,
  .container-xxl {
    width: min(var(--container-width), calc(100% - 1.4rem));
  }

  .utility-inner,
  .brand-inner,
  .cookie-banner__inner,
  .footer-bottom {
    align-items: center;
    flex-direction: column;
  }

  .utility-actions,
  .brand-actions {
    width: auto;
  }

  .hero-actions,
  .sidebar-actions {
    width: 100%;
  }

  .utility-actions,
  .brand-actions {
    justify-content: center;
    flex-wrap: wrap;
  }

  .utility-inner {
    gap: 0.35rem;
    padding: 0.58rem 0;
  }

  .brand-inner {
    padding: 0.88rem 0;
  }

  .utility-support {
    text-align: center;
  }

  .brand-lockup__meta {
    display: none;
  }

  .hero {
    padding-top: 3.2rem;
  }

  .upgrade-banner {
    padding: 1.8rem 0 1.35rem;
  }

  .upgrade-banner__shell {
    padding: 1.55rem;
  }

  .upgrade-banner__content h2 {
    font-size: clamp(2rem, 11vw, 3.1rem);
  }

  .upgrade-banner__actions .btn {
    width: 100%;
    min-width: 0;
  }

  .hero-meta {
    min-width: 0;
    width: 100%;
  }

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

  .content-block,
  .sidebar-card,
  .official-resources,
  .faq-block,
  .related-block,
  .lead-form-block,
  .cta-pair,
  .site-disclaimer,
  .trust-marker-block {
    padding: 1.15rem;
  }

  .mobile-nav-actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .sidebar-card--map,
  .hero-actions a[href="#page-map"] {
    display: none !important;
  }

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

  .lead-form {
    grid-template-columns: 1fr;
  }

  .floating-whatsapp {
    right: 0.85rem;
    bottom: 5rem;
  }

  .footer-search-trigger {
    min-width: 100%;
  }

  .main-header__upper {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.7rem;
    align-items: center;
  }

  .main-header__identity {
    min-width: 0;
  }

  .main-header__identity .brand-lockup {
    min-width: 0;
  }

  .main-header__identity .brand-wordmark__mark {
    width: 42px;
    height: 42px;
  }

  .main-header__identity .brand-wordmark__text {
    min-width: 0;
  }

  .main-header__identity .brand-wordmark__line--top,
  .main-header__identity .brand-wordmark__line--bottom {
    font-size: 0.98rem;
    line-height: 0.9;
  }

  .main-header__actions {
    justify-self: end;
    justify-content: flex-end;
    gap: 0.55rem;
    width: auto;
  }
}

/* Extra-small screens tighten spacing, panel layout, and floating utilities. */
@media (max-width: 479px) {
  h1 {
    font-size: clamp(2.7rem, 14vw, 4rem);
  }

  .accessibility-panel__inner {
    padding-inline: 0.85rem;
  }

  .main-header__upper {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.4rem;
  }

  .main-header__identity .brand-wordmark__mark {
    width: 38px;
    height: 38px;
  }

  .main-header__identity .brand-wordmark__line--top,
  .main-header__identity .brand-wordmark__line--bottom {
    font-size: 0.9rem;
  }

  .panel-actions {
    grid-template-columns: 1fr;
  }

  .page-map__links,
  .mobile-nav-links {
    grid-template-columns: 1fr;
    display: grid;
  }



  .cookie-banner {
    left: 0.75rem;
    right: 0.75rem;
    width: auto;
  }

}

/* ==========================================================================
   34. Premium Brazil Prototype
   One-page prototype for a burgundy, green, and graphite design direction.
   Scoped to the About page so the concept can be reviewed in context first.
   ========================================================================== */
body.site-root {
  --font-display: "Playfair Display", var(--font-display-default);
  --font-body: "Inter", var(--font-body-default);
  --font-label: "Inter", var(--font-label-default);
  --container-width: 1280px;
  --radius-xs: 1rem;
  --radius-sm: 1.35rem;
  --radius-md: 1.7rem;
  --radius-lg: 2.25rem;
}

body.site-root.theme-dark,
body.site-root:not(.theme-light) {
  color-scheme: dark;
  --surface-base: #2e2e2e;
  --surface-raised: rgba(55, 55, 55, 0.94);
  --surface-glass: rgba(63, 63, 63, 0.72);
  --surface-strong: #3f3f3f;
  --surface-dark: #242424;
  --surface-dark-soft: rgba(36, 36, 36, 0.92);
  --surface-card-start: rgba(63, 63, 63, 0.96);
  --surface-card-end: rgba(48, 48, 48, 0.98);
  --surface-card-solid: rgba(58, 58, 58, 0.97);
  --surface-card-contrast: rgba(72, 72, 72, 0.96);
  --nav-surface-top: rgba(40, 40, 40, 0.96);
  --nav-surface-bottom: rgba(28, 28, 28, 0.96);
  --panel-surface: rgba(51, 51, 51, 0.96);
  --banner-surface: rgba(45, 45, 45, 0.92);
  --footer-surface-top: #332328;
  --footer-surface-bottom: #24191d;
  --text-main: #f5f5f5;
  --text-muted: rgba(245, 245, 245, 0.78);
  --text-soft: rgba(199, 199, 199, 0.82);
  --text-inverse: #f5f5f5;
  --heading-color: #fff8f8;
  --border-soft: rgba(var(--logo-gold-rgb), 0.14);
  --border-strong: rgba(var(--logo-gold-rgb), 0.3);
  --shadow-xs: 0 12px 22px rgba(0, 0, 0, 0.18);
  --shadow-sm: 0 20px 40px rgba(0, 0, 0, 0.26);
  --shadow-md: 0 32px 70px rgba(0, 0, 0, 0.34);
  --shadow-lg: 0 54px 104px rgba(0, 0, 0, 0.42);
  --accent: var(--logo-gold);
  --accent-strong: var(--gold-100);
  --accent-soft: rgba(var(--logo-gold-rgb), 0.24);
  --accent-wash: rgba(var(--logo-gold-rgb), 0.18);
  --accent-contrast: #2a1907;
  --secondary-accent: #1c4b3e;
  --secondary-soft: rgba(28, 75, 62, 0.24);
  --sun-accent: var(--logo-gold);
  --hero-top: rgba(28, 18, 22, 0.44);
  --hero-bottom: rgba(22, 16, 18, 0.82);
  --hero-side-left: rgba(43, 20, 29, 0.78);
  --hero-side-right: rgba(28, 49, 42, 0.44);
  --hero-glow: rgba(var(--logo-gold-rgb), 0.22);
  --content-stage-surface:
    radial-gradient(circle at 12% 0%, rgba(var(--logo-gold-rgb), 0.08), transparent 24%),
    radial-gradient(circle at 86% 10%, rgba(28, 75, 62, 0.14), transparent 18%),
    linear-gradient(180deg, rgba(63, 63, 63, 0.98) 0%, rgba(51, 51, 51, 0.98) 42%, rgba(46, 46, 46, 0.98) 100%);
  --content-stage-border: rgba(var(--logo-gold-rgb), 0.14);
  --content-stage-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    inset 0 -1px 0 rgba(0, 0, 0, 0.16);
  background:
    radial-gradient(circle at top left, rgba(107, 34, 53, 0.22), transparent 26%),
    radial-gradient(circle at 86% 12%, rgba(28, 75, 62, 0.18), transparent 22%),
    radial-gradient(circle at 70% 84%, rgba(var(--logo-gold-rgb), 0.1), transparent 22%),
    linear-gradient(180deg, #252525 0%, #2e2e2e 40%, #373737 100%);
}

body.site-root.theme-dark::before,
body.site-root:not(.theme-light)::before {
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.04), transparent 34%),
    radial-gradient(circle at 16% 18%, rgba(var(--logo-gold-rgb), 0.08), transparent 22%);
}

body.site-root.theme-light {
  color-scheme: light;
  --surface-base: #f9f6f1;
  --surface-raised: rgba(249, 246, 241, 0.95);
  --surface-glass: rgba(240, 237, 230, 0.76);
  --surface-strong: #f0ede6;
  --surface-dark: #1f1f1f;
  --surface-dark-soft: rgba(31, 31, 31, 0.9);
  --surface-card-start: rgba(240, 237, 230, 0.96);
  --surface-card-end: rgba(249, 246, 241, 0.98);
  --surface-card-solid: rgba(244, 240, 234, 0.98);
  --surface-card-contrast: rgba(255, 251, 246, 0.98);
  --nav-surface-top: rgba(249, 246, 241, 0.96);
  --nav-surface-bottom: rgba(240, 237, 230, 0.96);
  --panel-surface: rgba(240, 237, 230, 0.96);
  --banner-surface: rgba(249, 246, 241, 0.94);
  --footer-surface-top: #efe4d9;
  --footer-surface-bottom: #ddd0c4;
  --text-main: #1f1f1f;
  --text-muted: rgba(74, 74, 74, 0.9);
  --text-soft: rgba(74, 74, 74, 0.74);
  --text-inverse: #f9f6f1;
  --heading-color: #211d1d;
  --border-soft: rgba(var(--logo-gold-rgb), 0.12);
  --border-strong: rgba(var(--logo-gold-rgb), 0.24);
  --accent: var(--logo-gold);
  --accent-strong: #7b521c;
  --accent-soft: rgba(var(--logo-gold-rgb), 0.16);
  --accent-wash: rgba(var(--logo-gold-rgb), 0.1);
  --accent-contrast: #2a1907;
  --secondary-accent: #1c4b3e;
  --secondary-soft: rgba(28, 75, 62, 0.12);
  --sun-accent: var(--logo-gold);
  --hero-top: rgba(41, 22, 29, 0.24);
  --hero-bottom: rgba(41, 22, 29, 0.62);
  --hero-side-left: rgba(107, 34, 53, 0.48);
  --hero-side-right: rgba(28, 75, 62, 0.22);
  --hero-glow: rgba(var(--logo-gold-rgb), 0.18);
}

body.site-root h1,
body.site-root h2,
body.site-root h3,
body.site-root h4 {
  letter-spacing: -0.03em;
}

body.site-root .hero {
  padding-top: clamp(4.8rem, 9vw, 7rem);
  padding-bottom: clamp(5rem, 10vw, 7.5rem);
}

body.site-root .hero::before {
  background: radial-gradient(circle, rgba(var(--logo-gold-rgb), 0.12), transparent 72%);
}

body.site-root .hero-overlay {
  background:
    linear-gradient(180deg, var(--hero-top) 0%, rgba(28, 18, 22, 0.24) 24%, var(--hero-bottom) 100%),
    linear-gradient(108deg, var(--hero-side-left) 0%, rgba(37, 27, 31, 0.24) 44%, rgba(28, 49, 42, 0.14) 68%, var(--hero-side-right) 100%),
    radial-gradient(circle at 18% 36%, rgba(var(--logo-gold-rgb), 0.09), transparent 28%);
}

body.site-root .hero-copy,
body.site-root .hero-panel,
body.site-root .hero-glance-card {
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  box-shadow: 0 28px 54px rgba(0, 0, 0, 0.26);
}

body.site-root .hero-copy {
  background:
    linear-gradient(145deg, rgba(43, 31, 35, 0.84), rgba(43, 31, 35, 0.42)),
    rgba(43, 31, 35, 0.54);
  backdrop-filter: blur(18px);
}

body.site-root .hero-kicker,
body.site-root .hero-badge {
  background: rgba(255, 248, 247, 0.06);
  border-color: rgba(var(--logo-gold-rgb), 0.2);
}

body.site-root .hero-badge__icon,
body.site-root .hero-panel-item__icon {
  color: var(--lion-gold);
}

body.site-root .hero-panel--brand {
  background:
    linear-gradient(145deg, rgba(54, 34, 41, 0.86), rgba(28, 75, 62, 0.32)),
    rgba(40, 32, 35, 0.6);
}

body.site-root .hero-panel {
  background:
    linear-gradient(145deg, rgba(41, 41, 41, 0.84), rgba(54, 34, 41, 0.32)),
    rgba(41, 41, 41, 0.58);
}

body.site-root .hero-panel-item__icon {
  background: rgba(var(--logo-gold-rgb), 0.12);
}

body.site-root .hero-glance-card {
  background:
    linear-gradient(145deg, rgba(46, 46, 46, 0.78), rgba(28, 75, 62, 0.18)),
    rgba(46, 46, 46, 0.46);
}

body.site-root .hero-glance-card span,
body.site-root .eyebrow,
body.site-root .section-kicker {
  color: var(--logo-gold);
}

body.site-root .btn {
  min-height: 54px;
  border-radius: 999px;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

body.site-root .btn-cta,
body.site-root .btn-cta:visited,
body.site-root .btn-primary {
  color: var(--lion-gold-ink);
  background: var(--lion-gold-button);
  border-color: rgba(var(--logo-gold-rgb), 0.34);
  box-shadow:
    0 24px 44px rgba(122, 77, 22, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

body.site-root .btn-cta:hover,
body.site-root .btn-cta:focus-visible,
body.site-root .btn-primary:hover,
body.site-root .btn-primary:focus-visible {
  color: #241406;
  background: var(--lion-gold-button-hover);
  border-color: rgba(var(--logo-gold-rgb), 0.48);
  box-shadow:
    0 30px 50px rgba(122, 77, 22, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

body.site-root .btn-secondary,
body.site-root .btn-secondary:visited {
  color: #eff7f3;
  background: linear-gradient(135deg, #2a6b59 0%, #1c4b3e 52%, #14342b 100%);
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  box-shadow:
    0 22px 40px rgba(12, 44, 36, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

body.site-root .btn-secondary:hover,
body.site-root .btn-secondary:focus-visible {
  color: #f7fbf9;
  background: linear-gradient(135deg, #2f7c67 0%, #225949 52%, #153a30 100%);
}

body.site-root .btn-outline {
  border: 1px solid rgba(var(--logo-gold-rgb), 0.3);
  color: #f5f5f5;
  background: rgba(255, 255, 255, 0.03);
}

body.site-root .main-shell--intro {
  margin-top: -4.8rem;
}

body.site-root .content-block,
body.site-root .sidebar-card,
body.site-root .official-resources,
body.site-root .faq-block,
body.site-root .related-block,
body.site-root .lead-form-block,
body.site-root .cta-pair,
body.site-root .site-disclaimer,
body.site-root .trust-marker-block {
  border-color: rgba(var(--logo-gold-rgb), 0.12);
  background:
    linear-gradient(180deg, rgba(67, 67, 67, 0.96), rgba(49, 49, 49, 0.98)),
    rgba(58, 58, 58, 0.98);
  box-shadow:
    0 24px 54px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.site-root .intro-block,
body.site-root .topic-section--frame .topic-section__shell {
  padding: clamp(1.5rem, 3vw, 2.2rem);
}

body.site-root .topic-section--band,
body.site-root .highlight-block,
body.site-root .timeline-block,
body.site-root .lead-form-block,
body.site-root .testimonial-strip,
body.site-root .related-block {
  background:
    linear-gradient(145deg, rgba(67, 67, 67, 0.98) 0%, rgba(81, 48, 59, 0.96) 52%, rgba(29, 63, 53, 0.94) 100%),
    rgba(58, 58, 58, 0.98);
}

body.site-root .topic-section--rail {
  border-left-color: var(--logo-gold);
}

body.site-root .topic-note {
  border-color: rgba(var(--logo-gold-rgb), 0.14);
  background: linear-gradient(135deg, rgba(107, 34, 53, 0.16), rgba(28, 75, 62, 0.16));
}

body.site-root .sidebar-card--brand {
  background:
    linear-gradient(145deg, rgba(88, 33, 50, 0.96), rgba(28, 75, 62, 0.94)),
    rgba(52, 34, 40, 0.98);
  border-color: rgba(var(--logo-gold-rgb), 0.18);
}

body.site-root .sidebar-card--map {
  border-color: rgba(var(--logo-gold-rgb), 0.16);
  background:
    linear-gradient(180deg, rgba(63, 63, 63, 0.98), rgba(49, 49, 49, 0.98)),
    rgba(58, 58, 58, 0.98);
  box-shadow: 0 28px 56px rgba(0, 0, 0, 0.24);
}

body.site-root .sidebar-card--map .page-map__head p,
body.site-root .sidebar-list strong,
body.site-root .sidebar-list span,
body.site-root .sidebar-card--action p,
body.site-root .sidebar-note {
  color: var(--text-muted);
}

body.site-root .sidebar-card--map .page-map__title .section-title__icon,
body.site-root .sidebar-card--map .page-map__icon {
  color: var(--lion-gold);
}

body.site-root .sidebar-card--map .page-map__link {
  border-color: rgba(var(--logo-gold-rgb), 0.12);
  background: rgba(255, 255, 255, 0.03);
  color: #f5f5f5;
}

body.site-root .sidebar-card--map .page-map__link:hover,
body.site-root .sidebar-card--map .page-map__link:focus-visible {
  border-color: rgba(var(--logo-gold-rgb), 0.24);
  background: rgba(107, 34, 53, 0.14);
  color: #fff9fa;
}

body.site-root .site-footer {
  background:
    radial-gradient(circle at top, rgba(var(--logo-gold-rgb), 0.12), transparent 40%),
    linear-gradient(180deg, #35252a 0%, #24191d 100%);
}

body.site-root .footer-panel {
  border-left-color: rgba(var(--logo-gold-rgb), 0.12);
}

body.site-root .footer-description,
body.site-root .footer-panel a {
  color: rgba(245, 245, 245, 0.78);
}

body.site-root .footer-panel a:hover,
body.site-root .footer-panel a:focus-visible {
  color: #fff8f8;
}

body.site-root .btn-primary {
  border-radius: 999px;
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .footer-buttons {
  flex-wrap: wrap;
}

@media (max-width: 991px) {
  body.site-root .hero-inner,
  body.site-root .hero-glance,
  body.site-root .main-shell,
  body.site-root .topic-section--split .topic-section__shell,
  body.site-root .topic-section--band .topic-section__shell {
    grid-template-columns: 1fr;
  }

  body.site-root .main-shell--intro {
    margin-top: -2.6rem;
  }
}

/* ==========================================================================
   35. Luxury Burgundy System
   Global overrides that replace the older mint/plum direction with the new
   premium burgundy, green, graphite, and gold language site-wide.
   ========================================================================== */
:root {
  --font-display-default: "Playfair Display", "Iowan Old Style", "Georgia Pro", "Palatino Linotype", serif;
  --font-body-default: "Inter", "Avenir Next", "Segoe UI Variable", "Segoe UI", sans-serif;
  --font-label-default: "Inter", "Avenir Next", "Segoe UI Variable", "Segoe UI", sans-serif;
  --container-width: 1280px;
  --reading-width: 68ch;
  --radius-xs: 1rem;
  --radius-sm: 1.35rem;
  --radius-md: 1.7rem;
  --radius-lg: 2.25rem;
}

body.site-root {
  background:
    radial-gradient(circle at top left, rgba(107, 34, 53, 0.22), transparent 26%),
    radial-gradient(circle at 86% 12%, rgba(28, 75, 62, 0.18), transparent 22%),
    radial-gradient(circle at 70% 84%, rgba(var(--logo-gold-rgb), 0.1), transparent 22%),
    linear-gradient(180deg, #252525 0%, #2e2e2e 40%, #373737 100%);
  color: var(--text-main);
  font-family: var(--font-body);
}

body.site-root::before {
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.04), transparent 34%),
    radial-gradient(circle at 16% 18%, rgba(var(--logo-gold-rgb), 0.08), transparent 22%);
}

body.site-root.theme-light {
  background:
    radial-gradient(circle at top left, rgba(107, 34, 53, 0.08), transparent 26%),
    radial-gradient(circle at 86% 12%, rgba(28, 75, 62, 0.1), transparent 22%),
    linear-gradient(180deg, #fbf8f3 0%, #f9f6f1 42%, #efe8df 100%);
}

body.site-root h1,
body.site-root h2,
body.site-root h3,
body.site-root h4,
body.site-root h5,
body.site-root h6 {
  letter-spacing: -0.03em;
}

body.site-root a {
  color: var(--sun-accent);
  text-decoration-color: rgba(var(--logo-gold-rgb), 0.4);
}

body.site-root a:hover,
body.site-root a:focus-visible {
  color: var(--heading-color);
}

body.site-root ::selection {
  background: rgba(107, 34, 53, 0.34);
  color: #fff8f8;
}

body.site-root .lead,
body.site-root .section-strap,
body.site-root .topic-section__body p,
body.site-root .info-card p,
body.site-root .resource-card p,
body.site-root .related-card span,
body.site-root .quote-card p {
  color: var(--text-muted);
}

body.site-root .section-title__icon,
body.site-root .page-map__icon,
body.site-root .footer-heading-icon {
  color: var(--lion-gold);
}

body.site-root .utility-bar {
  border-bottom: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  background: linear-gradient(180deg, rgba(53, 37, 42, 0.92), rgba(36, 25, 29, 0.94));
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.22);
}

body.site-root.theme-light .utility-bar {
  background: linear-gradient(180deg, rgba(252, 248, 243, 0.94), rgba(243, 236, 228, 0.96));
}

body.site-root .utility-inner {
  gap: 1rem;
  padding: 0.62rem 0;
}

body.site-root .utility-support {
  color: var(--text-muted);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.site-root .utility-actions {
  gap: 0.7rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

body.site-root .utility-theme-switch,
body.site-root .lang-switcher--minimal {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.24rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
}

body.site-root.theme-light .utility-theme-switch,
body.site-root.theme-light .lang-switcher--minimal {
  background: rgba(107, 34, 53, 0.04);
}

body.site-root .utility-theme-button,
body.site-root .lang-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0.4rem 0.8rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--text-muted);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-decoration: none;
  text-transform: uppercase;
  transition:
    background-color 180ms ease,
    color 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

body.site-root .utility-theme-button:hover,
body.site-root .utility-theme-button:focus-visible,
body.site-root .lang-link:hover,
body.site-root .lang-link:focus-visible {
  color: var(--heading-color);
  transform: translateY(-1px);
  text-decoration: none;
}

body.site-root .utility-theme-button.is-active,
body.site-root .lang-link.active {
  border-color: rgba(var(--logo-gold-rgb), 0.34);
  background: var(--lion-gold-button);
  box-shadow: 0 14px 28px rgba(122, 77, 22, 0.24);
  color: var(--lion-gold-ink);
}

body.site-root .utility-action--text {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0.4rem 0.95rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-muted);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
}

body.site-root .utility-action--text:hover,
body.site-root .utility-action--text:focus-visible {
  background: rgba(107, 34, 53, 0.14);
  color: var(--heading-color);
  text-decoration: none;
}

body.site-root .accessibility-panel {
  background:
    linear-gradient(180deg, rgba(53, 37, 42, 0.98), rgba(36, 25, 29, 0.98)),
    rgba(46, 46, 46, 0.98);
  box-shadow: -28px 0 80px rgba(0, 0, 0, 0.32);
}

body.site-root.theme-light .accessibility-panel {
  background:
    linear-gradient(180deg, rgba(250, 245, 239, 0.98), rgba(242, 235, 227, 0.98)),
    rgba(249, 246, 241, 0.98);
}

body.site-root .scale-control,
body.site-root .toggle-button,
body.site-root .panel-close {
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  background:
    linear-gradient(180deg, rgba(67, 67, 67, 0.96), rgba(49, 49, 49, 0.98)),
    rgba(58, 58, 58, 0.98);
  color: var(--text-main);
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.16);
}

body.site-root.theme-light .scale-control,
body.site-root.theme-light .toggle-button,
body.site-root.theme-light .panel-close {
  background:
    linear-gradient(180deg, rgba(255, 251, 246, 0.98), rgba(240, 237, 230, 0.96)),
    rgba(244, 240, 234, 0.98);
}

body.site-root .toggle-button.is-active {
  border-color: rgba(var(--logo-gold-rgb), 0.34);
  background: var(--lion-gold-button);
  box-shadow: 0 18px 34px rgba(122, 77, 22, 0.24);
  color: var(--lion-gold-ink);
}

body.site-root .main-nav {
  border-bottom: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  background: linear-gradient(180deg, rgba(53, 37, 42, 0.96), rgba(36, 25, 29, 0.98));
  backdrop-filter: blur(22px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.24);
}

body.site-root.theme-light .main-nav {
  background: linear-gradient(180deg, rgba(250, 245, 239, 0.96), rgba(242, 235, 227, 0.98));
}

body.site-root .main-header {
  gap: 0.85rem;
  padding: 1rem 0 1.05rem;
}

body.site-root .main-header__lower {
  border-top-color: rgba(var(--logo-gold-rgb), 0.12);
}

body.site-root .main-nav .navbar-toggler {
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-main);
}

body.site-root .main-nav .navbar-toggler-icon {
  opacity: 0.88;
}

body.site-root:not(.theme-light) .main-nav .navbar-toggler-icon {
  filter: none;
}

body.site-root.theme-light .main-nav .navbar-toggler-icon {
  filter: none;
}

body.site-root .main-nav .brand-lockup__meta small,
body.site-root .brand-lockup__meta small {
  color: var(--logo-gold);
}

body.site-root .main-nav .brand-wordmark--inverse .brand-wordmark__line--top,
body.site-root .main-nav .brand-wordmark--inverse .brand-wordmark__line--bottom {
  color: var(--heading-color);
}

body.site-root .main-nav .nav-link,
body.site-root .main-nav .dropdown-toggle,
body.site-root .main-nav .main-header__home {
  color: var(--text-muted);
  font-weight: 600;
  letter-spacing: 0.02em;
}

body.site-root .main-nav .nav-link:hover,
body.site-root .main-nav .nav-link:focus-visible,
body.site-root .main-nav .dropdown.show > .nav-link,
body.site-root .main-nav .dropdown.show > .dropdown-toggle,
body.site-root .main-nav .main-header__home:hover,
body.site-root .main-nav .main-header__home:focus-visible {
  border-color: rgba(var(--logo-gold-rgb), 0.5);
  color: var(--heading-color);
}

body.site-root .navbar-nav--services .dropdown-toggle::after {
  border-top-color: var(--lion-gold);
}

body.site-root .main-nav .dropdown-menu,
body.site-root .service-family-menu,
body.site-root .mobile-nav-shell,
body.site-root .mobile-nav-group__body {
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, rgba(63, 63, 63, 0.98), rgba(49, 49, 49, 0.98)),
    rgba(58, 58, 58, 0.98);
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.26);
}

body.site-root.theme-light .main-nav .dropdown-menu,
body.site-root.theme-light .service-family-menu,
body.site-root.theme-light .mobile-nav-shell,
body.site-root.theme-light .mobile-nav-group__body {
  background:
    linear-gradient(180deg, rgba(255, 251, 246, 0.98), rgba(240, 237, 230, 0.96)),
    rgba(244, 240, 234, 0.98);
}

body.site-root .service-family-menu__head,
body.site-root .mobile-nav-group__intro,
body.site-root .mobile-nav-shell__eyebrow,
body.site-root .service-family-menu__head p {
  color: var(--text-muted);
}

body.site-root .service-family-menu__heading h3,
body.site-root .mobile-nav-group summary {
  color: var(--heading-color);
}

body.site-root .mobile-nav-home,
body.site-root .mobile-nav-links a,
body.site-root .service-family-menu__link {
  color: var(--text-main);
}

body.site-root .mobile-nav-links a:hover,
body.site-root .mobile-nav-links a:focus-visible,
body.site-root .service-family-menu__link:hover,
body.site-root .service-family-menu__link:focus-visible {
  color: var(--sun-accent);
}

body.site-root .breadcrumbs {
  padding-top: 1.15rem;
}

body.site-root .breadcrumbs ol {
  gap: 0.5rem;
}

body.site-root .breadcrumbs a,
body.site-root .breadcrumbs li {
  color: var(--text-soft);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .breadcrumbs li + li::before {
  color: rgba(var(--logo-gold-rgb), 0.58);
}

body.site-root [data-section-image="true"] {
  border-color: rgba(var(--logo-gold-rgb), 0.16);
  background: rgba(46, 46, 46, 0.18);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.24);
}

body.site-root [data-section-image="true"]::before {
  background-color: rgba(36, 36, 36, 0.12);
  filter: saturate(0.84) contrast(1.06) brightness(0.76);
}

body.site-root [data-section-image="true"]::after {
  opacity: 0.9;
  background:
    linear-gradient(180deg, rgba(28, 18, 22, 0.8), rgba(28, 18, 22, 0.56) 34%, rgba(28, 18, 22, 0.86) 100%),
    linear-gradient(126deg, rgba(107, 34, 53, 0.44), rgba(28, 75, 62, 0.24) 70%, rgba(var(--logo-gold-rgb), 0.1) 100%);
}

body.site-root [data-section-image="true"] .topic-section__shell {
  padding: 1.55rem;
  background:
    linear-gradient(110deg, rgba(24, 24, 24, 0.52), rgba(24, 24, 24, 0.2) 56%, rgba(24, 24, 24, 0.1)),
    rgba(24, 24, 24, 0.1);
  backdrop-filter: blur(8px);
}

body.site-root [data-section-image="true"] .topic-note,
body.site-root [data-section-image="true"] .info-card,
body.site-root [data-section-image="true"] .resource-card,
body.site-root [data-section-image="true"] .related-card {
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(32, 32, 32, 0.6), rgba(32, 32, 32, 0.24)),
    rgba(32, 32, 32, 0.26);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.18);
}

body.site-root .info-card,
body.site-root .resource-card,
body.site-root .quote-card,
body.site-root .related-card,
body.site-root .page-map__link {
  border-color: rgba(var(--logo-gold-rgb), 0.12);
  background:
    linear-gradient(180deg, rgba(67, 67, 67, 0.96), rgba(49, 49, 49, 0.98)),
    rgba(58, 58, 58, 0.98);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.16);
}

body.site-root.theme-light .info-card,
body.site-root.theme-light .resource-card,
body.site-root.theme-light .quote-card,
body.site-root.theme-light .related-card,
body.site-root.theme-light .page-map__link {
  background:
    linear-gradient(180deg, rgba(255, 251, 246, 0.98), rgba(240, 237, 230, 0.96)),
    rgba(244, 240, 234, 0.98);
}

body.site-root .info-card:hover,
body.site-root .resource-card:hover,
body.site-root .quote-card:hover,
body.site-root .related-card:hover,
body.site-root .page-map__link:hover,
body.site-root .page-map__link:focus-visible {
  border-color: rgba(var(--logo-gold-rgb), 0.24);
  background:
    linear-gradient(180deg, rgba(90, 49, 62, 0.96), rgba(58, 39, 45, 0.98)),
    rgba(67, 67, 67, 0.98);
  color: #fff8f8;
}

body.site-root .newsletter-signup,
body.site-root .social-sharing,
body.site-root .comments-system {
  padding: 1.35rem;
  margin-bottom: 1.35rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(67, 67, 67, 0.96), rgba(49, 49, 49, 0.98)),
    rgba(58, 58, 58, 0.98);
  box-shadow: 0 24px 54px rgba(0, 0, 0, 0.22);
}

body.site-root.theme-light .newsletter-signup,
body.site-root.theme-light .social-sharing,
body.site-root.theme-light .comments-system {
  background:
    linear-gradient(180deg, rgba(255, 251, 246, 0.98), rgba(240, 237, 230, 0.96)),
    rgba(244, 240, 234, 0.98);
}

body.site-root .newsletter-signup h2,
body.site-root .social-sharing h2,
body.site-root .comments-system h2 {
  margin-bottom: 0.95rem;
}

body.site-root .newsletter-form,
body.site-root .comments-form {
  display: grid;
  gap: 0.9rem;
}

body.site-root .social-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

body.site-root .social-share-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.78rem 1rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-main);
  font-weight: 700;
  text-decoration: none;
}

body.site-root .social-share-link:hover,
body.site-root .social-share-link:focus-visible {
  background: rgba(107, 34, 53, 0.14);
  color: #fff8f8;
}

body.site-root input:not([type="checkbox"]):not([type="radio"]),
body.site-root textarea,
body.site-root select {
  width: 100%;
  padding: 0.92rem 1rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-main);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.site-root.theme-light input:not([type="checkbox"]):not([type="radio"]),
body.site-root.theme-light textarea,
body.site-root.theme-light select {
  background: rgba(255, 255, 255, 0.72);
}

body.site-root input:not([type="checkbox"]):not([type="radio"])::placeholder,
body.site-root textarea::placeholder {
  color: var(--text-soft);
}

body.site-root input:not([type="checkbox"]):not([type="radio"]):focus-visible,
body.site-root textarea:focus-visible,
body.site-root select:focus-visible {
  outline: 3px solid rgba(var(--logo-gold-rgb), 0.22);
  outline-offset: 2px;
  border-color: rgba(var(--logo-gold-rgb), 0.3);
}

body.site-root .site-footer {
  padding-top: clamp(3.5rem, 7vw, 5rem);
  padding-bottom: 2.4rem;
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.1);
}

body.site-root .footer-grid.footer-grid--simple {
  grid-template-columns: minmax(280px, 1.7fr) repeat(6, minmax(0, 1fr));
  gap: 1.25rem;
}

body.site-root .footer-panel__head,
body.site-root .footer-panel__group,
body.site-root .footer-panel__groups,
body.site-root .footer-panel__actions {
  display: grid;
  gap: 0.7rem;
}

body.site-root .footer-panel__head h2,
body.site-root .footer-panel__head p,
body.site-root .footer-brand-title,
body.site-root .footer-contact-list,
body.site-root .footer-panel ul {
  margin: 0;
}

body.site-root .footer-panel__head h2 {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.88rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff8f8;
}

body.site-root .footer-panel__head p,
body.site-root .footer-contact-list li,
body.site-root .footer-panel__group a,
body.site-root .footer-panel__group strong,
body.site-root .footer-panel__group span {
  color: rgba(245, 245, 245, 0.76);
  font-size: 0.78rem;
  line-height: 1.55;
}

body.site-root .footer-panel__group a:hover,
body.site-root .footer-panel__group a:focus-visible,
body.site-root .footer-contact-list a:hover,
body.site-root .footer-contact-list a:focus-visible {
  color: #fff8f8;
}

body.site-root .footer-contact-list {
  display: grid;
  gap: 0.55rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  list-style: none;
}

body.site-root .footer-contact-list li {
  display: grid;
  gap: 0.12rem;
}

body.site-root .footer-contact-list span {
  color: var(--logo-gold);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .floating-whatsapp {
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background: linear-gradient(135deg, #2a6b59 0%, #1c4b3e 56%, #14342b 100%);
  box-shadow: 0 24px 48px rgba(12, 44, 36, 0.28);
}

body.site-root .floating-whatsapp::before {
  background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.18), transparent 48%);
}

body.site-root .floating-whatsapp::after {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.16), transparent 70%);
}

body.site-root .floating-whatsapp:hover,
body.site-root .floating-whatsapp:focus-visible {
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 30px 58px rgba(12, 44, 36, 0.34);
}

body.site-root .cookie-banner {
  left: 50%;
  right: auto;
  bottom: max(1rem, env(safe-area-inset-bottom));
  width: min(46rem, calc(100vw - 2rem));
  transform: translateX(-50%);
}

body.site-root .cookie-banner__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.7rem 0.9rem;
  padding: 0.76rem 0.95rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(49, 41, 39, 0.94), rgba(28, 24, 23, 0.97)),
    rgba(36, 31, 30, 0.95);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(24px);
}

body.site-root.theme-light .cookie-banner__inner {
  background:
    linear-gradient(180deg, rgba(255, 251, 246, 0.96), rgba(242, 235, 226, 0.94)),
    rgba(247, 241, 234, 0.95);
}

body.site-root .cookie-badge {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0.32rem 0.78rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  color: #e8c98f;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  white-space: nowrap;
}

body.site-root.theme-light .cookie-badge {
  background: rgba(95, 71, 49, 0.05);
  color: #6a4b35;
}

body.site-root .cookie-text {
  min-width: 0;
  flex: 1 1 22rem;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.12rem 0.55rem;
}

body.site-root .cookie-text strong {
  display: inline;
  margin: 0;
  color: var(--heading-color);
  font-size: 0.88rem;
}

body.site-root .cookie-text p {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.82rem;
  display: inline;
}

body.site-root .cookie-link {
  display: inline-flex;
  align-items: center;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

body.site-root .cookie-actions {
  flex: 0 0 auto;
  justify-content: flex-end;
  flex-wrap: nowrap;
  gap: 0.5rem;
}

body.site-root .cookie-actions .btn {
  min-height: 36px;
  padding: 0.55rem 0.95rem;
  font-size: 0.68rem;
  letter-spacing: 0.13em;
  box-shadow: none;
}

body.site-root .cookie-actions .btn::after {
  display: none;
}

body.site-root .cookie-actions .btn:hover,
body.site-root .cookie-actions .btn:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(16, 12, 10, 0.18);
}

body.site-root .cookie-actions .btn-secondary,
body.site-root .cookie-actions .btn-secondary:visited {
  background: rgba(255, 255, 255, 0.05);
  color: #f6efe4;
  border-color: rgba(var(--logo-gold-rgb), 0.24);
}

body.site-root.theme-light .cookie-actions .btn-secondary,
body.site-root.theme-light .cookie-actions .btn-secondary:visited {
  background: rgba(102, 78, 56, 0.05);
  color: var(--text-main);
  border-color: rgba(106, 75, 53, 0.16);
}

body.site-root .cookie-actions .btn-cta,
body.site-root .cookie-actions .btn-cta:visited {
  background: var(--lion-gold-button);
  border-color: rgba(var(--logo-gold-rgb), 0.32);
  box-shadow: none;
}

body.site-root .cookie-actions .btn-cta:hover,
body.site-root .cookie-actions .btn-cta:focus-visible {
  background: var(--lion-gold-button-hover);
}

@media (max-width: 1279px) {
  body.site-root .footer-grid.footer-grid--simple {
    grid-template-columns: minmax(280px, 1.7fr) repeat(3, minmax(0, 1fr));
  }

  body.site-root .footer-grid.footer-grid--simple .footer-panel--brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 767px) {
  body.site-root .utility-inner {
    align-items: stretch;
  }

  body.site-root .utility-actions {
    justify-content: center;
  }

  body.site-root .utility-theme-switch,
  body.site-root .lang-switcher--minimal {
    justify-content: center;
  }

  body.site-root .footer-grid.footer-grid--simple {
    grid-template-columns: 1fr;
  }

  body.site-root .cookie-banner {
    left: 0.75rem;
    right: 0.75rem;
    bottom: max(0.75rem, env(safe-area-inset-bottom));
    width: auto;
    transform: none;
  }

  body.site-root .cookie-banner__inner {
    padding: 0.82rem 0.9rem;
    border-radius: 1.2rem;
    align-items: flex-start;
  }

  body.site-root .cookie-text {
    flex-basis: 100%;
  }
}

/* ==========================================================================
   36. Shell Refinements
   Tightens the shared chrome so the new palette feels deliberate rather than
   layered over the previous layout system.
   ========================================================================== */
body.site-root .utility-bar {
  border-bottom: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  background:
    linear-gradient(180deg, rgba(65, 41, 50, 0.96), rgba(46, 31, 38, 0.97));
  box-shadow: 0 16px 34px rgba(26, 16, 20, 0.26);
}

body.site-root .utility-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 0.5rem;
  padding: 0.46rem 0;
}

body.site-root .utility-support {
  grid-column: 2;
  justify-self: center;
  text-align: center;
  color: rgba(var(--logo-gold-rgb), 0.82);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

body.site-root .utility-actions {
  grid-column: 3;
  justify-self: end;
  gap: 0.65rem;
}

body.site-root .lang-switcher--minimal {
  gap: 0.15rem;
  padding: 0.18rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
}

body.site-root .lang-switcher--minimal span {
  color: rgba(var(--logo-gold-rgb), 0.52);
}

body.site-root .lang-link,
body.site-root .utility-action--text {
  min-height: 1.95rem;
  padding: 0.34rem 0.74rem;
  border: 1px solid transparent;
  border-radius: 999px;
  color: var(--lion-gold);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
}

body.site-root .lang-link.active {
  color: var(--lion-gold-ink);
  border-color: rgba(var(--logo-gold-rgb), 0.34);
  background: var(--lion-gold-button);
  box-shadow:
    0 10px 24px rgba(122, 77, 22, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

body.site-root .utility-action--text {
  border-color: rgba(var(--logo-gold-rgb), 0.14);
  background: rgba(255, 255, 255, 0.03);
}

body.site-root .lang-link:hover,
body.site-root .lang-link:focus-visible,
body.site-root .utility-action--text:hover,
body.site-root .utility-action--text:focus-visible {
  color: var(--lion-gold-soft);
  border-color: rgba(var(--logo-gold-rgb), 0.36);
  background: rgba(var(--logo-gold-rgb), 0.08);
  transform: translateY(-1px);
  text-decoration: none;
}

body.site-root .lang-link.active:hover,
body.site-root .lang-link.active:focus-visible {
  color: var(--lion-gold-ink);
  background: var(--lion-gold-button-hover);
}

body.site-root .main-nav {
  border-bottom: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  background:
    linear-gradient(180deg, rgba(56, 40, 48, 0.98), rgba(38, 28, 33, 0.96));
  box-shadow: 0 22px 44px rgba(22, 14, 17, 0.32);
}

body.site-root .main-header {
  gap: 0.34rem;
  padding: 0.62rem 0 0.46rem;
}

body.site-root .main-header__upper {
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 0.95rem;
  align-items: end;
}

body.site-root .main-header__center {
  display: flex !important;
  align-self: end;
  padding-bottom: 0.12rem;
}

body.site-root .main-header__identity {
  align-items: flex-start;
}

body.site-root .main-nav .brand-lockup {
  gap: 0.1rem;
}

body.site-root .brand-wordmark {
  align-items: center;
  gap: 0.7rem;
}

body.site-root .main-nav .brand-wordmark__mark {
  width: 48px;
  height: 48px;
  transform: translateY(-1px);
}

body.site-root .site-footer .brand-wordmark__mark {
  width: 58px;
  height: 58px;
}

body.site-root .brand-wordmark__text {
  gap: 0.02rem;
  padding-top: 0.08rem;
}

body.site-root .main-nav .brand-wordmark--inverse .brand-wordmark__line--top,
body.site-root .main-nav .brand-wordmark--inverse .brand-wordmark__line--bottom,
body.site-root .site-footer .brand-wordmark--inverse .brand-wordmark__line--top,
body.site-root .site-footer .brand-wordmark--inverse .brand-wordmark__line--bottom {
  color: #f6eee6;
}

body.site-root .main-nav .brand-wordmark__line--top,
body.site-root .main-nav .brand-wordmark__line--bottom {
  letter-spacing: -0.01em;
}

body.site-root .main-nav .brand-lockup__meta,
body.site-root .main-nav .brand-lockup__meta small {
  display: block;
}

body.site-root .main-nav .brand-lockup__meta {
  max-width: max-content;
}

body.site-root .main-header__actions {
  gap: 0.55rem;
  align-self: end;
  padding-bottom: 0.12rem;
}

body.site-root .main-header__cta {
  gap: 0.58rem;
  padding: 0.62rem 0.98rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.34);
  background: var(--lion-gold-button);
  color: var(--lion-gold-ink);
  box-shadow:
    0 18px 34px rgba(122, 77, 22, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
  animation: none;
}

body.site-root .main-header__cta .main-header__cta-icon {
  color: inherit;
}

body.site-root .main-header__cta-label {
  font-size: 0.86rem;
  letter-spacing: 0.08em;
}

body.site-root .main-header__cta:hover,
body.site-root .main-header__cta:focus-visible {
  transform: translateY(-1px);
  background: var(--lion-gold-button-hover);
  box-shadow:
    0 22px 40px rgba(122, 77, 22, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}

body.site-root .main-header__lower {
  justify-content: center;
  padding-top: 0.32rem;
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.12);
}

body.site-root .main-nav .navbar-nav {
  justify-content: center;
  gap: clamp(0.75rem, 1.55vw, 1.25rem);
  width: auto;
}

body.site-root .nav-item--home {
  margin-right: 0.25rem;
}

body.site-root .main-nav .nav-link,
body.site-root .main-nav .dropdown-toggle,
body.site-root .main-nav .main-header__home {
  padding: 0.38rem 0 0.48rem;
  border-bottom: 2px solid transparent;
  color: var(--lion-gold);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}

body.site-root .main-nav .brand-lockup__meta small {
  color: rgba(246, 238, 230, 0.8);
  font-family: var(--font-display);
  font-size: 0.64rem;
  font-style: italic;
  font-weight: 400;
  letter-spacing: 0.03em;
  line-height: 1.1;
  text-transform: none;
  white-space: nowrap;
}

body.site-root .main-nav .nav-link:hover,
body.site-root .main-nav .nav-link:focus-visible,
body.site-root .main-nav .dropdown.show > .nav-link,
body.site-root .main-nav .dropdown.show > .dropdown-toggle,
body.site-root .main-nav .main-header__home:hover,
body.site-root .main-nav .main-header__home:focus-visible {
  color: var(--lion-gold-soft);
  border-color: rgba(var(--logo-gold-rgb), 0.78);
}

body.site-root .main-header__home.is-active,
body.site-root .navbar-nav--services .nav-link.is-active,
body.site-root .navbar-nav--services .dropdown-toggle.is-active,
body.site-root .service-family-dropdown.is-active > .nav-link,
body.site-root .service-family-dropdown.show > .nav-link,
body.site-root .service-family-dropdown.show > .dropdown-toggle {
  color: var(--lion-gold-soft);
  border-color: rgba(var(--logo-gold-rgb), 0.88);
}

body.site-root .navbar-nav--services .dropdown-toggle::after {
  margin-left: 0.48rem;
  border-top-color: rgba(var(--logo-gold-rgb), 0.86);
  animation: none;
}

body.site-root .main-nav .dropdown-menu,
body.site-root .service-family-menu,
body.site-root .mobile-nav-shell,
body.site-root .mobile-nav-group__body {
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  background:
    linear-gradient(180deg, rgba(61, 45, 52, 0.98), rgba(34, 25, 30, 0.98));
  box-shadow: 0 24px 48px rgba(18, 11, 14, 0.32);
}

body.site-root .service-family-menu__head {
  margin-bottom: 0.95rem;
  padding-bottom: 0.95rem;
  border-bottom: 1px solid rgba(var(--logo-gold-rgb), 0.12);
}

body.site-root .service-family-menu__heading h3 {
  font-size: 1.18rem;
}

body.site-root .service-family-menu__link {
  padding: 0.38rem 0;
  font-size: 0.9rem;
}

body.site-root .site-footer {
  background:
    radial-gradient(circle at 12% 0%, rgba(107, 34, 53, 0.28), transparent 22%),
    radial-gradient(circle at 85% 8%, rgba(28, 75, 62, 0.14), transparent 22%),
    linear-gradient(180deg, #35262c 0%, #2b1f24 54%, #251a1f 100%);
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.14);
}

body.site-root .site-footer .container {
  width: min(1400px, 92%);
}

body.site-root .footer-grid.footer-grid--directory {
  grid-template-columns: minmax(300px, 1.5fr) repeat(5, minmax(120px, 0.92fr)) minmax(220px, 1.16fr);
  gap: 1.95rem;
  align-items: start;
}

body.site-root .footer-grid.footer-grid--simple {
  grid-template-columns: minmax(300px, 1.45fr) repeat(6, minmax(120px, 1fr));
  gap: 1.95rem;
  align-items: start;
}

body.site-root .footer-grid.footer-grid--directory .footer-panel,
body.site-root .footer-grid.footer-grid--simple .footer-panel {
  gap: 0.95rem;
  padding-left: 1.45rem;
  border-left: 1px solid rgba(var(--logo-gold-rgb), 0.16);
}

body.site-root .footer-grid.footer-grid--directory .footer-panel:first-child,
body.site-root .footer-grid.footer-grid--simple .footer-panel:first-child {
  padding-left: 0;
  border-left: none;
}

body.site-root .footer-brand,
body.site-root .footer-panel--brand {
  max-width: 24rem;
  padding-right: 0.45rem;
}

body.site-root .footer-brand-title {
  margin: 0;
  display: block;
  letter-spacing: normal;
  text-transform: none;
}

body.site-root .footer-brand-lockup {
  display: inline-flex;
  align-items: center;
}

body.site-root .footer-description,
body.site-root .footer-panel__head p {
  max-width: 31ch;
  margin: 0;
  color: rgba(245, 245, 245, 0.78);
  font-size: 0.94rem;
  line-height: 1.75;
}

body.site-root .footer-panel__actions,
body.site-root .footer-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

body.site-root .footer-panel__actions .btn,
body.site-root .footer-buttons .btn,
body.site-root .footer-main-cta {
  min-height: 2.8rem;
}

body.site-root .footer-grid.footer-grid--directory .footer-panel--directory h3,
body.site-root .footer-grid.footer-grid--simple .footer-panel:not(.footer-panel--brand) .footer-panel__head h2 {
  margin: 0 0 0.95rem;
  color: #f8efe5;
  font-family: var(--font-label);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

body.site-root .footer-grid.footer-grid--directory .footer-panel--directory h3 a {
  color: inherit;
}

body.site-root .footer-grid.footer-grid--directory .footer-link-list,
body.site-root .footer-grid.footer-grid--simple .footer-panel__group ul {
  display: grid;
  gap: 0.56rem;
}

body.site-root .footer-grid.footer-grid--directory .footer-panel:not(.footer-brand) a,
body.site-root .footer-panel__group a,
body.site-root .footer-panel__group strong,
body.site-root .footer-panel__group span,
body.site-root .footer-contact-list li {
  color: rgba(245, 245, 245, 0.8);
  font-size: 0.92rem;
  line-height: 1.6;
}

body.site-root .footer-grid.footer-grid--directory .footer-panel:not(.footer-brand) a,
body.site-root .footer-panel__group a {
  text-decoration: none;
}

body.site-root .footer-grid.footer-grid--directory .footer-panel:not(.footer-brand) a:hover,
body.site-root .footer-grid.footer-grid--directory .footer-panel:not(.footer-brand) a:focus-visible,
body.site-root .footer-panel__group a:hover,
body.site-root .footer-panel__group a:focus-visible {
  color: var(--lion-gold-soft);
}

body.site-root .footer-contact-list,
body.site-root .footer-contact {
  display: grid;
  gap: 0.72rem;
  padding-top: 0.95rem;
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  list-style: none;
}

body.site-root .footer-contact-list li {
  display: grid;
  gap: 0.14rem;
}

body.site-root .footer-contact-list span {
  color: var(--logo-gold);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

body.site-root .footer-panel--stacked {
  gap: 1rem;
}

body.site-root .footer-disclosure {
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  padding-top: 0.9rem;
}

body.site-root .footer-disclosure summary {
  color: #f8efe5;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.16em;
}

body.site-root .footer-disclosure summary::after {
  color: var(--lion-gold);
  font-size: 1.1rem;
}

body.site-root .footer-subgroup__title {
  color: rgba(var(--logo-gold-rgb), 0.84);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
}

body.site-root .footer-row--legal,
body.site-root .footer-row--meta {
  margin-top: 2rem;
  padding-top: 1.35rem;
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.14);
}

body.site-root .footer-row--legal p,
body.site-root .footer-row--meta p,
body.site-root .footer-links a {
  color: rgba(245, 245, 245, 0.74);
  font-size: 0.9rem;
}

body.site-root .footer-main-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.8rem 1.2rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.34);
  border-radius: 999px;
  background: var(--lion-gold-button);
  color: var(--lion-gold-ink);
  text-decoration: none;
  box-shadow: 0 18px 34px rgba(122, 77, 22, 0.28);
}

body.site-root .footer-main-cta:hover,
body.site-root .footer-main-cta:focus-visible {
  background: var(--lion-gold-button-hover);
  color: #241406;
}

body.site-root .footer-search {
  border-color: rgba(var(--logo-gold-rgb), 0.24);
  background: rgba(255, 255, 255, 0.04);
  color: rgba(245, 245, 245, 0.82);
}

body.site-root .floating-whatsapp {
  border-color: rgba(75, 129, 108, 0.54);
  background: linear-gradient(135deg, #235546 0%, #1c4b3e 58%, #14342b 100%);
  box-shadow:
    0 20px 42px rgba(12, 44, 36, 0.28),
    0 0 0 7px rgba(28, 75, 62, 0.12);
}

body.site-root .floating-whatsapp::after {
  background: radial-gradient(circle, rgba(28, 75, 62, 0.42) 0%, rgba(28, 75, 62, 0.18) 40%, rgba(28, 75, 62, 0) 72%);
}

body.site-root .floating-whatsapp:hover,
body.site-root .floating-whatsapp:focus-visible {
  box-shadow:
    0 24px 46px rgba(12, 44, 36, 0.34),
    0 0 0 8px rgba(28, 75, 62, 0.16);
}

body.site-root .back-to-top {
  --back-to-top-progress: 0;
  bottom: max(1rem, env(safe-area-inset-bottom));
  z-index: 1070;
  width: 54px;
  height: 54px;
  min-height: 54px;
  border: 1px solid rgba(240, 198, 140, 0.24);
  border-radius: 1.05rem;
  background: rgba(9, 22, 17, 0.42);
  color: #fff2d4;
  box-shadow:
    0 18px 34px rgba(8, 28, 21, 0.24),
    0 0 0 1px rgba(255, 255, 255, 0.05),
    0 0 0 5px rgba(240, 198, 140, 0.05);
  overflow: hidden;
  isolation: isolate;
  transform: translateY(14px) scale(0.92);
}

body.site-root .back-to-top.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

body.site-root .back-to-top::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background: conic-gradient(
    from 215deg,
    rgba(115, 217, 165, 0.2) 0turn,
    rgba(248, 223, 173, 0.98) calc(var(--back-to-top-progress, 0) * 1turn),
    rgba(236, 201, 157, 0.14) 0turn,
    rgba(236, 201, 157, 0.14) 1turn
  );
  opacity: 0.92;
  transition:
    opacity 220ms ease,
    filter 220ms ease;
}

body.site-root .back-to-top::after {
  content: "";
  position: absolute;
  inset: 3px;
  z-index: 0;
  border-radius: 0.9rem;
  background:
    radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.26), transparent 42%),
    radial-gradient(circle at 50% 130%, rgba(248, 228, 183, 0.24), transparent 58%),
    linear-gradient(180deg, rgba(36, 76, 61, 0.96), rgba(13, 31, 24, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05);
  transition:
    transform 220ms ease,
    opacity 220ms ease,
    background 220ms ease;
}

body.site-root .back-to-top.is-visible,
body.site-root .back-to-top__icon {
  animation: none;
}

body.site-root .back-to-top.is-visible::before {
  animation: back-to-top-aura 4.4s ease-in-out infinite;
}

body.site-root .back-to-top.is-visible::after {
  animation: back-to-top-core 4.4s ease-in-out infinite;
}

body.site-root .back-to-top__icon {
  position: relative;
  z-index: 1;
  width: 1.1rem;
  height: 1.1rem;
  color: #fff0cf;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.24));
  animation: back-to-top-arrow-site 2.6s cubic-bezier(0.22, 1, 0.36, 1) infinite;
}

body.site-root .back-to-top:hover,
body.site-root .back-to-top:focus-visible {
  border-color: rgba(248, 223, 173, 0.38);
  background: rgba(11, 26, 20, 0.5);
  color: #fff8ee;
  box-shadow:
    0 24px 40px rgba(8, 28, 21, 0.28),
    0 0 0 6px rgba(240, 198, 140, 0.1);
}

body.site-root .back-to-top:hover::before,
body.site-root .back-to-top:focus-visible::before {
  opacity: 1;
  filter: saturate(1.08) brightness(1.08);
}

body.site-root .back-to-top:hover::after,
body.site-root .back-to-top:focus-visible::after {
  transform: scale(1.02);
}

@media (max-width: 1199px) {
  body.site-root .utility-inner {
    gap: 0.45rem;
    padding: 0.28rem 0 0.34rem;
  }

  body.site-root .utility-support {
    justify-self: center;
    text-align: center;
    max-width: 42ch;
    font-size: 0.6rem;
    letter-spacing: 0.06em;
    line-height: 1.25;
  }

  body.site-root .utility-actions {
    width: 100%;
    gap: 0.6rem;
  }

  body.site-root .main-header__upper {
    grid-template-areas:
      "identity actions"
      "center center";
    grid-template-columns: minmax(0, 1fr) auto;
  }

  body.site-root .lang-switcher--minimal {
    padding: 0.08rem;
  }

  body.site-root .lang-link,
  body.site-root .utility-action--text {
    min-height: 1.6rem;
    padding: 0.22rem 0.54rem;
    font-size: 0.55rem;
    letter-spacing: 0.06em;
  }

  body.site-root .utility-action--icon {
    width: 2.3rem;
    min-width: 2.3rem;
    min-height: 1.6rem;
    padding: 0.08rem 0.16rem;
  }

  body.site-root .utility-action__icon {
    width: 1.22rem;
    height: 1.22rem;
  }

  body.site-root .main-header {
    padding: 0.42rem 0 0.32rem;
    gap: 0.36rem;
  }

  body.site-root .main-nav .brand-wordmark__mark {
    width: 42px;
    height: 42px;
  }

  body.site-root .main-nav .brand-wordmark__line--top,
  body.site-root .main-nav .brand-wordmark__line--bottom {
    font-size: 0.96rem;
  }

  body.site-root .main-header__actions {
    gap: 0.4rem;
  }

  body.site-root .main-nav .navbar-toggler {
    padding: 0.34rem 0.54rem;
    min-height: 36px;
  }

  body.site-root .main-nav .navbar-collapse.show,
  body.site-root .main-nav .navbar-collapse.collapsing {
    padding-top: 0.65rem;
    padding-bottom: 0.78rem;
  }

  body.site-root .mobile-nav-shell {
    padding: 0.68rem 0 0.85rem;
  }

  body.site-root .mobile-nav-actions {
    margin-bottom: 0.62rem;
  }

  body.site-root .footer-grid.footer-grid--directory,
  body.site-root .footer-grid.footer-grid--simple {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.6rem;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-brand,
  body.site-root .footer-grid.footer-grid--simple .footer-panel--brand {
    grid-column: 1 / -1;
    max-width: none;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-panel--stacked {
    grid-column: span 2;
  }
}

@media (max-width: 767px) {
  body.site-root .utility-inner {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 0.38rem;
    padding: 0.28rem 0 0.34rem;
  }

  body.site-root .utility-support {
    justify-self: center;
    text-align: center;
    max-width: 34ch;
    font-size: 0.58rem;
    letter-spacing: 0.05em;
    line-height: 1.2;
  }

  body.site-root .utility-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    width: 100%;
    align-items: center;
    gap: 0.38rem;
  }

  body.site-root .lang-switcher--minimal {
    justify-self: start;
  }

  body.site-root .utility-action--text {
    justify-content: center;
    justify-self: end;
  }

  body.site-root .lang-link,
  body.site-root .utility-action--text {
    min-height: 1.52rem;
    padding: 0.18rem 0.44rem;
    font-size: 0.52rem;
    letter-spacing: 0.05em;
  }

  body.site-root .utility-action--icon {
    width: 2.12rem;
    min-width: 2.12rem;
    min-height: 1.52rem;
    padding: 0.07rem 0.14rem;
  }

  body.site-root .utility-action__icon {
    width: 1.12rem;
    height: 1.12rem;
  }

  body.site-root .main-header {
    gap: 0.36rem;
    padding: 0.4rem 0 0.3rem;
  }

  body.site-root .main-header__upper {
    grid-template-areas:
      "identity actions"
      "center center";
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.55rem 0.45rem;
    align-items: center;
  }

  body.site-root .main-header__identity {
    grid-area: identity;
    min-width: 0;
  }

  body.site-root .main-nav .brand-lockup {
    align-items: center;
    gap: 0.55rem;
  }

  body.site-root .main-nav .brand-lockup__meta {
    padding-top: 0.08rem;
  }

  body.site-root .main-nav .brand-wordmark__mark {
    width: 38px;
    height: 38px;
  }

  body.site-root .main-nav .brand-wordmark__line--top,
  body.site-root .main-nav .brand-wordmark__line--bottom {
    font-size: 0.84rem;
  }

  body.site-root .main-header__actions {
    grid-area: actions;
    gap: 0.35rem;
    justify-self: end;
    align-self: center;
    padding-bottom: 0;
  }

  body.site-root .main-nav .navbar-toggler {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.7rem;
    min-width: 2.7rem;
    min-height: 2.7rem;
    padding: 0.32rem;
    border: 1px solid rgba(var(--logo-gold-rgb), 0.28);
    border-radius: 0.85rem;
    background: linear-gradient(180deg, rgba(var(--logo-gold-rgb), 0.08), rgba(255, 255, 255, 0.02));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
  }

  body.site-root .main-header__center {
    grid-area: center;
    justify-self: stretch;
    justify-content: center;
    align-items: center;
    gap: clamp(1rem, 6vw, 1.9rem);
    flex-wrap: nowrap;
    overflow: visible;
    padding-top: 0.4rem;
    padding-bottom: 0.05rem;
    border-top: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  }

  body.site-root .main-header__center .main-header__home {
    flex: 0 0 auto;
    min-width: auto;
    padding: 0.28rem 0 0.62rem;
    font-size: 0.72rem;
    letter-spacing: 0.06em;
    text-align: center;
  }

  body.site-root .mobile-nav-shell {
    padding: 0.55rem 0 0.72rem;
  }

  body.site-root .mobile-nav-actions {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.55rem;
  }

  body.site-root .footer-grid.footer-grid--directory,
  body.site-root .footer-grid.footer-grid--simple {
    grid-template-columns: 1fr;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-panel,
  body.site-root .footer-grid.footer-grid--simple .footer-panel {
    padding-left: 0;
    padding-top: 1rem;
    border-left: none;
    border-top: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  }

  body.site-root .footer-grid.footer-grid--directory .footer-panel:first-child,
  body.site-root .footer-grid.footer-grid--simple .footer-panel:first-child {
    padding-top: 0;
    border-top: none;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-panel--stacked {
    grid-column: auto;
  }

  body.site-root .floating-whatsapp {
    right: 0.65rem;
    width: 50px;
    height: 50px;
    min-height: 50px;
  }

  body.site-root .back-to-top {
    right: 0.75rem;
    bottom: max(0.75rem, env(safe-area-inset-bottom));
    width: 48px;
    height: 48px;
    min-height: 48px;
  }

  body.site-root .cookie-banner {
    left: 0.5rem;
    right: 0.5rem;
    bottom: max(0.5rem, env(safe-area-inset-bottom));
    width: auto;
    transform: none;
  }

  body.site-root .cookie-banner__inner {
    padding: 0.75rem 0.8rem;
    gap: 0.6rem 0.75rem;
  }

  body.site-root .cookie-actions {
    width: 100%;
    justify-content: flex-start;
  }

  body.site-root .cookie-actions .btn {
    flex: 1 1 0;
  }

}

@media (max-width: 479px) {
  body.site-root .utility-support {
    font-size: 0.52rem;
    letter-spacing: 0.06em;
  }

  body.site-root .utility-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 0.32rem;
  }

  body.site-root .lang-switcher--minimal,
  body.site-root .utility-action--text {
    justify-self: auto;
  }

  body.site-root .lang-switcher--minimal {
    align-self: center;
  }

  body.site-root .utility-action--text {
    width: min(100%, 11.5rem);
    margin: 0 auto;
    justify-content: center;
  }

  body.site-root .main-nav .brand-wordmark__mark {
    width: 34px;
    height: 34px;
  }

  body.site-root .main-nav .brand-wordmark__line--top,
  body.site-root .main-nav .brand-wordmark__line--bottom {
    font-size: 0.76rem;
  }

  body.site-root .main-header__upper {
    gap: 0.4rem;
  }

  body.site-root .main-nav .navbar-toggler {
    padding: 0.28rem 0.46rem;
    min-height: 34px;
  }

  body.site-root .cookie-banner__inner {
    padding: 0.68rem 0.72rem;
    gap: 0.55rem 0.65rem;
  }

  body.site-root .cookie-badge {
    min-height: 28px;
    padding: 0.26rem 0.65rem;
    font-size: 0.62rem;
  }

  body.site-root .cookie-text strong {
    font-size: 0.82rem;
  }

  body.site-root .cookie-text p {
    font-size: 0.76rem;
  }

  body.site-root .cookie-link {
    font-size: 0.68rem;
  }

  body.site-root .cookie-actions .btn {
    min-height: 34px;
    padding: 0.5rem 0.72rem;
    flex-basis: calc(50% - 0.25rem);
  }
}

/* ==========================================================================
   37. Final Shell Direction
   Tightens the premium shell, aligns gold to the lion mark, and resolves the
   last navigation, footer, and hero rhythm issues.
   ========================================================================== */
body.site-root {
  --lion-gold-soft: var(--logo-gold-soft);
  --lion-gold: var(--logo-gold);
  --lion-gold-deep: var(--logo-gold-deep);
  --lion-gold-ink: #2e1a07;
  --lion-gold-button:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--logo-gold) 34%, white) 0%,
      var(--logo-gold) 52%,
      color-mix(in srgb, var(--logo-gold) 82%, black) 100%
    );
  --lion-gold-button-hover:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--logo-gold) 40%, white) 0%,
      color-mix(in srgb, var(--logo-gold) 92%, white) 52%,
      color-mix(in srgb, var(--logo-gold) 88%, black) 100%
    );
}

body.site-root a {
  color: var(--lion-gold);
  text-decoration-color: rgba(var(--logo-gold-rgb), 0.38);
}

body.site-root a:hover,
body.site-root a:focus-visible {
  color: var(--lion-gold-soft);
}

body.site-root .section-title__icon,
body.site-root .page-map__icon,
body.site-root .footer-heading-icon,
body.site-root .hero-badge__icon,
body.site-root .hero-panel-item__icon,
body.site-root .sidebar-card--map .page-map__title .section-title__icon,
body.site-root .sidebar-card--map .page-map__icon {
  color: var(--lion-gold);
}

body.site-root .utility-bar {
  border-bottom-color: rgba(var(--logo-gold-rgb), 0.16);
}

body.site-root .utility-inner {
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 0.55rem;
  padding: 0.26rem 0 0.3rem;
}

body.site-root .utility-support {
  grid-column: 2;
  grid-row: 1;
  justify-self: center;
  text-align: center;
  color: rgba(245, 236, 219, 0.82);
  font-family: var(--font-display);
  font-size: 0.62rem;
  font-style: italic;
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1.2;
  text-transform: none;
}

body.site-root .utility-actions {
  grid-column: 1 / -1;
  grid-row: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 0.75rem;
  width: 100%;
}

body.site-root .lang-switcher--minimal {
  grid-column: 1;
  padding: 0.08rem;
  border-color: rgba(var(--logo-gold-rgb), 0.16);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(var(--logo-gold-rgb), 0.08), rgba(255, 255, 255, 0.02));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
  justify-self: start;
}

body.site-root .lang-link,
body.site-root .utility-action--text {
  min-height: 1.56rem;
  padding: 0.2rem 0.56rem;
  font-size: 0.54rem;
  letter-spacing: 0.09em;
}

body.site-root .utility-action--text {
  grid-column: 3;
  border-color: rgba(var(--logo-gold-rgb), 0.16);
  justify-self: end;
}

body.site-root .utility-action--icon {
  width: 2.48rem;
  min-width: 2.48rem;
  min-height: 1.56rem;
  padding: 0.08rem 0.18rem;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(var(--logo-gold-rgb), 0.08), rgba(255, 255, 255, 0.02));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

body.site-root .utility-action__icon {
  display: inline-block;
  width: 1.32rem;
  height: 1.32rem;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%2032%2032%22%20fill%3D%22none%22%3E%3Ccircle%20cx%3D%2216%22%20cy%3D%225.75%22%20r%3D%222.75%22%20fill%3D%22%23c89832%22/%3E%3Cpath%20d%3D%22M11.5%2011.25c1.7-.9%203.07-1.35%204.5-1.35s2.8.45%204.5%201.35%22%20stroke%3D%22%23c89832%22%20stroke-width%3D%221.9%22%20stroke-linecap%3D%22round%22/%3E%3Cpath%20d%3D%22M16%2010.75v5.2%22%20stroke%3D%22%23c89832%22%20stroke-width%3D%221.9%22%20stroke-linecap%3D%22round%22/%3E%3Cpath%20d%3D%22M12.65%2015.35%2016%2013.9l3.35%201.45%22%20stroke%3D%22%23c89832%22%20stroke-width%3D%221.9%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22/%3E%3Cpath%20d%3D%22M14.2%2016.2%2012.7%2026.2%22%20stroke%3D%22%23c89832%22%20stroke-width%3D%221.9%22%20stroke-linecap%3D%22round%22/%3E%3Cpath%20d%3D%22M17.8%2016.2%2019.3%2026.2%22%20stroke%3D%22%23c89832%22%20stroke-width%3D%221.9%22%20stroke-linecap%3D%22round%22/%3E%3Cpath%20d%3D%22M13.85%2020.2H18.15%22%20stroke%3D%22%23c89832%22%20stroke-width%3D%221.9%22%20stroke-linecap%3D%22round%22/%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

body.site-root .utility-action--text:hover,
body.site-root .utility-action--text:focus-visible {
  background: rgba(var(--logo-gold-rgb), 0.08);
  color: #fff8ee;
}

body.site-root .main-header {
  gap: 0.4rem;
  padding: 0.46rem 0 0.3rem;
}

body.site-root .main-header__upper {
  grid-template-areas:
    "identity actions"
    "center center";
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.72rem 0.65rem;
  align-items: center;
}

body.site-root .main-header__identity {
  grid-area: identity;
  min-width: 0;
}

body.site-root .main-header__center {
  grid-area: center;
  display: flex;
  align-items: center;
  justify-content: center;
  justify-self: stretch;
  align-self: stretch;
  min-width: 0;
  width: 100%;
  gap: clamp(0.85rem, 1.6vw, 1.5rem);
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  padding-top: 0.42rem;
  padding-bottom: 0.05rem;
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.12);
}

body.site-root .main-header__center::-webkit-scrollbar {
  display: none;
}

body.site-root .main-header__actions {
  grid-area: actions;
  gap: 0.55rem;
  justify-self: end;
  align-items: center;
  align-self: center;
  padding-bottom: 0;
}

body.site-root .main-header__consult-prompt {
  display: none;
}

body.site-root .main-header__consult-prompt::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -0.16rem;
  width: 100%;
  height: 1.5px;
  background: linear-gradient(90deg, transparent 0%, var(--lion-gold) 42%, var(--lion-gold-soft) 100%);
  opacity: 0.9;
  transform: scaleX(0.34);
  transform-origin: right center;
  transition: transform 180ms ease, opacity 180ms ease;
}

body.site-root .main-header__consult-kicker {
  color: rgba(var(--logo-gold-rgb), 0.74);
  font-size: 0.54rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

body.site-root .main-header__consult-link {
  color: var(--lion-gold);
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

body.site-root .main-header__consult-prompt:hover,
body.site-root .main-header__consult-prompt:focus-visible {
  text-decoration: none;
}

body.site-root .main-header__consult-prompt:hover::after,
body.site-root .main-header__consult-prompt:focus-visible::after {
  transform: scaleX(1);
}

body.site-root .main-header__consult-prompt:hover .main-header__consult-link,
body.site-root .main-header__consult-prompt:focus-visible .main-header__consult-link {
  color: var(--logo-gold-soft);
}

body.site-root .main-header__lower {
  display: none !important;
}

body.site-root .main-nav .navbar-nav {
  gap: clamp(0.75rem, 1.45vw, 1.15rem);
  align-items: flex-end;
  justify-content: center;
}

body.site-root .main-nav .nav-link,
body.site-root .main-nav .dropdown-toggle,
body.site-root .main-nav .main-header__home {
  padding: 0.4rem 0 0.72rem;
  color: rgba(245, 236, 219, 0.82);
  font-size: 0.91rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}

body.site-root .main-header__center .main-header__home {
  flex: 0 0 auto;
  align-self: center;
  position: relative;
  padding: 0.46rem 0.18rem 0.82rem;
  border: 0;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: rgba(255, 248, 238, 0.88);
  white-space: nowrap;
  line-height: 1;
}

body.site-root .main-header__center .main-header__home::before {
  content: "";
  position: absolute;
  left: 50%;
  right: 50%;
  bottom: 0.18rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(var(--logo-gold-rgb), 0), rgba(var(--logo-gold-rgb), 0.82), rgba(var(--logo-gold-rgb), 0));
  opacity: 0;
  transition: left 180ms ease, right 180ms ease, opacity 180ms ease;
}

body.site-root .main-nav .nav-link:hover,
body.site-root .main-nav .nav-link:focus-visible,
body.site-root .main-nav .dropdown.show > .nav-link,
body.site-root .main-nav .dropdown.show > .dropdown-toggle,
body.site-root .main-nav .main-header__home:hover,
body.site-root .main-nav .main-header__home:focus-visible {
  border-color: rgba(var(--logo-gold-rgb), 0.56);
  color: #fff8ee;
}

body.site-root .main-header__center .main-header__home:hover::before,
body.site-root .main-header__center .main-header__home:focus-visible::before {
  left: 0;
  right: 0;
  opacity: 0.82;
}

body.site-root .main-header__home.is-active {
  color: var(--lion-gold);
  border-color: rgba(var(--logo-gold-rgb), 0.96);
  background: linear-gradient(180deg, rgba(var(--logo-gold-rgb), 0.08), rgba(var(--logo-gold-rgb), 0) 72%);
  box-shadow: inset 0 1px 0 rgba(var(--logo-gold-rgb), 0.16);
}

body.site-root .main-header__home.is-active::before {
  left: 0;
  right: 0;
  opacity: 1;
  height: 2px;
  background: linear-gradient(90deg, rgba(var(--logo-gold-rgb), 0.18), rgba(var(--logo-gold-rgb), 0.98), rgba(var(--logo-gold-rgb), 0.18));
}

body.site-root .mobile-nav-home {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 0.24rem 0 0.56rem;
  border: 0;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  background: transparent;
  color: rgba(255, 248, 238, 0.88);
  font-weight: 600;
  text-decoration: none;
}

body.site-root .mobile-nav-home:hover,
body.site-root .mobile-nav-home:focus-visible {
  color: #fff8ee;
  border-bottom-color: rgba(var(--logo-gold-rgb), 0.56);
}

body.site-root .mobile-nav-home.is-active {
  color: var(--lion-gold);
  border-bottom-color: rgba(var(--logo-gold-rgb), 0.96);
}

body.site-root .mobile-nav-shell {
  display: block;
}

body.site-root .mobile-nav-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  padding-bottom: 0.7rem;
  margin-bottom: 0.85rem;
  border-bottom: 1px solid rgba(var(--logo-gold-rgb), 0.12);
}

body.site-root .mobile-nav-consult-prompt {
  display: grid;
  gap: 0.08rem;
  text-decoration: none;
}

body.site-root .main-nav .navbar-toggler {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
}

body.site-root .navbar-nav--services .dropdown-toggle::after {
  border-top-color: var(--lion-gold);
}

body.site-root .service-family-menu__link {
  position: relative;
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  padding: 0.34rem 0 0.42rem;
}

body.site-root .service-family-menu__link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0.08rem;
  width: 100%;
  height: 1.5px;
  background: linear-gradient(90deg, var(--lion-gold-deep) 0%, var(--lion-gold) 58%, var(--lion-gold-soft) 100%);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 180ms ease;
}

body.site-root .service-family-menu__link:hover,
body.site-root .service-family-menu__link:focus-visible {
  color: var(--logo-gold-soft);
}

body.site-root .service-family-menu__link:hover::after,
body.site-root .service-family-menu__link:focus-visible::after {
  transform: scaleX(1);
}

body.site-root .mobile-nav-actions {
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

body.site-root .mobile-nav-consult-prompt {
  width: 100%;
  justify-items: center;
  padding: 0.22rem 0 0.62rem;
  border-left: 0;
  text-align: center;
}

body.site-root .mobile-nav-consult-prompt::after {
  left: 50%;
  right: auto;
  bottom: -0.04rem;
  width: min(12rem, 100%);
  transform: translateX(-50%) scaleX(0.34);
  transform-origin: center center;
}

body.site-root .mobile-nav-consult-prompt .main-header__consult-kicker,
body.site-root .mobile-nav-consult-prompt .main-header__consult-link {
  text-align: center;
}

body.site-root .mobile-nav-consult-prompt:hover::after,
body.site-root .mobile-nav-consult-prompt:focus-visible::after {
  transform: translateX(-50%) scaleX(1);
}

body.site-root .mobile-nav-home,
body.site-root .mobile-nav-consult {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  min-height: 2rem;
  text-decoration: none;
}

body.site-root .mobile-nav-home {
  display: inline-flex;
  color: var(--lion-gold);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .mobile-nav-home.is-active {
  color: var(--lion-gold-soft);
}

body.site-root .mobile-nav-consult {
  color: var(--lion-gold);
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
}

body.site-root .mobile-nav-consult:hover,
body.site-root .mobile-nav-consult:focus-visible {
  color: var(--logo-gold-soft);
  text-decoration: none;
}

body.site-root .breadcrumbs {
  padding-top: 0.72rem;
}

body.site-root .hero {
  padding: clamp(2.9rem, 5vw, 4.4rem) 0 clamp(3.1rem, 6vw, 5rem);
}

body.site-root .hero-inner {
  grid-template-columns: minmax(0, 1.12fr) minmax(300px, 0.88fr);
  align-items: stretch;
  gap: clamp(1.25rem, 2vw, 2.1rem);
}

body.site-root .hero-copy {
  max-width: none;
  min-height: 100%;
  padding: clamp(1.15rem, 1.8vw, 1.55rem);
}

body.site-root .hero-copy__lead {
  margin-bottom: 0.82rem;
}

body.site-root .hero-summary {
  max-width: 43rem;
  margin-bottom: 0.9rem;
}

body.site-root .hero-badges {
  gap: 0.55rem;
  margin: 0.9rem 0 0.95rem;
}

body.site-root .hero-actions {
  gap: 0.7rem;
  margin-top: 0.1rem;
}

body.site-root .hero-meta {
  width: min(390px, 100%);
  min-width: 0;
  gap: 0.82rem;
  align-content: start;
  justify-self: end;
}

body.site-root .hero-panel {
  padding: 1rem 1.05rem;
}

body.site-root .hero-glance {
  gap: 0.85rem;
  margin-top: 1.05rem;
}

body.site-root .main-shell--intro {
  margin-top: -3.6rem;
}

body.site-root .site-footer .container {
  width: min(1360px, 94%);
}

body.site-root .footer-grid.footer-grid--directory {
  grid-template-columns: minmax(280px, 1.45fr) repeat(5, minmax(110px, 0.82fr)) minmax(180px, 1.02fr);
  gap: clamp(1rem, 1.6vw, 1.5rem);
}

body.site-root .footer-grid.footer-grid--simple {
  grid-template-columns: minmax(280px, 1.35fr) repeat(6, minmax(110px, 0.84fr));
  gap: clamp(1rem, 1.6vw, 1.5rem);
}

body.site-root .footer-grid.footer-grid--directory .footer-panel,
body.site-root .footer-grid.footer-grid--simple .footer-panel {
  min-width: 0;
  padding-left: 1.15rem;
}

body.site-root .footer-grid.footer-grid--directory .footer-link-list,
body.site-root .footer-grid.footer-grid--simple .footer-panel__group ul {
  gap: 0.62rem;
}

body.site-root .footer-grid.footer-grid--directory .footer-link-list a,
body.site-root .footer-panel__group a,
body.site-root .footer-meta__links a {
  overflow-wrap: break-word;
  word-break: normal;
}

body.site-root .footer-disclosure__body--scroll {
  max-height: min(15rem, 40vh);
}

html[lang="pt-BR"] body.site-root .site-footer .container {
  width: min(1420px, 95%);
}

html[lang="pt-BR"] body.site-root .footer-grid.footer-grid--directory {
  grid-template-columns: minmax(290px, 1.42fr) repeat(5, minmax(116px, 0.84fr)) minmax(210px, 1.08fr);
}

html[lang="pt-BR"] body.site-root .footer-grid.footer-grid--directory .footer-panel,
html[lang="pt-BR"] body.site-root .footer-grid.footer-grid--simple .footer-panel {
  padding-left: 1rem;
}

html[lang="pt-BR"] body.site-root .footer-description,
html[lang="pt-BR"] body.site-root .footer-panel__head p {
  max-width: 34ch;
}

html[lang="pt-BR"] body.site-root .footer-grid.footer-grid--directory .footer-panel:not(.footer-brand) a,
html[lang="pt-BR"] body.site-root .footer-panel__group a,
html[lang="pt-BR"] body.site-root .footer-panel__group strong,
html[lang="pt-BR"] body.site-root .footer-panel__group span,
html[lang="pt-BR"] body.site-root .footer-contact-list li {
  font-size: 0.89rem;
  line-height: 1.55;
}

html[lang="pt-BR"] body.site-root .footer-meta__statement {
  max-width: 118ch;
}

body.site-root .footer-main-cta {
  display: none;
}

body.site-root .footer-row--meta.footer-row--meta-compact {
  display: grid;
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
  gap: 0.12rem;
  margin-top: 1rem;
  padding-top: 0.72rem;
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.16);
}

body.site-root .footer-meta__statement {
  margin: 0;
  color: rgba(245, 236, 219, 0.68);
  font-size: 0.74rem;
  line-height: 1.18;
  max-width: 110ch;
}

body.site-root .footer-meta__statement:first-of-type {
  white-space: normal;
}

body.site-root .footer-meta__links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  color: rgba(245, 236, 219, 0.62);
  white-space: nowrap;
  line-height: 1;
}

body.site-root .footer-meta__links a {
  color: rgba(245, 236, 219, 0.78);
  text-decoration: none;
}

body.site-root .footer-meta__links a:hover,
body.site-root .footer-meta__links a:focus-visible {
  color: #fff8ee;
}

body.site-root .scroll-progress {
  position: fixed;
  top: calc(var(--utility-bar-height) + var(--main-nav-height) - 2px);
  left: 0;
  width: 100%;
  height: 3px;
  z-index: 59;
  pointer-events: none;
  background: rgba(var(--logo-gold-rgb), 0.08);
  opacity: 0;
  transition: opacity 180ms ease;
}

body.site-root .scroll-progress::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--lion-gold-deep) 0%, var(--lion-gold) 52%, var(--lion-gold-soft) 100%);
  box-shadow: 0 0 16px rgba(var(--logo-gold-rgb), 0.5);
  transform: scaleX(var(--scroll-progress, 0));
  transform-origin: left center;
}

body.site-root .scroll-progress.is-active {
  opacity: 1;
}

@media (max-width: 1439px) {
  body.site-root .footer-grid.footer-grid--directory {
    grid-template-columns: minmax(250px, 1.35fr) repeat(3, minmax(150px, 1fr));
  }

  body.site-root .footer-grid.footer-grid--simple {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  body.site-root .footer-grid.footer-grid--directory .footer-brand,
  body.site-root .footer-grid.footer-grid--simple .footer-panel--brand {
    grid-column: 1 / -1;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-panel--stacked {
    grid-column: span 2;
  }
}

@media (max-width: 1199px) {
  body.site-root .utility-inner {
    padding: 0.24rem 0;
  }

  body.site-root .utility-support {
    font-size: 0.52rem;
    letter-spacing: 0.06em;
  }

  body.site-root .hero {
    padding: 2.6rem 0 3.2rem;
  }

  body.site-root .main-shell--intro {
    margin-top: -2.4rem;
  }
}

@media (max-width: 767px) {
  body.site-root .utility-inner {
    gap: 0.28rem;
    padding: 0.22rem 0 0.28rem;
  }

  body.site-root .utility-support {
    max-width: 30ch;
    font-size: 0.5rem;
    line-height: 1.15;
  }

  body.site-root .mobile-nav-actions {
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 0.78rem;
  }

  body.site-root .mobile-nav-home {
    display: inline-flex;
  }

  body.site-root .mobile-nav-consult-prompt {
    padding-left: 0;
  }

  body.site-root .hero {
    padding: 2.35rem 0 2.8rem;
  }

  body.site-root .hero-copy,
  body.site-root .hero-panel,
  body.site-root .hero-glance-card {
    padding: 1rem;
  }

  body.site-root .hero-glance {
    margin-top: 0.82rem;
  }

  body.site-root .main-shell--intro {
    margin-top: -1.5rem;
  }

  body.site-root .footer-row--meta.footer-row--meta-compact {
    grid-template-columns: 1fr;
    justify-items: start;
    text-align: left;
  }

  body.site-root .footer-meta__links {
    justify-self: start;
    white-space: normal;
  }

  body.site-root .scroll-progress {
    height: 2px;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  body.site-root .footer-row--meta.footer-row--meta-compact {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  body.site-root .footer-meta__statement:first-of-type {
    white-space: normal;
  }

  body.site-root .footer-meta__statement:nth-of-type(2) {
    grid-column: 1 / -1;
  }
}

@media (max-width: 479px) {
  body.site-root .utility-support {
    max-width: 28ch;
    font-size: 0.46rem;
  }

  body.site-root .mobile-nav-consult {
    width: 100%;
    justify-content: flex-start;
  }

  body.site-root .hero-summary {
    max-width: 100%;
  }
}

@media (max-width: 991px) {
  body.site-root .hero-inner {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  body.site-root .hero-meta {
    width: 100%;
    justify-self: stretch;
  }
}

@media (max-width: 767px) {
  body.site-root .hero-copy__lead {
    gap: 0.55rem;
    margin-bottom: 0.7rem;
  }

  body.site-root .hero h1 {
    font-size: clamp(2.5rem, 12vw, 3.4rem);
    line-height: 0.96;
  }

  body.site-root .hero-summary {
    font-size: 1rem;
  }

  body.site-root .hero-panel-item {
    font-size: 0.9rem;
  }
}

body.site-root .home-hero {
  padding-bottom: 4.8rem;
}

body.site-root .home-hero .hero-inner {
  align-items: stretch;
  gap: clamp(1.15rem, 2vw, 1.95rem);
}

body.site-root .home-hero .hero-copy {
  max-width: 40rem;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  background: rgb(9 27 23 / 96%);
  box-shadow:
    0 28px 58px rgba(6, 16, 14, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(20px);
}

body.site-root .home-hero .hero-copy::before,
body.site-root .home-hero .hero-copy::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  z-index: 0;
}

body.site-root .home-hero .hero-copy::before {
  top: -11.5rem;
  left: -10.5rem;
  width: 36rem;
  height: 36rem;
  background: radial-gradient(circle, rgba(199, 129, 146, 0.34) 0%, rgba(199, 129, 146, 0.2) 32%, rgba(199, 129, 146, 0.1) 56%, transparent 78%);
  filter: blur(34px);
}

body.site-root .home-hero .hero-copy::after {
  right: -7rem;
  bottom: -7.5rem;
  width: 24rem;
  height: 24rem;
  background: radial-gradient(circle, rgba(var(--logo-gold-rgb), 0.12) 0%, rgba(var(--logo-gold-rgb), 0.05) 34%, rgba(17, 26, 40, 0.05) 56%, transparent 80%);
  filter: blur(28px);
}

body.site-root .home-hero .hero-copy > * {
  position: relative;
  z-index: 1;
}

body.site-root .home-hero h1 {
  max-width: 10.5ch;
  font-size: clamp(3.2rem, 5.6vw, 5.2rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
}

body.site-root .home-hero .hero-summary {
  max-width: 37rem;
  margin-bottom: 0;
  font-size: 1.04rem;
  color: rgba(248, 244, 236, 0.9);
}

body.site-root .home-hero-tagline {
  max-width: 34rem;
  margin: 0 0 0.8rem;
  color: rgba(249, 245, 237, 0.97);
  font-size: 1.08rem;
  line-height: 1.55;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.48);
}

body.site-root .home-hero .hero-kicker {
  background: rgba(255, 248, 247, 0.06);
  border-color: rgba(var(--logo-gold-rgb), 0.24);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.site-root .home-hero .hero-actions {
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 0.2rem;
}

body.site-root .home-signal-list,
body.site-root .home-bullet-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

body.site-root .home-signal-list {
  display: grid;
  gap: 0.72rem;
  max-width: 38rem;
  margin: 1.15rem 0 0.1rem;
}

body.site-root .home-signal-list li,
body.site-root .home-bullet-list li {
  position: relative;
  padding-left: 1.25rem;
}

body.site-root .home-signal-list li::before,
body.site-root .home-bullet-list li::before {
  content: "";
  position: absolute;
  top: 0.62rem;
  left: 0;
  width: 0.46rem;
  height: 0.46rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--lion-gold, var(--logo-gold)), var(--lion-gold-soft));
  box-shadow: 0 0 0 0.16rem rgba(var(--logo-gold-rgb), 0.18);
}

body.site-root .home-hero-meta {
  display: grid;
  gap: 1rem;
}

body.site-root .home-hero-portrait {
  display: grid;
  align-items: end;
  justify-items: center;
  overflow: hidden;
  padding: 1rem 1rem 0;
  background:
    linear-gradient(180deg, rgba(8, 19, 35, 0.9), rgba(8, 19, 35, 0.22)),
    #111a28;
}

body.site-root .home-hero-portrait img {
  display: block;
  width: min(100%, 24rem);
  height: clamp(20rem, 33vw, 28rem);
  aspect-ratio: auto;
  object-fit: contain;
  object-position: center bottom;
}

body.site-root .home-hero-portrait figcaption {
  display: grid;
  gap: 0.3rem;
  padding: 0.95rem 1rem 1.1rem;
  justify-items: center;
  text-align: center;
}

body.site-root .home-hero-portrait strong {
  color: var(--logo-gold);
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

body.site-root .home-hero-portrait span {
  color: rgba(245, 236, 219, 0.84);
  font-size: 0.95rem;
  line-height: 1.55;
}

body.site-root .home-hero-proof {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

body.site-root .home-hero-proof strong {
  font-size: 1.02rem;
}

body.site-root .home-hero-proof .hero-panel-list {
  display: grid;
  gap: 0.65rem;
}

body.site-root .home-hero-proof .hero-panel-item {
  padding-left: 0;
}

body.site-root .home-hero-proof .hero-panel-item::before {
  display: none;
}

body.site-root .hero-glance a.hero-glance-card,
body.site-root a.hero-glance-card {
  display: block;
  color: inherit;
  text-decoration: none;
}

body.site-root .hero-glance {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.site-root a.hero-glance-card:hover,
body.site-root a.hero-glance-card:focus-visible {
  transform: translateY(-4px);
}

body.site-root .page-home-atlas {
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.12), transparent 30%),
    linear-gradient(180deg, #f6f0e6 0%, #f5efe7 28%, #ede2d2 100%);
  padding-bottom: clamp(3rem, 7vw, 5rem);
}

body.site-root .home-editorial {
  padding: clamp(3.1rem, 7.5vw, 5.8rem) 0;
}

body.site-root .home-editorial--light {
  background: linear-gradient(180deg, #f7f2ea 0%, #efe5d8 100%);
  color: #1d1814;
}

body.site-root .home-editorial--warm {
  background: linear-gradient(180deg, #f4eadb 0%, #ecddc9 100%);
  color: #1d1814;
}

body.site-root .home-editorial--dark {
  background:
    linear-gradient(135deg, rgba(9, 27, 23, 0.96), rgba(26, 39, 55, 0.92)),
    linear-gradient(180deg, rgba(var(--logo-gold-rgb), 0.08), rgba(0, 0, 0, 0));
  color: #f7f1e6;
}

body.site-root .home-editorial--ink {
  background:
    radial-gradient(circle at top left, rgba(var(--logo-gold-rgb), 0.14), transparent 30%),
    linear-gradient(135deg, rgba(20, 23, 30, 0.98), rgba(26, 33, 43, 0.96));
  color: #f7f1e6;
}

body.site-root .home-manifesto {
  position: relative;
  z-index: 3;
  margin-top: clamp(-3.6rem, -5vw, -2.4rem);
}

body.site-root .home-manifesto-shell {
  padding: clamp(1.45rem, 3vw, 2.2rem);
  border: 1px solid rgba(var(--logo-gold-rgb), 0.22);
  border-radius: 1.7rem;
  background:
    linear-gradient(160deg, rgba(255, 252, 246, 0.99), rgba(242, 226, 198, 0.96));
  color: #1b1612;
  box-shadow: 0 32px 70px rgba(34, 26, 14, 0.12);
}

body.site-root .home-manifesto-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
  gap: clamp(1.1rem, 2.6vw, 2rem);
  align-items: start;
}

body.site-root .home-section-head {
  display: grid;
  gap: 0.75rem;
  margin-bottom: clamp(1.15rem, 2.6vw, 1.9rem);
}

body.site-root .home-section-head h2 {
  margin: 0;
  font-size: clamp(2.05rem, 4vw, 3.3rem);
  line-height: 0.98;
  letter-spacing: -0.03em;
}

body.site-root .home-section-head p {
  margin: 0;
  max-width: 72ch;
  font-size: 1rem;
  line-height: 1.7;
}

body.site-root .home-editorial--light .home-section-head h2,
body.site-root .home-editorial--warm .home-section-head h2,
body.site-root .home-manifesto-shell .home-section-head h2,
body.site-root .home-atlas-feature__content h3,
body.site-root .home-service-family h3,
body.site-root .home-service-band h3,
body.site-root .home-brazil-cluster__body h3 {
  color: #1d1712;
}

body.site-root .home-editorial--light .home-section-head p,
body.site-root .home-editorial--warm .home-section-head p,
body.site-root .home-manifesto-shell .home-section-head p,
body.site-root .home-atlas-feature__content p,
body.site-root .home-link-group,
body.site-root .home-service-family p,
body.site-root .home-service-family li,
body.site-root .home-brazil-cluster__body p,
body.site-root .home-brazil-cluster__body li {
  color: rgba(42, 33, 24, 0.86);
}

body.site-root .home-section-head--light p,
body.site-root .home-section-head--light h2 {
  color: inherit;
}

body.site-root .home-manifesto-copy {
  display: grid;
  gap: 0.85rem;
  align-content: start;
}

body.site-root .home-manifesto-subhead {
  margin: 0;
  color: rgba(113, 77, 25, 0.9);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

body.site-root .home-map-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.95rem;
}

body.site-root .home-chapter-card {
  display: grid;
  gap: 0.55rem;
  min-height: 11.2rem;
  padding: 1.2rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background: rgba(255, 255, 255, 0.86);
  color: #1b1c1d;
  text-decoration: none;
  box-shadow: 0 18px 40px rgba(31, 28, 21, 0.06);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

body.site-root .home-chapter-card:hover,
body.site-root .home-chapter-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(var(--logo-gold-rgb), 0.4);
  box-shadow: 0 22px 48px rgba(31, 28, 21, 0.1);
}

body.site-root .home-chapter-card span {
  color: rgba(117, 87, 27, 0.8);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.16em;
}

body.site-root .home-chapter-card strong {
  font-size: 1.1rem;
}

body.site-root .home-chapter-card p {
  margin: 0;
  color: rgba(34, 34, 34, 0.76);
  line-height: 1.58;
}

body.site-root .home-bullet-list {
  display: grid;
  gap: 0.7rem;
}

body.site-root .home-bullet-list--compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem 1rem;
  max-width: 56rem;
}

body.site-root .home-bullet-list--light li {
  color: rgba(247, 241, 230, 0.9);
}

body.site-root .home-mini-section {
  display: grid;
  gap: 0.72rem;
  padding: 1.05rem 1.1rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  background: rgba(255, 252, 248, 0.8);
}

body.site-root .home-mini-section h3 {
  margin: 0;
  font-size: 1rem;
}

body.site-root .home-atlas-grid {
  display: grid;
  gap: clamp(1.25rem, 2.8vw, 2.1rem);
}

body.site-root .home-atlas-feature {
  display: grid;
  grid-template-columns: minmax(280px, 0.72fr) minmax(0, 1.28fr);
  gap: clamp(1.1rem, 2.5vw, 1.8rem);
  align-items: stretch;
}

body.site-root .home-atlas-feature__media {
  margin: 0;
  border-radius: 1.8rem;
  overflow: hidden;
  box-shadow: 0 26px 60px rgba(38, 32, 22, 0.14);
}

body.site-root .home-atlas-feature__media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
}

body.site-root .home-atlas-feature__content {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body.site-root .home-atlas-feature__content p {
  margin: 0;
  line-height: 1.72;
}

body.site-root .home-highlight-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

body.site-root .home-highlight-links--dark {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.site-root .home-highlight-link {
  display: grid;
  gap: 0.45rem;
  padding: 1rem 1.05rem;
  border-radius: 1.2rem;
  text-decoration: none;
  color: #1a1511;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background: rgba(255, 252, 248, 0.92);
}

body.site-root .home-highlight-links--dark .home-highlight-link {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  color: #f7f1e6;
}

body.site-root .home-highlight-link strong {
  font-size: 1rem;
}

body.site-root .home-highlight-link span {
  color: rgba(47, 45, 41, 0.78);
  line-height: 1.6;
}

body.site-root .home-highlight-links--dark .home-highlight-link span {
  color: rgba(247, 241, 230, 0.76);
}

body.site-root .home-link-groups {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

body.site-root .home-link-group {
  padding: 1rem 1.05rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background: rgba(255, 252, 248, 0.9);
  color: #1b1612;
}

body.site-root .home-link-group h3 {
  margin: 0 0 0.85rem;
  font-size: 0.95rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.site-root .home-link-group ul,
body.site-root .home-service-family ul,
body.site-root .home-process-chapter ul,
body.site-root .home-brazil-cluster__body ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

body.site-root .home-link-group ul {
  display: grid;
  gap: 0.58rem;
}

body.site-root .home-link-group a,
body.site-root .home-service-family a,
body.site-root .home-process-chapter a,
body.site-root .home-brazil-cluster__body a,
body.site-root .home-process-step,
body.site-root .home-route-option,
body.site-root .home-text-link,
body.site-root .home-inline-link {
  color: inherit;
  text-decoration: none;
}

body.site-root .home-link-group a:hover,
body.site-root .home-link-group a:focus-visible,
body.site-root .home-service-family a:hover,
body.site-root .home-service-family a:focus-visible,
body.site-root .home-process-chapter a:hover,
body.site-root .home-process-chapter a:focus-visible,
body.site-root .home-brazil-cluster__body a:hover,
body.site-root .home-brazil-cluster__body a:focus-visible,
body.site-root .home-text-link:hover,
body.site-root .home-text-link:focus-visible,
body.site-root .home-inline-link:hover,
body.site-root .home-inline-link:focus-visible {
  color: var(--lion-gold, var(--logo-gold));
}

body.site-root .home-text-link,
body.site-root .home-inline-link {
  font-weight: 700;
  letter-spacing: 0.01em;
}

body.site-root .home-section-footer {
  margin-top: 1.1rem;
}

body.site-root .home-section-footer--links {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
}

body.site-root .home-service-rows {
  display: grid;
  gap: clamp(1.4rem, 3vw, 2.1rem);
}

body.site-root .home-service-row {
  display: grid;
  grid-template-columns: minmax(280px, 0.84fr) minmax(0, 1.16fr);
  gap: clamp(1rem, 2.7vw, 1.8rem);
  align-items: stretch;
}

body.site-root .home-service-row--reverse .home-service-row__media {
  order: 2;
}

body.site-root .home-service-row--reverse .home-service-row__families {
  order: 1;
}

body.site-root .home-service-row__media {
  margin: 0;
  border-radius: 1.8rem;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(38, 32, 22, 0.14);
  min-height: 100%;
}

body.site-root .home-service-row__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.site-root .home-service-row__families {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body.site-root .home-service-family {
  display: grid;
  gap: 0.85rem;
  padding: 1.1rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background: rgba(255, 252, 248, 0.95);
  color: #1b1714;
  box-shadow: 0 18px 44px rgba(37, 28, 18, 0.08);
}

body.site-root .home-service-family h3,
body.site-root .home-process-chapter h3,
body.site-root .home-brazil-cluster__body h3 {
  margin: 0;
  font-size: 1.18rem;
}

body.site-root .home-service-family p,
body.site-root .home-brazil-cluster__body p {
  margin: 0;
  line-height: 1.66;
}

body.site-root .home-service-list--dense {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 9rem), 1fr));
  gap: 0.55rem 0.95rem;
}

body.site-root .home-service-family ul,
body.site-root .home-process-chapter ul {
  display: grid;
  gap: 0.55rem;
}

body.site-root .home-service-family li,
body.site-root .home-process-chapter li,
body.site-root .home-brazil-cluster__body li {
  position: relative;
  min-width: 0;
  padding-left: 1rem;
}

body.site-root .home-service-family li a,
body.site-root .home-process-chapter li a,
body.site-root .home-brazil-cluster__body li a {
  display: block;
  min-width: 0;
}

body.site-root .home-service-family li::before,
body.site-root .home-process-chapter li::before,
body.site-root .home-brazil-cluster__body li::before {
  content: "";
  position: absolute;
  top: 0.7rem;
  left: 0;
  width: 0.36rem;
  height: 0.36rem;
  border-radius: 999px;
  background: rgba(var(--logo-gold-rgb), 0.9);
}

body.site-root .home-service-band {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(0, 1.28fr);
  gap: 1.2rem;
  padding: 1.25rem 1.35rem;
  border-radius: 1.55rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(135deg, rgba(19, 33, 32, 0.98), rgba(30, 31, 43, 0.94)),
    rgba(19, 33, 32, 0.94);
  color: #f7f1e6;
  box-shadow: 0 24px 58px rgba(0, 0, 0, 0.18);
}

body.site-root .home-service-band__content {
  display: grid;
  gap: 0.5rem;
  align-content: start;
}

body.site-root .home-service-band__content h3 {
  margin: 0;
  color: #fff7ea;
  font-size: 1.3rem;
}

body.site-root .home-service-band__content p {
  margin: 0;
  color: rgba(247, 241, 230, 0.86);
  line-height: 1.7;
}

body.site-root .home-service-band__links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem 1rem;
}

body.site-root .home-service-band__links li {
  position: relative;
  padding-left: 1rem;
}

body.site-root .home-service-band__links li::before {
  content: "";
  position: absolute;
  top: 0.68rem;
  left: 0;
  width: 0.36rem;
  height: 0.36rem;
  border-radius: 999px;
  background: rgba(var(--logo-gold-rgb), 0.9);
}

body.site-root .home-service-band__links a {
  color: #f7f1e6;
  text-decoration: none;
}

body.site-root .home-service-band__links a:hover,
body.site-root .home-service-band__links a:focus-visible {
  color: var(--lion-gold, var(--logo-gold));
}

body.site-root .home-process-pano {
  position: relative;
  min-height: 21rem;
  border-radius: 2rem;
  overflow: hidden;
  margin-bottom: 1.25rem;
  box-shadow: 0 30px 68px rgba(0, 0, 0, 0.22);
}

body.site-root .home-process-pano img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.site-root .home-process-pano__overlay {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.7rem;
  align-content: end;
  min-height: inherit;
  padding: clamp(1.3rem, 3.2vw, 2rem);
  background:
    linear-gradient(180deg, rgba(12, 23, 24, 0.12), rgba(12, 23, 24, 0.74)),
    linear-gradient(135deg, rgba(0, 82, 92, 0.16), rgba(var(--logo-gold-rgb), 0.08));
}

body.site-root .home-process-pano__overlay h3,
body.site-root .home-proof-quote p {
  margin: 0;
}

body.site-root .home-process-pano__overlay p {
  margin: 0;
  max-width: 50rem;
  color: rgba(247, 241, 230, 0.88);
}

body.site-root .home-process-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.8rem;
  margin-bottom: 1rem;
}

body.site-root .home-process-step {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 4rem;
  padding: 0.85rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.22);
  background: rgba(255, 255, 255, 0.06);
  font-weight: 700;
  text-align: center;
  transition: transform 180ms ease, background 180ms ease, border-color 180ms ease;
}

body.site-root .home-process-step:hover,
body.site-root .home-process-step:focus-visible {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(var(--logo-gold-rgb), 0.36);
}

body.site-root .home-process-chapters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}

body.site-root .home-process-chapter {
  padding: 1.1rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background: rgba(255, 255, 255, 0.06);
}

body.site-root .home-proof-shell {
  display: grid;
  grid-template-columns: minmax(280px, 0.76fr) minmax(0, 1.24fr);
  gap: clamp(1.1rem, 2.6vw, 1.9rem);
  align-items: stretch;
}

body.site-root .home-proof-media {
  margin: 0;
  align-self: start;
  display: grid;
  padding: clamp(0.9rem, 1.8vw, 1.3rem);
  border-radius: 1.85rem;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(7, 16, 28, 0.96), rgba(19, 33, 42, 0.84)),
    rgba(7, 16, 28, 0.92);
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.26);
}

body.site-root .home-proof-media img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center top;
}

body.site-root .home-next-step__portrait img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.site-root .home-proof-card {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body.site-root .home-proof-quote {
  margin: 0;
  padding: 1.2rem 1.25rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background: rgba(255, 255, 255, 0.06);
}

body.site-root .home-proof-quote p {
  font-size: 1.12rem;
  line-height: 1.7;
}

body.site-root .home-proof-quote footer {
  margin-top: 0.7rem;
  color: rgba(247, 241, 230, 0.72);
}

body.site-root .home-brazil-clusters {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body.site-root .home-brazil-cluster {
  border-radius: 1.6rem;
  overflow: hidden;
  background: rgba(255, 252, 248, 0.95);
  color: #1b1714;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  box-shadow: 0 20px 50px rgba(34, 26, 14, 0.08);
}

body.site-root .home-brazil-cluster img {
  display: block;
  width: 100%;
  height: 14rem;
  object-fit: cover;
}

body.site-root .home-brazil-cluster__body {
  display: grid;
  gap: 0.8rem;
  padding: 1.15rem;
}

body.site-root .home-brazil-cluster__body ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem 0.9rem;
}

body.site-root .home-next-step__shell {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
  gap: clamp(1.1rem, 2.8vw, 2rem);
  align-items: stretch;
}

body.site-root .home-next-step__content {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body.site-root .home-route-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body.site-root .home-route-option {
  display: grid;
  gap: 0.4rem;
  padding: 1rem 1.05rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background: rgba(255, 255, 255, 0.06);
}

body.site-root .home-route-option strong {
  font-size: 1rem;
}

body.site-root .home-route-option span {
  color: rgba(247, 241, 230, 0.76);
}

body.site-root .home-next-step__portrait {
  margin: 0;
  border-radius: 1.85rem;
  overflow: hidden;
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.22);
}

body.site-root .home-next-step__actions {
  align-items: center;
}

body.site-root.page-home .site-disclaimer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.15rem 0.45rem;
  margin-top: clamp(0.7rem, 1.4vw, 1rem);
  padding: 0.22rem 0.55rem;
  border: 0;
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  border-bottom: 1px solid rgba(var(--logo-gold-rgb), 0.1);
  border-radius: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01));
  box-shadow: none;
  color: rgba(247, 241, 230, 0.62);
  font-size: clamp(0.48rem, 0.46rem + 0.06vw, 0.54rem);
  line-height: 1.18;
  letter-spacing: 0.02em;
}

body.site-root.page-home .site-disclaimer p {
  display: inline;
}

body.site-root.page-home .site-disclaimer p + p {
  margin-top: 0;
}

body.site-root.page-home .site-disclaimer p + p::before {
  content: "•";
  display: inline-block;
  margin: 0 0.34rem 0 0.04rem;
  color: rgba(var(--logo-gold-rgb), 0.48);
}

body.site-root.page-home.theme-light .site-disclaimer {
  border-top-color: rgba(123, 82, 28, 0.16);
  border-bottom-color: rgba(123, 82, 28, 0.09);
  background: linear-gradient(180deg, rgba(123, 82, 28, 0.03), rgba(123, 82, 28, 0));
  color: rgba(56, 40, 24, 0.76);
}

body.site-root.page-home.theme-light .site-disclaimer p + p::before {
  color: rgba(123, 82, 28, 0.4);
}

body.site-root {
  --home-icon-scale: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 4v16'/%3E%3Cpath d='M5 7h14'/%3E%3Cpath d='M7 7l-3 5h6l-3-5z'/%3E%3Cpath d='M17 7l-3 5h6l-3-5z'/%3E%3Cpath d='M9.5 19h5'/%3E%3C/svg%3E");
  --home-icon-globe: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='8'/%3E%3Cpath d='M4 12h16'/%3E%3Cpath d='M12 4a12 12 0 0 1 0 16'/%3E%3Cpath d='M12 4a12 12 0 0 0 0 16'/%3E%3C/svg%3E");
  --home-icon-message: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 11.5A7.5 7.5 0 0 1 12.5 19H8l-4 2 1.3-3.3A7.5 7.5 0 0 1 12 4a8 8 0 0 1 8 7.5z'/%3E%3Cpath d='M8.5 11.5h7'/%3E%3Cpath d='M8.5 14.5H13'/%3E%3C/svg%3E");
  --home-icon-compass: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='8'/%3E%3Cpath d='M14.8 9.2l-2 5.6-5.6 2 2-5.6 5.6-2z'/%3E%3C/svg%3E");
  --home-icon-file: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 3.5h6l4 4V20a1 1 0 0 1-1 1H8a2 2 0 0 1-2-2V5.5a2 2 0 0 1 2-2z'/%3E%3Cpath d='M14 3.5V8h4'/%3E%3Cpath d='M9 12h6'/%3E%3Cpath d='M9 16h6'/%3E%3C/svg%3E");
  --home-icon-shield: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l6 3v6c0 4.2-2.6 7.7-6 9-3.4-1.3-6-4.8-6-9V6l6-3z'/%3E%3Cpath d='M9.5 12.5l1.7 1.7 3.3-3.4'/%3E%3C/svg%3E");
  --home-icon-calendar: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='5.5' width='16' height='14' rx='2'/%3E%3Cpath d='M8 3.5v4'/%3E%3Cpath d='M16 3.5v4'/%3E%3Cpath d='M4 9.5h16'/%3E%3C/svg%3E");
  --home-icon-badge: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l6 3v6c0 4.2-2.6 7.7-6 9-3.4-1.3-6-4.8-6-9V6l6-3z'/%3E%3Cpath d='M9.5 12l1.6 1.6 3.4-3.6'/%3E%3C/svg%3E");
  --home-icon-briefcase: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='7' width='16' height='11' rx='2'/%3E%3Cpath d='M9 7V5.5A1.5 1.5 0 0 1 10.5 4h3A1.5 1.5 0 0 1 15 5.5V7'/%3E%3Cpath d='M4 11h16'/%3E%3C/svg%3E");
  --home-icon-passport: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='6' y='4' width='12' height='16' rx='2'/%3E%3Cpath d='M9 4v16'/%3E%3Ccircle cx='13' cy='10' r='2.4'/%3E%3Cpath d='M10.8 10h4.4'/%3E%3Cpath d='M13 7.6a3.8 3.8 0 0 1 0 4.8'/%3E%3Cpath d='M13 7.6a3.8 3.8 0 0 0 0 4.8'/%3E%3C/svg%3E");
  --home-icon-house: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 11.5L12 5l8 6.5'/%3E%3Cpath d='M6.5 10.5V19h11v-8.5'/%3E%3Cpath d='M10 19v-4.5h4V19'/%3E%3C/svg%3E");
  --home-icon-spark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l1.9 4.9L19 9.8l-4.1 3.2 1.4 5L12 15.2 7.7 18l1.4-5L5 9.8l5.1-1.9L12 3z'/%3E%3C/svg%3E");
  --home-icon-alert: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 4l8 14H4L12 4z'/%3E%3Cpath d='M12 9v4'/%3E%3Cpath d='M12 16h.01'/%3E%3C/svg%3E");
  --home-icon-folder: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3.5 7.5A2.5 2.5 0 0 1 6 5h4l2 2h6a2.5 2.5 0 0 1 2.5 2.5V17A2.5 2.5 0 0 1 18 19.5H6A2.5 2.5 0 0 1 3.5 17V7.5z'/%3E%3C/svg%3E");
  --home-icon-map: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6.5l5-2 6 2 5-2v13l-5 2-6-2-5 2v-13z'/%3E%3Cpath d='M9 4.5v13'/%3E%3Cpath d='M15 6.5v13'/%3E%3C/svg%3E");
  --home-icon-city: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 20h16'/%3E%3Cpath d='M6 20V9l5-2v13'/%3E%3Cpath d='M11 20V5l7 3v12'/%3E%3Cpath d='M8 12h.01'/%3E%3Cpath d='M8 15h.01'/%3E%3Cpath d='M14 10h.01'/%3E%3Cpath d='M14 13h.01'/%3E%3C/svg%3E");
  --home-icon-heart: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20s-7-4.4-7-10a4 4 0 0 1 7-2.6A4 4 0 0 1 19 10c0 5.6-7 10-7 10z'/%3E%3C/svg%3E");
  --home-icon-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c89832' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='M13 6l6 6-6 6'/%3E%3C/svg%3E");
}

body.site-root .page-home-atlas {
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.12), transparent 24%),
    linear-gradient(180deg, #111721 0%, #16202d 36%, #18252c 100%);
}

body.site-root .home-manifesto-shell {
  border-color: rgba(var(--logo-gold-rgb), 0.24);
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.14), transparent 28%),
    linear-gradient(145deg, rgba(17, 23, 33, 0.99), rgba(26, 37, 44, 0.97));
  color: #f7f1e6;
  box-shadow: 0 32px 70px rgba(6, 10, 18, 0.38);
}

body.site-root .home-editorial--dark {
  background:
    radial-gradient(circle at top left, rgba(var(--logo-gold-rgb), 0.12), transparent 28%),
    linear-gradient(135deg, rgba(18, 34, 40, 0.98), rgba(24, 37, 44, 0.96));
  color: #f7f1e6;
}

body.site-root .home-editorial--ink {
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.12), transparent 26%),
    linear-gradient(135deg, rgba(15, 20, 30, 0.99), rgba(22, 28, 38, 0.97));
  color: #f7f1e6;
}

body.site-root .home-manifesto-shell .home-section-head h2,
body.site-root .home-editorial .home-section-head h2,
body.site-root .home-atlas-feature__content h3,
body.site-root .home-service-family h3,
body.site-root .home-service-band h3,
body.site-root .home-brazil-cluster__body h3,
body.site-root .home-link-group h3 {
  color: #fff7ea;
}

body.site-root .home-manifesto-shell .home-section-head p,
body.site-root .home-editorial .home-section-head p,
body.site-root .home-atlas-feature__content p,
body.site-root .home-link-group,
body.site-root .home-service-family p,
body.site-root .home-service-family li,
body.site-root .home-process-chapter li,
body.site-root .home-brazil-cluster__body p,
body.site-root .home-brazil-cluster__body li,
body.site-root .home-service-band__content p,
body.site-root .home-service-band__links a,
body.site-root .home-route-option span,
body.site-root .home-highlight-link span {
  color: rgba(247, 241, 230, 0.8);
}

body.site-root .home-manifesto-subhead,
body.site-root .home-chapter-card span,
body.site-root .home-link-group h3 {
  color: rgba(223, 190, 118, 0.9);
}

body.site-root .hero-glance-card,
body.site-root .home-chapter-card,
body.site-root .home-mini-section,
body.site-root .home-highlight-link,
body.site-root .home-link-group,
body.site-root .home-service-family,
body.site-root .home-brazil-cluster,
body.site-root .home-route-option {
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
    rgba(13, 20, 31, 0.7);
  color: #f7f1e6;
  box-shadow: 0 22px 54px rgba(0, 0, 0, 0.22);
}

body.site-root .home-chapter-card p,
body.site-root .hero-glance-card strong {
  color: rgba(247, 241, 230, 0.82);
}

body.site-root .hero-glance-card span {
  color: rgba(223, 190, 118, 0.88);
}

body.site-root .home-highlight-links--dark .home-highlight-link {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
    rgba(12, 18, 28, 0.78);
}

body.site-root .home-service-band,
body.site-root .home-process-chapter,
body.site-root .home-proof-quote {
  border-color: rgba(var(--logo-gold-rgb), 0.2);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
    rgba(12, 18, 28, 0.72);
  color: #f7f1e6;
}

body.site-root .home-process-step {
  background: rgba(255, 255, 255, 0.08);
}

body.site-root .home-proof-quote footer {
  color: rgba(247, 241, 230, 0.72);
}

body.site-root .home-signal-list li,
body.site-root .home-bullet-list li,
body.site-root .home-service-family li,
body.site-root .home-process-chapter li,
body.site-root .home-brazil-cluster__body li,
body.site-root .home-service-band__links li {
  padding-left: 1.45rem;
}

body.site-root .home-signal-list li::before,
body.site-root .home-bullet-list li::before,
body.site-root .home-service-family li::before,
body.site-root .home-process-chapter li::before,
body.site-root .home-brazil-cluster__body li::before,
body.site-root .home-service-band__links li::before {
  top: 0.26rem;
  width: 0.95rem;
  height: 0.95rem;
  border-radius: 0;
  background: transparent;
  background-image: var(--home-item-icon, var(--home-icon-spark));
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  box-shadow: none;
}

body.site-root .home-signal-list--hero li:nth-child(1) {
  --home-item-icon: var(--home-icon-scale);
}

body.site-root .home-signal-list--hero li:nth-child(2) {
  --home-item-icon: var(--home-icon-message);
}

body.site-root .home-signal-list--hero li:nth-child(3) {
  --home-item-icon: var(--home-icon-globe);
}

body.site-root .home-signal-list--hero li:nth-child(4) {
  --home-item-icon: var(--home-icon-briefcase);
}

body.site-root .home-bullet-list--route-needs li:nth-child(1) {
  --home-item-icon: var(--home-icon-compass);
}

body.site-root .home-bullet-list--route-needs li:nth-child(2) {
  --home-item-icon: var(--home-icon-file);
}

body.site-root .home-bullet-list--route-needs li:nth-child(3) {
  --home-item-icon: var(--home-icon-house);
}

body.site-root .home-bullet-list--route-needs li:nth-child(4) {
  --home-item-icon: var(--home-icon-alert);
}

body.site-root .home-bullet-list--route-needs li:nth-child(5) {
  --home-item-icon: var(--home-icon-map);
}

body.site-root .home-bullet-list--trust li:nth-child(1) {
  --home-item-icon: var(--home-icon-scale);
}

body.site-root .home-bullet-list--trust li:nth-child(2) {
  --home-item-icon: var(--home-icon-message);
}

body.site-root .home-bullet-list--trust li:nth-child(3) {
  --home-item-icon: var(--home-icon-compass);
}

body.site-root .home-bullet-list--trust li:nth-child(4) {
  --home-item-icon: var(--home-icon-globe);
}

body.site-root .home-bullet-list--trust li:nth-child(5) {
  --home-item-icon: var(--home-icon-shield);
}

body.site-root .home-bullet-list--highlights li:nth-child(1) {
  --home-item-icon: var(--home-icon-calendar);
}

body.site-root .home-bullet-list--highlights li:nth-child(2) {
  --home-item-icon: var(--home-icon-badge);
}

body.site-root .home-bullet-list--highlights li:nth-child(3) {
  --home-item-icon: var(--home-icon-message);
}

body.site-root .home-bullet-list--highlights li:nth-child(4) {
  --home-item-icon: var(--home-icon-briefcase);
}

body.site-root .home-bullet-list--highlights li:nth-child(5) {
  --home-item-icon: var(--home-icon-globe);
}

body.site-root .home-bullet-list--services li:nth-child(1) {
  --home-item-icon: var(--home-icon-compass);
}

body.site-root .home-bullet-list--services li:nth-child(2) {
  --home-item-icon: var(--home-icon-passport);
}

body.site-root .home-bullet-list--services li:nth-child(3) {
  --home-item-icon: var(--home-icon-house);
}

body.site-root .home-bullet-list--services li:nth-child(4) {
  --home-item-icon: var(--home-icon-spark);
}

body.site-root .home-bullet-list--services li:nth-child(5) {
  --home-item-icon: var(--home-icon-alert);
}

body.site-root .home-bullet-list--services li:nth-child(6) {
  --home-item-icon: var(--home-icon-folder);
}

body.site-root .home-bullet-list--proof li:nth-child(1) {
  --home-item-icon: var(--home-icon-calendar);
}

body.site-root .home-bullet-list--proof li:nth-child(2) {
  --home-item-icon: var(--home-icon-badge);
}

body.site-root .home-bullet-list--proof li:nth-child(3) {
  --home-item-icon: var(--home-icon-briefcase);
}

body.site-root .home-bullet-list--proof li:nth-child(4) {
  --home-item-icon: var(--home-icon-globe);
}

body.site-root .home-bullet-list--proof li:nth-child(5) {
  --home-item-icon: var(--home-icon-map);
}

body.site-root .home-bullet-list--proof li:nth-child(6) {
  --home-item-icon: var(--home-icon-shield);
}

body.site-root .home-service-family--advisory li {
  --home-item-icon: var(--home-icon-compass);
}

body.site-root .home-service-family--visas li {
  --home-item-icon: var(--home-icon-passport);
}

body.site-root .home-service-family--residency li {
  --home-item-icon: var(--home-icon-house);
}

body.site-root .home-service-family--naturalisation li {
  --home-item-icon: var(--home-icon-spark);
}

body.site-root .home-service-family--defense li {
  --home-item-icon: var(--home-icon-alert);
}

body.site-root .home-service-family--other li,
body.site-root .home-service-band__links--permanent li {
  --home-item-icon: var(--home-icon-folder);
}

body.site-root .home-process-chapter--before li {
  --home-item-icon: var(--home-icon-compass);
}

body.site-root .home-process-chapter--during li {
  --home-item-icon: var(--home-icon-file);
}

body.site-root .home-process-chapter--protection li {
  --home-item-icon: var(--home-icon-shield);
}

body.site-root .home-process-chapter--aftercare li {
  --home-item-icon: var(--home-icon-heart);
}

body.site-root .home-brazil-cluster--fit li {
  --home-item-icon: var(--home-icon-map);
}

body.site-root .home-brazil-cluster--regions li {
  --home-item-icon: var(--home-icon-city);
}

body.site-root .home-brazil-cluster--systems li {
  --home-item-icon: var(--home-icon-house);
}

body.site-root .home-hero-proof strong {
  margin-bottom: 0.2rem;
  font-size: 1.08rem;
}

body.site-root .home-hero-proof__list {
  gap: 0.72rem;
}

body.site-root .home-hero-proof .hero-panel-item {
  align-items: flex-start;
  line-height: 1.5;
}

body.site-root .home-hero-proof .hero-panel-item__icon {
  margin-top: 0.05rem;
  background:
    linear-gradient(145deg, rgba(var(--logo-gold-rgb), 0.22), rgba(var(--logo-gold-rgb), 0.08)),
    rgba(255, 255, 255, 0.04);
  box-shadow: inset 0 0 0 1px rgba(var(--logo-gold-rgb), 0.16);
}

body.site-root .hero-glance-card,
body.site-root .home-chapter-card,
body.site-root .home-route-option {
  position: relative;
  overflow: hidden;
}

body.site-root .hero-glance-card::before,
body.site-root .home-chapter-card::before,
body.site-root .home-route-option::before {
  content: "";
  display: block;
  width: 1.15rem;
  height: 1.15rem;
  margin-bottom: 0.85rem;
  background-image: var(--home-card-icon, var(--home-icon-arrow));
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

body.site-root .hero-glance-card--about,
body.site-root .home-chapter-card--about,
body.site-root .home-route-option--about {
  --home-card-icon: var(--home-icon-scale);
}

body.site-root .hero-glance-card--services,
body.site-root .home-chapter-card--services,
body.site-root .home-route-option--services {
  --home-card-icon: var(--home-icon-briefcase);
}

body.site-root .hero-glance-card--process,
body.site-root .home-chapter-card--process,
body.site-root .home-route-option--process {
  --home-card-icon: var(--home-icon-file);
}

body.site-root .hero-glance-card--brazil,
body.site-root .home-chapter-card--brazil,
body.site-root .home-route-option--brazil {
  --home-card-icon: var(--home-icon-map);
}

body.site-root .home-route-option--consultation {
  --home-card-icon: var(--home-icon-message);
}

body.site-root .home-service-family h3,
body.site-root .home-process-chapter h3,
body.site-root .home-brazil-cluster__body h3 {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}

body.site-root .home-service-family h3::before,
body.site-root .home-process-chapter h3::before,
body.site-root .home-brazil-cluster__body h3::before {
  content: "";
  width: 1rem;
  height: 1rem;
  flex: 0 0 1rem;
  background-image: var(--home-heading-icon, var(--home-icon-spark));
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

body.site-root .home-service-family--advisory {
  --home-heading-icon: var(--home-icon-compass);
}

body.site-root .home-service-family--visas {
  --home-heading-icon: var(--home-icon-passport);
}

body.site-root .home-service-family--residency {
  --home-heading-icon: var(--home-icon-house);
}

body.site-root .home-service-family--naturalisation {
  --home-heading-icon: var(--home-icon-spark);
}

body.site-root .home-service-family--defense {
  --home-heading-icon: var(--home-icon-alert);
}

body.site-root .home-service-family--other {
  --home-heading-icon: var(--home-icon-folder);
}

body.site-root .home-process-chapter--before {
  --home-heading-icon: var(--home-icon-compass);
}

body.site-root .home-process-chapter--during {
  --home-heading-icon: var(--home-icon-file);
}

body.site-root .home-process-chapter--protection {
  --home-heading-icon: var(--home-icon-shield);
}

body.site-root .home-process-chapter--aftercare {
  --home-heading-icon: var(--home-icon-heart);
}

body.site-root .home-brazil-cluster--fit {
  --home-heading-icon: var(--home-icon-map);
}

body.site-root .home-brazil-cluster--regions {
  --home-heading-icon: var(--home-icon-city);
}

body.site-root .home-brazil-cluster--systems {
  --home-heading-icon: var(--home-icon-house);
}

body.site-root.theme-light .page-home-atlas {
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.12), transparent 30%),
    linear-gradient(180deg, #f6f0e6 0%, #f5efe7 28%, #ede2d2 100%);
}

body.site-root.theme-light .home-manifesto-shell {
  background:
    linear-gradient(160deg, rgba(255, 252, 246, 0.99), rgba(242, 226, 198, 0.96));
  color: #1b1612;
  box-shadow: 0 32px 70px rgba(34, 26, 14, 0.12);
}

body.site-root.theme-light .home-editorial--dark {
  background: linear-gradient(180deg, #f7f2ea 0%, #efe5d8 100%);
  color: #1d1814;
}

body.site-root.theme-light .home-editorial--ink {
  background: linear-gradient(180deg, #f4eadb 0%, #ecddc9 100%);
  color: #1d1814;
}

body.site-root.theme-light .home-manifesto-shell .home-section-head h2,
body.site-root.theme-light .home-editorial .home-section-head h2,
body.site-root.theme-light .home-atlas-feature__content h3,
body.site-root.theme-light .home-service-family h3,
body.site-root.theme-light .home-service-band h3,
body.site-root.theme-light .home-brazil-cluster__body h3,
body.site-root.theme-light .home-link-group h3 {
  color: #1d1712;
}

body.site-root.theme-light .home-manifesto-shell .home-section-head p,
body.site-root.theme-light .home-editorial .home-section-head p,
body.site-root.theme-light .home-atlas-feature__content p,
body.site-root.theme-light .home-link-group,
body.site-root.theme-light .home-service-family p,
body.site-root.theme-light .home-service-family li,
body.site-root.theme-light .home-process-chapter li,
body.site-root.theme-light .home-brazil-cluster__body p,
body.site-root.theme-light .home-brazil-cluster__body li,
body.site-root.theme-light .home-service-band__content p,
body.site-root.theme-light .home-service-band__links a,
body.site-root.theme-light .home-route-option span,
body.site-root.theme-light .home-highlight-link span,
body.site-root.theme-light .home-chapter-card p,
body.site-root.theme-light .hero-glance-card strong {
  color: rgba(42, 33, 24, 0.86);
}

body.site-root.theme-light .home-manifesto-subhead,
body.site-root.theme-light .home-chapter-card span,
body.site-root.theme-light .hero-glance-card span,
body.site-root.theme-light .home-link-group h3 {
  color: rgba(117, 87, 27, 0.86);
}

body.site-root.theme-light .hero-glance-card,
body.site-root.theme-light .home-chapter-card,
body.site-root.theme-light .home-mini-section,
body.site-root.theme-light .home-highlight-link,
body.site-root.theme-light .home-link-group,
body.site-root.theme-light .home-service-family,
body.site-root.theme-light .home-brazil-cluster,
body.site-root.theme-light .home-route-option,
body.site-root.theme-light .home-service-band,
body.site-root.theme-light .home-process-chapter,
body.site-root.theme-light .home-proof-quote {
  background: rgba(255, 252, 248, 0.92);
  color: #1b1714;
  box-shadow: 0 18px 44px rgba(37, 28, 18, 0.08);
}

body.site-root.theme-light .home-highlight-links--dark .home-highlight-link {
  background: rgba(255, 252, 248, 0.92);
  color: #1b1714;
}

body.site-root.theme-light .home-process-step {
  background: rgba(255, 255, 255, 0.74);
  color: #1b1714;
}

body.site-root.theme-light .home-process-step:hover,
body.site-root.theme-light .home-process-step:focus-visible {
  background: rgba(255, 255, 255, 0.92);
}

body.site-root.theme-light .home-proof-quote footer,
body.site-root.theme-light .home-route-option span {
  color: rgba(42, 33, 24, 0.72);
}

body.site-root.theme-light .home-bullet-list--light li {
  color: rgba(42, 33, 24, 0.82);
}

body.site-root.theme-light .home-proof-media {
  background: rgba(255, 252, 248, 0.92);
}

body.site-root .page-services-directory-main {
  padding-bottom: 3rem;
}

body.site-root .services-directory-atlas {
  display: grid;
  gap: clamp(1.3rem, 3vw, 2rem);
  padding-bottom: 1rem;
}

body.site-root .services-directory-jump-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
}

body.site-root .services-directory-jump-card {
  display: grid;
  gap: 0.55rem;
  padding: 1.05rem 1.1rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
    rgba(12, 18, 28, 0.72);
  color: #f7f1e6;
  box-shadow: 0 22px 54px rgba(0, 0, 0, 0.18);
  text-decoration: none;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

body.site-root .services-directory-jump-card:hover,
body.site-root .services-directory-jump-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(var(--logo-gold-rgb), 0.32);
  box-shadow: 0 28px 62px rgba(0, 0, 0, 0.24);
}

body.site-root .services-directory-jump-card span {
  color: rgba(223, 190, 118, 0.9);
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .services-directory-jump-card strong {
  color: #fff7ea;
  font-size: 1.08rem;
}

body.site-root .services-directory-jump-card p {
  margin: 0;
  color: rgba(247, 241, 230, 0.78);
  line-height: 1.6;
}

body.site-root .services-directory-manifesto {
  padding: clamp(1.2rem, 3vw, 1.8rem);
  border-radius: 1.95rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.2);
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.14), transparent 28%),
    linear-gradient(145deg, rgba(17, 23, 33, 0.99), rgba(26, 37, 44, 0.97));
  color: #f7f1e6;
  box-shadow: 0 32px 70px rgba(6, 10, 18, 0.38);
}

body.site-root .services-directory-manifesto__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  gap: clamp(1.1rem, 2.8vw, 2rem);
  align-items: start;
}

body.site-root .services-directory-manifesto__copy,
body.site-root .services-directory-manifesto__notes {
  display: grid;
  gap: 0.85rem;
}

body.site-root .services-directory-manifesto__copy h2 {
  margin: 0;
  color: #fff7ea;
  font-size: clamp(2rem, 4vw, 2.8rem);
}

body.site-root .services-directory-manifesto__copy p,
body.site-root .services-directory-manifesto__notes p,
body.site-root .services-directory-manifesto__notes li {
  margin: 0;
  color: rgba(247, 241, 230, 0.82);
  line-height: 1.7;
}

body.site-root .services-directory-manifesto__notes {
  padding: 1.15rem;
  border-radius: 1.45rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
    rgba(12, 18, 28, 0.7);
}

body.site-root .services-directory-family {
  display: grid;
  gap: 1.15rem;
  padding: clamp(1.1rem, 2.8vw, 1.7rem);
  border-radius: 1.95rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.18);
}

body.site-root .services-directory-family__feature {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(1rem, 2.8vw, 1.8rem);
  align-items: stretch;
}

body.site-root .services-directory-family__media {
  margin: 0;
  border-radius: 1.65rem;
  overflow: hidden;
  min-height: 100%;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
}

body.site-root .services-directory-family__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.site-root .services-directory-family__copy {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: clamp(1rem, 2vw, 1.25rem);
  border-radius: 1.55rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
    rgba(12, 18, 28, 0.68);
}

body.site-root .services-directory-family__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
}

body.site-root .services-directory-family__eyebrow,
body.site-root .services-directory-family__count {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0.3rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.22);
  background: rgba(255, 255, 255, 0.06);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .services-directory-family__eyebrow {
  color: rgba(223, 190, 118, 0.92);
}

body.site-root .services-directory-family__count {
  color: rgba(247, 241, 230, 0.78);
}

body.site-root .services-directory-family__copy h2 {
  margin: 0;
  color: #fff7ea;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
}

body.site-root .services-directory-family__copy p {
  margin: 0;
  color: rgba(247, 241, 230, 0.82);
  line-height: 1.72;
}

body.site-root .services-directory-family__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

body.site-root .services-directory-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 245px), 1fr));
  gap: 1rem;
}

body.site-root .services-directory-card {
  display: grid;
  gap: 0.8rem;
  height: 100%;
  padding: 1.05rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
    rgba(12, 18, 28, 0.72);
  color: #f7f1e6;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.16);
}

body.site-root .services-directory-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body.site-root .services-directory-card__eyebrow {
  color: rgba(223, 190, 118, 0.88);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .services-directory-card__icon {
  display: grid;
  place-items: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 999px;
  background:
    linear-gradient(145deg, rgba(var(--logo-gold-rgb), 0.22), rgba(var(--logo-gold-rgb), 0.08)),
    rgba(255, 255, 255, 0.04);
  box-shadow: inset 0 0 0 1px rgba(var(--logo-gold-rgb), 0.16);
}

body.site-root .services-directory-card__icon::before {
  content: "";
  width: 1.1rem;
  height: 1.1rem;
  background-image: var(--services-directory-icon, var(--home-icon-spark));
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

body.site-root .services-directory-card h3 {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.35;
}

body.site-root .services-directory-card h3 a {
  color: #fff7ea;
  text-decoration: none;
}

body.site-root .services-directory-card h3 a:hover,
body.site-root .services-directory-card h3 a:focus-visible,
body.site-root .services-directory-card__related a:hover,
body.site-root .services-directory-card__related a:focus-visible {
  color: var(--lion-gold, var(--logo-gold));
}

body.site-root .services-directory-card p {
  margin: 0;
  color: rgba(247, 241, 230, 0.8);
  line-height: 1.68;
}

body.site-root .services-directory-card__related {
  font-size: 0.94rem;
}

body.site-root .services-directory-card__related a {
  color: #fff7ea;
}

body.site-root .services-directory-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: auto;
}

body.site-root .services-directory-next-step {
  margin-top: 0.5rem;
}

body.site-root .services-directory-next-step .home-route-option strong {
  color: #fff7ea;
}

body.site-root .services-directory-family--advisory,
body.site-root .services-directory-card--advisory {
  --services-directory-icon: var(--home-icon-compass);
}

body.site-root .services-directory-family--visas,
body.site-root .services-directory-card--visas {
  --services-directory-icon: var(--home-icon-passport);
}

body.site-root .services-directory-family--residencies,
body.site-root .services-directory-card--residencies {
  --services-directory-icon: var(--home-icon-house);
}

body.site-root .services-directory-family--naturalisation,
body.site-root .services-directory-card--naturalisation {
  --services-directory-icon: var(--home-icon-spark);
}

body.site-root .services-directory-family--defense,
body.site-root .services-directory-card--defense {
  --services-directory-icon: var(--home-icon-alert);
}

body.site-root .services-directory-family--support,
body.site-root .services-directory-card--support {
  --services-directory-icon: var(--home-icon-folder);
}

body.site-root.theme-light .services-directory-jump-card,
body.site-root.theme-light .services-directory-manifesto,
body.site-root.theme-light .services-directory-manifesto__notes,
body.site-root.theme-light .services-directory-family,
body.site-root.theme-light .services-directory-family__copy,
body.site-root.theme-light .services-directory-card {
  background: rgba(255, 252, 248, 0.94);
  color: #1b1714;
  box-shadow: 0 18px 44px rgba(37, 28, 18, 0.08);
}

body.site-root.theme-light .services-directory-jump-card strong,
body.site-root.theme-light .services-directory-manifesto__copy h2,
body.site-root.theme-light .services-directory-family__copy h2,
body.site-root.theme-light .services-directory-card h3 a,
body.site-root.theme-light .services-directory-next-step .home-route-option strong {
  color: #1d1712;
}

body.site-root.theme-light .services-directory-jump-card p,
body.site-root.theme-light .services-directory-manifesto__copy p,
body.site-root.theme-light .services-directory-manifesto__notes p,
body.site-root.theme-light .services-directory-manifesto__notes li,
body.site-root.theme-light .services-directory-family__copy p,
body.site-root.theme-light .services-directory-card p,
body.site-root.theme-light .services-directory-card__related,
body.site-root.theme-light .services-directory-family__count {
  color: rgba(42, 33, 24, 0.82);
}

body.site-root.theme-light .services-directory-jump-card span,
body.site-root.theme-light .services-directory-family__eyebrow,
body.site-root.theme-light .services-directory-card__eyebrow {
  color: rgba(117, 87, 27, 0.86);
}

body.site-root.theme-light .services-directory-card__related a {
  color: #1d1712;
}

body.site-root.theme-light .services-directory-card__icon,
body.site-root.theme-light .services-directory-family__eyebrow,
body.site-root.theme-light .services-directory-family__count {
  background: rgba(255, 255, 255, 0.74);
}

body.site-root .page-services-directory-main--clean {
  padding: clamp(1.2rem, 3vw, 2.4rem) 0 3.5rem;
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.1), transparent 26%),
    linear-gradient(180deg, rgba(9, 14, 22, 0.98) 0%, rgba(11, 18, 29, 0.99) 34%, rgba(8, 13, 22, 1) 100%);
}

body.site-root .services-directory-hero {
  padding: 0 0 clamp(1.4rem, 3vw, 2rem);
}

body.site-root .services-directory-hero__inner {
  display: grid;
  gap: 1.2rem;
  padding: clamp(1.25rem, 3vw, 1.9rem);
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  border-radius: 1.75rem;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.015)),
    rgba(12, 18, 28, 0.88);
  box-shadow: 0 24px 54px rgba(0, 0, 0, 0.18);
}

body.site-root .services-directory-hero__eyebrow {
  margin: 0 0 0.45rem;
  color: rgba(223, 190, 118, 0.88);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.site-root .services-directory-hero h1 {
  margin: 0;
  color: #fff7ea;
  font-size: clamp(2.6rem, 5vw, 4.2rem);
  line-height: 0.95;
}

body.site-root .services-directory-hero__lede {
  max-width: 64rem;
  margin: 0;
  color: rgba(247, 241, 230, 0.78);
  font-size: 1.02rem;
  line-height: 1.72;
}

body.site-root .services-directory-family-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

body.site-root .services-directory-family-nav a {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  min-height: 2.9rem;
  padding: 0.55rem 0.95rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background: rgba(255, 255, 255, 0.04);
  color: #fff7ea;
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

body.site-root .services-directory-family-nav a span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  min-height: 2rem;
  padding: 0 0.48rem;
  border-radius: 999px;
  background: rgba(var(--logo-gold-rgb), 0.16);
  color: rgba(223, 190, 118, 0.96);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

body.site-root .services-directory-family-nav a:hover,
body.site-root .services-directory-family-nav a:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(var(--logo-gold-rgb), 0.34);
  background: rgba(255, 255, 255, 0.07);
}

body.site-root .services-directory-atlas--clean {
  gap: 1.15rem;
}

body.site-root .page-services-directory-main--clean .services-directory-family {
  gap: 1rem;
  padding: clamp(1.15rem, 2.6vw, 1.55rem);
}

body.site-root .page-services-directory-main--clean .services-directory-family__header {
  display: grid;
  gap: 0.8rem;
}

body.site-root .page-services-directory-main--clean .services-directory-family__heading {
  display: grid;
  gap: 0.45rem;
}

body.site-root .page-services-directory-main--clean .services-directory-family__heading h2 {
  margin: 0;
  color: #fff7ea;
  font-size: clamp(1.45rem, 2.3vw, 1.95rem);
}

body.site-root .page-services-directory-main--clean .services-directory-family__heading p {
  margin: 0;
  max-width: 60rem;
  color: rgba(247, 241, 230, 0.76);
  line-height: 1.68;
}

body.site-root .page-services-directory-main--clean .services-directory-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 290px), 1fr));
  gap: 1rem;
}

body.site-root .page-services-directory-main--clean .services-directory-card {
  position: relative;
  display: grid;
  gap: 0.85rem;
  min-height: 100%;
  padding: 1rem;
  overflow: hidden;
  isolation: isolate;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

body.site-root .page-services-directory-main--clean .services-directory-card:hover,
body.site-root .page-services-directory-main--clean .services-directory-card:focus-within {
  transform: translateY(-2px);
  border-color: rgba(var(--logo-gold-rgb), 0.32);
  box-shadow: 0 26px 56px rgba(0, 0, 0, 0.2);
}

body.site-root .page-services-directory-main--clean .services-directory-card::after {
  content: "";
  position: absolute;
  inset: auto 1rem 0.9rem 1rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(var(--logo-gold-rgb), 0.34), rgba(var(--logo-gold-rgb), 0));
  opacity: 0.7;
}

body.site-root .page-services-directory-main--clean .services-directory-card__media,
body.site-root .page-services-directory-main--clean .services-directory-card__top,
body.site-root .page-services-directory-main--clean .services-directory-card h3,
body.site-root .page-services-directory-main--clean .services-directory-card p,
body.site-root .page-services-directory-main--clean .services-directory-card__actions {
  position: relative;
  z-index: 2;
}

body.site-root .page-services-directory-main--clean .services-directory-card__media {
  margin: 0;
  overflow: hidden;
  border-radius: 1.1rem;
  aspect-ratio: 16 / 10;
  background: rgba(255, 255, 255, 0.04);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.16);
}

body.site-root .page-services-directory-main--clean .services-directory-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.site-root .page-services-directory-main--clean .services-directory-card__top {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-height: 3rem;
}

body.site-root .page-services-directory-main--clean .services-directory-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  overflow: hidden;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 247, 214, 0.16), transparent 34%),
    linear-gradient(145deg, rgba(86, 64, 20, 0.92), rgba(34, 24, 8, 0.98));
  border: 1px solid rgba(225, 183, 72, 0.54);
  box-shadow:
    inset 0 1px 0 rgba(255, 247, 222, 0.24),
    0 10px 24px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(var(--logo-gold-rgb), 0.08);
}

body.site-root .page-services-directory-main--clean .services-directory-card__icon img {
  display: block;
  width: 1.35rem;
  height: 1.35rem;
  filter: brightness(0) saturate(100%) invert(74%) sepia(41%) saturate(834%) hue-rotate(8deg) brightness(98%) contrast(93%);
}

body.site-root .page-services-directory-main--clean .services-directory-card__consult {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 2.95rem;
  height: auto;
  padding: 0.74rem 0.9rem;
  border-radius: 1rem;
  text-align: center;
  line-height: 1.35;
  white-space: normal;
}

body.site-root .page-services-directory-main--clean .services-directory-card__consult:hover,
body.site-root .page-services-directory-main--clean .services-directory-card__consult:focus-visible {
  transform: translateY(-1px);
}

body.site-root .page-services-directory-main--clean .services-directory-card h3 {
  color: #fff7ea;
  font-size: 1.08rem;
  line-height: 1.4;
  margin: 0;
}

body.site-root .page-services-directory-main--clean .services-directory-card h3 a {
  color: inherit;
  text-decoration: none;
}

body.site-root .page-services-directory-main--clean .services-directory-card p {
  color: rgba(247, 241, 230, 0.78);
  margin: 0;
  font-size: 0.97rem;
  line-height: 1.63;
}

body.site-root .page-services-directory-main--clean .services-directory-card__actions {
  display: grid;
  gap: 0.65rem;
  margin-top: auto;
}

body.site-root .page-services-directory-main--clean .services-directory-card__read {
  width: 100%;
  min-height: 2.95rem;
  padding: 0.74rem 0.9rem;
  border-radius: 1rem;
  justify-content: center;
  line-height: 1.35;
  white-space: normal;
}

body.site-root.theme-light .page-services-directory-main--clean {
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.1), transparent 24%),
    linear-gradient(180deg, #f7f1e8 0%, #f2e7d9 36%, #ebddca 100%);
}

body.site-root.theme-light .page-services-directory-main--clean .services-directory-hero__inner,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-family,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-card {
  background: rgba(255, 252, 248, 0.94);
  color: #1b1714;
  box-shadow: 0 18px 44px rgba(37, 28, 18, 0.08);
}

body.site-root.theme-light .page-services-directory-main--clean .services-directory-hero h1,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-family__heading h2,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-card h3,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-family-nav a {
  color: #1d1712;
}

body.site-root.theme-light .page-services-directory-main--clean .services-directory-hero__lede,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-family__heading p,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-card p {
  color: rgba(42, 33, 24, 0.82);
}

body.site-root.theme-light .page-services-directory-main--clean .services-directory-hero__eyebrow,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-family-nav a span,
body.site-root.theme-light .page-services-directory-main--clean .services-directory-family__eyebrow {
  color: rgba(117, 87, 27, 0.88);
}

body.site-root.theme-light .page-services-directory-main--clean .services-directory-family-nav a {
  background: rgba(255, 255, 255, 0.72);
}

body.site-root.theme-light .page-services-directory-main--clean .services-directory-family-nav a span {
  background: rgba(var(--logo-gold-rgb), 0.14);
}

body.site-root.theme-light .page-services-directory-main--clean .services-directory-card__icon {
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.76), transparent 36%),
    linear-gradient(145deg, rgba(247, 237, 212, 0.98), rgba(229, 203, 147, 0.96));
  border-color: rgba(162, 118, 24, 0.3);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 10px 24px rgba(103, 76, 26, 0.12),
    0 0 0 1px rgba(var(--logo-gold-rgb), 0.08);
}

body.site-root.theme-light .page-services-directory-main--clean .services-directory-card__consult {
  background: rgba(255, 255, 255, 0.88);
}

@media (max-width: 1199px) {
  body.site-root .hero-glance,
  body.site-root .home-map-grid,
  body.site-root .home-link-groups,
  body.site-root .home-process-chapters,
  body.site-root .home-brazil-clusters {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.site-root .home-highlight-links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.site-root .services-directory-jump-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body.site-root .home-hero {
    padding-bottom: 3.6rem;
  }

  body.site-root .home-hero .hero-copy {
    order: 2;
  }

  body.site-root .home-hero-meta {
    order: 1;
  }

  body.site-root .home-manifesto {
    margin-top: -2.4rem;
  }

  body.site-root .home-manifesto-grid,
  body.site-root .home-atlas-feature,
  body.site-root .home-service-row,
  body.site-root .home-service-band,
  body.site-root .home-proof-shell,
  body.site-root .home-next-step__shell {
    grid-template-columns: 1fr;
  }

  body.site-root .home-service-row--reverse .home-service-row__media,
  body.site-root .home-service-row--reverse .home-service-row__families {
    order: initial;
  }

  body.site-root .home-service-row__families,
  body.site-root .home-bullet-list--compact,
  body.site-root .home-route-options,
  body.site-root .home-highlight-links,
  body.site-root .home-highlight-links--dark,
  body.site-root .home-service-band__links,
  body.site-root .home-process-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.site-root .services-directory-manifesto__grid,
  body.site-root .services-directory-family__feature {
    grid-template-columns: 1fr;
  }

  body.site-root .page-services-directory-main--clean .services-directory-family-nav a {
    flex: 1 1 calc(50% - 0.7rem);
    justify-content: space-between;
  }
}

@media (max-width: 767px) {
  body.site-root .page-home-atlas {
    padding-bottom: 2.4rem;
  }

  body.site-root .home-hero {
    padding-bottom: 3rem;
  }

  body.site-root .home-manifesto {
    margin-top: -1.4rem;
  }

  body.site-root .home-manifesto-shell,
  body.site-root .home-chapter-card,
  body.site-root .home-link-group,
  body.site-root .home-service-family,
  body.site-root .home-service-band,
  body.site-root .home-process-chapter,
  body.site-root .home-brazil-cluster__body,
  body.site-root .home-route-option {
    padding: 1rem;
  }

  body.site-root .home-section-head h2 {
    font-size: clamp(2rem, 10vw, 2.75rem);
  }

  body.site-root .home-map-grid,
  body.site-root .hero-glance,
  body.site-root .home-link-groups,
  body.site-root .home-bullet-list--compact,
  body.site-root .home-service-list--dense,
  body.site-root .home-service-row__families,
  body.site-root .home-service-band__links,
  body.site-root .home-process-chapters,
  body.site-root .home-process-strip,
  body.site-root .home-highlight-links,
  body.site-root .home-highlight-links--dark,
  body.site-root .home-brazil-clusters,
  body.site-root .home-route-options,
  body.site-root .services-directory-jump-grid {
    grid-template-columns: 1fr;
  }

  body.site-root .page-services-directory-main--clean {
    padding: 0.85rem 0 2.6rem;
  }

  body.site-root .page-services-directory-main--clean .services-directory-hero__inner,
  body.site-root .page-services-directory-main--clean .services-directory-family {
    padding: 1rem;
    border-radius: 1.35rem;
  }

  body.site-root .page-services-directory-main--clean .services-directory-hero h1 {
    font-size: clamp(2rem, 11vw, 2.8rem);
  }

  body.site-root .page-services-directory-main--clean .services-directory-family-nav {
    display: grid;
    grid-template-columns: 1fr;
  }

  body.site-root .page-services-directory-main--clean .services-directory-family-nav a {
    width: 100%;
    justify-content: space-between;
  }

  body.site-root .page-services-directory-main--clean .services-directory-card {
    min-height: 0;
  }

  body.site-root .page-services-directory-main--clean .services-directory-card__media {
    aspect-ratio: 16 / 11;
  }

  body.site-root .home-process-pano {
    min-height: 18rem;
  }

  body.site-root .services-directory-manifesto,
  body.site-root .services-directory-family,
  body.site-root .services-directory-family__copy,
  body.site-root .services-directory-card {
    padding: 1rem;
  }

  body.site-root .home-hero h1 {
    max-width: 12ch;
  }

  body.site-root .home-hero-portrait img {
    height: 24rem;
  }

  body.site-root .home-brazil-cluster__body ul {
    grid-template-columns: 1fr;
  }

  body.site-root.page-home .site-disclaimer {
    justify-content: flex-start;
    gap: 0.12rem 0.3rem;
    padding: 0.22rem 0;
    font-size: 0.46rem;
    line-height: 1.14;
    text-align: left;
  }

  body.site-root.page-home .site-disclaimer p + p::before {
    margin: 0 0.28rem 0 0.04rem;
  }
}

@media (max-width: 575px) {
  body.site-root .home-signal-list {
    gap: 0.62rem;
  }

  body.site-root .home-hero .hero-actions {
    align-items: stretch;
  }

  body.site-root .home-hero .hero-actions .btn {
    width: 100%;
    justify-content: center;
  }

  body.site-root .home-process-step {
    min-height: 3.25rem;
  }
}

@media (max-width: 767px) {
  body.site-root .footer-grid.footer-grid--directory,
  body.site-root .footer-grid.footer-grid--simple {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-brand,
  body.site-root .footer-grid.footer-grid--simple .footer-panel--brand,
  body.site-root .footer-grid.footer-grid--directory .footer-panel--stacked {
    grid-column: 1 / -1;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-panel,
  body.site-root .footer-grid.footer-grid--simple .footer-panel {
    min-width: 0;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-link-list,
  body.site-root .footer-grid.footer-grid--simple .footer-panel__group ul {
    gap: 0.5rem;
  }
}

@media (min-width: 768px) and (max-width: 1199px) {
  body.site-root .footer-grid.footer-grid--directory,
  body.site-root .footer-grid.footer-grid--simple {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.site-root .footer-grid.footer-grid--directory .footer-brand,
  body.site-root .footer-grid.footer-grid--simple .footer-panel--brand {
    grid-column: 1 / -1;
  }

  body.site-root .footer-grid.footer-grid--directory .footer-panel--stacked {
    grid-column: span 2;
  }
}

/* ==========================================================================
   58. Nina Concierge
   Premium floating route-guidance widget shared across the site.
   ========================================================================== */
.floating-whatsapp--concierge,
body.site-root .floating-whatsapp--concierge {
  --nina-text: #f8efe2;
  --nina-muted: rgba(248, 239, 226, 0.76);
  --nina-subtle: rgba(248, 239, 226, 0.58);
  --nina-border: rgba(236, 201, 157, 0.16);
  --nina-border-strong: rgba(236, 201, 157, 0.28);
  --nina-panel: linear-gradient(180deg, rgba(13, 25, 37, 0.98), rgba(7, 18, 28, 0.98));
  --nina-card: linear-gradient(180deg, rgba(21, 38, 53, 0.94), rgba(14, 28, 40, 0.94));
  --nina-card-soft: rgba(20, 35, 48, 0.88);
  --nina-launcher: linear-gradient(135deg, rgba(18, 38, 56, 0.98), rgba(9, 22, 33, 0.98));
  --nina-highlight: #f0c68c;
  --nina-emerald: #73d9a5;
  --nina-shadow: 0 28px 60px rgba(5, 14, 23, 0.42);
  --nina-glow: 0 0 0 1px rgba(255, 255, 255, 0.04), 0 10px 26px rgba(9, 30, 45, 0.28);
  position: fixed;
  right: 1rem;
  bottom: 10.35rem;
  z-index: 1060;
  display: grid;
  justify-items: end;
  gap: 0;
  width: auto;
  height: auto;
  min-height: 0;
  padding: 0;
  border: 0;
  background: none;
  box-shadow: none;
  color: var(--nina-text);
  text-decoration: none;
  backdrop-filter: none;
  animation: none;
  overflow: visible !important;
  align-items: end;
  justify-content: end;
}

.floating-whatsapp--direct .floating-whatsapp__icon {
  width: 2.55rem;
  height: 2.55rem;
  border-radius: 50%;
  overflow: hidden;
}

.floating-whatsapp--direct .floating-whatsapp__avatar {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: contain;
  background: transparent;
  transform: scale(1.33);
  transform-origin: center;
}

body.theme-light .floating-whatsapp--concierge,
body.site-root.theme-light .floating-whatsapp--concierge {
  --nina-text: #1f2530;
  --nina-muted: rgba(31, 37, 48, 0.76);
  --nina-subtle: rgba(31, 37, 48, 0.56);
  --nina-border: rgba(114, 92, 66, 0.18);
  --nina-border-strong: rgba(114, 92, 66, 0.28);
  --nina-panel: linear-gradient(180deg, rgba(255, 250, 242, 0.98), rgba(247, 240, 231, 0.98));
  --nina-card: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(247, 241, 233, 0.95));
  --nina-card-soft: rgba(255, 255, 255, 0.94);
  --nina-launcher: linear-gradient(135deg, rgba(255, 251, 245, 0.98), rgba(243, 236, 226, 0.98));
  --nina-highlight: #936129;
  --nina-emerald: #0d7d53;
  --nina-shadow: 0 24px 50px rgba(74, 58, 40, 0.18);
  --nina-glow: 0 0 0 1px rgba(255, 255, 255, 0.4), 0 10px 26px rgba(111, 85, 54, 0.12);
}

.floating-whatsapp--concierge::before,
.floating-whatsapp--concierge::after,
body.site-root .floating-whatsapp--concierge::before,
body.site-root .floating-whatsapp--concierge::after {
  display: none !important;
  content: none;
}

.floating-whatsapp--concierge:not(:has(.floating-whatsapp__icon)) {
  overflow: visible;
}

.floating-whatsapp--concierge .nina-concierge__launcher {
  position: relative;
  width: 3.78rem;
  height: 3.78rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid rgba(240, 198, 140, 0.28);
  border-radius: 50%;
  background: linear-gradient(160deg, rgba(12, 25, 37, 0.98), rgba(7, 18, 28, 0.98));
  color: var(--nina-text);
  box-shadow: 0 18px 36px rgba(5, 14, 23, 0.32);
  overflow: hidden;
  cursor: pointer;
  transition:
    transform 220ms ease,
    box-shadow 220ms ease,
    border-color 220ms ease,
    background-color 220ms ease;
}

.floating-whatsapp--concierge .nina-concierge__launcher:hover,
.floating-whatsapp--concierge .nina-concierge__launcher:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(240, 198, 140, 0.42);
  box-shadow:
    0 24px 44px rgba(5, 14, 23, 0.36),
    0 0 0 0.3rem rgba(240, 198, 140, 0.08);
}

.floating-whatsapp--concierge .nina-concierge__launcher-image,
.floating-whatsapp--concierge .nina-concierge__hero-image {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: contain;
  padding: 0.12rem;
  background: radial-gradient(circle at 32% 22%, rgba(255, 255, 255, 0.18), transparent 44%), rgba(8, 18, 28, 0.6);
}

.floating-whatsapp--concierge .nina-concierge__launcher-status {
  position: absolute;
  right: 0.22rem;
  bottom: 0.22rem;
  width: 0.84rem;
  height: 0.84rem;
  border: 2px solid rgba(7, 18, 28, 0.96);
  border-radius: 50%;
  background: #74c69d;
  box-shadow: 0 0 0 0.15rem rgba(116, 198, 157, 0.2);
}

.floating-whatsapp--concierge .nina-concierge__launcher-arrow svg,
.floating-whatsapp--concierge .nina-concierge__close svg,
.floating-whatsapp--concierge .nina-concierge__option-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.floating-whatsapp--concierge .nina-concierge__panel {
  position: absolute;
  right: 0;
  bottom: calc(100% + 0.78rem);
  width: min(22.5rem, calc(100vw - 1.25rem));
  max-width: calc(100vw - 0.9rem);
  max-height: min(38rem, calc(100dvh - 2rem));
  opacity: 0;
  transform: translateY(14px) scale(0.985);
  transform-origin: bottom right;
  pointer-events: none;
  transition:
    opacity 220ms ease,
    transform 220ms ease;
}

.floating-whatsapp--concierge.is-live .nina-concierge__panel {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.floating-whatsapp--concierge .nina-concierge__shell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  max-height: inherit;
  overflow: hidden;
  border: 1px solid var(--nina-border-strong);
  border-radius: 1.35rem;
  background: var(--nina-panel);
  box-shadow: var(--nina-shadow);
}

.floating-whatsapp--concierge .nina-concierge__header,
.floating-whatsapp--concierge .nina-concierge__footer {
  padding: 0.92rem;
}

.floating-whatsapp--concierge .nina-concierge__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.9rem;
  border-bottom: 1px solid var(--nina-border);
}

.floating-whatsapp--concierge .nina-concierge__identity {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.85rem;
  align-items: flex-start;
  min-width: 0;
}

.floating-whatsapp--concierge .nina-concierge__hero-image {
  width: 2.8rem;
  height: 2.8rem;
  flex-shrink: 0;
  border: 1px solid rgba(240, 198, 140, 0.2);
  box-shadow: 0 12px 28px rgba(7, 18, 28, 0.24);
}

.floating-whatsapp--concierge .nina-concierge__eyebrow {
  margin: 0 0 0.22rem;
  color: var(--nina-highlight);
  font-family: var(--font-label);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.floating-whatsapp--concierge .nina-concierge__header h2,
.floating-whatsapp--concierge .nina-concierge__recommendations-head h3 {
  margin: 0;
  color: var(--nina-text);
  font-size: clamp(0.98rem, 0.94rem + 0.22vw, 1.16rem);
  line-height: 1.12;
}

.floating-whatsapp--concierge .nina-concierge__subhead,
.floating-whatsapp--concierge .nina-concierge__recommendations-head p,
.floating-whatsapp--concierge .nina-concierge__search-note,
.floating-whatsapp--concierge .nina-concierge__result p,
.floating-whatsapp--concierge .nina-concierge__result small {
  color: var(--nina-muted);
}

.floating-whatsapp--concierge .nina-concierge__subhead {
  margin: 0.28rem 0 0;
  font-size: 0.84rem;
  line-height: 1.45;
}

.floating-whatsapp--concierge .nina-concierge__close,
.floating-whatsapp--concierge .nina-concierge__reset {
  border: 0;
  background: transparent;
  color: var(--nina-subtle);
  cursor: pointer;
}

.floating-whatsapp--concierge .nina-concierge__close {
  width: 2.3rem;
  height: 2.3rem;
  padding: 0.5rem;
  border-radius: 999px;
  border: 1px solid var(--nina-border);
  background: var(--nina-card-soft);
  color: var(--icon-gold);
  transition: background-color 180ms ease, color 180ms ease, border-color 180ms ease;
}

.floating-whatsapp--concierge .nina-concierge__close:hover,
.floating-whatsapp--concierge .nina-concierge__close:focus-visible,
.floating-whatsapp--concierge .nina-concierge__reset:hover,
.floating-whatsapp--concierge .nina-concierge__reset:focus-visible {
  color: var(--nina-text);
  border-color: var(--nina-border-strong);
}

.floating-whatsapp--concierge .nina-concierge__close:hover,
.floating-whatsapp--concierge .nina-concierge__close:focus-visible,
.floating-whatsapp--concierge .nina-concierge__launcher-arrow,
.floating-whatsapp--concierge .nina-concierge__option-icon {
  color: var(--icon-gold);
}

.floating-whatsapp--concierge .nina-concierge__body {
  display: grid;
  gap: 1rem;
  min-height: 0;
  max-height: min(26rem, calc(100dvh - 11rem));
  padding: 0.8rem;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}

.floating-whatsapp--concierge .nina-concierge__transcript {
  display: grid;
  gap: 0.75rem;
}

.floating-whatsapp--concierge .nina-concierge__bubble {
  width: fit-content;
  max-width: 100%;
  padding: 0.9rem 1rem;
  border: 1px solid var(--nina-border);
  border-radius: 1.1rem;
  background: var(--nina-card);
  color: var(--nina-text);
  line-height: 1.5;
  box-shadow: var(--nina-glow);
  overflow-wrap: anywhere;
}

.floating-whatsapp--concierge .nina-concierge__bubble--user {
  margin-left: auto;
  background: linear-gradient(180deg, rgba(102, 58, 39, 0.95), rgba(66, 35, 27, 0.95));
  border-color: rgba(227, 175, 122, 0.24);
}

.floating-whatsapp--concierge .nina-concierge__bubble--note {
  color: var(--nina-subtle);
  font-size: 0.88rem;
}

.floating-whatsapp--concierge .nina-concierge__bubble--typing::after {
  content: "";
  display: inline-block;
  width: 0.55ch;
  height: 1.05em;
  margin-left: 0.08rem;
  vertical-align: -0.12em;
  border-right: 2px solid currentColor;
  animation: nina-cursor 900ms steps(1, end) infinite;
}

.floating-whatsapp--concierge .nina-concierge__prompt-shell,
.floating-whatsapp--concierge .nina-concierge__recommendations,
.floating-whatsapp--concierge .nina-concierge__lead-shell,
.floating-whatsapp--concierge .nina-concierge__search-shell,
.floating-whatsapp--concierge .nina-concierge__search-results {
  display: grid;
  gap: 0.8rem;
  padding: 0.88rem;
  border: 1px solid var(--nina-border);
  border-radius: 1.1rem;
  background: var(--nina-card-soft);
}

.floating-whatsapp--concierge .nina-concierge__prompt-label,
.floating-whatsapp--concierge .nina-concierge__search label {
  margin: 0;
  color: var(--nina-text);
  font-family: var(--font-label);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.floating-whatsapp--concierge .nina-concierge__options {
  display: grid;
  gap: 0.7rem;
}

.floating-whatsapp--concierge .nina-concierge__option {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.85rem;
  align-items: flex-start;
  padding: 0.82rem;
  border: 1px solid var(--nina-border);
  border-radius: 1rem;
  background: var(--nina-card);
  color: var(--nina-text);
  text-align: left;
  box-shadow: var(--nina-glow);
  cursor: pointer;
  min-width: 0;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

.floating-whatsapp--concierge .nina-concierge__option:hover,
.floating-whatsapp--concierge .nina-concierge__option:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(240, 198, 140, 0.34);
  box-shadow: 0 18px 34px rgba(5, 14, 23, 0.3);
}

.floating-whatsapp--concierge .nina-concierge__option-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  padding: 0.48rem;
  border-radius: 0.85rem;
  background: linear-gradient(160deg, rgba(126, 211, 167, 0.18), rgba(57, 116, 161, 0.18));
  flex-shrink: 0;
}

.floating-whatsapp--concierge .nina-concierge__option-copy {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
}

.floating-whatsapp--concierge .nina-concierge__option-copy strong,
.floating-whatsapp--concierge .nina-concierge__result strong {
  color: var(--nina-text);
  font-size: 0.98rem;
}

.floating-whatsapp--concierge .nina-concierge__option-copy small,
.floating-whatsapp--concierge .nina-concierge__result small,
.floating-whatsapp--concierge .nina-concierge__search-status p + p {
  color: var(--nina-muted);
  line-height: 1.45;
}

.floating-whatsapp--concierge .nina-concierge__results {
  display: grid;
  gap: 0.75rem;
}

.floating-whatsapp--concierge .nina-concierge__result {
  display: grid;
  gap: 0.55rem;
  padding: 0.82rem;
  border: 1px solid var(--nina-border);
  border-radius: 1rem;
  background: var(--nina-card);
}

.floating-whatsapp--concierge .nina-concierge__result-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  align-items: center;
}

.floating-whatsapp--concierge .nina-concierge__family,
.floating-whatsapp--concierge .nina-concierge__best {
  display: inline-flex;
  align-items: center;
  min-height: 1.7rem;
  padding: 0.16rem 0.62rem;
  border-radius: 999px;
  font-family: var(--font-label);
  font-size: 0.72rem;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.floating-whatsapp--concierge .nina-concierge__family {
  border: 1px solid rgba(115, 217, 165, 0.18);
  background: rgba(115, 217, 165, 0.12);
  color: var(--nina-emerald);
}

.floating-whatsapp--concierge .nina-concierge__best {
  border: 1px solid rgba(240, 198, 140, 0.2);
  background: rgba(240, 198, 140, 0.12);
  color: var(--nina-highlight);
}

.floating-whatsapp--concierge .nina-concierge__result strong a {
  color: var(--nina-text);
  text-decoration: none;
}

.floating-whatsapp--concierge .nina-concierge__result strong a:hover,
.floating-whatsapp--concierge .nina-concierge__result strong a:focus-visible {
  color: var(--nina-highlight);
}

.floating-whatsapp--concierge .nina-concierge__lead-head {
  display: grid;
  gap: 0.45rem;
}

.floating-whatsapp--concierge .nina-concierge__lead-head h3,
.floating-whatsapp--concierge .nina-concierge__lead-head p {
  margin: 0;
}

.floating-whatsapp--concierge .nina-concierge__lead-form {
  display: grid;
  gap: 0.85rem;
}

.floating-whatsapp--concierge .nina-concierge__lead-grid {
  display: grid;
  gap: 0.75rem;
}

.floating-whatsapp--concierge .nina-concierge__lead-grid--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.floating-whatsapp--concierge .nina-concierge__field {
  display: grid;
  gap: 0.35rem;
}

.floating-whatsapp--concierge .nina-concierge__field span,
.floating-whatsapp--concierge .nina-concierge__lead-status {
  margin: 0;
  color: var(--nina-text);
  font-family: var(--font-label);
  font-size: 0.76rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.floating-whatsapp--concierge .nina-concierge__field-input {
  width: 100%;
  min-width: 0;
  padding: 0.8rem 0.92rem;
  border: 1px solid var(--nina-border);
  border-radius: 0.88rem;
  background: var(--nina-card);
  color: var(--nina-text);
  font: inherit;
}

.floating-whatsapp--concierge .nina-concierge__field-input::placeholder {
  color: var(--nina-subtle);
}

.floating-whatsapp--concierge .nina-concierge__field-input:focus-visible {
  outline: 3px solid rgba(240, 198, 140, 0.18);
  outline-offset: 2px;
  border-color: rgba(240, 198, 140, 0.34);
}

.floating-whatsapp--concierge .nina-concierge__field-input--textarea {
  min-height: 8rem;
  resize: vertical;
}

.floating-whatsapp--concierge .nina-concierge__lead-actions {
  display: flex;
  justify-content: flex-start;
}

.floating-whatsapp--concierge .nina-concierge__lead-status {
  color: var(--nina-muted);
  line-height: 1.45;
  text-transform: none;
  letter-spacing: 0;
}

.floating-whatsapp--concierge .nina-concierge__search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.7rem;
}

.floating-whatsapp--concierge .nina-concierge__search-input {
  width: 100%;
  min-width: 0;
  padding: 0.8rem 0.92rem;
  border: 1px solid var(--nina-border);
  border-radius: 0.88rem;
  background: var(--nina-card);
  color: var(--nina-text);
  font: inherit;
}

.floating-whatsapp--concierge .nina-concierge__search-input::placeholder {
  color: var(--nina-subtle);
}

.floating-whatsapp--concierge .nina-concierge__search-input:focus-visible {
  outline: 3px solid rgba(240, 198, 140, 0.18);
  outline-offset: 2px;
  border-color: rgba(240, 198, 140, 0.34);
}

.floating-whatsapp--concierge .nina-concierge__suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.floating-whatsapp--concierge .nina-concierge__suggestion {
  padding: 0.52rem 0.8rem;
  border: 1px solid var(--nina-border);
  border-radius: 999px;
  background: transparent;
  color: var(--nina-text);
  font: inherit;
  cursor: pointer;
  transition: border-color 180ms ease, transform 180ms ease, background-color 180ms ease;
}

.floating-whatsapp--concierge .nina-concierge__suggestion:hover,
.floating-whatsapp--concierge .nina-concierge__suggestion:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(240, 198, 140, 0.3);
  background: rgba(255, 255, 255, 0.03);
}

.floating-whatsapp--concierge .nina-concierge__search-status {
  display: grid;
  gap: 0.45rem;
}

.floating-whatsapp--concierge .nina-concierge__search-status p,
.floating-whatsapp--concierge .nina-concierge__result p,
.floating-whatsapp--concierge .nina-concierge__result small {
  margin: 0;
}

.floating-whatsapp--concierge .nina-concierge__footer {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
  border-top: 1px solid var(--nina-border);
  align-items: center;
}

.floating-whatsapp--concierge .nina-concierge__footer .btn {
  width: 100%;
  justify-content: center;
}

.floating-whatsapp--concierge .nina-concierge__reset {
  grid-column: 1 / -1;
  justify-self: center;
  padding: 0.2rem 0.5rem;
  color: var(--nina-subtle);
  font-family: var(--font-label);
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.floating-whatsapp--concierge.is-nudging .nina-concierge__launcher {
  animation: nina-concierge-pulse 1.8s ease-in-out infinite;
}

@keyframes nina-concierge-pulse {
  0%,
  100% {
    transform: translateY(0);
    box-shadow: var(--nina-shadow);
  }

  50% {
    transform: translateY(-2px);
    box-shadow:
      0 34px 70px rgba(5, 14, 23, 0.5),
      0 0 0 8px rgba(115, 217, 165, 0.08);
  }
}

@keyframes nina-cursor {
  0%,
  49% {
    opacity: 1;
  }

  50%,
  100% {
    opacity: 0;
  }
}

body.a11y-contrast .floating-whatsapp--concierge,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__launcher,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__shell,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__prompt-shell,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__recommendations,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__lead-shell,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__search-shell,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__search-results,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__bubble,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__option,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__result,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__field-input,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__search-input,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__suggestion,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__close {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__teaser,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__launcher-copy small,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__subhead,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__lead-head p,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__lead-head h3,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__field span,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__lead-status,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__search-note,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__result p,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__result small {
  color: #000000 !important;
}

body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__option-icon,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__launcher,
body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__hero-image {
  background: #ffffff !important;
  color: #000000 !important;
  box-shadow: none !important;
}

body.a11y-contrast .floating-whatsapp--concierge .nina-concierge__launcher-status {
  border-color: #ffffff !important;
  background: #000000 !important;
  box-shadow: none !important;
}

body.a11y-contrast .insights-lead-capture,
body.a11y-contrast .insights-lead-capture__card,
body.a11y-contrast .insights-lead-capture__form,
body.a11y-contrast .insights-exit-modal__close,
body.a11y-contrast .btn-ghost {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: #000000 !important;
  box-shadow: none !important;
}

body.a11y-contrast .insights-lead-capture *,
body.a11y-contrast .btn-ghost {
  color: #000000 !important;
}

@media (min-width: 768px) and (max-width: 1199px) {
  .floating-whatsapp--concierge,
  body.site-root .floating-whatsapp--concierge {
    right: 0.75rem;
    bottom: 10.15rem;
  }

  .floating-whatsapp--concierge .nina-concierge__panel {
    width: min(24.5rem, calc(100vw - 2rem));
    max-height: min(39rem, calc(100dvh - 2rem));
  }

  .floating-whatsapp--concierge .nina-concierge__body {
    max-height: min(27rem, calc(100dvh - 11.5rem));
  }
}

@media (max-width: 767px) {
  .floating-whatsapp--concierge,
  body.site-root .floating-whatsapp--concierge {
    right: 0.5rem;
    bottom: 9.95rem;
    width: auto;
  }

  .floating-whatsapp--concierge .nina-concierge__launcher {
    width: 3.48rem;
    height: 3.48rem;
  }

  .floating-whatsapp--concierge .nina-concierge__panel {
    width: min(23.5rem, calc(100vw - 1rem));
    max-width: calc(100vw - 1rem);
    max-height: min(35rem, calc(100dvh - 1rem));
  }

  .floating-whatsapp--concierge .nina-concierge__search-row,
  .floating-whatsapp--concierge .nina-concierge__footer {
    grid-template-columns: 1fr;
  }

  .floating-whatsapp--concierge .nina-concierge__lead-grid--two {
    grid-template-columns: 1fr;
  }

  .floating-whatsapp--concierge .nina-concierge__header,
  .floating-whatsapp--concierge .nina-concierge__footer {
    padding: 0.8rem;
  }

  .floating-whatsapp--concierge .nina-concierge__body {
    gap: 0.85rem;
    padding: 0.72rem;
    max-height: min(24rem, calc(100dvh - 10.5rem));
  }

  .floating-whatsapp--concierge .nina-concierge__option {
    gap: 0.72rem;
    padding: 0.76rem;
  }

  .floating-whatsapp--concierge .nina-concierge__option-icon {
    width: 2.15rem;
    height: 2.15rem;
  }

  .floating-whatsapp--concierge .nina-concierge__hero-image {
    width: 2.45rem;
    height: 2.45rem;
  }

  body.site-root .insights-exit-modal {
    padding: 0.72rem;
  }

  body.site-root .insights-exit-modal__close {
    top: 0.7rem;
    right: 0.7rem;
  }
}

@media (max-height: 760px) {
  .floating-whatsapp--concierge .nina-concierge__panel {
    max-height: calc(100dvh - 0.75rem);
  }

  .floating-whatsapp--concierge .nina-concierge__body {
    max-height: calc(100dvh - 9.75rem);
  }
}

@media (max-width: 991px) {
  body.site-root .insights-lead-capture__cards,
  body.site-root .insights-lead-capture__actions {
    grid-template-columns: 1fr;
  }
}

@keyframes clientProofFill {
  from {
    opacity: 0.45;
    transform: scaleX(0.04);
  }

  to {
    opacity: 1;
    transform: scaleX(1);
  }
}

@keyframes clientProofSweep {
  from {
    transform: translateX(-140%) skewX(-18deg);
  }

  to {
    transform: translateX(220%) skewX(-18deg);
  }
}

@keyframes clientProofDrift {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }

  50% {
    transform: translate3d(0, -0.35rem, 0);
  }
}

body.site-root .download-gateway {
  --gateway-accent: var(--logo-gold);
  --gateway-secondary: rgba(var(--logo-gold-rgb), 0.24);
  position: relative;
  overflow: hidden;
  margin-bottom: 1.35rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.16), transparent 30%),
    radial-gradient(circle at bottom left, rgba(47, 124, 103, 0.16), transparent 32%),
    linear-gradient(145deg, rgba(18, 24, 30, 0.98), rgba(43, 31, 36, 0.97) 54%, rgba(19, 40, 34, 0.96) 100%);
  box-shadow:
    0 28px 64px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  isolation: isolate;
}

body.site-root .download-gateway::before,
body.site-root .download-gateway::after {
  content: "";
  position: absolute;
  inset: auto;
  pointer-events: none;
}

body.site-root .download-gateway::before {
  top: -30%;
  right: -8%;
  width: 16rem;
  height: 16rem;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--gateway-accent) 28%, transparent), transparent 68%);
  opacity: 0.9;
  filter: blur(0.4rem);
}

body.site-root .download-gateway::after {
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gateway-secondary), transparent);
}

body.site-root .download-gateway--newsletter {
  --gateway-accent: var(--logo-gold);
  --gateway-secondary: rgba(var(--logo-gold-rgb), 0.3);
}

body.site-root .download-gateway--guide {
  --gateway-accent: #2f7c67;
  --gateway-secondary: rgba(47, 124, 103, 0.28);
}

body.site-root .download-gateway--residency {
  --gateway-accent: #8b4d63;
  --gateway-secondary: rgba(139, 77, 99, 0.3);
}

body.site-root .download-gateway__shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(19rem, 0.92fr);
  gap: 1.15rem;
  align-items: stretch;
  padding: clamp(1.2rem, 2.4vw, 1.6rem);
}

body.site-root .download-gateway__content {
  display: grid;
  align-content: center;
  gap: 0.85rem;
}

body.site-root .download-gateway__eyebrow {
  margin: 0;
  color: color-mix(in srgb, var(--gateway-accent) 88%, #fff 12%);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

body.site-root .download-gateway h2 {
  margin: 0;
  color: #fff7f0;
  font-family: var(--font-display-default);
  font-size: clamp(1.55rem, 2vw, 2.25rem);
  line-height: 1.05;
}

body.site-root .download-gateway__summary {
  margin: 0;
  max-width: 38rem;
  color: rgba(245, 239, 233, 0.82);
  font-size: 1rem;
  line-height: 1.65;
}

body.site-root .download-gateway__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

body.site-root .download-gateway__chip {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0.4rem 0.82rem;
  border: 1px solid color-mix(in srgb, var(--gateway-accent) 34%, rgba(255, 255, 255, 0.08));
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  color: #fffaf3;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .download-gateway__points {
  display: grid;
  gap: 0.58rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

body.site-root .download-gateway__points li {
  position: relative;
  padding-left: 1.15rem;
  color: rgba(245, 239, 233, 0.76);
  line-height: 1.6;
}

body.site-root .download-gateway__points li::before {
  content: "";
  position: absolute;
  top: 0.62rem;
  left: 0;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 50%;
  background: linear-gradient(135deg, color-mix(in srgb, var(--gateway-accent) 86%, #fff 14%), #fff2d8);
  box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--gateway-accent) 18%, transparent);
}

body.site-root .download-gateway__form {
  display: grid;
  gap: 0.82rem;
  align-content: start;
  padding: 1rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: calc(var(--radius-md) - 0.15rem);
  background:
    linear-gradient(180deg, rgba(14, 18, 23, 0.92), rgba(23, 27, 32, 0.9)),
    rgba(12, 15, 19, 0.92);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 18px 34px rgba(0, 0, 0, 0.24);
  backdrop-filter: blur(14px);
}

body.site-root .download-gateway__form label {
  display: grid;
  gap: 0.42rem;
  margin: 0;
  color: #fff6ef;
  font-size: 0.84rem;
  font-weight: 700;
}

body.site-root .download-gateway__form input {
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  background: rgba(248, 245, 240, 0.06);
  color: #fff8f4;
}

body.site-root .download-gateway__form input::placeholder {
  color: rgba(245, 239, 233, 0.52);
}

body.site-root .download-gateway__form input:focus {
  border-color: color-mix(in srgb, var(--gateway-accent) 62%, #ffffff 10%);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--gateway-accent) 20%, transparent),
    0 10px 24px rgba(0, 0, 0, 0.2);
}

body.site-root .download-gateway__fineprint {
  margin: 0;
  color: rgba(245, 239, 233, 0.62);
  font-size: 0.8rem;
  line-height: 1.55;
}

body.site-root .download-gateway__form .btn {
  width: 100%;
  justify-content: center;
}

body.site-root .insights-lead-capture {
  margin: 0 0 1.45rem;
}

body.site-root .insights-lead-capture .download-gateway__shell {
  gap: 1.2rem;
}

body.site-root .insights-lead-capture__content {
  gap: 0.95rem;
}

body.site-root .insights-lead-capture__cards {
  display: grid;
  gap: 0.82rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.site-root .insights-lead-capture__card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.78rem;
  align-items: flex-start;
  padding: 0.92rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: 1.05rem;
  background:
    linear-gradient(180deg, rgba(16, 21, 27, 0.9), rgba(27, 24, 29, 0.9)),
    rgba(12, 16, 20, 0.88);
  box-shadow:
    0 18px 34px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.site-root .insights-lead-capture__card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  padding: 0.5rem;
  border-radius: 0.88rem;
  background: linear-gradient(155deg, rgba(240, 198, 140, 0.18), rgba(115, 217, 165, 0.16));
  color: #f3cb8f;
  flex-shrink: 0;
}

body.site-root .insights-lead-capture__card-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

body.site-root .insights-lead-capture__card-copy {
  display: grid;
  gap: 0.3rem;
  min-width: 0;
}

body.site-root .insights-lead-capture__card-copy strong,
body.site-root .insights-lead-capture__success h3 {
  color: #fff7f0;
}

body.site-root .insights-lead-capture__card-copy strong {
  font-size: 0.98rem;
}

body.site-root .insights-lead-capture__card-copy p,
body.site-root .insights-lead-capture__form-copy,
body.site-root .insights-lead-capture__status,
body.site-root .insights-lead-capture__success p {
  margin: 0;
  color: rgba(245, 239, 233, 0.72);
  line-height: 1.55;
}

body.site-root .insights-lead-capture__form {
  gap: 0.88rem;
}

body.site-root .insights-lead-capture__form-head {
  display: grid;
  gap: 0.36rem;
}

body.site-root .insights-lead-capture__form-eyebrow {
  margin: 0;
  color: #fff7ef;
  font-family: var(--font-label);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.site-root .insights-lead-capture__actions {
  display: grid;
  gap: 0.72rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.site-root .insights-lead-capture__actions .btn {
  width: 100%;
  justify-content: center;
}

body.site-root .insights-lead-capture__status {
  min-height: 1.45rem;
  font-size: 0.85rem;
}

body.site-root .insights-lead-capture__form[data-state="error"] .insights-lead-capture__status {
  color: #ffd9c2;
}

body.site-root .insights-lead-capture__success {
  display: grid;
  gap: 0.82rem;
  align-content: start;
  min-height: 100%;
}

body.site-root .insights-lead-capture__success h3 {
  margin: 0;
  font-family: var(--font-display-default);
  font-size: clamp(1.3rem, 1.15rem + 0.55vw, 1.7rem);
  line-height: 1.08;
}

body.site-root .insights-lead-capture__actions--success {
  align-items: center;
}

body.site-root .insights-lead-capture__modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
}

body.site-root .insights-lead-capture__modal-actions .btn {
  justify-content: center;
}

body.page-about-atlas .atlas-hero__portrait {
  margin: 0 0 1rem;
}

body.page-about-atlas .atlas-hero__portrait img {
  display: block;
  width: 100%;
  max-width: 320px;
  margin: 0 auto 0.85rem;
  border-radius: 1.25rem;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
  object-fit: cover;
}

body.page-about-atlas .atlas-hero__portrait figcaption {
  text-align: center;
  font-size: 0.95rem;
  opacity: 0.88;
}

body.page-about-atlas .atlas-jump-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
  padding-top: 1.25rem;
}

body.page-about-atlas .atlas-jump-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.72rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(67, 67, 67, 0.9), rgba(81, 48, 59, 0.88)),
    rgba(58, 58, 58, 0.98);
  color: #fff7ef;
  text-decoration: none;
  font-family: var(--font-label);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.18);
}

body.page-about-atlas .atlas-jump-links a:hover,
body.page-about-atlas .atlas-jump-links a:focus-visible {
  color: #fffaf2;
  border-color: rgba(var(--logo-gold-rgb), 0.34);
  background:
    linear-gradient(145deg, rgba(88, 52, 63, 0.94), rgba(29, 63, 53, 0.9)),
    rgba(58, 58, 58, 0.98);
}

body.page-about-atlas .atlas-section,
body.page-about-atlas .atlas-consultation {
  overflow: hidden;
}

body.page-about-atlas .atlas-section__grid,
body.page-about-atlas .atlas-proof-layout,
body.page-about-atlas .atlas-story-layout,
body.page-about-atlas .atlas-consultation__shell {
  display: grid;
  gap: 1.35rem;
  align-items: center;
}

body.page-about-atlas .atlas-section__copy,
body.page-about-atlas .atlas-section__intro,
body.page-about-atlas .atlas-story-copy,
body.page-about-atlas .atlas-consultation__intro {
  display: grid;
  gap: 0.95rem;
}

body.page-about-atlas .atlas-section h2,
body.page-about-atlas .atlas-consultation h2 {
  margin: 0;
  font-size: clamp(1.7rem, 1.38rem + 1vw, 2.35rem);
  line-height: 1.08;
}

body.page-about-atlas .atlas-section p,
body.page-about-atlas .atlas-consultation p {
  max-width: 70ch;
}

body.page-about-atlas .atlas-section__highlight,
body.page-about-atlas .atlas-quote-card {
  padding: 1rem 1.1rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background:
    linear-gradient(145deg, rgba(107, 34, 53, 0.16), rgba(28, 75, 62, 0.16)),
    rgba(67, 67, 67, 0.78);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.14);
}

body.page-about-atlas .atlas-section__highlight strong,
body.page-about-atlas .atlas-proof-card strong,
body.page-about-atlas .atlas-stat strong,
body.page-about-atlas .atlas-quote-card,
body.page-about-atlas .atlas-form-success h3 {
  color: #fff7f0;
}

body.page-about-atlas .atlas-section__highlight strong {
  display: block;
  margin-bottom: 0.45rem;
  font-family: var(--font-label);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

body.page-about-atlas .atlas-section__highlight span,
body.page-about-atlas .atlas-proof-card p,
body.page-about-atlas .atlas-form-success p,
body.page-about-atlas .atlas-section__media figcaption {
  color: rgba(245, 239, 233, 0.74);
}

body.page-about-atlas .atlas-section__media,
body.page-about-atlas .atlas-consultation__portrait {
  margin: 0;
  min-width: 0;
}

body.page-about-atlas .atlas-section__media {
  display: grid;
  gap: 0.72rem;
}

body.page-about-atlas .atlas-section__media img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 11;
  object-fit: cover;
  border-radius: 1.4rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  box-shadow: 0 24px 52px rgba(0, 0, 0, 0.2);
}

body.page-about-atlas .atlas-section__media--portrait img {
  aspect-ratio: 4 / 5;
}

body.page-about-atlas .atlas-section__media figcaption {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.5;
}

body.page-about-atlas .atlas-section--frame {
  background:
    linear-gradient(150deg, rgba(67, 67, 67, 0.98), rgba(88, 45, 58, 0.96) 52%, rgba(46, 67, 61, 0.94)),
    rgba(58, 58, 58, 0.98);
}

body.page-about-atlas .atlas-section--band,
body.page-about-atlas .atlas-consultation {
  background:
    linear-gradient(145deg, rgba(82, 47, 59, 0.98), rgba(67, 67, 67, 0.96) 48%, rgba(29, 63, 53, 0.94)),
    rgba(58, 58, 58, 0.98);
}

body.page-about-atlas .atlas-section--quote {
  background:
    linear-gradient(145deg, rgba(67, 67, 67, 0.98), rgba(29, 63, 53, 0.94) 54%, rgba(88, 45, 58, 0.94)),
    rgba(58, 58, 58, 0.98);
}

body.page-about-atlas .atlas-proof-grid,
body.page-about-atlas .atlas-service-grid,
body.page-about-atlas .atlas-stat-grid {
  display: grid;
  gap: 0.85rem;
}

body.page-about-atlas .atlas-proof-card,
body.page-about-atlas .atlas-stat {
  padding: 1rem 1rem 1.05rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  background:
    linear-gradient(145deg, rgba(73, 73, 73, 0.92), rgba(33, 66, 56, 0.32)),
    rgba(62, 62, 62, 0.94);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.14);
}

body.page-about-atlas .atlas-proof-card strong {
  display: block;
  margin-bottom: 0.45rem;
  font-size: 1rem;
}

body.page-about-atlas .atlas-proof-card p,
body.page-about-atlas .atlas-stat span,
body.page-about-atlas .atlas-form__status,
body.page-about-atlas .atlas-form-success__eyebrow {
  margin: 0;
  line-height: 1.55;
}

body.page-about-atlas .atlas-stat {
  display: grid;
  gap: 0.28rem;
  align-content: start;
}

body.page-about-atlas .atlas-stat strong {
  font-size: 1.15rem;
  line-height: 1.1;
}

body.page-about-atlas .atlas-section__actions,
body.page-about-atlas .atlas-consultation__actions,
body.page-about-atlas .atlas-form-success__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
}

body.page-about-atlas .atlas-consultation__head {
  display: grid;
  gap: 0.72rem;
  max-width: 76ch;
}

body.page-about-atlas .atlas-consultation__portrait img {
  display: block;
  width: min(180px, 100%);
  height: auto;
  border-radius: 999px;
  box-shadow: 0 22px 46px rgba(0, 0, 0, 0.22);
  object-fit: cover;
}

body.page-about-atlas form[data-itb-atlas-form='true'] {
  gap: 0.92rem;
}

body.page-about-atlas .atlas-form__status {
  min-height: 1.45rem;
  font-size: 0.86rem;
  color: rgba(245, 239, 233, 0.74);
}

body.page-about-atlas form[data-itb-atlas-form='true'][data-state='submitting'] .atlas-form__status {
  color: #fff1d7;
}

body.page-about-atlas form[data-itb-atlas-form='true'][data-state='error'] .atlas-form__status {
  color: #ffd9c2;
}

body.page-about-atlas .atlas-form-success {
  display: grid;
  gap: 0.9rem;
  align-content: start;
  min-height: 100%;
}

body.page-about-atlas .atlas-form-success__eyebrow {
  color: var(--logo-gold);
  font-family: var(--font-label);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.page-about-atlas .atlas-form-success h3 {
  margin: 0;
  font-family: var(--font-display-default);
  font-size: clamp(1.35rem, 1.15rem + 0.6vw, 1.8rem);
  line-height: 1.08;
}

@media (min-width: 900px) {
  body.page-about-atlas .atlas-section__grid,
  body.page-about-atlas .atlas-proof-layout,
  body.page-about-atlas .atlas-story-layout {
    grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  }

  body.page-about-atlas .atlas-section--reverse .atlas-section__copy,
  body.page-about-atlas .atlas-section--reverse .atlas-section__intro {
    order: 2;
  }

  body.page-about-atlas .atlas-section--reverse .atlas-section__media {
    order: 1;
  }

  body.page-about-atlas .atlas-proof-grid,
  body.page-about-atlas .atlas-service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.page-about-atlas .atlas-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.page-about-atlas .atlas-consultation__shell {
    grid-template-columns: minmax(0, 0.84fr) minmax(0, 1.16fr);
    align-items: start;
  }
}

@media (max-width: 899px) {
  body.page-about-atlas .atlas-proof-grid,
  body.page-about-atlas .atlas-service-grid,
  body.page-about-atlas .atlas-stat-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body.page-about-atlas .atlas-jump-links {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.2rem;
  }

  body.page-about-atlas .atlas-jump-links a {
    white-space: nowrap;
  }

  body.page-about-atlas .atlas-section__media img {
    aspect-ratio: 4 / 3;
  }

  body.page-about-atlas .atlas-section__media--portrait img {
    aspect-ratio: 4 / 5;
  }
}

@keyframes atlasBadgeGlow {
  0%,
  100% {
    transform: translateY(0);
    box-shadow: 0 18px 32px rgba(0, 0, 0, 0.18);
  }
  50% {
    transform: translateY(-2px);
    box-shadow: 0 24px 40px rgba(0, 0, 0, 0.24);
  }
}

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

@keyframes atlasFrameSheen {
  0% {
    transform: translateX(-120%);
    opacity: 0;
  }
  25% {
    opacity: 0.18;
  }
  60% {
    opacity: 0.08;
  }
  100% {
    transform: translateX(180%);
    opacity: 0;
  }
}

body.page-about-atlas .hero-summary {
  max-width: 70ch;
}

body.page-about-atlas .hero-badges--atlas {
  gap: 0.55rem;
}

body.page-about-atlas .hero-badges--atlas .hero-badge {
  position: relative;
  overflow: hidden;
  min-height: 42px;
  padding-inline: 0.95rem;
  animation: atlasBadgeGlow 5.8s ease-in-out infinite;
}

body.page-about-atlas .hero-badges--atlas .hero-badge:nth-child(2n) {
  animation-delay: 180ms;
}

body.page-about-atlas .hero-badges--atlas .hero-badge:nth-child(3n) {
  animation-delay: 320ms;
}

body.page-about-atlas .atlas-bullet-list {
  display: grid;
  gap: 0.72rem;
  padding-left: 1.1rem;
  margin: 0;
}

body.page-about-atlas .atlas-bullet-list li {
  color: rgba(245, 239, 233, 0.82);
  line-height: 1.62;
}

body.page-about-atlas .atlas-bullet-list strong {
  color: #fff7ef;
}

body.page-about-atlas .atlas-stat-grid--wide {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.page-about-atlas .atlas-feature-grid {
  display: grid;
  gap: 0.9rem;
  margin-bottom: 1.3rem;
}

body.page-about-atlas .atlas-feature-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.95rem;
  align-items: start;
  padding: 1rem 1rem 1.05rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.15);
  background:
    linear-gradient(145deg, rgba(77, 47, 57, 0.92), rgba(33, 66, 56, 0.22)),
    rgba(63, 63, 63, 0.96);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.16);
}

body.page-about-atlas .atlas-feature-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  color: var(--logo-gold);
  background: linear-gradient(145deg, rgba(200, 152, 50, 0.16), rgba(28, 75, 62, 0.2));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  animation: atlasIconFloat 4.8s ease-in-out infinite;
}

body.page-about-atlas .atlas-feature-card__icon svg,
body.page-about-atlas .atlas-form-pill svg {
  width: 1.35rem;
  height: 1.35rem;
  display: block;
}

body.page-about-atlas .atlas-feature-card__copy {
  display: grid;
  gap: 0.3rem;
}

body.page-about-atlas .atlas-feature-card__copy strong,
body.page-about-atlas .atlas-form-pill span {
  color: #fff7ef;
}

body.page-about-atlas .atlas-feature-card__copy p,
body.page-about-atlas .atlas-consultation__closing {
  margin: 0;
  color: rgba(245, 239, 233, 0.76);
  line-height: 1.58;
}

body.page-about-atlas .atlas-form-frame {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 1rem;
  padding: 1.15rem;
  border-radius: 1.55rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(155deg, rgba(67, 67, 67, 0.98), rgba(83, 48, 60, 0.95) 48%, rgba(28, 75, 62, 0.9)),
    rgba(58, 58, 58, 0.98);
  box-shadow:
    0 26px 54px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-form-frame::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 34%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.12), transparent);
  transform: translateX(-120%);
  pointer-events: none;
  animation: atlasFrameSheen 8.5s ease-in-out infinite;
}

body.page-about-atlas .atlas-form-pills {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body.page-about-atlas .atlas-form-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 40px;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background: rgba(255, 248, 247, 0.06);
  color: #fff7ef;
  font-family: var(--font-label);
  font-size: 0.77rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body.page-about-atlas .atlas-form-pill svg {
  color: var(--logo-gold);
  flex-shrink: 0;
}

body.page-about-atlas .atlas-form-frame form {
  position: relative;
  z-index: 1;
}

body.page-about-atlas .atlas-consultation__closing {
  max-width: 78ch;
  margin: 1.1rem 0 0;
}

body.page-about-atlas .atlas-consultation__closing a {
  color: #fff4df;
}

body.page-about-atlas .atlas-consultation__closing a:hover,
body.page-about-atlas .atlas-consultation__closing a:focus-visible {
  color: #ffffff;
}

@media (min-width: 900px) {
  body.page-about-atlas .atlas-feature-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.page-about-atlas .atlas-stat-grid--wide {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  body.page-about-atlas .hero-badges--atlas {
    gap: 0.45rem;
  }

  body.page-about-atlas .hero-badges--atlas .hero-badge {
    min-height: 40px;
    padding-inline: 0.8rem;
  }

  body.page-about-atlas .atlas-feature-card {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.page-about-atlas .hero-badges--atlas .hero-badge,
  body.page-about-atlas .atlas-feature-card__icon,
  body.page-about-atlas .atlas-form-frame::before {
    animation: none !important;
  }
}

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

body.page-about-atlas .atlas-hero {
  padding: clamp(3.5rem, 8vw, 6.25rem) 0 clamp(3.3rem, 7vw, 5.25rem);
  background:
    radial-gradient(circle at top right, rgba(215, 176, 92, 0.18), transparent 26%),
    radial-gradient(circle at left center, rgba(255, 255, 255, 0.06), transparent 24%),
    var(--hero-image);
}

body.page-about-atlas .atlas-hero .hero-overlay {
  background:
    linear-gradient(135deg, rgba(21, 23, 27, 0.2), rgba(21, 23, 27, 0.04)),
    linear-gradient(125deg, rgba(59, 32, 44, 0.58), rgba(16, 45, 41, 0.48));
}

body.page-about-atlas .atlas-hero__shell {
  align-items: center;
}

body.page-about-atlas .atlas-hero__copy {
  max-width: none;
  border-radius: 2rem;
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(155deg, rgba(44, 30, 36, 0.95), rgba(28, 42, 41, 0.9) 58%, rgba(20, 25, 31, 0.88)),
    rgba(23, 27, 32, 0.92);
  box-shadow:
    0 30px 60px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

body.page-about-atlas .atlas-hero__summary {
  max-width: 34rem;
  margin-bottom: 0;
  font-size: clamp(1.02rem, 0.94rem + 0.25vw, 1.14rem);
  line-height: 1.75;
}

body.page-about-atlas .atlas-hero__stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
  margin-top: 1.25rem;
}

body.page-about-atlas .atlas-stat-pill {
  display: grid;
  gap: 0.18rem;
  padding: 0.85rem 0.92rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
    rgba(255, 248, 240, 0.04);
}

body.page-about-atlas .atlas-stat-pill strong {
  color: #fff8f0;
  font-size: 0.96rem;
  letter-spacing: 0.08em;
}

body.page-about-atlas .atlas-stat-pill span {
  color: rgba(245, 239, 233, 0.74);
  font-size: 0.78rem;
  line-height: 1.45;
}

body.page-about-atlas .atlas-hero__meta {
  width: auto;
  min-width: 0;
}

body.page-about-atlas .hero-panel--portrait {
  padding: 0.9rem;
  border-radius: 2rem;
  border-color: rgba(var(--logo-gold-rgb), 0.2);
  background:
    linear-gradient(155deg, rgba(48, 31, 39, 0.92), rgba(24, 46, 42, 0.88)),
    rgba(20, 25, 31, 0.9);
  box-shadow:
    0 28px 58px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.page-about-atlas .atlas-hero__portrait {
  margin: 0;
  display: grid;
  gap: 0.88rem;
}

body.page-about-atlas .atlas-hero__portrait img {
  max-width: none;
  margin: 0;
  aspect-ratio: 4 / 5;
  border-radius: 1.55rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.28);
  animation: atlasPortraitDrift 8s ease-in-out infinite;
}

body.page-about-atlas .atlas-hero__portrait figcaption,
body.page-about-atlas .atlas-section__media figcaption,
body.page-about-atlas .atlas-consultation__portrait figcaption {
  margin: 0;
  text-align: center;
  color: rgba(245, 239, 233, 0.8);
  font-family: var(--font-label);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

body.page-about-atlas .hero-badges--atlas {
  margin-top: 1.35rem;
}

body.page-about-atlas .hero-actions {
  margin-top: 1.2rem;
}

body.page-about-atlas .atlas-section,
body.page-about-atlas .atlas-consultation {
  position: relative;
  padding: clamp(1.15rem, 2.5vw, 1.7rem);
  border-radius: 2rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  box-shadow:
    0 24px 48px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-section::before,
body.page-about-atlas .atlas-consultation::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(255, 255, 255, 0.04);
  pointer-events: none;
}

body.page-about-atlas .atlas-section--proof {
  background:
    linear-gradient(150deg, rgba(45, 39, 45, 0.98), rgba(54, 45, 60, 0.94) 50%, rgba(23, 47, 43, 0.92)),
    rgba(34, 35, 40, 0.98);
}

body.page-about-atlas .atlas-section__grid,
body.page-about-atlas .atlas-proof-layout,
body.page-about-atlas .atlas-story-layout,
body.page-about-atlas .atlas-consultation__shell {
  gap: 1.5rem;
}

body.page-about-atlas .atlas-section__copy,
body.page-about-atlas .atlas-section__intro,
body.page-about-atlas .atlas-story-copy,
body.page-about-atlas .atlas-consultation__intro {
  padding: clamp(1rem, 2.2vw, 1.4rem);
  border-radius: 1.65rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015)),
    rgba(20, 25, 31, 0.18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-section__media,
body.page-about-atlas .atlas-consultation__portrait {
  padding: 0.8rem;
  border-radius: 1.75rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015)),
    rgba(14, 18, 23, 0.2);
  box-shadow:
    0 22px 44px rgba(0, 0, 0, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-section__media img,
body.page-about-atlas .atlas-consultation__portrait img {
  width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: 1.25rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.1);
  transition:
    transform 260ms ease,
    filter 260ms ease,
    box-shadow 260ms ease;
}

body.page-about-atlas .atlas-section:hover .atlas-section__media img,
body.page-about-atlas .atlas-consultation:hover .atlas-consultation__portrait img {
  transform: translateY(-3px) scale(1.01);
  filter: saturate(1.04);
  box-shadow: 0 26px 48px rgba(0, 0, 0, 0.22);
}

body.page-about-atlas .atlas-consultation__portrait img {
  width: 100%;
  border-radius: 1.25rem;
}

body.page-about-atlas .atlas-section h2,
body.page-about-atlas .atlas-consultation h2 {
  font-size: clamp(1.78rem, 1.38rem + 1vw, 2.45rem);
}

body.page-about-atlas .atlas-section .lead,
body.page-about-atlas .atlas-consultation .lead {
  color: #fff7ef;
  font-size: clamp(1.02rem, 0.97rem + 0.22vw, 1.16rem);
  line-height: 1.65;
}

body.page-about-atlas .atlas-section__highlight,
body.page-about-atlas .atlas-quote-card {
  border-radius: 1.45rem;
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(109, 54, 68, 0.22), rgba(23, 67, 58, 0.16)),
    rgba(40, 42, 47, 0.72);
}

body.page-about-atlas .atlas-proof-card,
body.page-about-atlas .atlas-stat,
body.page-about-atlas .atlas-feature-card {
  border-color: rgba(var(--logo-gold-rgb), 0.16);
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.015)),
    rgba(40, 42, 48, 0.9);
  box-shadow:
    0 18px 34px rgba(0, 0, 0, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-proof-card strong,
body.page-about-atlas .atlas-feature-card__copy strong {
  font-size: 1.02rem;
}

body.page-about-atlas .atlas-consultation__head {
  gap: 0.86rem;
  margin-bottom: 1rem;
}

body.page-about-atlas .atlas-form-frame {
  border-radius: 1.75rem;
}

body.page-about-atlas .atlas-consultation__closing {
  max-width: 70ch;
  text-align: left;
}

@media (min-width: 900px) {
  body.page-about-atlas .atlas-hero__shell {
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    gap: clamp(1.8rem, 3vw, 3rem);
  }

  body.page-about-atlas .atlas-proof-layout {
    grid-template-columns: minmax(0, 0.74fr) minmax(0, 1.26fr);
  }

  body.page-about-atlas .atlas-section__grid,
  body.page-about-atlas .atlas-story-layout {
    grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
  }

  body.page-about-atlas .atlas-consultation__shell {
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  }
}

@media (max-width: 899px) {
  body.page-about-atlas .atlas-hero__shell {
    grid-template-columns: 1fr;
  }

  body.page-about-atlas .atlas-hero__meta {
    max-width: 34rem;
  }
}

@media (max-width: 767px) {
  body.page-about-atlas .atlas-hero__copy,
  body.page-about-atlas .hero-panel--portrait,
  body.page-about-atlas .atlas-section,
  body.page-about-atlas .atlas-consultation,
  body.page-about-atlas .atlas-section__copy,
  body.page-about-atlas .atlas-section__intro,
  body.page-about-atlas .atlas-story-copy,
  body.page-about-atlas .atlas-consultation__intro,
  body.page-about-atlas .atlas-section__media,
  body.page-about-atlas .atlas-consultation__portrait,
  body.page-about-atlas .atlas-form-frame {
    border-radius: 1.45rem;
  }

  body.page-about-atlas .atlas-stat-pill {
    padding: 0.8rem 0.85rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.page-about-atlas .atlas-hero__portrait img {
    animation: none !important;
  }

  body.page-about-atlas .atlas-section:hover .atlas-section__media img,
  body.page-about-atlas .atlas-consultation:hover .atlas-consultation__portrait img {
    transform: none;
  }
}

body.page-about-atlas {
  --atlas-emerald-deep: rgba(8, 28, 21, 0.98);
  --atlas-emerald-rich: rgba(16, 36, 27, 0.96);
  --atlas-emerald-soft: rgba(22, 58, 42, 0.76);
  --atlas-blue-charcoal: rgba(22, 38, 49, 0.94);
  --atlas-blue-charcoal-soft: rgba(31, 52, 66, 0.9);
  --atlas-panel: rgba(12, 27, 24, 0.72);
  --atlas-panel-strong: rgba(11, 24, 30, 0.84);
  --atlas-border: rgba(var(--logo-gold-rgb), 0.18);
  --atlas-border-soft: rgba(183, 228, 199, 0.1);
  --atlas-copy: rgba(231, 245, 235, 0.86);
  --atlas-muted: rgba(231, 245, 235, 0.72);
}

body.page-about-atlas .atlas-hero {
  padding: clamp(3.7rem, 7vw, 6rem) 0 clamp(3.5rem, 7vw, 5rem);
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.16), transparent 24%),
    radial-gradient(circle at left center, rgba(116, 198, 157, 0.1), transparent 30%),
    linear-gradient(135deg, rgba(8, 28, 21, 0.98), rgba(16, 36, 27, 0.96) 44%, rgba(22, 38, 49, 0.96));
}

body.page-about-atlas .atlas-hero .hero-overlay {
  background:
    linear-gradient(180deg, rgba(3, 13, 9, 0.18), rgba(3, 13, 9, 0.32)),
    linear-gradient(115deg, rgba(8, 28, 21, 0.3), rgba(16, 36, 27, 0.18) 48%, rgba(22, 38, 49, 0.24));
}

body.page-about-atlas .atlas-hero__shell {
  align-items: center;
  gap: clamp(1.5rem, 3vw, 2.75rem);
}

body.page-about-atlas .atlas-hero__copy {
  max-width: none;
  border-radius: 2rem;
  border: 1px solid var(--atlas-border);
  background:
    linear-gradient(160deg, rgba(11, 26, 22, 0.96), rgba(16, 36, 27, 0.9) 56%, rgba(22, 38, 49, 0.92)),
    rgba(9, 19, 16, 0.94);
  box-shadow:
    0 28px 60px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.page-about-atlas .atlas-hero__summary {
  max-width: 34rem;
  color: rgba(245, 255, 247, 0.88);
  line-height: 1.78;
}

body.page-about-atlas .atlas-hero__stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 1.3rem;
}

body.page-about-atlas .atlas-stat-pill {
  display: grid;
  gap: 0.2rem;
  padding: 0.9rem 0.95rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background:
    linear-gradient(155deg, rgba(var(--logo-gold-rgb), 0.08), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-stat-pill strong {
  color: #fff8ee;
  font-size: 0.98rem;
  letter-spacing: 0.08em;
}

body.page-about-atlas .atlas-stat-pill span {
  color: rgba(231, 245, 235, 0.72);
  font-size: 0.78rem;
  line-height: 1.42;
}

body.page-about-atlas .hero-badges--atlas {
  gap: 0.55rem;
  margin-top: 1.25rem;
}

body.page-about-atlas .hero-badges--atlas .hero-badge {
  position: relative;
  overflow: hidden;
  min-height: 42px;
  padding-inline: 1rem;
  border-color: rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(16, 36, 27, 0.84), rgba(22, 38, 49, 0.84)),
    rgba(11, 24, 20, 0.92);
  color: #f8fff9;
}

body.page-about-atlas .hero-badges--atlas .hero-badge::before {
  content: "";
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--logo-gold);
  box-shadow: 0 0 0 0.22rem rgba(var(--logo-gold-rgb), 0.12);
}

body.page-about-atlas .hero-badges--atlas .hero-badge:hover,
body.page-about-atlas .hero-badges--atlas .hero-badge:focus-visible {
  border-color: rgba(var(--logo-gold-rgb), 0.34);
  background:
    linear-gradient(145deg, rgba(22, 58, 42, 0.9), rgba(31, 52, 66, 0.9)),
    rgba(11, 24, 20, 0.94);
}

body.page-about-atlas .atlas-hero__meta {
  width: auto;
  min-width: 0;
}

body.page-about-atlas .hero-panel--portrait {
  padding: 0.9rem;
  border-radius: 2rem;
  border: 1px solid var(--atlas-border);
  background:
    linear-gradient(155deg, rgba(8, 28, 21, 0.94), rgba(18, 40, 30, 0.9) 52%, rgba(22, 38, 49, 0.92)),
    rgba(11, 24, 20, 0.94);
}

body.page-about-atlas .atlas-hero__portrait {
  margin: 0;
  display: grid;
  gap: 0.9rem;
}

body.page-about-atlas .atlas-hero__portrait img {
  width: 100%;
  max-width: none;
  margin: 0;
  aspect-ratio: 4 / 5;
  border-radius: 1.5rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.28);
}

body.page-about-atlas .atlas-hero__portrait figcaption,
body.page-about-atlas .atlas-section__media figcaption,
body.page-about-atlas .atlas-consultation__portrait figcaption {
  margin: 0;
  text-align: center;
  color: rgba(245, 255, 247, 0.8);
  font-family: var(--font-label);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

body.page-about-atlas .atlas-section,
body.page-about-atlas .atlas-consultation {
  position: relative;
  overflow: hidden;
  padding: clamp(1.2rem, 2.5vw, 1.8rem);
  border-radius: 1.95rem;
  border: 1px solid var(--atlas-border-soft);
  box-shadow:
    0 24px 48px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-section::before,
body.page-about-atlas .atlas-consultation::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(255, 255, 255, 0.04);
  pointer-events: none;
}

body.page-about-atlas .atlas-section--spotlight,
body.page-about-atlas .atlas-section--mission,
body.page-about-atlas .atlas-section--results,
body.page-about-atlas .atlas-consultation {
  background:
    linear-gradient(155deg, rgba(8, 28, 21, 0.97), rgba(16, 36, 27, 0.94) 55%, rgba(22, 38, 49, 0.92)),
    rgba(8, 19, 15, 0.96);
}

body.page-about-atlas .atlas-section--editorial,
body.page-about-atlas .atlas-section--audience,
body.page-about-atlas .atlas-section--story,
body.page-about-atlas .atlas-section--stories {
  background:
    linear-gradient(145deg, rgba(10, 24, 18, 0.97), rgba(18, 40, 30, 0.9) 42%, rgba(23, 42, 54, 0.92)),
    rgba(10, 22, 18, 0.96);
}

body.page-about-atlas .atlas-section--credential,
body.page-about-atlas .atlas-section--proof,
body.page-about-atlas .atlas-section--service,
body.page-about-atlas .atlas-section--philosophy,
body.page-about-atlas .atlas-section--testimonials {
  background:
    linear-gradient(150deg, rgba(11, 24, 20, 0.98), rgba(22, 38, 49, 0.92) 52%, rgba(16, 36, 27, 0.92)),
    rgba(10, 22, 18, 0.96);
}

body.page-about-atlas .atlas-section--ethos {
  background:
    linear-gradient(150deg, rgba(10, 24, 18, 0.98), rgba(16, 36, 27, 0.95) 44%, rgba(21, 43, 39, 0.92)),
    rgba(10, 22, 18, 0.96);
}

body.page-about-atlas .atlas-section__grid,
body.page-about-atlas .atlas-proof-layout,
body.page-about-atlas .atlas-story-layout,
body.page-about-atlas .atlas-consultation__shell {
  display: grid;
  gap: 1.45rem;
  align-items: center;
}

body.page-about-atlas .atlas-section__copy,
body.page-about-atlas .atlas-section__intro,
body.page-about-atlas .atlas-story-copy,
body.page-about-atlas .atlas-consultation__intro {
  display: grid;
  gap: 0.95rem;
  padding: clamp(1rem, 2.1vw, 1.35rem);
  border-radius: 1.55rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015)),
    rgba(11, 24, 30, 0.34);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-section h2,
body.page-about-atlas .atlas-consultation h2 {
  margin: 0;
  font-size: clamp(1.8rem, 1.42rem + 1vw, 2.45rem);
  line-height: 1.06;
}

body.page-about-atlas .atlas-section p,
body.page-about-atlas .atlas-consultation p {
  max-width: 70ch;
  color: var(--atlas-copy);
}

body.page-about-atlas .atlas-section .lead,
body.page-about-atlas .atlas-consultation .lead {
  color: #f6fff8;
  font-size: clamp(1.02rem, 0.97rem + 0.2vw, 1.14rem);
  line-height: 1.68;
}

body.page-about-atlas .atlas-section__media,
body.page-about-atlas .atlas-consultation__portrait {
  margin: 0;
  display: grid;
  gap: 0.75rem;
  min-width: 0;
  padding: 0.8rem;
  border-radius: 1.7rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015)),
    rgba(11, 24, 30, 0.38);
  box-shadow:
    0 22px 44px rgba(0, 0, 0, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-section__media img,
body.page-about-atlas .atlas-consultation__portrait img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 1.2rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.2);
  transition:
    transform 260ms ease,
    filter 260ms ease,
    box-shadow 260ms ease;
}

body.page-about-atlas .atlas-section:hover .atlas-section__media img,
body.page-about-atlas .atlas-consultation:hover .atlas-consultation__portrait img {
  transform: translateY(-3px) scale(1.01);
  filter: saturate(1.04);
}

body.page-about-atlas .atlas-stat-grid,
body.page-about-atlas .atlas-proof-grid,
body.page-about-atlas .atlas-service-grid,
body.page-about-atlas .atlas-feature-grid,
body.page-about-atlas .atlas-principle-grid,
body.page-about-atlas .atlas-story-cards {
  display: grid;
  gap: 0.9rem;
}

body.page-about-atlas .atlas-proof-card,
body.page-about-atlas .atlas-stat,
body.page-about-atlas .atlas-feature-card,
body.page-about-atlas .atlas-principle,
body.page-about-atlas .atlas-story-card {
  position: relative;
  display: grid;
  gap: 0.4rem;
  padding: 1rem 1rem 1.05rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.015)),
    rgba(12, 27, 24, 0.76);
  box-shadow:
    0 18px 34px rgba(0, 0, 0, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-proof-card::before,
body.page-about-atlas .atlas-principle::before,
body.page-about-atlas .atlas-story-card::before {
  content: "";
  width: 0.52rem;
  height: 0.52rem;
  border-radius: 999px;
  background: var(--logo-gold);
  box-shadow: 0 0 0 0.22rem rgba(var(--logo-gold-rgb), 0.1);
}

body.page-about-atlas .atlas-proof-card strong,
body.page-about-atlas .atlas-principle strong,
body.page-about-atlas .atlas-story-card strong,
body.page-about-atlas .atlas-feature-card__copy strong,
body.page-about-atlas .atlas-stat strong,
body.page-about-atlas .atlas-form-success h3 {
  color: #fff8ef;
}

body.page-about-atlas .atlas-proof-card p,
body.page-about-atlas .atlas-principle p,
body.page-about-atlas .atlas-story-card p,
body.page-about-atlas .atlas-feature-card__copy p,
body.page-about-atlas .atlas-stat span,
body.page-about-atlas .atlas-form__status,
body.page-about-atlas .atlas-form-success__eyebrow {
  margin: 0;
  color: var(--atlas-muted);
  line-height: 1.56;
}

body.page-about-atlas .atlas-stat {
  align-content: start;
}

body.page-about-atlas .atlas-stat strong {
  font-size: 1.14rem;
  line-height: 1.08;
}

body.page-about-atlas .atlas-card-tag,
body.page-about-atlas .atlas-token-list__badge,
body.page-about-atlas .atlas-list-badge,
body.page-about-atlas .atlas-form-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 32px;
  padding: 0.42rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.22);
  background:
    linear-gradient(145deg, rgba(var(--logo-gold-rgb), 0.18), rgba(255, 255, 255, 0.06)),
    rgba(14, 22, 18, 0.62);
  color: #fff7ea;
  font-family: var(--font-label);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.page-about-atlas .atlas-token-list {
  display: grid;
  gap: 0.82rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

body.page-about-atlas .atlas-token-list li {
  display: grid;
  gap: 0.5rem;
  padding: 0.95rem 1rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.015)),
    rgba(11, 24, 30, 0.28);
}

body.page-about-atlas .atlas-token-list li span:last-child {
  color: var(--atlas-copy);
  line-height: 1.58;
}

body.page-about-atlas .atlas-bullet-list {
  display: grid;
  gap: 0.8rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

body.page-about-atlas .atlas-bullet-list--badges li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.8rem;
  align-items: start;
  padding: 0.95rem 1rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.015)),
    rgba(11, 24, 30, 0.28);
}

body.page-about-atlas .atlas-bullet-list--badges li > div {
  color: var(--atlas-copy);
  line-height: 1.58;
}

body.page-about-atlas .atlas-bullet-list--badges strong {
  color: #fff8ef;
}

body.page-about-atlas .atlas-section__highlight,
body.page-about-atlas .atlas-quote-card {
  padding: 1rem 1.1rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(var(--logo-gold-rgb), 0.12), rgba(116, 198, 157, 0.08)),
    rgba(12, 27, 24, 0.72);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.14);
}

body.page-about-atlas .atlas-section__highlight strong {
  display: block;
  margin-bottom: 0.45rem;
  color: #fff8ef;
  font-family: var(--font-label);
  font-size: 0.76rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

body.page-about-atlas .atlas-section__highlight span,
body.page-about-atlas .atlas-quote-card p {
  color: var(--atlas-copy);
}

body.page-about-atlas .atlas-feature-card {
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 0.95rem;
}

body.page-about-atlas .atlas-feature-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  color: var(--logo-gold);
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(145deg, rgba(var(--logo-gold-rgb), 0.14), rgba(116, 198, 157, 0.06)),
    rgba(11, 24, 20, 0.64);
}

body.page-about-atlas .atlas-feature-card__icon svg,
body.page-about-atlas .atlas-form-pill svg {
  width: 1.3rem;
  height: 1.3rem;
  display: block;
}

body.page-about-atlas .atlas-feature-card__copy {
  display: grid;
  gap: 0.3rem;
}

body.page-about-atlas .atlas-form-frame {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 1rem;
  padding: 1.15rem;
  border-radius: 1.7rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.18);
  background:
    linear-gradient(155deg, rgba(8, 28, 21, 0.96), rgba(16, 36, 27, 0.9) 48%, rgba(22, 38, 49, 0.92)),
    rgba(11, 24, 20, 0.94);
  box-shadow:
    0 26px 54px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.page-about-atlas .atlas-form-frame::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 34%;
  background: linear-gradient(90deg, transparent, rgba(var(--logo-gold-rgb), 0.12), transparent);
  transform: translateX(-120%);
  pointer-events: none;
  animation: atlasFrameSheen 9s ease-in-out infinite;
}

body.page-about-atlas .atlas-form-pills {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body.page-about-atlas .atlas-form-pill {
  gap: 0.5rem;
  min-height: 38px;
  padding: 0.52rem 0.82rem;
}

body.page-about-atlas .atlas-form-pill svg {
  color: var(--logo-gold);
  flex-shrink: 0;
}

body.page-about-atlas .atlas-form-frame form {
  position: relative;
  z-index: 1;
}

body.page-about-atlas form[data-itb-atlas-form='true'] {
  gap: 0.92rem;
}

body.page-about-atlas .atlas-form__status {
  min-height: 1.45rem;
  font-size: 0.86rem;
}

body.page-about-atlas form[data-itb-atlas-form='true'][data-state='submitting'] .atlas-form__status {
  color: #fff0c8;
}

body.page-about-atlas form[data-itb-atlas-form='true'][data-state='error'] .atlas-form__status {
  color: #ffd8bd;
}

body.page-about-atlas .atlas-consultation__actions,
body.page-about-atlas .atlas-section__actions,
body.page-about-atlas .atlas-form-success__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
}

body.page-about-atlas .atlas-consultation__head {
  display: grid;
  gap: 0.8rem;
  max-width: 78ch;
  margin-bottom: 1rem;
}

body.page-about-atlas .atlas-consultation__closing {
  max-width: 72ch;
  margin: 1rem 0 0;
  color: var(--atlas-muted);
  line-height: 1.62;
}

body.page-about-atlas .atlas-consultation__closing a {
  color: #fff3d8;
}

body.page-about-atlas .atlas-consultation__closing a:hover,
body.page-about-atlas .atlas-consultation__closing a:focus-visible {
  color: #ffffff;
}

body.page-about-atlas .atlas-form-success {
  display: grid;
  gap: 0.9rem;
  align-content: start;
  min-height: 100%;
}

body.page-about-atlas .atlas-form-success__eyebrow {
  color: var(--logo-gold);
  font-family: var(--font-label);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.page-about-atlas .atlas-form-success h3 {
  margin: 0;
  font-family: var(--font-display-default);
  font-size: clamp(1.35rem, 1.15rem + 0.6vw, 1.8rem);
  line-height: 1.08;
}

@media (min-width: 980px) {
  body.page-about-atlas .atlas-hero__shell {
    grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr);
  }

  body.page-about-atlas .atlas-section__grid,
  body.page-about-atlas .atlas-story-layout {
    grid-template-columns: minmax(0, 0.98fr) minmax(0, 1.02fr);
  }

  body.page-about-atlas .atlas-proof-layout {
    grid-template-columns: minmax(0, 0.76fr) minmax(0, 1.24fr);
  }

  body.page-about-atlas .atlas-section--reverse .atlas-section__copy,
  body.page-about-atlas .atlas-section--reverse .atlas-section__intro {
    order: 2;
  }

  body.page-about-atlas .atlas-section--reverse .atlas-section__media {
    order: 1;
  }

  body.page-about-atlas .atlas-proof-grid,
  body.page-about-atlas .atlas-service-grid,
  body.page-about-atlas .atlas-feature-grid,
  body.page-about-atlas .atlas-principle-grid,
  body.page-about-atlas .atlas-story-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.page-about-atlas .atlas-principle-grid--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.page-about-atlas .atlas-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.page-about-atlas .atlas-stat-grid--wide {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  body.page-about-atlas .atlas-consultation__shell {
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
    align-items: start;
  }
}

@media (max-width: 979px) {
  body.page-about-atlas .atlas-proof-grid,
  body.page-about-atlas .atlas-service-grid,
  body.page-about-atlas .atlas-feature-grid,
  body.page-about-atlas .atlas-principle-grid,
  body.page-about-atlas .atlas-story-cards,
  body.page-about-atlas .atlas-stat-grid,
  body.page-about-atlas .atlas-stat-grid--wide {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body.page-about-atlas .atlas-hero__copy,
  body.page-about-atlas .hero-panel--portrait,
  body.page-about-atlas .atlas-section,
  body.page-about-atlas .atlas-consultation,
  body.page-about-atlas .atlas-section__copy,
  body.page-about-atlas .atlas-section__intro,
  body.page-about-atlas .atlas-story-copy,
  body.page-about-atlas .atlas-consultation__intro,
  body.page-about-atlas .atlas-section__media,
  body.page-about-atlas .atlas-consultation__portrait,
  body.page-about-atlas .atlas-form-frame {
    border-radius: 1.45rem;
  }

  body.page-about-atlas .hero-badges--atlas {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.15rem;
  }

  body.page-about-atlas .hero-badges--atlas .hero-badge {
    white-space: nowrap;
  }

  body.page-about-atlas .atlas-feature-card,
  body.page-about-atlas .atlas-bullet-list--badges li {
    grid-template-columns: 1fr;
  }

  body.page-about-atlas .atlas-hero__stats {
    grid-template-columns: 1fr 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.page-about-atlas .atlas-form-frame::before,
  body.page-about-atlas .hero-badges--atlas .hero-badge,
  body.page-about-atlas .atlas-feature-card__icon,
  body.page-about-atlas .atlas-hero__portrait img {
    animation: none !important;
  }
}

body.site-root .btn-ghost {
  border-color: rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.04);
  color: #f4ede5;
}

body.site-root .btn-ghost:hover,
body.site-root .btn-ghost:focus-visible {
  border-color: rgba(240, 198, 140, 0.28);
  background: rgba(240, 198, 140, 0.08);
  color: #fff8f1;
}

body.site-root.insights-exit-modal-open {
  overflow: hidden;
}

body.site-root .insights-exit-modal {
  position: fixed;
  inset: 0;
  z-index: 1600;
  display: grid;
  place-items: center;
  padding: 1rem;
}

body.site-root .insights-exit-modal[hidden] {
  display: none;
}

body.site-root .insights-exit-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(5, 12, 18, 0.78);
  backdrop-filter: blur(14px);
}

body.site-root .insights-exit-modal__frame {
  position: relative;
  z-index: 1;
  width: min(68rem, 100%);
  max-height: calc(100dvh - 2rem);
  overflow: auto;
  overscroll-behavior: contain;
  opacity: 0;
  transform: translateY(18px) scale(0.986);
  transition:
    opacity 220ms ease,
    transform 220ms ease;
}

body.site-root .insights-exit-modal.is-open .insights-exit-modal__frame {
  opacity: 1;
  transform: translateY(0) scale(1);
}

body.site-root .insights-exit-modal__close {
  position: absolute;
  top: 0.9rem;
  right: 0.9rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid rgba(240, 198, 140, 0.2);
  border-radius: 999px;
  background: rgba(12, 18, 24, 0.84);
  color: #f3cb8f;
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.22);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease;
}

body.site-root .insights-exit-modal__close:hover,
body.site-root .insights-exit-modal__close:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(240, 198, 140, 0.34);
  background: rgba(18, 26, 34, 0.94);
}

body.site-root .insights-lead-capture--modal {
  margin: 0;
}

body.site-root .client-proof-band,
body.site-root .client-proof-stage {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

body.site-root .client-proof-stage {
  margin-bottom: 1.35rem;
  padding: clamp(1.15rem, 2.4vw, 1.55rem);
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at top right, rgba(var(--logo-gold-rgb), 0.12), transparent 34%),
    linear-gradient(145deg, rgba(18, 24, 30, 0.98), rgba(42, 29, 34, 0.97) 54%, rgba(19, 39, 34, 0.96) 100%);
  box-shadow:
    0 24px 54px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.site-root .client-proof-stage--indicators {
  background:
    radial-gradient(circle at 84% 20%, rgba(47, 124, 103, 0.16), transparent 28%),
    linear-gradient(145deg, rgba(17, 22, 28, 0.98), rgba(38, 27, 32, 0.97) 52%, rgba(19, 39, 34, 0.96) 100%);
}

body.site-root .client-review-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.site-root .client-review-card {
  display: grid;
  gap: 0.72rem;
  height: 100%;
  margin: 0;
  padding: 1rem 1rem 0.95rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: 1.25rem;
  background:
    linear-gradient(180deg, rgba(16, 21, 26, 0.96), rgba(31, 24, 28, 0.94)),
    rgba(16, 19, 24, 0.96);
  box-shadow:
    0 20px 38px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

body.site-root .client-review-card:hover,
body.site-root .client-review-card:focus-within {
  transform: translateY(-0.18rem);
  border-color: rgba(var(--logo-gold-rgb), 0.24);
  box-shadow:
    0 24px 44px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

body.site-root .client-review-card__stars {
  color: #f2c66d;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
}

body.site-root .client-review-card p {
  margin: 0;
  color: rgba(245, 239, 233, 0.82);
  font-size: 0.96rem;
  line-height: 1.65;
}

body.site-root .client-review-card footer {
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem 0.72rem;
  align-items: center;
  margin-top: auto;
  color: #fff8f0;
}

body.site-root .client-review-card__source {
  color: rgba(245, 239, 233, 0.58);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.site-root .client-indicators-grid {
  display: grid;
  gap: 0.82rem 0.95rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.site-root .client-indicators-grid > .client-indicator-bar:first-child {
  grid-column: 1 / -1;
}

body.site-root .client-indicator-bar {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 0.42rem;
  padding: 0.78rem 0.86rem 0.8rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: 1.05rem;
  background:
    linear-gradient(180deg, rgba(14, 18, 23, 0.94), rgba(27, 22, 26, 0.93)),
    rgba(15, 18, 22, 0.94);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 18px 30px rgba(0, 0, 0, 0.22);
}

body.site-root .client-indicator-bar::before {
  content: "";
  position: absolute;
  inset: auto auto 0.6rem 0.85rem;
  width: 0.48rem;
  height: 0.48rem;
  border-radius: 50%;
  background: rgba(var(--logo-gold-rgb), 0.8);
  box-shadow: 0 0 0 0.35rem rgba(var(--logo-gold-rgb), 0.08);
  animation: clientProofDrift 4.8s ease-in-out infinite;
}

body.site-root .client-indicator-bar__meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.85rem;
}

body.site-root .client-indicator-bar__meta span {
  color: rgba(245, 239, 233, 0.72);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-root .client-indicator-bar__meta strong {
  color: #fff8f0;
  font-size: 1rem;
  font-weight: 800;
}

body.site-root .client-indicator-bar__track {
  position: relative;
  overflow: hidden;
  height: 0.56rem;
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.04)),
    rgba(255, 255, 255, 0.06);
}

body.site-root .client-indicator-bar__fill {
  position: relative;
  display: block;
  width: calc(var(--score) * 10%);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #7a2330 0%, #b48641 52%, #2f7c67 100%);
  transform-origin: left center;
  animation: clientProofFill 1.25s cubic-bezier(0.18, 0.9, 0.24, 1) both;
  animation-delay: var(--proof-delay, 0ms);
}

body.site-root .client-indicator-bar__fill::after {
  content: "";
  position: absolute;
  inset: -60% auto -60% 0;
  width: 34%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.9), transparent);
  opacity: 0.7;
  mix-blend-mode: screen;
  animation: clientProofSweep 4.8s linear infinite;
  animation-delay: calc(var(--proof-delay, 0ms) + 180ms);
}

body.site-root .client-indicator-bar__description {
  margin: 0;
  color: rgba(245, 239, 233, 0.66);
  font-size: 0.84rem;
  line-height: 1.55;
}

body.page-home .home-client-proof {
  padding: 0.95rem 0 1.15rem;
  background:
    radial-gradient(circle at 12% 0%, rgba(var(--logo-gold-rgb), 0.12), transparent 24%),
    radial-gradient(circle at 86% 10%, rgba(47, 124, 103, 0.16), transparent 28%),
    linear-gradient(180deg, rgba(13, 18, 22, 0.98), rgba(30, 22, 27, 0.98) 50%, rgba(16, 28, 24, 0.98) 100%);
  border-top: 1px solid rgba(var(--logo-gold-rgb), 0.12);
  border-bottom: 1px solid rgba(var(--logo-gold-rgb), 0.12);
}

body.page-home .home-client-proof + .home-client-proof {
  padding-top: 0.72rem;
}

body.page-home .home-client-proof::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(125deg, rgba(255, 255, 255, 0.04), transparent 26%),
    linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.12));
  pointer-events: none;
}

body.page-home .home-client-proof .client-proof-band__shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) auto;
  gap: 0.9rem 1rem;
  align-items: end;
  margin-bottom: 0.9rem;
}

body.page-home .home-client-proof .client-proof-band__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  justify-content: flex-end;
  align-items: center;
}

body.page-home .home-client-proof .home-manifesto-subhead {
  color: rgba(var(--logo-gold-rgb), 0.92);
}

body.page-home .home-client-proof .home-section-head h2 {
  margin-bottom: 0.28rem;
  color: #fff8f0;
  font-family: var(--font-display-default);
  font-size: clamp(1.45rem, 2.1vw, 2rem);
}

body.page-home .home-client-proof .home-section-head p {
  max-width: 42rem;
  margin: 0;
  color: rgba(245, 239, 233, 0.74);
}

body.page-home .client-proof-score-pill {
  display: grid;
  gap: 0.08rem;
  min-width: 9.2rem;
  padding: 0.68rem 0.92rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
  text-align: left;
}

body.page-home .client-proof-score-pill span {
  color: rgba(245, 239, 233, 0.58);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.page-home .client-proof-score-pill strong {
  color: #fff8f0;
  font-size: 1.05rem;
}

body.page-home .client-proof-band__note {
  position: relative;
  z-index: 1;
  margin: 0 0 0.78rem;
  color: rgba(245, 239, 233, 0.62);
  font-size: 0.82rem;
}

body.page-home .home-client-proof--reviews .client-review-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(16.5rem, 20rem);
  grid-template-columns: none;
  gap: 0.82rem;
  overflow-x: auto;
  padding-bottom: 0.35rem;
  scrollbar-width: thin;
  scroll-snap-type: x proximity;
}

body.page-home .home-client-proof--reviews .client-review-card {
  min-height: 100%;
  padding: 0.92rem 0.98rem 0.86rem;
  scroll-snap-align: start;
}

body.page-home .home-client-proof--reviews .client-review-card p {
  display: -webkit-box;
  overflow: hidden;
  font-size: 0.9rem;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
}

body.page-home .home-client-proof--indicators .client-indicators-grid {
  position: relative;
  z-index: 1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.72rem 0.86rem;
}

body.page-home .home-client-proof--indicators .client-indicator-bar {
  padding: 0.7rem 0.76rem 0.72rem;
}

body.page-home .home-client-proof--indicators .client-indicator-bar__description {
  font-size: 0.78rem;
}

body.page-client-feedback .trust-marker-block {
  gap: 0.88rem;
}

body.page-client-feedback .marker {
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  background:
    linear-gradient(180deg, rgba(14, 18, 24, 0.92), rgba(32, 24, 29, 0.92)),
    rgba(14, 18, 24, 0.92);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 18px 32px rgba(0, 0, 0, 0.18);
}

body.page-client-feedback .feedback-evaluate-grid,
body.page-client-feedback .feedback-visual-grid {
  display: grid;
  gap: 1rem;
}

body.page-client-feedback .feedback-evaluate-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.page-client-feedback .feedback-visual-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.page-client-feedback .feedback-important-note {
  border-left: 4px solid rgba(var(--logo-gold-rgb), 0.8);
}

body.page-client-feedback .client-scale-guide__numbers {
  display: grid;
  grid-template-columns: repeat(11, minmax(2.6rem, 1fr));
  gap: 0.45rem;
  padding-bottom: 0.2rem;
  overflow-x: auto;
}

body.page-client-feedback .client-scale-guide__numbers span {
  display: grid;
  place-items: center;
  min-height: 2.7rem;
  border: 1px solid color-mix(in srgb, var(--score-tone, var(--logo-gold)) 48%, rgba(var(--logo-gold-rgb), 0.16));
  border-radius: 0.9rem;
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--score-tone, var(--logo-gold)) 24%, rgba(15, 19, 24, 0.92)),
      rgba(35, 28, 32, 0.92)
    ),
    rgba(14, 18, 22, 0.92);
  color: color-mix(in srgb, var(--score-tone, var(--logo-gold)) 66%, #fff 34%);
  font-weight: 700;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    inset 0 0 0 1px color-mix(in srgb, var(--score-tone, var(--logo-gold)) 10%, transparent);
}

body.page-client-feedback .feedback-form-stage {
  padding: clamp(1.3rem, 2.8vw, 1.8rem);
}

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

body.page-client-feedback .lead-form-feedback > label,
body.page-client-feedback .lead-form-feedback > .feedback-textarea {
  margin: 0;
}

body.page-client-feedback .lead-form-feedback > .feedback-score-grid,
body.page-client-feedback .lead-form-feedback > .feedback-textarea,
body.page-client-feedback .lead-form-feedback > .feedback-consent,
body.page-client-feedback .lead-form-feedback > .form-note,
body.page-client-feedback .lead-form-feedback > .btn,
body.page-client-feedback .lead-form-feedback > .feedback-honeypot {
  grid-column: 1 / -1;
}

body.page-client-feedback .feedback-score-grid {
  display: grid;
  gap: 0.92rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.page-client-feedback .feedback-score-card {
  margin: 0;
  min-width: 0;
  padding: 1rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.15);
  border-radius: 1.3rem;
  background:
    linear-gradient(180deg, rgba(14, 18, 24, 0.92), rgba(28, 21, 26, 0.9)),
    rgba(14, 18, 24, 0.92);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 16px 30px rgba(0, 0, 0, 0.18);
}

body.page-client-feedback .feedback-score-card legend {
  padding: 0;
  color: #fff8f0;
  font-size: 1rem;
  font-weight: 800;
}

body.page-client-feedback .feedback-score-card p {
  margin: 0.5rem 0 0.8rem;
  color: rgba(245, 239, 233, 0.68);
  font-size: 0.9rem;
  line-height: 1.55;
}

body.page-client-feedback .feedback-score-scale {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(2.35rem, 1fr));
  gap: 0.45rem;
}

body.page-client-feedback .feedback-score-option {
  position: relative;
  display: block;
  margin: 0;
}

body.page-client-feedback .feedback-score-option input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

body.page-client-feedback .feedback-score-option span {
  display: grid;
  place-items: center;
  min-height: 2.55rem;
  border: 1px solid color-mix(in srgb, var(--score-tone, var(--logo-gold)) 42%, rgba(var(--logo-gold-rgb), 0.14));
  border-radius: 0.82rem;
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--score-tone, var(--logo-gold)) 14%, rgba(255, 255, 255, 0.04)),
    rgba(255, 255, 255, 0.035)
  );
  color: color-mix(in srgb, var(--score-tone, var(--logo-gold)) 64%, #fff 36%);
  font-size: 0.88rem;
  font-weight: 700;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    background 160ms ease,
    color 160ms ease,
    box-shadow 160ms ease;
}

body.page-client-feedback .feedback-score-option input:checked + span {
  transform: translateY(-0.08rem);
  border-color: color-mix(in srgb, var(--score-tone, var(--logo-gold)) 78%, #fff 22%);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--score-tone, var(--logo-gold)) 92%, #10161a 8%),
    color-mix(in srgb, var(--score-tone, var(--logo-gold)) 74%, #f6ead9 26%)
  );
  color: #140f11;
  box-shadow:
    0 10px 18px rgba(0, 0, 0, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

body.page-client-feedback .feedback-score-option input:focus-visible + span {
  outline: 2px solid rgba(var(--logo-gold-rgb), 0.86);
  outline-offset: 2px;
}

body.page-client-feedback .feedback-textarea {
  display: grid;
  gap: 0.42rem;
}

body.page-client-feedback .feedback-consent {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.7rem;
  align-items: start;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(var(--logo-gold-rgb), 0.14);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.04);
}

body.page-client-feedback .feedback-consent input {
  margin-top: 0.24rem;
}

body.page-client-feedback .feedback-consent span,
body.page-client-feedback .feedback-privacy-note p {
  color: rgba(245, 239, 233, 0.72);
}

body.page-client-feedback .feedback-honeypot {
  position: absolute !important;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

body.page-client-feedback .lead-form-feedback > .btn {
  justify-self: start;
}

@media (min-width: 900px) {
  body.site-root .download-gateway__form .btn {
    width: auto;
    justify-self: start;
  }
}

@media (max-width: 1199px) {
  body.page-client-feedback .feedback-visual-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.page-home .home-client-proof--indicators .client-indicators-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body.site-root .download-gateway__shell,
  body.page-home .home-client-proof .client-proof-band__shell,
  body.page-client-feedback .lead-form-feedback,
  body.page-client-feedback .feedback-score-grid {
    grid-template-columns: 1fr;
  }

  body.page-home .home-client-proof .client-proof-band__actions {
    justify-content: flex-start;
  }

  body.page-client-feedback .feedback-evaluate-grid,
  body.page-client-feedback .trust-marker-block,
  body.site-root .client-review-grid,
  body.site-root .client-indicators-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body.site-root .download-gateway__shell,
  body.site-root .client-proof-stage {
    padding: 1rem;
  }

  body.page-home .home-client-proof {
    padding: 0.85rem 0 1rem;
  }

  body.page-home .home-client-proof--reviews .client-review-grid {
    grid-auto-columns: minmax(84vw, 18rem);
  }

  body.page-client-feedback .feedback-visual-grid,
  body.page-client-feedback .feedback-evaluate-grid,
  body.page-home .home-client-proof--indicators .client-indicators-grid {
    grid-template-columns: 1fr;
  }

  body.page-client-feedback .feedback-score-card {
    padding: 0.9rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.site-root .client-indicator-bar::before,
  body.site-root .client-indicator-bar__fill,
  body.site-root .client-indicator-bar__fill::after {
    animation: none !important;
  }

  body.site-root .client-review-card,
  body.page-client-feedback .feedback-score-option span {
    transition: none !important;
  }
}
