/* ============================================================
   S72 DEVELOPMENTS — styles.css
   Brand: black / white / warm grey · Montserrat · Living Redefined
   No accent colour (green reserved for Scout). Editorial / architectural.
   ============================================================ */

:root {
  /* warm monochrome palette */
  --black:   #000000;
  --ink:     #0c0b0a;   /* warm near-black for dark sections */
  --paper:   #ffffff;
  --bone:    #f6f4f0;   /* warm off-white alt background */
  --line:    #e3ded7;   /* warm hairline */
  --line-d:  rgba(255,255,255,.16); /* hairline on dark */
  --grey:    #6f6a63;   /* warm secondary text */
  --grey-lt: #9b958c;   /* warm tertiary */
  --grey-d:  #a9a39a;   /* secondary text on dark */

  --maxw: 1240px;
  --gutter: clamp(1.25rem, 5vw, 4rem);
  --pad-y: clamp(4.5rem, 10vw, 9rem);

  --ease: cubic-bezier(.22,.61,.36,1);

  --eyebrow-spacing: .26em;
}

/* ---------- reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body {
  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-weight: 300;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display:block; max-width:100%; height:auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

/* ---------- type ---------- */
h1,h2,h3,h4 { font-weight: 600; letter-spacing: -.02em; line-height: 1.08; }

.eyebrow {
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: var(--eyebrow-spacing);
  text-transform: uppercase;
  color: var(--grey);
}
.eyebrow.on-dark { color: rgba(255,255,255,.78); }
.model__body .eyebrow.on-dark { text-shadow: 0 1px 14px rgba(0,0,0,.55); }

.lead { font-size: clamp(1.1rem, 2.2vw, 1.45rem); font-weight: 300; line-height: 1.5; }

/* ---------- layout helpers ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: var(--pad-y); }
.section--bone { background: var(--bone); }
.section--dark { background: var(--ink); color: var(--paper); }
.section--dark .lead { color: #e7e3dd; }

.section-head { max-width: 760px; }
.section-head h2 { font-size: clamp(1.9rem, 4.6vw, 3.1rem); margin-top: 1.1rem; }
.section-head .lead { margin-top: 1.5rem; color: var(--grey); }
.section--dark .section-head .lead { color: var(--grey-d); }

.rule { height:1px; background: var(--line); border:0; }
.section--dark .rule { background: var(--line-d); }

/* reveal on scroll */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 50;
  display:flex; align-items:center; justify-content:space-between;
  padding: clamp(1rem,2.4vw,1.6rem) var(--gutter);
  transition: background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
}
.nav.solid { background: var(--paper); box-shadow: 0 1px 0 var(--line); padding-block: clamp(.8rem,1.8vw,1.1rem); }
.nav__logo img { height: 30px; width:auto; }
.nav__logo .logo-black { display:none; }
.nav.solid .nav__logo .logo-white { display:none; }
.nav.solid .nav__logo .logo-black { display:block; }

.nav__links { display:flex; align-items:center; gap: clamp(1.2rem,2.4vw,2.4rem); }
.nav__links a {
  font-size: .8rem; font-weight: 500; letter-spacing: .04em;
  color: #fff; transition: opacity .25s;
}
.nav.solid .nav__links a { color: var(--ink); }
.nav__links a.navlink:hover { opacity:.6; }
.nav__cta {
  font-size: .76rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  border: 1px solid rgba(255,255,255,.5); color:#fff;
  padding: .7rem 1.15rem; border-radius: 0; transition: all .3s var(--ease);
}
.nav.solid .nav__cta { border-color: var(--ink); color: var(--ink); }
.nav__cta:hover { background:#fff; color:#000; border-color:#fff; }
.nav.solid .nav__cta:hover { background: var(--ink); color:#fff; }

.nav__toggle { display:none; flex-direction:column; gap:5px; background:none; border:0; padding:.4rem; }
.nav__toggle span { width:24px; height:2px; background:#fff; transition: background .3s; }
.nav.solid .nav__toggle span { background: var(--ink); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position:relative; min-height: 100svh; display:flex; align-items:flex-end; color:#fff; }
.hero__bg { position:absolute; inset:0; overflow:hidden; }
.hero__bg img { width:100%; height:100%; object-fit:cover; transform: scale(1.06); animation: heroZoom 18s ease-out forwards; }
@keyframes heroZoom { to { transform: scale(1); } }
@media (prefers-reduced-motion: reduce){ .hero__bg img{ animation:none; transform:none; } }
.hero__bg::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.15) 32%, rgba(0,0,0,.55) 78%, rgba(0,0,0,.82) 100%);
}
.hero__inner { position:relative; width:100%; max-width:var(--maxw); margin-inline:auto; padding: 0 var(--gutter) clamp(2.5rem,6vw,4.5rem); }
.hero__eyebrow { color: rgba(255,255,255,.85); letter-spacing: .4em; }
.hero h1 {
  font-size: clamp(2.3rem, 5.4vw, 4.25rem);
  max-width: 15ch; margin-top: 1.3rem;
}
.hero__sub { margin-top: 1.6rem; max-width: 50ch; color: rgba(255,255,255,.9); font-weight:300; }
.hero__actions { display:flex; flex-wrap:wrap; gap: .9rem; margin-top: 2.2rem; }

.btn {
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  padding: 1rem 1.6rem; border-radius:0; border:1px solid transparent;
  transition: all .3s var(--ease);
}
.btn--solid { background:#fff; color:#000; }
.btn--solid:hover { background:transparent; color:#fff; border-color:#fff; }
.btn--ghost { background:transparent; color:#fff; border-color: rgba(255,255,255,.55); }
.btn--ghost:hover { background:#fff; color:#000; border-color:#fff; }
.btn--ink { background: var(--ink); color:#fff; }
.btn--ink:hover { background:transparent; color:var(--ink); border-color:var(--ink); }
.btn--outline-ink { border-color: var(--ink); color: var(--ink); }
.btn--outline-ink:hover { background: var(--ink); color:#fff; }

/* hero stats */
.hero__stats {
  display:grid; grid-template-columns: repeat(4,1fr);
  border-top:1px solid rgba(255,255,255,.22);
  margin-top: clamp(2.4rem,5vw,3.6rem);
}
.stat { padding: 1.4rem 1.2rem 0 0; }
.hero__stats .stat + .stat { border-left:1px solid rgba(255,255,255,.22); padding-left:1.2rem; }
.stat__num { font-size: clamp(1.7rem,3.4vw,2.6rem); font-weight:300; letter-spacing:-.02em; line-height:1; }
.stat__label { display:block; margin-top:.6rem; font-size:.66rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color: rgba(255,255,255,.7); }

/* ============================================================
   APPROACH / pillars
   ============================================================ */
.pillars { display:grid; grid-template-columns: repeat(4,1fr); gap: clamp(1.4rem,2.6vw,2.2rem); margin-top: clamp(3rem,6vw,4.5rem); }
.pillar { border-top:1px solid var(--line); padding-top:1.5rem; }
.pillar h3 { font-size:1.15rem; margin-bottom:.9rem; }
.pillar p { color: var(--grey); font-size:.95rem; }
.pillar__idx { font-size:.7rem; font-weight:600; letter-spacing:.12em; color: var(--grey-lt); }

/* ============================================================
   ENGAGEMENT MODELS (diptych)
   ============================================================ */
.models { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(1.25rem,2.5vw,2rem); margin-top: clamp(3rem,6vw,4.5rem); }
.model {
  position:relative; display:flex; flex-direction:column; justify-content:flex-end;
  min-height: 460px; color:#fff; padding: clamp(1.6rem,3vw,2.5rem); overflow:hidden;
}
.model__bg { position:absolute; inset:0; z-index:0; }
.model__bg img { width:100%; height:100%; object-fit:cover; transition: transform 1.2s var(--ease); }
.model:hover .model__bg img { transform: scale(1.05); }
.model__bg::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.55) 50%, rgba(0,0,0,.9) 100%); }
.model__body { position:relative; z-index:1; }
.model h3 { font-size: clamp(1.5rem,2.6vw,2.05rem); margin: .9rem 0 1rem; }
.model p { color: rgba(255,255,255,.88); font-weight:300; font-size:.98rem; max-width: 42ch; }
.model__link { display:inline-flex; align-items:center; gap:.55rem; margin-top:1.5rem; font-size:.76rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; }
.model__link span.arrow { transition: transform .3s var(--ease); }
.model:hover .model__link span.arrow { transform: translateX(5px); }

/* ============================================================
   PORTFOLIO
   ============================================================ */
.portfolio-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: clamp(1.1rem,2.2vw,1.8rem); margin-top: clamp(3rem,6vw,4.5rem); }
.project { display:block; }
.project__media { position:relative; aspect-ratio: 4/3; overflow:hidden; background: var(--mist,#eee); }
.project__media img { width:100%; height:100%; object-fit:cover; transition: transform 1.2s var(--ease); }
.project:hover .project__media img { transform: scale(1.045); }
.project__status {
  position:absolute; top:1rem; left:1rem; z-index:2;
  font-size:.62rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  padding:.45rem .7rem;
}
.project__status--open { background: rgba(255,255,255,.92); color:#000; }
.project__status--active { background: rgba(12,11,10,.82); color:#fff; backdrop-filter: blur(2px); }
.project__status--complete { background: rgba(255,255,255,.14); color:#fff; border:1px solid rgba(255,255,255,.6); backdrop-filter: blur(2px); }
.project__meta { display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-top:1.1rem; padding-bottom:1.1rem; border-bottom:1px solid var(--line); }
.project__name { font-size:1.25rem; font-weight:600; letter-spacing:-.01em; }
.project__loc { font-size:.7rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--grey); white-space:nowrap; }
.project__config { margin-top:.7rem; font-size:.85rem; color:var(--grey); }
.project__type { margin-top:.7rem; font-size:.66rem; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--grey-lt); }

/* wide 'now open' feature card */
.project--wide { grid-column: 1 / -1; display:grid; grid-template-columns: 1.35fr 1fr; gap: clamp(1.4rem,3vw,3rem); align-items:center; margin-top: clamp(.4rem,1vw,1rem); }
.project--wide .project__media { aspect-ratio: 16/10; }
.project--wide .project__meta { border-bottom:0; padding-bottom:0; margin-top:0; }
.project--wide .project__config { margin-top:1.1rem; max-width:46ch; }
.project__widelink { display:inline-flex; align-items:center; gap:.55rem; margin-top:1.5rem; color:var(--ink); font-size:.76rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; }
.project--wide:hover .project__widelink .arrow { transform: translateX(5px); }
.portfolio-note { margin-top: clamp(2rem,4vw,3rem); font-size:.72rem; line-height:1.6; color:var(--grey-lt); max-width:74ch; }
@media (max-width: 900px){ .project--wide { grid-template-columns:1fr; } }

/* ============================================================
   INTERIORS GALLERY (full-bleed horizontal scroll)
   ============================================================ */
.gallery-section { overflow: hidden; }
.gallery {
  display: flex; gap: clamp(.9rem,1.6vw,1.4rem);
  margin-top: clamp(2.5rem,5vw,3.5rem);
  padding-inline: var(--gutter);
  overflow-x: auto; scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.gallery::-webkit-scrollbar { display: none; }
.gallery__item {
  flex: 0 0 auto; margin: 0;
  width: clamp(280px, 46vw, 620px);
  height: clamp(320px, 52vh, 560px);
  overflow: hidden; scroll-snap-align: start; background: var(--mist,#e9e6e0);
}
.gallery__item--tall { width: clamp(240px, 32vw, 420px); }
.gallery__item img { width:100%; height:100%; object-fit: cover; transition: transform 1.4s var(--ease); }
.gallery__item:hover img { transform: scale(1.04); }

/* ============================================================
   END GALLERY
   ============================================================ */

.opps { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(1.25rem,2.5vw,2rem); margin-top: clamp(3rem,6vw,4.5rem); }
.opp { display:flex; flex-direction:column; background:#111010; border:1px solid var(--line-d); }
.opp__media { position:relative; aspect-ratio: 16/10; overflow:hidden; }
.opp__media img { width:100%; height:100%; object-fit:cover; }
.opp__tag { position:absolute; top:1rem; left:1rem; font-size:.62rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; background:#fff; color:#000; padding:.45rem .7rem; }
.opp__body { padding: clamp(1.5rem,2.6vw,2.2rem); display:flex; flex-direction:column; flex:1; }
.opp__eyebrow { font-size:.66rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--grey-d); }
.opp h3 { font-size: clamp(1.5rem,2.6vw,2rem); margin:.7rem 0 1rem; }
.opp p { color:#cfcac3; font-weight:300; font-size:.95rem; }
.opp__note { margin-top:1.3rem; padding-top:1.1rem; border-top:1px solid var(--line-d); font-size:.78rem; letter-spacing:.04em; color:#e9e4dd; }
.opp .btn { margin-top:1.6rem; align-self:flex-start; }
.opps__disclaimer { margin-top:2.5rem; font-size:.72rem; line-height:1.6; color: var(--grey-d); max-width:70ch; }

/* ============================================================
   PROCESS 01–05
   ============================================================ */
.steps { margin-top: clamp(3rem,6vw,4.5rem); }
.step { display:grid; grid-template-columns: 5.5rem 1fr; gap: clamp(1rem,3vw,3rem); padding: clamp(1.6rem,3vw,2.2rem) 0; border-top:1px solid var(--line); align-items:start; }
.step__num { font-size: clamp(1.6rem,3vw,2.4rem); font-weight:300; color:var(--grey-lt); letter-spacing:-.02em; }
.step__title { font-size: clamp(1.2rem,2.2vw,1.6rem); font-weight:600; }
.step__body { margin-top:.8rem; color:var(--grey); max-width:60ch; font-size:.97rem; }
.step--feature { background:var(--ink); color:#fff; margin-top:1.5rem; padding: clamp(1.8rem,4vw,3rem) clamp(1.5rem,4vw,3rem); border:0; grid-template-columns: 5.5rem 1fr; }
.step--feature .step__num { color:#fff; }
.step--feature .step__body { color:#d8d3cc; }
.waterfall { list-style:none; padding:0; margin:1.6rem 0 0; display:grid; gap:.65rem; max-width:48ch; }
.waterfall li { display:flex; gap:.9rem; align-items:baseline; font-size:.92rem; color:#e7e3dd; }
.waterfall li b { font-weight:600; color:#fff; }
.waterfall .wf-idx { font-size:.7rem; font-weight:600; letter-spacing:.1em; color:var(--grey-d); min-width:1.4rem; }

/* ============================================================
   TEAM
   ============================================================ */
.team-lead { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem,3vw,3rem); margin-top: clamp(2.5rem,5vw,4rem); }
.leaders { display:grid; gap:1.4rem; }
.leader { border-top:1px solid var(--line); padding-top:1.1rem; }
.section--bone .leader { border-color: #e0dbd2; }
.leader__name { font-size:1.1rem; font-weight:600; }
.leader__role { font-size:.72rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--grey); margin-top:.35rem; }
.bench { align-self:end; }
.bench__label { font-size:.66rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--grey-lt); margin-bottom:1.1rem; }
.bench ul { list-style:none; padding:0; display:grid; gap:.55rem; }
.bench li { font-size:.95rem; color:var(--ink); border-bottom:1px solid var(--line); padding-bottom:.55rem; }

/* ============================================================
   TEAM
   ============================================================ */
.founders { display:grid; grid-template-columns: repeat(3,1fr); gap: clamp(1.5rem,3vw,2.5rem); margin-top: clamp(2.5rem,5vw,4rem); }
.founder { border-top:1px solid var(--line); padding-top:1.3rem; }
.founder__name { font-size:1.15rem; font-weight:600; }
.founder__role { font-size:.7rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--grey); margin:.4rem 0 1rem; }
.founder__bio { font-size:.92rem; color:var(--grey); max-width:36ch; }

.team-sub { margin-top: clamp(3.5rem,7vw,5.5rem); }
.team-sub__h { font-size: clamp(1.3rem,2.4vw,1.85rem); margin-top:.9rem; }

.advisors { display:grid; grid-template-columns: repeat(4,1fr); gap: clamp(1.3rem,2.6vw,2.2rem); margin-top: clamp(2rem,4vw,3rem); }
.advisor { border-top:1px solid var(--line); padding-top:1.1rem; }
.advisor__name { font-size:1rem; font-weight:600; }
.advisor__role { font-size:.66rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--grey); margin:.35rem 0 .8rem; }
.advisor__bio { font-size:.88rem; color:var(--grey); }
.advisor__photo { width: clamp(96px,9vw,128px); aspect-ratio: 1 / 1; border-radius: 50%; overflow: hidden; margin: 0 0 1.1rem; background: var(--bone); }
.advisor__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center; filter: grayscale(100%); transition: transform .6s var(--ease); }
.advisor:hover .advisor__photo img { transform: scale(1.04); }

.builders { margin-top: clamp(3rem,6vw,4.5rem); border-top:2px solid var(--ink); padding-top:1.6rem; max-width:64ch; }
.builders__body { margin-top:1rem; color:var(--grey); font-size:.95rem; }

@media (max-width:900px){ .founders, .advisors { grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .founders, .advisors { grid-template-columns:1fr; } }

/* ============================================================
   MARKETS (dark, typographic)
   ============================================================ */
.markets { margin-top: clamp(3rem,6vw,4.5rem); border-top:1px solid var(--line-d); }
.market {
  display:flex; align-items:baseline; gap:1.5rem; justify-content:space-between;
  padding: clamp(1.1rem,2.4vw,1.7rem) 0; border-bottom:1px solid var(--line-d);
}
.market__name { font-size: clamp(1.6rem,4.4vw,2.9rem); font-weight:600; letter-spacing:-.02em; }
.market__tag { font-size:.66rem; font-weight:500; letter-spacing:.16em; text-transform:uppercase; color:var(--grey-d); text-align:right; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact { display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(2rem,5vw,5rem); margin-top: clamp(3rem,6vw,4.5rem); align-items:start; }
.form { display:grid; gap:1.3rem; }
.form__row { display:grid; grid-template-columns:1fr 1fr; gap:1.3rem; }
.field { display:flex; flex-direction:column; gap:.5rem; }
.field label { font-size:.68rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--grey); }
.field input, .field select, .field textarea {
  font-family:inherit; font-size:.95rem; font-weight:300; color:var(--ink);
  background:transparent; border:0; border-bottom:1px solid var(--line);
  padding:.65rem 0; transition: border-color .3s;
}
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--ink); }
.field textarea { resize:vertical; min-height:90px; }
.contact__details { border-top:2px solid var(--ink); padding-top:1.6rem; }
.contact__details .who { font-size:1.05rem; font-weight:600; }
.contact__details .role { font-size:.72rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--grey); margin:.3rem 0 1.6rem; }
.contact__line { display:block; font-size:.95rem; padding:.55rem 0; border-bottom:1px solid var(--line); color:var(--ink); }
.contact__line:hover { color:var(--grey); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--black); color:#fff; padding-block: clamp(3.5rem,7vw,5.5rem) 2rem; }
.footer__top { display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(2rem,4vw,3.5rem); }
.footer__brand img { height:34px; }
.footer__tagline { font-size:.66rem; font-weight:500; letter-spacing:.3em; text-transform:uppercase; color:var(--grey-d); margin-top:1.1rem; }
.footer__brand p { color:#bdb8b0; font-weight:300; font-size:.9rem; margin-top:1.3rem; max-width:34ch; }
.footer__col h4 { font-size:.66rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--grey-d); margin-bottom:1.2rem; }
.footer__col ul { list-style:none; padding:0; display:grid; gap:.7rem; }
.footer__col a { font-size:.9rem; color:#d7d2ca; font-weight:300; }
.footer__col a:hover { color:#fff; }
.footer__disclaimer { margin-top: clamp(2.5rem,5vw,3.5rem); padding-top:1.8rem; border-top:1px solid var(--line-d); font-size:.7rem; line-height:1.7; color:#8d877f; max-width:90ch; }
.footer__bottom { margin-top:2rem; display:flex; flex-wrap:wrap; gap:.6rem 1.5rem; justify-content:space-between; font-size:.72rem; color:#8d877f; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px){
  .nav__links { display:none; }
  .nav__toggle { display:flex; }
  .nav__links.open {
    display:flex; flex-direction:column; align-items:flex-start; gap:1.4rem;
    position:absolute; top:100%; left:0; right:0; background:var(--paper);
    padding: 1.6rem var(--gutter) 2rem; box-shadow:0 12px 24px rgba(0,0,0,.08);
  }
  .nav__links.open a { color:var(--ink); }
  .models, .opps, .team-lead, .contact, .footer__top { grid-template-columns: 1fr; }
  .pillars { grid-template-columns: 1fr 1fr; }
  .portfolio-grid { grid-template-columns: 1fr 1fr; }
  .hero__stats { grid-template-columns: 1fr 1fr; }
  .hero__stats .stat:nth-child(3) { border-left:0; padding-left:0; }
  .hero__stats .stat { border-top:1px solid rgba(255,255,255,.22); padding-top:1.2rem; }
  .form__row { grid-template-columns:1fr; }
  .footer__bottom { justify-content:flex-start; }
}
@media (max-width: 560px){
  .hero__stats { grid-template-columns:1fr 1fr; }
  .pillars { grid-template-columns: 1fr; }
  .portfolio-grid { grid-template-columns: 1fr; }
  .step { grid-template-columns: 3rem 1fr; gap:1rem; }
  .market__name { font-size: 2rem; }
}

/* focus visibility (quality floor) */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid currentColor; outline-offset: 3px;
}

/* ============================================================
   STAGING BUILD TAG (Scout convention) — remove at go-live
   ============================================================ */
.buildtag {
  position: fixed; bottom: 9px; right: 12px; z-index: 300;
  font-size: .58rem; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(120,116,110,.55); font-weight: 500; pointer-events: none;
  mix-blend-mode: difference;
}

/* Scout (internal app) links — utility styling, kept distinct from marketing nav */
.navlink--scout { opacity:.62; font-size:.82rem; }
.navlink--scout:hover { opacity:1; }
.footer__scout { color:#8d877f; transition: color .25s var(--ease); }
.footer__scout:hover { color:#fff; }
.footer__legal a { color:#8d877f; transition: color .25s var(--ease); }
.footer__legal a:hover { color:#fff; }

/* Profit waterfall as plain dot points (no numerals) */
.waterfall--dots { list-style: none; padding: 0; margin: 1rem 0 0; }
.waterfall--dots li { position: relative; padding-left: 1.4em; margin-bottom: .5rem; }
.waterfall--dots li::before { content: ""; position: absolute; left: .2em; top: .62em; width: 5px; height: 5px; border-radius: 50%; background: currentColor; opacity: .55; }
.waterfall--dots .wf-idx { display: none; }

/* Scenario labels in step 05 (client-funded vs development partner) */
.waterfall__label { margin-top: 1.8rem; font-size: .66rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--grey-d); }
.waterfall__label + .step__body { margin-top: .5rem; }

/* Founder headshots */
.founder__photo { width: 100%; aspect-ratio: 4 / 5; overflow: hidden; margin-bottom: 1.4rem; background: var(--bone); border-top: 1px solid var(--line); }
.founder__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; filter: grayscale(100%); transition: transform .6s var(--ease); }
.founder:hover .founder__photo img { transform: scale(1.03); }
.founders--photo .founder { border-top: none; padding-top: 0; }
.founders--photo .founder__name { margin-top: 0; }
