/* ==========================================================================
   MJF General Contractors — site design system
   Industrial concrete / safety-red. Archivo Expanded display + Archivo body.
   Single source of truth for every page.
   ========================================================================== */

:root{
  /* surfaces */
  --bg:#101114;            /* base concrete charcoal */
  --bg-2:#16181d;          /* elevated panel */
  --bg-3:#1d2128;          /* card / inset */
  --bg-4:#0b0c0e;          /* deepest (footer, stage night) */
  --concrete:#e9e7e2;      /* light section */
  --concrete-2:#dedbd4;    /* light alt */

  /* ink (text on light) */
  --ink:#14161a;
  --ink-soft:#4b515a;
  --ink-faint:#727983;

  /* text on dark */
  --text:#f5f6f7;
  --muted:#c7ccd3;         /* body on dark — AA */
  --muted-2:#969da7;       /* secondary on dark */

  /* brand */
  --red:#d8362a;
  --red-deep:#ad271d;
  --red-bright:#ef4533;

  /* lines */
  --line:rgba(255,255,255,.12);
  --line-strong:rgba(255,255,255,.22);
  --line-dark:rgba(20,22,26,.14);
  --line-dark-strong:rgba(20,22,26,.26);

  /* metrics */
  --maxw:1280px;
  --pad:clamp(1.25rem,5vw,5rem);
  --radius:3px;
  --z-header:100;--z-menu:200;--z-stage:1;

  /* type */
  --display:"Archivo Expanded","Archivo","Arial Narrow",system-ui,sans-serif;
  --sans:"Archivo",system-ui,-apple-system,"Segoe UI",sans-serif;

  /* easing */
  --e-out:cubic-bezier(.16,1,.3,1);
  --e-io:cubic-bezier(.65,.05,.36,1);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:clamp(1rem,.96rem + .2vw,1.1rem);
  line-height:1.62;font-weight:400;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--display);font-weight:800;line-height:1.0;
  letter-spacing:-.01em;margin:0;text-transform:uppercase}
p{margin:0}
::selection{background:var(--red);color:#fff}
:focus-visible{outline:2px solid var(--red-bright);outline-offset:3px}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.section{padding-block:clamp(4rem,9vw,9rem)}
.section-sm{padding-block:clamp(3rem,6vw,5.5rem)}
.light{background:var(--concrete);color:var(--ink)}

/* ---------- shared motifs ---------- */
.eyebrow{font-family:var(--sans);font-weight:600;font-size:.72rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--red);
  display:inline-flex;align-items:center;gap:.65rem}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--red)}
.light .eyebrow{color:var(--red-deep)}
.light .eyebrow::before{background:var(--red-deep)}

.ruler{height:13px;width:100%;
  background:repeating-linear-gradient(90deg,var(--line) 0 1px,transparent 1px 30px);
  border-block:1px solid var(--line)}
.ruler.on-light{background:repeating-linear-gradient(90deg,var(--line-dark) 0 1px,transparent 1px 30px);
  border-color:var(--line-dark)}

.mk{width:11px;height:11px;background:var(--red);display:inline-block;transform:rotate(45deg)}

/* ---------- buttons ---------- */
.btn{font-family:var(--sans);font-weight:700;font-size:.85rem;letter-spacing:.04em;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:.6rem;
  padding:1rem 1.65rem;border-radius:var(--radius);cursor:pointer;border:1.5px solid transparent;
  transition:background .25s var(--e-out),color .25s var(--e-out),border-color .25s var(--e-out),transform .2s var(--e-out)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-deep)}
.btn-ghost{border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--text);background:rgba(255,255,255,.06)}
.light .btn-ghost{border-color:var(--line-dark-strong);color:var(--ink)}
.light .btn-ghost:hover{border-color:var(--ink);background:rgba(20,22,26,.05)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}
.btn .arw{transition:transform .25s var(--e-out)}
.btn:hover .arw{transform:translateX(4px)}

/* ---------- header ---------- */
header.site{position:sticky;top:0;z-index:var(--z-header);
  background:rgba(16,17,20,.55);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:background .35s var(--e-out),border-color .35s var(--e-out)}
header.site.scrolled{background:rgba(11,12,14,.94);border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;gap:2.2rem;height:78px}
.brand{display:flex;align-items:center;gap:.72rem;margin-right:auto}
.brand .logo-mark{flex:none;display:block}
.brand-txt{display:flex;flex-direction:column;line-height:1}
.brand-txt b{font-family:var(--display);font-weight:900;font-size:1.18rem;
  letter-spacing:.01em;color:var(--red)}
.brand-txt span{font-size:.56rem;letter-spacing:.2em;color:var(--muted-2);
  text-transform:uppercase;margin-top:.28rem;font-weight:600}
.nav-links{display:flex;gap:2rem}
.nav-links a{font-size:.82rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);transition:color .2s;position:relative;padding:.4rem 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--red);transition:width .3s var(--e-out)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--text)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1.2rem}
.nav-phone{font-family:var(--display);font-weight:800;font-size:.95rem;color:var(--text);white-space:nowrap}
.nav-phone:hover{color:var(--red)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-right:-8px}
.burger span{width:25px;height:2px;background:var(--text);transition:.3s var(--e-out)}
.mobile-menu{display:none}

/* ---------- footer ---------- */
footer.site{background:var(--bg-4);color:var(--muted);
  padding:clamp(3.5rem,6vw,5rem) 0 2rem;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:2.6rem}
.foot-brand .foot-lockup{display:flex;align-items:center;gap:.7rem;margin-bottom:1.1rem}
.foot-brand b{font-family:var(--display);font-weight:900;font-size:1.4rem;color:var(--red);
  text-transform:uppercase;line-height:1}
.foot-brand .foot-lockup span{font-size:.58rem;letter-spacing:.2em;color:var(--muted-2);
  text-transform:uppercase;font-weight:600}
.foot-brand>p{max-width:36ch;font-size:.94rem;line-height:1.65;color:var(--muted-2)}
.foot-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1.4rem}
.foot-badges span{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  color:var(--muted);border:1px solid var(--line);padding:.45rem .7rem}
.foot-col h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);
  font-weight:600;margin-bottom:1.1rem;font-family:var(--sans)}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:.95rem;margin-bottom:.65rem;line-height:1.55}
.foot-col a{transition:color .2s}
.foot-col a:hover{color:var(--red)}
.foot-bottom{max-width:var(--maxw);margin:3rem auto 0;padding:1.7rem var(--pad) 0;
  border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.8rem;color:var(--muted-2)}

/* ==========================================================================
   IMMERSIVE BUILD HERO  (index)
   Default = static finished state (no-JS / reduced-motion fallback).
   JS adds .is-live and the tall scroll track to drive the sequence.
   ========================================================================== */
.build{position:relative;height:100vh;background:var(--bg-4)}
.build.is-live{height:560vh}
.stage{position:sticky;top:0;height:100vh;overflow:hidden;z-index:var(--z-stage);
  display:grid;place-items:stretch}
.stage svg{position:absolute;inset:0;width:100%;height:100%;display:block}
/* cinematic scrim — keeps overlay copy readable across day->dusk sky states */
.stage-scrim{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(100deg,rgba(8,9,11,.8) 0%,rgba(8,9,11,.58) 32%,rgba(8,9,11,.26) 54%,transparent 76%),
             linear-gradient(0deg,rgba(8,9,11,.5) 0%,transparent 26%)}

/* overlay copy */
.stage-copy{position:absolute;inset:0;z-index:3;pointer-events:none;
  display:grid;align-content:center;padding-inline:var(--pad);max-width:var(--maxw);
  margin-inline:auto;left:0;right:0}
.stage-eyebrow{font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:#fff;display:inline-flex;align-items:center;gap:.7rem;
  opacity:.9;margin-bottom:1.3rem}
.stage-eyebrow::before{content:"";width:32px;height:2px;background:var(--red)}

/* the rotating phase phrases (live mode) */
.phase-stack{position:relative;min-height:clamp(3.4rem,13vw,11rem);display:block}
.phase{position:absolute;inset:0;opacity:0;transform:translateY(24px);
  transition:opacity .6s var(--e-out),transform .6s var(--e-out)}
.phase.show{opacity:1;transform:none}
.phase h2{font-size:clamp(2.4rem,8vw,7rem);font-weight:900;color:#fff;text-wrap:balance;
  text-shadow:0 2px 40px rgba(0,0,0,.4)}
.phase h2 .hl{color:var(--red-bright)}
.phase p{font-family:var(--sans);text-transform:none;font-weight:400;
  color:var(--muted);font-size:clamp(1rem,1.4vw,1.2rem);margin-top:1.1rem;max-width:46ch;line-height:1.55}

/* static fallback headline (shown when NOT live) */
.build-static{position:absolute;inset:0;z-index:3;display:grid;align-content:center;
  padding-inline:var(--pad);max-width:var(--maxw);margin-inline:auto;left:0;right:0}
.build-static h1{font-size:clamp(2.6rem,7vw,6rem);font-weight:900;color:#fff;text-wrap:balance;max-width:18ch}
.build-static h1 .hl{color:var(--red-bright)}
.build-static p{font-family:var(--sans);text-transform:none;font-weight:400;color:var(--muted);
  font-size:clamp(1.05rem,1.4vw,1.25rem);margin-top:1.5rem;max-width:50ch;line-height:1.6}
.build.is-live .build-static{display:none}

/* end-of-sequence CTA (appears at final phase, live mode) */
.stage-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem;align-items:center;
  pointer-events:auto;opacity:0;transform:translateY(16px);
  transition:opacity .6s var(--e-out) .1s,transform .6s var(--e-out) .1s}
.stage-cta.show{opacity:1;transform:none}
.stage-cta .tel{font-family:var(--display);font-weight:800;font-size:1.05rem;color:#fff;padding-left:.3rem}
.stage-cta .tel small{display:block;font-family:var(--sans);font-weight:500;font-size:.66rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.stage-cta .tel:hover{color:var(--red-bright)}
.build-static .stage-cta{opacity:1;transform:none}

/* live "now forming" tag */
.stage-tag{position:absolute;left:var(--pad);bottom:2.2rem;z-index:3;
  background:var(--red);color:#fff;font-weight:700;font-size:.72rem;letter-spacing:.13em;
  text-transform:uppercase;padding:.6rem 1rem;display:flex;align-items:center;gap:.55rem}
.stage-tag .dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 2s var(--e-out) infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

/* scroll cue + progress rail (live only) */
.scroll-cue{position:absolute;right:var(--pad);bottom:2.2rem;z-index:3;
  align-items:center;gap:.7rem;color:var(--muted);font-size:.68rem;
  letter-spacing:.18em;text-transform:uppercase;font-weight:600;transition:opacity .4s}
.scroll-cue .mouse{width:22px;height:34px;border:2px solid var(--muted);border-radius:12px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;left:50%;top:6px;width:3px;height:7px;border-radius:2px;
  background:var(--muted);transform:translateX(-50%);animation:wheel 1.7s var(--e-io) infinite}
@keyframes wheel{0%{opacity:1;transform:translate(-50%,0)}70%{opacity:0;transform:translate(-50%,12px)}100%{opacity:0}}

.progress-rail{position:absolute;left:0;top:0;bottom:0;width:6px;z-index:3;
  background:repeating-linear-gradient(180deg,var(--line) 0 1px,transparent 1px 26px)}
.progress-rail .fill{position:absolute;left:0;top:0;width:100%;height:0%;
  background:var(--red);box-shadow:0 0 16px rgba(216,54,42,.6)}

/* live-only elements: hidden by default (no-JS / reduced-motion shows static fallback) */
.stage-copy,.scroll-cue,.progress-rail,.stage-tag{display:none}
.build.is-live .stage-copy{display:grid}
.build.is-live .scroll-cue{display:flex}
.build.is-live .progress-rail,.build.is-live .stage-tag{display:block}
.build.is-live .stage-tag{display:flex}

/* ==========================================================================
   STATS
   ========================================================================== */
.stats{border-bottom:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:clamp(2rem,4vw,3.4rem) clamp(1.1rem,2.4vw,2.2rem);border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat .num{font-family:var(--display);font-weight:900;font-size:clamp(3rem,5.5vw,4.6rem);
  line-height:.95;color:var(--text);letter-spacing:-.02em}
.stat .num em{font-style:normal;color:var(--red)}
.stat .lbl{margin-top:.9rem;font-size:.84rem;color:var(--muted-2);line-height:1.45;max-width:24ch}

/* ==========================================================================
   SECTION HEAD
   ========================================================================== */
.sec-head{display:grid;grid-template-columns:1fr auto;gap:1.6rem 2.4rem;align-items:end;
  margin-bottom:clamp(2.4rem,5vw,4rem)}
.sec-head h2{font-size:clamp(2.2rem,5vw,4rem);margin-top:1.1rem;text-wrap:balance;line-height:1.0}
.light .sec-head h2{color:var(--ink)}
.sec-head .standfirst{color:var(--ink-soft);max-width:42rem;font-size:1.08rem;line-height:1.55;
  align-self:end;text-align:left}
.dark-sec .sec-head .standfirst{color:var(--muted)}
.sec-head .link{font-weight:700;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;
  color:var(--red);white-space:nowrap;display:inline-flex;gap:.5rem;align-items:center}
.dark-sec .sec-head .link{color:var(--red-bright)}
.sec-head .link .arw{transition:transform .25s var(--e-out)}
.sec-head .link:hover .arw{transform:translateX(4px)}

/* ==========================================================================
   CAPABILITIES
   ========================================================================== */
.scope{display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line-dark);border-left:1px solid var(--line-dark)}
.scope-item{padding:clamp(1.8rem,3vw,2.8rem) clamp(1.5rem,2.2vw,2.3rem);
  border-right:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);
  transition:background .3s var(--e-out)}
.scope-item:hover{background:rgba(216,54,42,.05)}
.scope-item .mk{margin-bottom:1.3rem}
.scope-item h3{font-size:1.22rem;color:var(--ink);text-transform:uppercase;font-weight:800;line-height:1.1;letter-spacing:0}
.scope-item p{margin-top:.8rem;color:var(--ink-soft);font-size:.98rem;line-height:1.55}
.dark-sec .scope{border-color:var(--line)}
.dark-sec .scope-item{border-color:var(--line)}
.dark-sec .scope-item h3{color:var(--text)}
.dark-sec .scope-item p{color:var(--muted)}

/* ==========================================================================
   FEATURED CURRENT BUILD
   ========================================================================== */
.feature{position:relative;background:var(--bg-2);border-block:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.feature-img{position:relative;overflow:hidden;min-height:480px}
.feature-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.03)}
.feature-badge{position:absolute;top:1.4rem;left:1.4rem;background:var(--red);color:#fff;
  font-weight:700;font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;padding:.55rem .9rem;
  display:flex;align-items:center;gap:.5rem;z-index:2}
.feature-badge .dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 2s infinite}
.feature-body{padding:clamp(2.4rem,5vw,4.5rem) var(--pad);display:flex;flex-direction:column;justify-content:center}
.feature-body h2{font-size:clamp(2.4rem,4.5vw,3.8rem);margin:1.1rem 0 0}
.feature-body .loc{color:var(--red-bright);font-weight:600;letter-spacing:.03em;margin-top:.7rem;
  text-transform:uppercase;font-size:.86rem}
.feature-body>p{color:var(--muted);margin-top:1.5rem;max-width:46ch;line-height:1.65}
.feature-meta{display:flex;gap:2.6rem;margin-top:2.1rem;flex-wrap:wrap}
.feature-meta div span{display:block;font-family:var(--display);font-weight:800;font-size:1.55rem;color:var(--text)}
.feature-meta div small{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2)}
.feature-body .btn{margin-top:2.2rem;align-self:flex-start}

/* ==========================================================================
   WORK GRID (cards link out)
   ========================================================================== */
.work-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:1.6rem}
.proj{position:relative;overflow:hidden;background:var(--bg-2);border:1px solid var(--line);
  display:block;transition:border-color .3s var(--e-out),transform .4s var(--e-out)}
.proj:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.proj-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.proj-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--e-out);filter:contrast(1.03) saturate(.96)}
.proj:hover .proj-img img{transform:scale(1.07)}
.proj-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(8,9,11,.86))}
.proj-floors{position:absolute;top:1rem;right:1rem;z-index:2;font-family:var(--display);font-weight:800;
  font-size:.95rem;color:#fff;background:rgba(16,17,20,.55);backdrop-filter:blur(4px);
  padding:.3rem .65rem;border:1px solid var(--line-strong)}
.proj-floors em{font-style:normal;color:var(--red-bright)}
.proj-cap{position:absolute;left:0;bottom:0;z-index:2;padding:1.3rem 1.4rem;width:100%}
.proj-cap h3{font-size:1.4rem;color:#fff;letter-spacing:0;line-height:1.05}
.proj-cap .meta{margin-top:.45rem;font-size:.78rem;letter-spacing:.04em;color:var(--muted);
  text-transform:uppercase;font-weight:500}
.proj-cap .meta b{color:var(--text);font-weight:700}
.proj-cap .go{margin-top:.9rem;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  font-weight:700;color:var(--red-bright);display:inline-flex;gap:.45rem;align-items:center;
  opacity:0;transform:translateY(6px);transition:opacity .3s var(--e-out),transform .3s var(--e-out)}
.proj:hover .go{opacity:1;transform:none}

/* ==========================================================================
   VALUES (why MJF)
   ========================================================================== */
.approach-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(2.4rem,5vw,5rem);align-items:center}
.approach-media{position:relative}
.approach-media img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:contrast(1.05) saturate(.92)}
.approach-media .stamp{position:absolute;left:0;bottom:0;background:var(--bg);color:var(--text);
  padding:1.4rem 1.6rem;border-top:3px solid var(--red);max-width:88%}
.approach-media .stamp b{font-family:var(--display);font-weight:800;font-size:1.2rem;display:block;text-transform:uppercase}
.approach-media .stamp span{font-size:.86rem;color:var(--muted);display:block;margin-top:.35rem;line-height:1.5}
.vals{list-style:none;margin:0;padding:0}
.vals li{padding:1.5rem 0;border-top:1px solid var(--line-dark);display:grid;
  grid-template-columns:auto 1fr;gap:1.3rem;align-items:start}
.vals li:last-child{border-bottom:1px solid var(--line-dark)}
.vals .vn{font-family:var(--display);font-weight:800;color:var(--red-deep);font-size:1.05rem;padding-top:.15rem}
.vals h3{font-size:1.24rem;letter-spacing:0;color:var(--ink);text-transform:uppercase}
.vals p{color:var(--ink-soft);margin-top:.4rem;font-size:1rem;line-height:1.55}
.dark-sec .vals li{border-color:var(--line)}
.dark-sec .vals .vn{color:var(--red-bright)}
.dark-sec .vals h3{color:var(--text)}
.dark-sec .vals p{color:var(--muted)}

/* ==========================================================================
   CTA BAND
   ========================================================================== */
.cta{background:var(--red);color:#fff;position:relative;overflow:hidden}
.cta .wrap{padding-block:clamp(3.5rem,7vw,6rem);display:grid;grid-template-columns:1.35fr auto;
  gap:2.4rem;align-items:center;position:relative;z-index:2}
.cta h2{font-size:clamp(2.2rem,5vw,4rem);color:#fff;text-wrap:balance}
.cta>.wrap>div>p{margin-top:1.2rem;max-width:48ch;color:rgba(255,255,255,.92);font-size:1.1rem;line-height:1.55}
.cta-actions{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.cta-actions .btn-dark{justify-content:center;width:100%}
.cta-tel{font-family:var(--display);font-weight:800;font-size:1.8rem;color:#fff;letter-spacing:.01em}
.cta-tel small{display:block;font-family:var(--sans);font-weight:500;font-size:.72rem;
  letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:.25rem}
.cta::before{content:"";position:absolute;right:-40px;top:-40px;bottom:-40px;width:44%;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.1) 0 1px,transparent 1px 32px);pointer-events:none;z-index:1}

/* ==========================================================================
   SUB-PAGE HERO
   ========================================================================== */
.page-hero{padding-block:clamp(7rem,12vw,11rem) clamp(3rem,6vw,5rem);border-bottom:1px solid var(--line);
  position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-60px;top:-60px;bottom:-60px;width:40%;
  background:repeating-linear-gradient(90deg,var(--line) 0 1px,transparent 1px 34px);pointer-events:none;opacity:.7}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-size:clamp(2.8rem,7vw,6rem);margin-top:1.2rem;text-wrap:balance;max-width:20ch}
.page-hero h1 .hl{color:var(--red-bright)}
.page-hero .lead{color:var(--muted);font-size:clamp(1.1rem,1.5vw,1.35rem);margin-top:1.6rem;max-width:54ch;line-height:1.6}

/* breadcrumb / back */
.crumb{display:inline-flex;align-items:center;gap:.5rem;font-size:.76rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;color:var(--muted-2);transition:color .2s}
.crumb:hover{color:var(--red-bright)}
.crumb .arw{transition:transform .25s var(--e-out)}
.crumb:hover .arw{transform:translateX(-4px)}

/* ==========================================================================
   PROJECT DETAIL
   ========================================================================== */
.proj-hero-img{position:relative;height:clamp(46vh,60vh,640px);overflow:hidden;border-bottom:1px solid var(--line)}
.proj-hero-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.95)}
.proj-hero-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,9,11,.45) 0%,transparent 30%,rgba(8,9,11,.7) 100%)}
.proj-hero-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding-block:clamp(2rem,4vw,3rem)}
.proj-hero-cap .loc{color:var(--red-bright);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.86rem}
.proj-hero-cap h1{font-size:clamp(2.6rem,6.5vw,5.4rem);margin-top:.7rem;color:#fff;text-wrap:balance}

.facts{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);background:var(--bg-2)}
.fact{padding:clamp(1.6rem,3vw,2.4rem) clamp(1.2rem,2.4vw,2rem);border-right:1px solid var(--line)}
.fact:last-child{border-right:0}
.fact small{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);font-weight:600;display:block}
.fact span{font-family:var(--display);font-weight:800;font-size:clamp(1.4rem,2.4vw,2rem);color:var(--text);
  margin-top:.7rem;display:block;line-height:1.05;text-transform:uppercase}
.fact span em{font-style:normal;color:var(--red-bright)}

.proj-body{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.proj-body .lede{font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.4;color:var(--text);
  font-weight:500;text-wrap:pretty}
.proj-body .lede .hl{color:var(--red-bright)}
.proj-body .copy p{color:var(--muted);margin-top:1.3rem;line-height:1.7;max-width:60ch}
.proj-aside h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);
  font-weight:600;margin-bottom:1.2rem;font-family:var(--sans)}
.scope-tags{list-style:none;margin:0;padding:0}
.scope-tags li{padding:1rem 0;border-top:1px solid var(--line);color:var(--text);font-size:1rem;
  display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:center}
.scope-tags li:last-child{border-bottom:1px solid var(--line)}
.scope-tags li .mk{width:9px;height:9px}

/* prev / next */
.proj-nav{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line)}
.proj-nav a{padding:clamp(2rem,4vw,3.2rem) var(--pad);transition:background .3s var(--e-out)}
.proj-nav a:hover{background:var(--bg-2)}
.proj-nav a.next{text-align:right;border-left:1px solid var(--line)}
.proj-nav small{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);font-weight:600}
.proj-nav b{font-family:var(--display);font-weight:800;font-size:clamp(1.3rem,2.5vw,1.9rem);color:var(--text);
  text-transform:uppercase;display:block;margin-top:.6rem;transition:color .25s}
.proj-nav a:hover b{color:var(--red-bright)}
.proj-nav a.disabled{opacity:.35;pointer-events:none}

/* ==========================================================================
   ABOUT page bits
   ========================================================================== */
.about-lede{font-size:clamp(1.5rem,3vw,2.4rem);line-height:1.32;font-weight:500;color:var(--ink);
  text-wrap:pretty;max-width:24ch}
.about-lede .hl{color:var(--red-deep)}
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.split .body p{color:var(--ink-soft);margin-top:1.3rem;line-height:1.7;max-width:60ch;font-size:1.05rem}
.split .body p:first-child{margin-top:0}
.dark-sec .split .body p{color:var(--muted)}
.timeline{list-style:none;margin:0;padding:0}
.timeline li{display:grid;grid-template-columns:auto 1fr;gap:1.6rem;padding:1.6rem 0;
  border-top:1px solid var(--line)}
.timeline li:last-child{border-bottom:1px solid var(--line)}
.timeline .yr{font-family:var(--display);font-weight:800;color:var(--red-bright);font-size:1.3rem}
.timeline h3{font-size:1.2rem;text-transform:uppercase;color:var(--text)}
.timeline p{color:var(--muted);margin-top:.4rem;line-height:1.55;font-size:.98rem}

/* ==========================================================================
   CONTACT
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2.5rem,6vw,5.5rem);align-items:start}
.field{margin-bottom:1.3rem}
.field label{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  font-weight:600;color:var(--muted-2);margin-bottom:.6rem}
.field input,.field textarea,.field select{width:100%;background:var(--bg-2);border:1px solid var(--line);
  color:var(--text);font-family:var(--sans);font-size:1rem;padding:.95rem 1.1rem;border-radius:var(--radius);
  transition:border-color .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--red)}
.field textarea{resize:vertical;min-height:140px}
.field select{appearance:none;cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.contact-side h3{font-size:1.5rem;text-transform:uppercase;margin-bottom:.4rem}
.contact-side .big-tel{font-family:var(--display);font-weight:800;font-size:clamp(1.8rem,3vw,2.4rem);
  color:var(--text);display:block;margin:.3rem 0 .2rem}
.contact-side .big-tel:hover{color:var(--red-bright)}
.contact-side .lbl{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);font-weight:600}
.contact-side .info-block{padding:1.6rem 0;border-top:1px solid var(--line)}
.contact-side .info-block:first-of-type{border-top:0}
.contact-side a.line{color:var(--muted);transition:color .2s;font-size:1.05rem}
.contact-side a.line:hover{color:var(--red-bright)}

/* ==========================================================================
   REVEAL
   ========================================================================== */
.reveal-on .reveal{opacity:0;transform:translateY(26px)}
.reveal-on .reveal.in{opacity:1;transform:none;transition:opacity .7s var(--e-out),transform .7s var(--e-out)}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:1040px){
  .nav-links{display:none}
  .burger{display:flex}
  .nav-phone{display:none}
  .feature{grid-template-columns:1fr}
  .feature-img{min-height:340px;order:1}
  .feature-body{order:2}
  .approach-grid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .proj-body{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cta .wrap{grid-template-columns:1fr}
  .cta-actions{align-items:stretch}
  .foot-grid{grid-template-columns:1fr 1fr}
  .sec-head{grid-template-columns:1fr}
  .scope{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .facts{grid-template-columns:1fr 1fr}
  .mobile-menu{position:fixed;inset:78px 0 auto 0;z-index:var(--z-menu);
    background:rgba(11,12,14,.98);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
    flex-direction:column;padding:1.2rem var(--pad) 2.2rem;gap:.1rem;
    transform:translateY(-118%);transition:transform .42s var(--e-out);display:flex}
  .mobile-menu.open{transform:translateY(0)}
  .mobile-menu a{padding:1.05rem 0;border-bottom:1px solid var(--line);font-family:var(--display);
    font-weight:800;text-transform:uppercase;letter-spacing:.03em;font-size:1.15rem;color:var(--text)}
  .mobile-menu .btn{margin-top:1.4rem;justify-content:center}
  .burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media(max-width:680px){
  .nav-cta{display:none}            /* burger menu carries the CTA — keeps header clean */
  .nav{gap:1rem}
  .scope{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .facts{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
  .feature-meta{gap:1.8rem}
  .proj-nav{grid-template-columns:1fr}
  .proj-nav a.next{border-left:0;border-top:1px solid var(--line);text-align:left}
  .form-row{grid-template-columns:1fr}
  .build.is-live{height:520vh}
}
@media(max-width:420px){
  .stats-grid{grid-template-columns:1fr}
  .facts{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important;transition:none!important}
  .reveal-on .reveal{opacity:1!important;transform:none!important}
}
@media print{
  header.site,footer.site,.scroll-cue,.progress-rail,.cta{display:none}
}
