@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Hanken+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --font-display: 'Instrument Serif', Georgia, 'Times New Roman', serif;
  --font-serif: 'Instrument Serif', Georgia, serif;
  --font-sans: 'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  --display-md: clamp(2.5rem, 4vw + 1rem, 4.5rem);
  --display-lg: clamp(3.25rem, 7vw + 1rem, 7rem);

  --gray-50:#FAF9F7; --gray-100:#F2F0EC; --gray-200:#E5E1DA; --gray-300:#D2CCC2;
  --gray-400:#A39B90; --gray-500:#7A736B; --gray-600:#5C564F; --gray-700:#423D37;
  --gray-800:#2A2622; --gray-900:#191512; --gray-950:#0E0B09;

  --altura-50:#EEF3EF; --altura-100:#DBE7DF; --altura-200:#B8CFC1; --altura-300:#8DB29C;
  --altura-400:#5C8B71; --altura-500:#3A6B4F; --altura-600:#2C5640; --altura-700:#214332;
  --altura-800:#182F24; --altura-900:#0F1F17; --altura-950:#08130D;

  --color-bg:#FAF9F7;
  --color-bg-subtle:#F2F0EC;
  --color-surface:#FFFFFF;
  --color-border:#E5E1DA;
  --color-border-strong:#D2CCC2;
  --color-text:#191512;
  --color-text-muted:#5C564F;
  --color-text-subtle:#7A736B;
  --color-primary:#0A0A0B;
  --color-primary-hover:#1A1A1D;
  --color-secondary:#2C5640;
  --color-secondary-hover:#214332;
  --color-focus-ring:#3A6B4F;
  --color-backdrop:hsl(140 18% 6% / 0.55);

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

  --shadow-sm:0 2px 8px hsl(30 8% 8% / 0.06);
  --shadow-md:0 8px 24px hsl(30 8% 8% / 0.08);
  --shadow-lg:0 16px 48px hsl(30 8% 8% / 0.12);

  --duration-fast:160ms; --duration-base:240ms; --duration-slow:400ms;
  --ease-standard:cubic-bezier(0.2,0,0,1);
  --ease-emphasized:cubic-bezier(0.16,1,0.3,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);

  --maxw:1280px;
  --pad:clamp(20px,5vw,64px);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
::selection { background: var(--altura-200); }
:focus-visible { outline: 2px solid var(--color-focus-ring); outline-offset: 3px; }

.wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--pad); }

.eyebrow {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  letter-spacing: 0.005em;
  text-transform: none;
  font-weight: 600;
  color: var(--color-secondary);
  display: inline-flex;
  gap: 0.5ch;
}
.eyebrow.on-dark { color: var(--altura-300); }
.eyebrow .paren { display: none; }

.serif-accent { font-family: var(--font-serif); font-weight: 300; font-style: italic; }

h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 300; letter-spacing: -0.042em; text-wrap: balance; line-height: 1.15; }

.lead { font-size: clamp(1.05rem,1.4vw,1.3rem); line-height: 1.6; color: var(--color-text-muted); text-wrap: pretty; }
p { text-wrap: pretty; }

/* Kinetic type */
.kinetic .kw { display: inline-block; overflow: hidden; vertical-align: top; margin-right: 0.24em; }
.kinetic .ki {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 0.9s var(--ease-emphasized);
  will-change: transform;
  letter-spacing: -0.01em;
  font-optical-sizing: none;
  padding: 0.04em 0.06em 0.1em 0.02em;
}
.kinetic.is-shown .ki { transform: translateY(0); }

/* Reveal */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease-emphasized), transform .7s var(--ease-emphasized); }
.reveal.is-shown { opacity: 1; transform: none; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  height: 52px; padding: 0 26px; border-radius: var(--radius-md);
  font-family: var(--font-sans); font-size: 15px; font-weight: 500;
  cursor: pointer; border: 1px solid transparent; white-space: nowrap;
  transition: background var(--duration-fast) var(--ease-standard), transform var(--duration-fast), color var(--duration-fast);
}
.btn .arrow { font-family: var(--font-serif); font-size: 18px; transition: transform var(--duration-base) var(--ease-emphasized); }
.btn:hover .arrow { transform: translateX(5px); }
.btn:active { transform: scale(.98); }
.btn--primary { background: var(--color-primary); color: var(--gray-50); }
.btn--primary:hover { background: var(--color-primary-hover); }
.btn--light { background: var(--altura-100); color: var(--altura-900); }
.btn--light:hover { background: #fff; }
.btn--ghost { background: transparent; border-color: var(--color-border-strong); color: var(--color-text); }
.btn--ghost:hover { border-color: var(--color-text); }
.btn--full { width: 100%; justify-content: center; }
.magnetic { transition: transform var(--duration-base) var(--ease-spring), background var(--duration-fast); }

.txtlink { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 500; color: var(--color-secondary); white-space: nowrap; }
.txtlink .arrow { font-family: var(--font-serif); transition: transform var(--duration-base) var(--ease-emphasized); }
.txtlink:hover .arrow { transform: translateX(5px); }

/* Nav */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 1100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px var(--pad);
  transition: background var(--duration-base), padding var(--duration-base), backdrop-filter var(--duration-base);
}
.nav.is-scrolled {
  background: hsl(140 22% 4% / 0.78);
  backdrop-filter: blur(14px) saturate(1.2);
  padding-top: 13px; padding-bottom: 13px;
}
.nav__brand { display: flex; align-items: center; gap: 12px; }
.nav__mark { height: 30px; width: auto; }
.nav__word { display: flex; flex-direction: column; line-height: 1; }
.nav__name { font-family: var(--font-display); font-weight: 600; font-size: 17px; letter-spacing: -.01em; color: #FAF9F7; }
.nav__tag { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .28em; text-transform: uppercase; color: var(--altura-300); margin-top: 4px; }
.nav__links { display: flex; align-items: center; gap: 30px; }
.nav__link { font-size: 14px; color: #E5E1DA; opacity: .85; position: relative; transition: opacity var(--duration-fast); white-space: nowrap; }
.nav__link::after { content: ''; position: absolute; left: 0; bottom: -6px; width: 0; height: 1px; background: var(--altura-300); transition: width var(--duration-base) var(--ease-emphasized); }
.nav__link:hover, .nav__link.is-active { opacity: 1; }
.nav__link:hover::after, .nav__link.is-active::after { width: 100%; }

.nav__has-sub { position: relative; }
.nav__sub {
  position: absolute; top: calc(100% + 14px); left: -18px;
  background: hsl(140 22% 4% / 0.92); backdrop-filter: blur(14px);
  border: 1px solid hsl(0 0% 100% / .12); border-radius: var(--radius-md);
  padding: 10px; min-width: 210px;
  display: flex; flex-direction: column; gap: 2px;
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity var(--duration-base), transform var(--duration-base), visibility var(--duration-base);
}
.nav__has-sub:hover .nav__sub, .nav__has-sub:focus-within .nav__sub { opacity: 1; visibility: visible; transform: translateY(0); }
.nav__sub a { font-size: 14px; color: #DBE7DF; padding: 9px 12px; border-radius: var(--radius-sm); transition: background var(--duration-fast), color var(--duration-fast); }
.nav__sub a:hover { background: hsl(0 0% 100% / .07); color: #fff; }
.nav__caret { display: inline-block; margin-left: 5px; font-size: 9px; opacity: .6; }

.nav__cta {
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid hsl(0 0% 100% / .35); color: #FAF9F7;
  height: 40px; padding: 0 18px; border-radius: var(--radius-full);
  font-family: var(--font-sans); font-size: 13px; font-weight: 500; line-height: 1; cursor: pointer; white-space: nowrap; text-decoration: none;
  transition: background var(--duration-fast), border-color var(--duration-fast), color var(--duration-fast);
}
.nav__cta:hover { background: #FAF9F7; color: var(--altura-900); border-color: #FAF9F7; }

.nav__lang { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .18em; }
.nav__lang a { color: #E5E1DA; opacity: .5; transition: opacity var(--duration-fast); }
.nav__lang a:hover { opacity: .9; }
.nav__lang a.is-active { opacity: 1; color: var(--altura-300); }
.nav__lang span { color: hsl(0 0% 100% / .28); }

.nav__toggle { display: none; background: none; border: none; cursor: pointer; width: 40px; height: 40px; position: relative; }
.nav__toggle span { position: absolute; left: 9px; right: 9px; height: 1.5px; background: #FAF9F7; transition: transform var(--duration-base), opacity var(--duration-base); }
.nav__toggle span:nth-child(1) { top: 15px; }
.nav__toggle span:nth-child(2) { top: 23px; }
.is-menu-open .nav__toggle span:nth-child(1) { top: 19px; transform: rotate(45deg); }
.is-menu-open .nav__toggle span:nth-child(2) { top: 19px; transform: rotate(-45deg); }

/* Mobile drawer */
.drawer {
  position: fixed; inset: 0; z-index: 1090;
  background: hsl(140 30% 4% / 0.98); backdrop-filter: blur(10px);
  display: flex; flex-direction: column; justify-content: center;
  padding: 90px var(--pad) 40px;
  opacity: 0; visibility: hidden; transition: opacity var(--duration-base), visibility var(--duration-base);
}
.is-menu-open .drawer { opacity: 1; visibility: visible; }
.drawer a { font-family: var(--font-display); font-size: clamp(1.6rem,7vw,2.4rem); color: #F2F0EC; padding: 10px 0; letter-spacing: -.02em; }
.drawer a.sub { font-size: clamp(1.1rem,4vw,1.4rem); color: var(--altura-300); padding-left: 18px; }
.drawer__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--altura-400); margin: 18px 0 4px; }
.drawer__lang { display: flex; gap: 20px; margin-top: 32px; padding-top: 24px; border-top: 1px solid hsl(0 0% 100% / .12); }
.drawer__lang a { font-family: var(--font-mono); font-size: 14px; letter-spacing: .22em; color: var(--altura-300); padding: 4px 0; }
.drawer__lang a.is-active { color: #F2F0EC; }

/* Hero (dark immersive) */
.hero { position: relative; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; background: #0E0B09; }
.hero--tall { min-height: 100vh; justify-content: center; }
.hero--short { min-height: 72vh; }
.hero__scene { position: absolute; inset: 0; z-index: 0; }
.hero__scene canvas, .hero__scene video { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero__scene::after { content: ''; position: absolute; inset: 0; background: rgba(0,0,0,.2); pointer-events: none; }
.hero__scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, hsl(140 30% 3% / .6) 0%, transparent 28%, transparent 52%, hsl(140 30% 3% / .72) 100%); }
.hero__inner { position: relative; z-index: 2; max-width: var(--maxw); margin-inline: auto; width: 100%; padding-inline: var(--pad); padding-top: 130px; }
.hero--tall .hero__inner { padding-bottom: 40px; }
.hero--short .hero__inner { padding-bottom: 64px; }
.hero__title { font-family: var(--font-display); font-weight: 300; font-optical-sizing: auto; color: #FAF9F7; line-height: 1.0; letter-spacing: -.056em; margin: 24px 0 0; text-wrap: balance; }
.hero--tall .hero__title { font-size: clamp(2.4rem, 4.4vw + 0.4rem, 4.5rem); max-width: 17ch; }
.hero--short .hero__title { font-size: var(--display-md); max-width: 18ch; }
/* Centered hero variant (home) */
.hero--center .hero__inner { text-align: center; }
.hero--center .hero__title,
.hero--center .hero__lead { margin-inline: auto; }
.hero--center .hero__actions { justify-content: center; }
.hero__lead { color: #D2CCC2; font-size: clamp(17px,1.4vw,21px); line-height: 1.55; max-width: 56ch; margin-top: 26px; }
.hero__lead em { font-family: inherit; font-style: normal; color: inherit; }
.hero__actions { display: flex; align-items: center; gap: 26px; margin-top: 38px; flex-wrap: wrap; }
.hero__actions .txtlink { color: var(--altura-300); }
.hero__sub { color: var(--altura-200); font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: clamp(20px,2vw,26px); margin-top: 18px; max-width: 30ch; }

/* Marquee */
.marquee { position: relative; z-index: 2; margin-top: 56px; border-top: 1px solid hsl(0 0% 100% / .12); border-bottom: 1px solid hsl(0 0% 100% / .12); overflow: hidden; padding: 15px 0; }
.marquee__track { display: flex; width: max-content; animation: marquee 30s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item { display: inline-flex; align-items: center; gap: 52px; padding-right: 52px; font-family: var(--font-display); font-style: italic; font-weight: 300; font-size: 21px; color: #E5E1DA; white-space: nowrap; }
.marquee__dot { color: var(--altura-400); font-size: 12px; font-style: normal; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* Section scaffolding */
.section { padding: clamp(70px,9vw,130px) 0; }
.section--subtle { background: var(--color-bg-subtle); }
.section--ink { background: #0E0B09; color: #FAF9F7; }
.section__head { margin-bottom: 52px; }
.section__head--row { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; flex-wrap: wrap; }
.section__head--row.section__head--top { align-items: flex-start; }
.section__title { font-size: clamp(30px,3.6vw,48px); line-height: 1.08; letter-spacing: -.046em; margin-top: 18px; max-width: 18ch; }
.section--ink .section__title { color: #FAF9F7; }

/* Full-bleed image background for dark sections.
   Drop-in placeholder: swap the file referenced by --media-img with real
   photography (same path) — no markup change needed. Balanced scrim keeps
   overlaid text legible while the image stays clearly visible. */
.section--media, .pullquote--media { position: relative; isolation: isolate; }
.media-bg__img {
  position: absolute; inset: 0; z-index: 0;
  background-image: var(--media-img);
  background-size: cover; background-position: center; background-repeat: no-repeat;
}
.media-bg__scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, hsl(150 32% 4% / .60) 0%, hsl(150 30% 6% / .34) 45%, hsl(150 32% 4% / .66) 100%);
}
.section--media > .wrap,
.pullquote--media > .pullquote__inner { position: relative; z-index: 2; }

/* Two-column editorial */
.editorial { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(40px,7vw,110px); align-items: start; }
.editorial__aside { position: sticky; top: 120px; }
.editorial__h { font-size: clamp(28px,3.2vw,42px); line-height: 1.1; letter-spacing: -.042em; }
.eyebrow + .editorial__h { margin-top: 18px; }
.editorial__body > p { font-size: clamp(1.05rem,1.3vw,1.2rem); line-height: 1.65; color: var(--color-text-muted); margin-bottom: 1.4em; max-width: 64ch; }
.editorial__body > p strong { color: var(--color-text); font-weight: 600; }

/* Pull quote */
.pullquote { background: #0E0B09; color: #F2F0EC; }
.pullquote__inner { max-width: 1040px; margin-inline: auto; padding-inline: var(--pad); padding-block: clamp(80px,12vw,150px); }
.pullquote__body { font-family: var(--font-display); font-weight: 300; font-style: normal; font-size: clamp(26px,3.4vw,46px); line-height: 1.32; letter-spacing: -.024em; color: #F2F0EC; text-wrap: balance; }
.pullquote__body .lift { color: var(--altura-300); font-style: normal; font-weight: 600; }
.pullquote__mark { font-family: var(--font-display); font-size: 90px; line-height: 0; color: var(--altura-600); display: block; height: 40px; }

/* Solutions / two divisions */
.divisions { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; }
.division { background: var(--color-bg); padding: clamp(32px,4vw,52px); display: flex; flex-direction: column; transition: background var(--duration-base); }
.division:hover { background: #fff; }
.division__tag { font-family: var(--font-mono); font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--color-secondary); }
.division__h { font-size: clamp(26px,2.8vw,38px); margin-top: 14px; letter-spacing: -.03em; }
.division__link { margin-top: 6px; margin-bottom: 28px; }
.division__list { list-style: none; display: flex; flex-direction: column; gap: 1px; margin-top: auto; }
.division__list li { padding: 16px 0; border-top: 1px solid var(--color-border); font-size: 16px; color: var(--color-text); display: flex; align-items: center; gap: 12px; }
.division__list li::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--altura-400); flex: none; }

/* CTA band */
.ctaband { background: var(--altura-900); position: relative; overflow: hidden; }
/* Solid evergreen variant — distinguishes the solutions-page band from the
   footer "get in touch" CTA, which keeps the WebGL scene. */
/* Solid evergreen variant — the solutions-page cross-link CTA.
   Distinct from the footer "get in touch" band: a darker tone (altura-950 vs
   the footer's altura-900) and a centered, stacked composition rather than the
   footer's left/right split, so the two adjacent dark bands read as an
   intentional two-tone sequence rather than a repeat. */
.ctaband--solid { background: var(--altura-950); border-top: 1px solid var(--altura-800); }
.ctaband__inner { max-width: var(--maxw); margin-inline: auto; padding: clamp(60px,8vw,110px) var(--pad); display: flex; justify-content: space-between; align-items: center; gap: 40px; flex-wrap: wrap; position: relative; z-index: 2; }
.ctaband--solid .ctaband__inner {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: clamp(30px,3.4vw,46px);
  padding-block: clamp(84px,11vw,150px);
}
.ctaband--solid .ctaband__inner::before {
  content: '';
  width: 56px; height: 1px;
  background: var(--altura-500);
}
.ctaband--solid .ctaband__h {
  max-width: 20ch;
  margin-inline: auto;
  font-size: clamp(36px,5vw,66px);
}
.ctaband__h { font-family: var(--font-display); font-weight: 300; font-size: clamp(30px,4vw,54px); letter-spacing: -.04em; line-height: 1.04; color: #FAF9F7; max-width: 16ch; }

/* CTA band + footer CTA now use a flat dark-green background (no WebGL scene) */
.footer__cta { background: var(--altura-900); }
.ctaband > .scene, .ctaband > .scene__scrim,
.footer__cta > .scene, .footer__cta > .scene__scrim { display: none; }

/* Reusable procedural 3D scene host */
.scene { position: absolute; inset: 0; z-index: 0; }
.scene canvas { width: 100%; height: 100%; display: block; }
.scene__scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.ctaband .scene__scrim { background: linear-gradient(90deg, hsl(140 32% 4% / .84) 0%, hsl(140 32% 4% / .5) 55%, hsl(140 32% 4% / .7) 100%); }

/* Affiliates */
.affiliates { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; }
.affiliate { background: var(--color-bg); min-height: 150px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 32px; text-align: center; transition: background var(--duration-base); }
.affiliate:hover { background: #fff; }
.affiliate__name { font-family: var(--font-display); font-size: 22px; font-weight: 600; letter-spacing: -.01em; color: var(--color-text); }
.affiliate__meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--color-text-subtle); }

/* Service blocks with accordion */
.service { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(36px,6vw,90px); align-items: start; }
.service + .service { margin-top: clamp(60px,8vw,110px); padding-top: clamp(60px,8vw,110px); border-top: 1px solid var(--color-border); }
.service__aside { position: sticky; top: 116px; }
.service__h { font-size: clamp(26px,3vw,40px); line-height: 1.08; letter-spacing: -.032em; margin-top: 16px; }
.service__intro { margin-top: 22px; color: var(--color-text-muted); font-size: 1.08rem; line-height: 1.65; max-width: 46ch; }
.service__intro + .service__intro { margin-top: 1em; }
.service__intro--lede { font-family: var(--font-serif); font-style: italic; color: var(--color-text); font-size: 1.2rem; }

.acc { border-top: 1px solid var(--color-border); }
.acc__item { border-bottom: 1px solid var(--color-border); }
.acc__btn {
  width: 100%; background: none; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  padding: 24px 4px; text-align: left;
  font-family: var(--font-display); font-size: clamp(18px,1.8vw,23px); font-weight: 500; letter-spacing: -.015em; color: var(--color-text);
  transition: color var(--duration-fast), padding var(--duration-base) var(--ease-emphasized);
}
.acc__btn:hover { color: var(--color-secondary); padding-inline: 14px 14px; }
.acc__sign { flex: none; width: 22px; height: 22px; position: relative; }
.acc__sign::before, .acc__sign::after { content: ''; position: absolute; background: var(--color-secondary); transition: transform var(--duration-base) var(--ease-emphasized), opacity var(--duration-base); }
.acc__sign::before { top: 10.5px; left: 2px; right: 2px; height: 1.5px; }
.acc__sign::after { left: 10.5px; top: 2px; bottom: 2px; width: 1.5px; }
.acc__item.is-open .acc__sign::after { transform: scaleY(0); opacity: 0; }
.acc__item.is-open .acc__btn { color: var(--color-secondary); }
.acc__panel { overflow: hidden; height: 0; transition: height var(--duration-slow) var(--ease-emphasized); }
.acc__panel p { padding: 0 4px 26px; color: var(--color-text-muted); font-size: 1.02rem; line-height: 1.62; max-width: 58ch; }

/* Plain feature list (no click) */
.featurelist { list-style: none; border-top: 1px solid var(--color-border); }
.featurelist li { display: flex; align-items: baseline; gap: 18px; padding: 20px 4px; border-bottom: 1px solid var(--color-border); font-size: clamp(17px,1.7vw,21px); font-family: var(--font-display); font-weight: 500; letter-spacing: -.01em; }
.featurelist li .n { font-family: var(--font-mono); font-size: 12px; font-weight: 400; letter-spacing: .1em; color: var(--color-secondary); flex: none; padding-top: 6px; }

/* Process steps */
.process { display: flex; flex-wrap: wrap; gap: 12px; align-items: stretch; }
.process__step { flex: 1 1 150px; background: var(--color-surface); color: var(--color-text); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 28px 22px; display: flex; flex-direction: column; gap: 14px; transition: transform var(--duration-base) var(--ease-emphasized), box-shadow var(--duration-base), border-color var(--duration-base); }
.process__step:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--color-border-strong); }
.process__n { font-family: var(--font-mono); font-size: 12px; letter-spacing: .2em; color: var(--color-secondary); }
.process__t { font-family: var(--font-display); font-size: 21px; font-weight: 600; letter-spacing: -.01em; color: var(--color-text); }
.process__arrow { display: grid; place-items: center; font-family: var(--font-serif); font-size: 22px; color: var(--altura-400); flex: 0 0 22px; align-self: center; }

/* Principles list */
.principles { display: grid; grid-template-columns: repeat(2,1fr); gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; }
.principle { background: var(--color-bg); padding: 36px clamp(24px,3vw,40px); display: flex; gap: 22px; align-items: center; transition: background var(--duration-base); }
.principle:hover { background: var(--color-bg-subtle, #fff); }
/* Dark-section variant used on the Investments philosophy grid */
.principles--dark { --color-bg: #191512; --color-border: #2A2622; --color-bg-subtle: #211C18; }
.principles--dark .principle p { color: #FAF9F7; }
.principle .n { font-family: var(--font-mono); font-size: 12px; letter-spacing: .14em; color: var(--color-secondary); flex: none; }
.principle p { font-family: var(--font-display); font-size: clamp(19px,1.9vw,25px); font-weight: 500; letter-spacing: -.015em; line-height: 1.25; }

/* Investment universe */
.universe { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(24px,3vw,48px); }
.universe__group { display: flex; flex-direction: column; }
.universe__cat { font-family: var(--font-mono); font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--color-secondary); padding-bottom: 18px; border-bottom: 1px solid var(--color-border-strong); }
.universe__list { list-style: none; margin-top: 6px; }
.universe__list li { padding: 16px 0; border-bottom: 1px solid var(--color-border); font-family: var(--font-display); font-size: clamp(17px,1.8vw,22px); font-weight: 500; letter-spacing: -.01em; }

/* Testimonials carousel */
.carousel { position: relative; }
.carousel__viewport { overflow: hidden; }
.carousel__track { display: flex; transition: transform .7s var(--ease-emphasized); }
.carousel__slide { flex: 0 0 100%; padding: 4px clamp(0px,2vw,40px); }
.carousel__quote { font-family: var(--font-display); font-weight: 300; font-style: italic; font-size: clamp(22px,3vw,38px); line-height: 1.34; letter-spacing: -.01em; color: var(--color-text); text-wrap: balance; max-width: 24ch; }
.carousel--ink .carousel__quote { color: #F2F0EC; }
.carousel__cite { margin-top: 30px; font-family: var(--font-mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--color-secondary); }
.carousel--ink .carousel__cite { color: var(--altura-300); }
.carousel__controls { display: flex; align-items: center; gap: 18px; margin-top: 48px; }
.carousel__btn { width: 52px; height: 52px; border-radius: var(--radius-full); border: 1px solid var(--color-border-strong); background: transparent; cursor: pointer; font-family: var(--font-serif); font-size: 22px; color: var(--color-text); display: grid; place-items: center; transition: background var(--duration-fast), border-color var(--duration-fast), color var(--duration-fast); }
.carousel--ink .carousel__btn { border-color: hsl(0 0% 100% / .25); color: #F2F0EC; }
.carousel__btn:hover { background: var(--color-secondary); border-color: var(--color-secondary); color: #fff; }
.carousel__count { font-family: var(--font-mono); font-size: 13px; letter-spacing: .1em; color: var(--color-text-subtle); margin-left: 6px; }
.carousel--ink .carousel__count { color: var(--altura-300); }

/* Contact */
.contact-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(40px,6vw,90px); align-items: start; }
.contact-detail { display: flex; flex-direction: column; gap: 4px; margin-bottom: 30px; }
.contact-detail__lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--color-text-subtle); }
.contact-detail__val { font-size: 1.15rem; color: var(--color-text); line-height: 1.5; }
.contact-detail__val a:hover { color: var(--color-secondary); }
.contact-note { font-family: var(--font-serif); font-style: italic; font-weight: 300; color: var(--color-text-muted); font-size: 1.1rem; margin-top: 8px; }

/* Contact — stacked layout: details row + centered form */
.contact-info { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; margin-bottom: clamp(40px,6vw,72px); }
.contact-info__item { background: var(--color-surface); padding: clamp(28px,3vw,40px); display: flex; flex-direction: column; gap: 12px; transition: background var(--duration-base); }
.contact-info__item:hover { background: var(--color-bg); }
.contact-info__lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--color-secondary); }
.contact-info__val { font-size: 1.15rem; color: var(--color-text); line-height: 1.5; }
.contact-info__val a { color: var(--color-text); transition: color var(--duration-fast); }
.contact-info__val a:hover { color: var(--color-secondary); }
.contact-form-wrap { max-width: 620px; margin-inline: auto; }
.contact-form-wrap__head { text-align: center; margin-bottom: 36px; }
.contact-form-wrap__head .contact-note { margin-top: 12px; }

.form { display: grid; gap: 20px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: clamp(28px,4vw,44px); box-shadow: var(--shadow-sm); }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-size: 13px; font-weight: 500; color: var(--color-text-muted); }
.field label .req { color: var(--color-secondary); }
.field input, .field textarea { font-family: var(--font-sans); font-size: 15px; padding: 14px; border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-bg); color: var(--color-text); resize: vertical; transition: border-color var(--duration-fast), box-shadow var(--duration-fast); }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--color-focus-ring); box-shadow: 0 0 0 3px hsl(140 30% 33% / .15); }
.form__done { display: none; }
.form.is-sent .field, .form.is-sent .btn { display: none; }
.form.is-sent .form__done { display: block; }
.form__done h3 { font-size: 28px; margin: 10px 0 12px; }

/* Legal / privacy document */
.legal { max-width: var(--container-prose); }
.legal__updated { font-family: var(--font-mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--color-text-subtle); padding-bottom: 28px; border-bottom: 1px solid var(--color-border); margin-bottom: 8px; }
.legal__sec { padding-top: 40px; }
.legal__sec h2 { display: flex; gap: 16px; align-items: baseline; font-size: clamp(20px,2.2vw,28px); margin-bottom: 18px; }
.legal__sec h2 .legal__n { font-family: var(--font-mono); font-size: 13px; font-weight: 400; letter-spacing: .08em; color: var(--color-secondary); flex: none; transform: translateY(-2px); }
.legal__sec h3 { font-family: var(--font-sans); font-weight: 600; font-size: 16px; letter-spacing: 0; color: var(--color-text); margin: 24px 0 10px; }
.legal p { color: var(--color-text-muted); line-height: 1.7; margin-bottom: 14px; max-width: 68ch; }
.legal ul { list-style: none; margin: 8px 0 18px; display: flex; flex-direction: column; gap: 9px; }
.legal li { position: relative; padding-left: 22px; color: var(--color-text-muted); line-height: 1.55; max-width: 64ch; }
.legal li::before { content: ""; position: absolute; left: 3px; top: 10px; width: 5px; height: 5px; border-radius: 50%; background: var(--color-secondary); }
.legal__contact { margin-top: 16px; padding: 28px 32px; border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-bg-subtle); }
.legal__contact p { margin-bottom: 4px; color: var(--color-text); }
.legal__contact .legal__org { font-family: var(--font-display); font-size: 20px; font-weight: 500; margin-bottom: 10px; }
.legal__contact a { color: var(--color-secondary); }

/* Footer */
.footer { background: #08130D; color: #DBE7DF; }
.footer__cta { border-bottom: 1px solid hsl(0 0% 100% / .1); position: relative; overflow: hidden; }
.footer__cta-inner { max-width: var(--maxw); margin-inline: auto; padding: clamp(56px,7vw,96px) var(--pad); display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; flex-wrap: wrap; position: relative; z-index: 2; }
.footer__cta .scene__scrim { background: linear-gradient(90deg, hsl(150 42% 3% / .88) 0%, hsl(150 42% 3% / .58) 60%, hsl(150 42% 3% / .74) 100%); }
.footer__cta-h { font-family: var(--font-display); font-weight: 300; font-size: clamp(28px,4vw,52px); letter-spacing: -.04em; line-height: 1.05; color: #FAF9F7; max-width: 16ch; margin-top: 16px; }
.footer__grid { max-width: var(--maxw); margin-inline: auto; padding: clamp(48px,6vw,80px) var(--pad) 0; display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 40px; }
.footer__mark { height: 38px; opacity: .9; margin-bottom: 16px; }
.footer__tagline { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: 17px; color: #B8CFC1; max-width: 30ch; }
.footer__fine { font-family: var(--font-mono); font-style: normal; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: #5C8B71; margin-top: 16px; line-height: 1.9; }
.footer__col { display: flex; flex-direction: column; gap: 11px; }
.footer__lbl { font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: #5C8B71; margin-bottom: 5px; }
.footer__col a, .footer__col span:not(.footer__lbl) { font-size: 14px; color: #B8CFC1; transition: color var(--duration-fast); }
.footer__col a:hover { color: #fff; }
.footer__legal { max-width: var(--maxw); margin: clamp(48px,6vw,72px) auto 0; padding: 28px var(--pad); border-top: 1px solid hsl(0 0% 100% / .1); display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; color: #5C8B71; }

/* Cookie consent — discreet paper card */
.cookie {
  position: fixed;
  left: var(--pad);
  bottom: clamp(16px, 3vw, 32px);
  z-index: 1200;
  width: min(400px, calc(100vw - var(--pad) * 2));
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: clamp(22px, 2.6vw, 30px);
  opacity: 0;
  transform: translateY(18px);
  transition: opacity var(--duration-slow) var(--ease-emphasized), transform var(--duration-slow) var(--ease-emphasized);
}
.cookie.is-shown { opacity: 1; transform: none; }
.cookie__label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--color-secondary);
}
.cookie__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(20px, 2.2vw, 25px);
  letter-spacing: -.02em;
  line-height: 1.1;
  margin-top: 12px;
}
.cookie__body {
  font-size: 14px;
  line-height: 1.6;
  color: var(--color-text-muted);
  margin-top: 12px;
  max-width: 46ch;
}
.cookie__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}
.cookie__actions .btn {
  height: 44px;
  padding: 0 20px;
  font-size: 14px;
  flex: 1 1 auto;
  justify-content: center;
}
.cookie__more {
  margin-top: 16px;
}

@media (prefers-reduced-motion: reduce) {
  .cookie { transition: none; }
}

@media (max-width: 980px) {
  .nav__links { display: none; }
  .nav__cta { display: none; }
  .nav__toggle { display: block; }
  .editorial { grid-template-columns: 1fr; gap: 32px; }
  .editorial__aside { position: static; }
  .service { grid-template-columns: 1fr; gap: 28px; }
  .service__aside { position: static; }
  .divisions { grid-template-columns: 1fr; }
  .affiliates { grid-template-columns: 1fr; }
  .principles { grid-template-columns: 1fr; }
  .universe { grid-template-columns: 1fr; gap: 36px; }
  .contact-grid { grid-template-columns: 1fr; gap: 36px; }
  .footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .process__arrow { display: none; }
  .process__step { flex-basis: 130px; }
}

@media (max-width: 560px) {
  .process__step { flex-basis: 100%; }
  .carousel__quote { font-size: 22px; max-width: none; }
  .section__head--row { align-items: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto; }
  .marquee__track { animation: none; }
  .kinetic .ki { transform: none; transition: none; }
  .reveal { opacity: 1; transform: none; }
}
