/* ============================================================
   GLOBA 3 VENTURES — Design System
   Distinct from Advisory: platform-portfolio feel,
   venture hierarchy, editorial-media energy.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300;1,9..40,400&display=swap');

/* ── Design Tokens ───────────────────────────────────────── */
:root {
  --charcoal:        #181816;
  --charcoal-mid:    #222220;
  --charcoal-soft:   #2C2C28;
  --ivory:           #F7F5F1;
  --ivory-warm:      #f2f0ec;
  --sand:            #f2f0ec;
  --stone:           #C4B49A;
  --stone-mid:       #9A8C7C;
  --stone-dim:       #6E6258;

  /* Primary accent: muted bronze */
  --accent:          #8B6932;
  --accent-light:    #A87D3C;
  --accent-pale:     rgba(139,105,50,.09);
  --accent-glow:     rgba(139,105,50,.13);

--ivory-text:      #F0ECE4;
  --text-dark:       #1A1918;
  --text-mid:        #4E4840;
  --text-light:      #7A7268;

  --border-light:    rgba(196,180,154,.28);
  --border-mid:      rgba(196,180,154,.50);
  --border-dark:     rgba(196,180,154,.10);

  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans:  'DM Sans', system-ui, -apple-system, sans-serif;

  --ease:        cubic-bezier(0.16, 1, 0.3, 1);
  --ease-soft:   cubic-bezier(0.45, 0, 0.55, 1);
  --t-fast:      150ms;
  --t-base:      260ms;
  --t-slow:      460ms;

  --nav-h:       72px;
  --max-w:       1280px;
  --gutter:      clamp(1.5rem, 5vw, 4rem);
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { font-family: var(--font-sans); font-size: 1rem; line-height: 1.65; color: var(--text-dark); background: var(--ivory); }
img { display: block; max-width: 100%; }
a   { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font: inherit; cursor: pointer; background: none; border: none; }

/* ── Layout ──────────────────────────────────────────────── */
.wrap {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.sec { padding-block: clamp(4rem, 8vw, 8rem); }
.sec--dark  { background: var(--charcoal); color: var(--ivory-text); position: relative; overflow: hidden; }
.sec--dark > .wrap { position: relative; z-index: 1; }
.sec--dark::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 65% 55% at 75% 38%, rgba(139,105,50,.10) 0%, transparent 62%),
    radial-gradient(ellipse 48% 62% at 20% 68%, rgba(90,84,72,.07) 0%, transparent 55%);
  filter: blur(76px);
  pointer-events: none;
  animation: drift-c 35s ease-in-out infinite alternate;
}
.sec--dark::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 52% 50% at 55% 85%, rgba(196,180,154,.05) 0%, transparent 58%);
  filter: blur(88px);
  pointer-events: none;
  animation: drift-a 42s ease-in-out infinite alternate;
}
.sec--sand  { background: var(--sand); }
.sec--ivory { background: var(--ivory-warm); }

/* ── Focus Areas page: single continuous dark canvas ──────── */
.focus-canvas {
  background: var(--charcoal);
  position: relative;
}
.focus-canvas::before {
  content: '';
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 75% 35% at 68% 18%, rgba(139,105,50,.12) 0%, transparent 65%),
    radial-gradient(ellipse 55% 45% at 18% 52%, rgba(90,84,72,.09) 0%, transparent 55%),
    radial-gradient(ellipse 60% 38% at 52% 82%, rgba(139,105,50,.09) 0%, transparent 62%);
  filter: blur(82px);
  pointer-events: none;
  animation: drift-a 36s ease-in-out infinite alternate;
}
.focus-canvas::after {
  content: '';
  position: absolute; inset: 0; z-index: 0;
  background: radial-gradient(ellipse 58% 42% at 88% 42%, rgba(196,180,154,.06) 0%, transparent 60%);
  filter: blur(92px);
  pointer-events: none;
  animation: drift-b 44s ease-in-out infinite alternate;
}
/* Lift inner sections above canvas ambient */
.focus-canvas > .phero,
.focus-canvas > .sec--dark {
  background: transparent;
  position: relative;
  z-index: 1;
}
/* Suppress section-level ambient within the canvas — canvas handles it */
.focus-canvas .phero::before,
.focus-canvas .phero::after,
.focus-canvas .sec--dark::before,
.focus-canvas .sec--dark::after { display: none; }
.sec--tight { padding-block: clamp(2.5rem, 5vw, 5rem); }
.phero + .sec--dark { padding-top: clamp(1.25rem, 2.5vw, 2.5rem); }

/* ── Typography ──────────────────────────────────────────── */
.kicker {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--stone-mid);
}
.kicker--light { color: rgba(196,180,154,.55); }
.kicker--accent { color: var(--accent); }

h1 { font-family: var(--font-serif); font-size: clamp(2.2rem, 4.5vw, 3.25rem); font-weight: 400; line-height: 1.1;  letter-spacing: -0.02em; }
h2 { font-family: var(--font-serif); font-size: clamp(1.7rem, 3.2vw, 2.25rem); font-weight: 400; line-height: 1.12; letter-spacing: -0.015em; }
h3 { font-family: var(--font-serif); font-size: clamp(1.2rem, 2vw, 1.75rem);   font-weight: 400; line-height: 1.2; }
h4 { font-family: var(--font-serif); font-size: 1rem; font-weight: 400; line-height: 1.2; }

p { line-height: 1.72; }

/* ── Navigation ──────────────────────────────────────────── */
.nav {
  position: fixed;
  inset-block-start: 0; inset-inline: 0;
  z-index: 100;
  height: var(--nav-h);
  display: flex;
  align-items: center;
  transition: background var(--t-base) var(--ease), border-color var(--t-base);
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(24,24,22,.96);
  border-bottom-color: var(--border-dark);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.nav__inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; width: 100%; }

.nav__logo { display: flex; align-items: center; line-height: 1; }
.nav__logo-img { width: 6.75rem; height: auto; }

.nav__links { display: flex; align-items: center; gap: 2rem; }
.nav__link  {
  font-size: 0.72rem; font-weight: 400; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(240,236,228,.6);
  transition: color var(--t-fast);
  position: relative;
}
.nav__link::after {
  content: ''; position: absolute; bottom: -4px; left: 0;
  width: 0; height: 1px; background: var(--accent-light);
  transition: width var(--t-base) var(--ease);
}
.nav__link:hover,
.nav__link.active { color: var(--ivory-text); }
.nav__link:hover::after,
.nav__link.active::after { width: 100%; }

.nav__contact {
  font-size: 0.72rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ivory-text);
  border: 1px solid rgba(240,236,228,.28);
  padding: 0.35rem 1.1rem;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.nav__contact:hover { background: rgba(240,236,228,.07); border-color: rgba(240,236,228,.55); }

.nav__burger { display: none; flex-direction: column; gap: 5px; padding: 4px; }
.nav__burger span { display: block; width: 22px; height: 1px; background: var(--ivory-text); transition: transform var(--t-base), opacity var(--t-base); }

.nav__mobile {
  display: none; position: fixed; inset: 0; background: var(--charcoal); z-index: 99;
  flex-direction: column; align-items: center; justify-content: center; gap: 2rem;
}
.nav__mobile.open { display: flex; }
.nav__mobile-link {
  font-family: var(--font-sans); font-size: 1rem; font-weight: 500;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ivory-text); transition: color var(--t-fast);
}
.nav__mobile-link:hover { color: var(--stone); }
.nav__mobile-close {
  position: absolute; top: 1.5rem; right: 1.5rem;
  font-size: 1.25rem; color: var(--ivory-text); opacity: .55;
  padding: .5rem; cursor: pointer;
  transition: opacity var(--t-fast);
}
.nav__mobile-close:hover { opacity: 1; }

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: var(--font-sans); font-size: 0.72rem; font-weight: 500;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: .6rem 1.6rem;
  border: 1px solid transparent;
  transition: background var(--t-base), border-color var(--t-base), color var(--t-base);
  white-space: nowrap; cursor: pointer;
}
.btn-primary   { background: var(--accent); color: var(--ivory-text); border-color: var(--accent); }
.btn-primary:hover { background: var(--accent-light); border-color: var(--accent-light); }

.btn-outline   { background: transparent; color: var(--text-dark); border-color: var(--text-dark); }
.btn-outline:hover { background: var(--text-dark); color: var(--ivory-text); }

.btn-outline-light { background: transparent; color: var(--ivory-text); border-color: rgba(240,236,228,.35); }
.btn-outline-light:hover { background: rgba(240,236,228,.07); border-color: rgba(240,236,228,.65); }

.btn-ghost {
  padding-inline: 0; border: none;
  font-size: 0.72rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-light);
  transition: color var(--t-fast);
  display: inline-flex; align-items: center; gap: .4rem;
}
.btn-ghost::after { content: '→'; transition: transform var(--t-fast); }
.btn-ghost:hover { color: var(--accent); }
.btn-ghost:hover::after { transform: translateX(4px); }

.btn-ghost-light { color: rgba(240,236,228,.5); }
.btn-ghost-light:hover { color: var(--ivory-text); }

.btn-row { display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }

/* ── Divider ─────────────────────────────────────────────── */
.rule { width: 40px; height: 1px; background: var(--border-mid); }
.rule--accent { background: var(--accent); }
.rule--light  { background: rgba(196,180,154,.22); }

/* ── Fade-in ─────────────────────────────────────────────── */
.fade-in {
  opacity: 0; transform: translateY(18px);
  transition: opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease);
}
.fade-in.visible { opacity: 1; transform: translateY(0); }

/* ============================================================
   AMBIENT DRIFT — slow background motion for dark sections
   ============================================================ */
@keyframes drift-a {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(5%, 4%) scale(1.08); }
}
@keyframes drift-b {
  from { transform: translate(0, 0) scale(1.05); }
  to   { transform: translate(-4%, 5%) scale(1); }
}
@keyframes drift-c {
  from { transform: translate(0, 0) scale(1.02); }
  to   { transform: translate(3%, -4%) scale(1.06); }
}
@media (prefers-reduced-motion: reduce) {
  .hero__ambient,
  .phero::before, .phero::after,
  .cta-sec::before, .cta-sec::after,
  .sec--dark::before, .sec--dark::after,
  .focus-canvas::before, .focus-canvas::after { animation: none !important; }
}

/* ============================================================
   HERO — Split layout with Venture Index
   ============================================================ */
.hero {
  min-height: 100svh;
  background: var(--charcoal);
  display: flex; align-items: flex-end;
  padding-top: var(--nav-h);
  padding-bottom: clamp(3.5rem, 6vw, 6rem);
  position: relative; overflow: hidden;
}

.hero__ambient {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 72% 62% at 28% 52%, rgba(139,105,50,.13) 0%, transparent 62%),
    radial-gradient(ellipse 48% 68% at 84% 32%, rgba(196,180,154,.07) 0%, transparent 58%),
    radial-gradient(ellipse 52% 42% at 58% 82%, rgba(90,84,72,.10) 0%, transparent 55%);
  filter: blur(64px);
  animation: drift-a 34s ease-in-out infinite alternate;
}

.hero__grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: clamp(2rem, 6vw, 6rem);
  align-items: end;
  width: 100%;
}

/* Left: headline content */
.hero__kicker {
  font-size: 0.68rem; font-weight: 500; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--stone-mid); margin-bottom: 1.75rem;
}
.hero__title {
  font-size: clamp(2.2rem, 4.5vw, 3.25rem);
  line-height: 1.1;
  color: var(--ivory-text);
  max-width: 820px;
  margin-bottom: 1.5rem;
}
.hero__bar { width: 36px; height: 1px; background: var(--accent); margin-bottom: 1.5rem; }
.hero__sub {
  font-size: 1.05rem; font-weight: 300;
  color: rgba(240,236,228,.58); max-width: 600px; line-height: 1.72;
  margin-bottom: 2.25rem;
}

/* Right: Venture Index panel */
.hero__index {
  border-left: 1px solid rgba(196,180,154,.14);
  padding-left: 1.75rem;
  padding-bottom: .5rem;
  align-self: end;
}
.hero__index-label {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(196,180,154,.38); margin-bottom: 1.25rem;
}
.hero__index-item {
  border-top: 1px solid rgba(196,180,154,.09);
  padding: .85rem 0;
}
.hero__index-item:last-of-type { border-bottom: 1px solid rgba(196,180,154,.09); }
.hero__index-num {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.14em;
  color: var(--stone-mid); margin-bottom: 2px;
}
.hero__index-name {
  font-family: var(--font-serif); font-size: 1.05rem; font-weight: 300;
  color: var(--ivory-text); line-height: 1.2; margin-bottom: 2px;
}
.hero__index-cat {
  font-size: 0.58rem; letter-spacing: 0.08em;
  color: rgba(196,180,154,.36);
}
.hero__index-footer {
  padding-top: .75rem;
  font-size: 0.58rem; letter-spacing: 0.08em;
  color: rgba(196,180,154,.28);
}

/* ============================================================
   INTRO BLOCK — Company definition
   ============================================================ */
.intro-block {
  max-width: 840px;
}
.intro-block__kicker { margin-bottom: 1.25rem; display: block; }
.intro-block__heading { margin-bottom: 1rem; }
.intro-block__body {
  font-size: 1.1rem; font-weight: 300; color: var(--text-mid); line-height: 1.8;
  max-width: 640px;
}

/* ============================================================
   THESIS STRIP — horizontal rule + italic statement
   ============================================================ */
.thesis-strip {
  display: grid;
  grid-template-columns: 3px 1fr;
  gap: 2.25rem;
  align-items: start;
}
.thesis-strip__bar { background: var(--accent); width: 3px; align-self: stretch; }
.thesis-strip__quote {
  font-family: var(--font-sans);
  font-size: clamp(1.05rem, 1.85vw, 1.15rem);
  font-weight: 300; line-height: 1.62;
  color: var(--text-dark); margin-bottom: .875rem;
  max-width: 800px;
}
.thesis-strip__note {
  font-size: .95rem; font-weight: 300; color: var(--text-mid); line-height: 1.75;
  max-width: 580px;
}

/* ============================================================
   PORTFOLIO SECTION HEADER
   ============================================================ */
.port-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 2rem;
  margin-bottom: 2rem;
}
.port-header__left {}
.port-header__kicker { margin-bottom: .75rem; display: block; }
.port-header__title  { margin-bottom: 0; }
.port-header__intro  {
  font-size: .95rem; font-weight: 300; color: var(--text-mid); max-width: 480px; line-height: 1.7;
}

/* ============================================================
   AFC — LEAD VENTURE (flagship full-width)
   ============================================================ */
.venture-lead {
  background: var(--charcoal);
  border: 1px solid var(--border-dark);
  overflow: hidden;
  margin-bottom: 1px;
}
.venture-lead__top-bar {
  height: 3px;
  background: linear-gradient(to right, var(--accent), var(--accent-light), transparent);
}
.venture-lead__inner {
  padding: clamp(2rem, 4vw, 3.5rem) clamp(1.75rem, 4vw, 3.5rem);
}
.venture-lead__meta {
  display: flex; align-items: center;
  justify-content: space-between; gap: 1rem;
  margin-bottom: 1.25rem;
}
.venture-lead__badge {
  font-size: 0.62rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent-light);
}
.venture-lead__cat {
  font-size: 0.62rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase;
  background: var(--accent); color: var(--ivory-text);
  padding: .25rem .65rem;
}
.venture-lead__name {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 4.5vw, 3.75rem);
  font-weight: 700; font-style: italic; line-height: .92; letter-spacing: -0.025em;
  color: var(--ivory-text);
  margin-bottom: 1.75rem;
}
.venture-lead__body {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem); align-items: start;
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(196,180,154,.08);
}
.venture-lead__desc {
  font-size: 1.05rem; font-weight: 300;
  color: rgba(240,236,228,.72); line-height: 1.75;
  max-width: none;
}
.venture-lead__side {}
.venture-lead__support {
  font-size: .875rem; font-weight: 300;
  color: rgba(240,236,228,.5); line-height: 1.72; margin-bottom: .875rem; max-width: none;
}
.venture-lead__proof {
  font-size: .8rem; font-weight: 300;
  color: rgba(240,236,228,.38); line-height: 1.65;
  border-left: 2px solid rgba(139,105,50,.35); padding-left: .875rem; max-width: none;
}
.venture-lead__layers {
  display: flex; flex-wrap: wrap; gap: .4rem;
  margin-bottom: 1.5rem;
}
.venture-lead__layer {
  font-size: 0.6rem; font-weight: 400; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(196,180,154,.45); border: 1px solid rgba(196,180,154,.14);
  padding: .2rem .6rem;
}

/* ============================================================
   NFF + UNSEEN ARABIA — Secondary featured tier (two-col)
   ============================================================ */
.ventures-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
}
.venture-sec {
  background: var(--ivory-warm);
  border: 1px solid var(--border-light);
  padding: clamp(1.75rem, 3.5vw, 2.75rem);
  position: relative;
  transition: border-color var(--t-base);
  overflow: hidden;
}
.venture-sec::after {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0; width: 2px;
  background: transparent;
  transition: background var(--t-base) var(--ease);
}
.venture-sec:hover { border-color: var(--stone-mid); }
.venture-sec:hover::after { background: var(--accent); }

.venture-sec__meta {
  display: flex; align-items: center; justify-content: space-between; gap: .75rem;
  margin-bottom: 1rem;
}
.venture-sec__badge {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--stone-mid);
}
.venture-sec__cat {
  font-size: 0.6rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent); background: var(--accent-pale); padding: .2rem .55rem;
}
.venture-sec__name {
  font-family: var(--font-serif);
  font-size: clamp(1.6rem, 3vw, 2.25rem);
  font-weight: 400; line-height: 1.1;
  color: var(--text-dark); margin-bottom: 1rem;
}
.venture-sec__desc {
  font-size: .875rem; font-weight: 300; color: var(--text-mid);
  line-height: 1.72; margin-bottom: .75rem; max-width: none;
}
.venture-sec__support {
  font-size: .78rem; font-weight: 300; color: var(--text-light);
  font-style: italic; line-height: 1.65; margin-bottom: .75rem; max-width: none;
}
.venture-sec__proof {
  font-size: .78rem; font-weight: 300; color: var(--text-mid);
  border-left: 1px solid var(--border-mid); padding-left: .875rem;
  line-height: 1.65; margin-bottom: 1.5rem; max-width: none;
}

/* ============================================================
   EMERGING PLATFORMS — Minimal inline list (not cards)
   ============================================================ */
.emerging-band {
  border: 1px solid var(--border-light);
  background: var(--ivory);
}
.emerging-band__header {
  padding: 1.25rem clamp(1.5rem, 3vw, 2.5rem);
  border-bottom: 1px solid var(--border-light);
  display: flex; align-items: center; gap: 1rem;
}
.emerging-band__label {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--stone-mid);
}
.emerging-band__note {
  font-size: 0.6rem; font-weight: 300; color: var(--stone-mid);
  font-style: italic;
}
.emerging-band__grid {
  display: grid; grid-template-columns: 1fr 1fr;
}
.emerging-item {
  padding: 1.5rem clamp(1.5rem, 3vw, 2.5rem);
  display: flex; gap: 1.25rem; align-items: flex-start;
}
.emerging-item:first-child { border-right: 1px solid var(--border-light); }
.emerging-item__num {
  font-family: var(--font-serif); font-size: 1.75rem; font-weight: 300;
  color: var(--border-mid); line-height: 1; flex-shrink: 0; padding-top: 2px;
}
.emerging-item__name {
  font-family: var(--font-serif); font-size: 1.1rem; font-weight: 400;
  color: var(--text-dark); margin-bottom: .15rem; line-height: 1.2;
}
.emerging-item__cat {
  font-size: 0.58rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--stone-mid); margin-bottom: .6rem;
}
.emerging-item__desc {
  font-size: .78rem; font-weight: 300; color: var(--text-light);
  line-height: 1.65; max-width: none;
}

/* ============================================================
   FOCUS MATRIX — Dark grid (distinct from Advisory's light grid)
   ============================================================ */
.focus-matrix {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.focus-cell {
  background: var(--charcoal-soft);
  border: 1px solid rgba(196,180,154,.13);
  padding: clamp(1.5rem, 3vw, 2.5rem);
  transition: background var(--t-base);
}
.focus-cell:hover { background: #333330; }
.focus-cell:hover .focus-cell__num { color: rgba(139,105,50,.45); }
.focus-cell__num {
  font-family: var(--font-serif); font-size: 2.5rem; font-weight: 300;
  color: rgba(196,180,154,.32); line-height: 1; margin-bottom: 1.25rem;
}
.focus-cell__title {
  font-family: var(--font-serif); font-size: 1.15rem; font-weight: 400; line-height: 1.2;
  color: var(--ivory-text); margin-bottom: .6rem;
}
.focus-cell__desc {
  font-size: .8rem; font-weight: 300;
  color: rgba(240,236,228,.62); line-height: 1.72; max-width: none;
}

/* ============================================================
   HOW WE BUILD — step grid
   ============================================================ */
.build-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border-light);
}
.build-step {
  background: var(--ivory-warm);
  padding: clamp(1.5rem, 3vw, 2.5rem);
  transition: background var(--t-base);
}
.build-step:hover { background: white; }
.build-step__num {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent-light); margin-bottom: .875rem;
}
.build-step__name {
  font-family: var(--font-serif); font-size: 1.625rem; font-weight: 400;
  color: var(--text-dark); margin-bottom: .75rem;
}
.build-step__desc {
  font-size: .82rem; font-weight: 300; color: var(--text-mid); line-height: 1.7; max-width: none;
}

/* ============================================================
   PART OF GLOBA 3 — Sister division block
   ============================================================ */
.globa-block {
  background: var(--charcoal-mid);
  border: 1px solid var(--border-dark);
  padding: clamp(2rem, 4vw, 3.5rem);
  display: grid; grid-template-columns: auto 1fr;
  gap: clamp(2rem, 6vw, 5rem);
  align-items: center;
}
.globa-block__left {}
.globa-block__kicker { margin-bottom: .75rem; display: block; }
.globa-block__name {
  font-family: var(--font-serif); font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  font-weight: 300; color: var(--ivory-text); line-height: 1.1; margin-bottom: 1.25rem;
}
.globa-block__tags { display: flex; flex-wrap: wrap; gap: .4rem; }
.globa-tag {
  font-size: 0.6rem; font-weight: 400; letter-spacing: 0.1em; text-transform: uppercase;
  border: 1px solid rgba(196,180,154,.18); padding: .25rem .65rem;
  color: rgba(240,236,228,.38);
}
.globa-tag--active { color: var(--ivory-text); border-color: rgba(196,180,154,.42); }
.globa-block__body {}
.globa-block__body p {
  font-size: .95rem; font-weight: 300; color: rgba(240,236,228,.58);
  line-height: 1.78; max-width: none; margin-bottom: .75rem;
}
.globa-block__body p:last-child { margin-bottom: 0; }

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta-sec {
  background: var(--charcoal); text-align: center;
  padding-block: clamp(5rem, 10vw, 9rem);
  position: relative; overflow: hidden;
}
.cta-sec::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 62% 58% at 50% 50%, rgba(139,105,50,.12) 0%, transparent 62%),
    radial-gradient(ellipse 40% 44% at 82% 68%, rgba(90,84,72,.07) 0%, transparent 55%);
  filter: blur(72px);
  pointer-events: none;
  animation: drift-a 28s ease-in-out infinite alternate;
}
.cta-sec::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 52% 52% at 18% 28%, rgba(196,180,154,.06) 0%, transparent 58%);
  filter: blur(80px);
  pointer-events: none;
  animation: drift-c 36s ease-in-out infinite alternate;
}
.cta-sec__inner { position: relative; z-index: 1; }
.cta-sec__kicker { margin-bottom: 1rem; display: block; }
.cta-sec__title {
  font-family: var(--font-serif); font-size: clamp(1.9rem, 4vw, 2.75rem);
  font-weight: 300; color: var(--ivory-text);
  line-height: 1.1;
  max-width: 640px; margin-inline: auto; margin-bottom: .875rem;
}
.cta-sec__sub {
  font-size: .9rem; font-weight: 300; color: rgba(240,236,228,.5);
  max-width: 440px; margin-inline: auto; line-height: 1.72; margin-bottom: 2rem;
}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.phero {
  background: var(--charcoal);
  padding-top: calc(var(--nav-h) + clamp(3rem, 7vw, 7rem));
  padding-bottom: clamp(3rem, 6vw, 6rem);
  position: relative; overflow: hidden;
}
.phero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 68% 52% at 72% 42%, rgba(139,105,50,.11) 0%, transparent 62%),
    radial-gradient(ellipse 44% 58% at 18% 72%, rgba(90,84,72,.08) 0%, transparent 55%);
  filter: blur(72px);
  pointer-events: none;
  animation: drift-b 30s ease-in-out infinite alternate;
}
.phero::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 50% 48% at 88% 78%, rgba(196,180,154,.06) 0%, transparent 58%);
  filter: blur(80px);
  pointer-events: none;
  animation: drift-c 38s ease-in-out infinite alternate;
}
.phero__inner { position: relative; z-index: 1; }
.phero__kicker { margin-bottom: 1rem; display: block; }
.phero__title  { color: var(--ivory-text); max-width: 720px; margin-bottom: .75rem; }
.phero__sub    {
  font-size: 1.05rem; font-weight: 300; color: rgba(240,236,228,.55);
  max-width: 580px; line-height: 1.72;
}

/* ============================================================
   FOCUS AREAS PAGE — Expanded detail layout
   ============================================================ */
.focus-row {
  display: grid; grid-template-columns: 280px 1fr;
  gap: clamp(2rem, 6vw, 5rem); align-items: start;
  padding-block: clamp(2.5rem, 5vw, 5rem);
  border-bottom: 1px solid var(--border-light);
}
.focus-row:first-child { border-top: 1px solid var(--border-light); }
.focus-row__anchor { position: sticky; top: calc(var(--nav-h) + 1.5rem); }
.focus-row__num  {
  font-family: var(--font-serif); font-size: 4rem; font-weight: 300;
  color: var(--border-mid); line-height: 1; margin-bottom: .5rem;
}
.focus-row__title {
  font-family: var(--font-serif); font-size: 1.5rem; font-weight: 400;
  color: var(--text-dark); margin-bottom: .35rem;
}
.focus-row__tag {
  font-size: 0.6rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent-light);
}
.focus-row__body p {
  font-size: 1rem; font-weight: 300; color: var(--text-mid);
  line-height: 1.8; margin-bottom: 1.1rem; max-width: 580px;
}
.focus-row__body p:last-of-type { margin-bottom: 0; }
.focus-row__chips {
  display: flex; flex-wrap: wrap; gap: .4rem; margin-top: 1.5rem;
}
.chip {
  font-size: 0.6rem; font-weight: 400; letter-spacing: 0.06em;
  color: var(--text-dark); background: var(--sand);
  padding: 2px 8px;
}
.chip-label {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-light); margin-bottom: .5rem;
}

/* ============================================================
   HOW WE BUILD PAGE — Full step detail
   ============================================================ */
.build-detail {
  display: grid; grid-template-columns: 260px 1fr;
  gap: clamp(2rem, 6vw, 5rem); align-items: start;
  padding-block: clamp(2.5rem, 5vw, 5rem);
  border-bottom: 1px solid var(--border-light);
}
.build-detail:first-child { border-top: 1px solid var(--border-light); }
.build-detail__anchor { position: sticky; top: calc(var(--nav-h) + 1.5rem); }
.build-detail__step {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent-light); margin-bottom: .5rem;
}
.build-detail__name {
  font-family: var(--font-serif); font-size: clamp(1.8rem, 3.8vw, 2.65rem);
  font-weight: 300; color: var(--text-dark); line-height: 1.05;
}
.build-detail__body p {
  font-size: 1.05rem; font-weight: 300; color: var(--text-mid);
  line-height: 1.78; max-width: 580px; margin-bottom: 1.1rem;
}
.build-detail__body p:last-of-type { margin-bottom: 0; }

/* ============================================================
   VENTURES PAGE — detail expansions
   ============================================================ */
.venture-detail-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem;
  padding-top: 1.5rem; margin-top: 1.5rem;
  border-top: 1px solid rgba(196,180,154,.1);
}
.detail-col__label {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(196,180,154,.4); margin-bottom: .75rem;
}
.detail-col__text {
  font-size: .82rem; font-weight: 300; color: rgba(240,236,228,.55);
  line-height: 1.7; max-width: none;
}
.layer-dot {
  display: flex; align-items: center; gap: .5rem;
  font-size: .78rem; font-weight: 300; color: rgba(240,236,228,.55);
  margin-bottom: .4rem;
}
.layer-dot::before {
  content: ''; display: block; width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent-light); flex-shrink: 0;
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-split {
  display: grid; grid-template-columns: 1fr 1.6fr;
  gap: clamp(2rem, 7vw, 6rem); align-items: start;
}
.founder-pair {
  display: flex;
  gap: 25px;
}
.founder-card {
  max-width: 370px;
  background: var(--ivory-warm);
  overflow: hidden;
}
.founder-card__photo {
  max-height: 370px;
  max-width: 370px;
  overflow: hidden;
}
.founder-card__photo img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 15%;
  display: block;
}
.founder-card__body {
  padding: clamp(1.75rem, 3vw, 2.75rem);
}
.founder-card__name {
  font-family: var(--font-serif); font-size: 1.75rem; font-weight: 400;
  color: var(--text-dark); margin-bottom: .2rem;
}
.founder-card__role {
  font-size: 0.62rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent-light); margin-bottom: 1.1rem;
}
.founder-card__bio {
  font-size: .85rem; font-weight: 300; color: var(--text-mid); line-height: 1.75; max-width: none;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-layout {
  display: grid; grid-template-columns: 1.5fr 1fr;
  gap: clamp(2rem, 7vw, 6rem); align-items: start;
}
.form-group { margin-bottom: 1.25rem; }
.form-label {
  display: block; font-size: 0.62rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-mid); margin-bottom: .4rem;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.form-input, .form-select, .form-textarea {
  width: 100%; padding: .65rem .875rem;
  background: white; border: 1px solid var(--border-mid);
  font-family: var(--font-sans); font-size: .9rem; font-weight: 300;
  color: var(--text-dark); border-radius: 0; appearance: none;
  transition: border-color var(--t-fast);
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline: none; border-color: var(--accent);
}
.form-input::placeholder, .form-textarea::placeholder { color: var(--text-light); }
.form-textarea { min-height: 130px; resize: vertical; }
.form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M.5.5l5 5 5-5' stroke='%237A7268' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem;
}
.form-note {
  font-size: .72rem; font-weight: 300; color: var(--text-light);
  line-height: 1.6; margin-top: 1rem; max-width: none;
}
.form-disclaimer {
  font-size: .72rem; font-weight: 300; color: var(--text-light);
  line-height: 1.6; margin-top: 1.25rem; padding-top: 1.25rem;
  border-top: 1px solid var(--border-light); font-style: italic; max-width: none;
}
.contact-sidebar {}
.contact-sidebar__block { margin-bottom: 2rem; }
.contact-sidebar__head {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-light); margin-bottom: .875rem;
}
.contact-sidebar__list { display: flex; flex-direction: column; gap: .5rem; }
.contact-sidebar__item {
  font-size: .82rem; font-weight: 300; color: var(--text-mid);
  padding-left: .875rem; border-left: 1px solid var(--border-light);
  line-height: 1.4;
}
.contact-sidebar__loc {
  background: var(--charcoal); padding: 1.25rem 1.5rem;
  border: 1px solid var(--border-dark);
}
.contact-sidebar__loc-label {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--stone-mid); margin-bottom: .5rem;
}
.contact-sidebar__loc-text {
  font-size: .78rem; font-weight: 300; color: rgba(240,236,228,.5);
  line-height: 1.7; max-width: none;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--charcoal); padding-top: clamp(3.5rem, 7vw, 6rem); padding-bottom: 2.5rem; }
.footer__top {
  display: grid; grid-template-columns: 2fr 1fr 1fr;
  gap: clamp(2rem, 6vw, 5rem);
  padding-bottom: 3rem; margin-bottom: 2rem;
  border-bottom: 1px solid rgba(196,180,154,.1);
}
.footer__logo { display: inline-flex; align-items: center; margin-bottom: 1rem; }
.footer__logo-img { width: 9.5rem; height: auto; }
.footer__desc  { font-size: .78rem; font-weight: 300; color: rgba(240,236,228,.42); line-height: 1.7; max-width: 320px; }
.footer__social { display: flex; gap: 1.25rem; margin-top: 1.25rem; }
.footer__social-link {
  font-size: 0.6rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(240,236,228,.38);
  border-bottom: 1px solid rgba(196,180,154,.18); padding-bottom: 1px;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.footer__social-link:hover { color: var(--ivory-text); border-color: rgba(196,180,154,.45); }
.footer__col-head {
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--stone-mid); margin-bottom: 1.1rem;
}
.footer__links { display: flex; flex-direction: column; gap: .55rem; }
.footer__link  {
  font-size: .78rem; font-weight: 300; color: rgba(240,236,228,.42);
  transition: color var(--t-fast);
}
.footer__link:hover { color: var(--ivory-text); }
.footer__bottom {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1.5rem;
}
.footer__copy  { font-size: .72rem; font-weight: 300; color: rgba(240,236,228,.28); line-height: 1.65; }
.footer__legal { display: flex; gap: 1.5rem; }
.footer__legal-link { font-size: .72rem; color: rgba(240,236,228,.28); transition: color var(--t-fast); }
.footer__legal-link:hover { color: rgba(240,236,228,.55); }
.footer__inv-note {
  font-size: .68rem; font-weight: 300; color: rgba(240,236,228,.2);
  border-top: 1px solid rgba(196,180,154,.07); padding-top: 1.25rem;
  line-height: 1.65; font-style: italic; max-width: none;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .hero__grid   { grid-template-columns: 1fr; }
  .hero__index  { display: none; }
  .focus-matrix { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .build-grid   { grid-template-columns: repeat(2, 1fr); }
  .focus-row, .build-detail { grid-template-columns: 1fr; }
  .focus-row__anchor, .build-detail__anchor { position: static; }
  .globa-block  { grid-template-columns: 1fr; gap: 2rem; }
  .footer__top  { grid-template-columns: 1fr 1fr; }
  .about-split  { grid-template-columns: 1fr; }
  .contact-layout { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .nav__links, .nav__contact { display: none; }
  .nav__burger  { display: flex; }
  .ventures-pair { grid-template-columns: 1fr; }
  .venture-lead__body { grid-template-columns: 1fr; }
  .focus-matrix { grid-template-columns: 1fr; gap: 16px; }
  .build-grid   { grid-template-columns: 1fr; }
  .footer__top  { grid-template-columns: 1fr; }
  .footer__bottom { flex-direction: column; gap: .75rem; }
  .emerging-band__grid { grid-template-columns: 1fr; }
  .emerging-item:first-child { border-right: none; border-bottom: 1px solid var(--border-light); }
  .founder-pair { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .venture-detail-row { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .venture-lead__name { font-size: 2.75rem; }
}
