/* ============================================================
   SUNSET CONSTRUCTION
   ============================================================ */

:root{
  --night:   #1a1228;
  --night-2: #20142e;
  --plum:    #3d2348;
  --coral:   #ff6b4a;
  --amber:   #ffa23a;
  --gold:    #ffd27d;
  --cream:   #fff6ec;
  --ink:     #181018;
  --charcoal:#231a26;
  --muted:   #8a7e8c;
  --line:    rgba(24,16,24,.10);

  --maxw: 1200px;
  --r: 18px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --font-display:'Fraunces', Georgia, serif;
  --font-sans:'Sora', system-ui, -apple-system, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
}
img,svg,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- Shared ---------- */
.section{ padding:clamp(72px,9vw,140px) clamp(20px,5vw,48px); max-width:var(--maxw); margin-inline:auto; }
.section__head{ max-width:720px; margin-bottom:clamp(40px,5vw,64px); }
.kicker{
  font-size:.78rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--coral); margin-bottom:18px;
}
h2{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2rem,4.2vw,3.3rem);
  line-height:1.05;
  letter-spacing:-.01em;
}
.lede{ font-size:clamp(1.05rem,1.6vw,1.25rem); color:#5a4f5c; margin-top:18px; max-width:60ch; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  padding:.95em 1.7em; border-radius:100px;
  font-weight:600; font-size:.98rem; letter-spacing:.01em;
  cursor:pointer; border:1px solid transparent;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, color .3s;
}
.btn--primary{
  background:linear-gradient(120deg,var(--amber),var(--coral));
  color:#fff; box-shadow:0 12px 30px -10px rgba(255,107,74,.6);
}
.btn--primary:hover{ transform:translateY(-3px); box-shadow:0 20px 40px -12px rgba(255,107,74,.7); }
.btn--ghost{
  background:rgba(255,255,255,.08); color:#fff;
  border-color:rgba(255,255,255,.5); backdrop-filter:blur(6px);
}
.btn--ghost:hover{ background:rgba(255,255,255,.18); transform:translateY(-3px); }
.btn--dark{ background:var(--ink); color:var(--cream); margin-top:28px; }
.btn--dark:hover{ transform:translateY(-3px); box-shadow:0 16px 34px -14px rgba(24,16,24,.5); }
.btn--full{ width:100%; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .4s, box-shadow .4s, padding .4s;
  padding:18px 0;
}
.nav.scrolled{
  background:rgba(255,246,236,.88);
  backdrop-filter:saturate(140%) blur(14px);
  box-shadow:0 1px 0 var(--line);
  padding:10px 0;
}
.nav__inner{
  max-width:var(--maxw); margin-inline:auto;
  padding:0 clamp(20px,5vw,48px);
  display:flex; align-items:center; justify-content:space-between;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand__mark{ display:grid; place-items:center; flex:none; }
.brand__text{ display:flex; flex-direction:column; line-height:1; }
.brand__text strong{
  font-family:var(--font-sans); font-weight:800; font-size:1.02rem;
  letter-spacing:.14em; color:#fff;
}
.brand__text em{
  font-style:normal; font-size:.62rem; font-weight:600;
  letter-spacing:.34em; color:var(--gold);
}
.nav.scrolled .brand__text strong{ color:var(--ink); }
.nav.scrolled .brand__text em{ color:var(--coral); }

.nav__links{ display:flex; align-items:center; gap:34px; }
.nav__links a{
  font-size:.95rem; font-weight:500; color:#fff;
  position:relative; transition:color .25s;
}
.nav__links a:not(.nav__cta)::after{
  content:''; position:absolute; left:0; bottom:-6px; height:2px; width:0;
  background:var(--amber); transition:width .3s var(--ease);
}
.nav__links a:not(.nav__cta):hover::after{ width:100%; }
.nav.scrolled .nav__links a{ color:var(--ink); }
.nav__cta{
  background:linear-gradient(120deg,var(--amber),var(--coral));
  color:#fff !important; padding:.6em 1.3em; border-radius:100px;
  font-weight:600; box-shadow:0 8px 22px -8px rgba(255,107,74,.6);
  transition:transform .3s var(--ease);
}
.nav__cta:hover{ transform:translateY(-2px); }

.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav__toggle span{ width:26px; height:2px; background:#fff; border-radius:2px; transition:.3s; }
.nav.scrolled .nav__toggle span{ background:var(--ink); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:center;
  padding-block:150px 120px;
  /* full-bleed video, but keep text aligned to the 1200px content column (matches nav + sections) */
  padding-inline:calc(clamp(20px,5vw,48px) + max(0px, (100% - var(--maxw)) / 2));
  width:100%; max-width:none; margin:0;
  color:#fff; overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:-1; }
.hero__video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:50% 32%; z-index:2;
  background:#1f0d3a;
}
/* JS adds .is-fallback only if the video source fails to load */
.hero__video.is-fallback{ display:none; }

/* ---- Animated sunset scene (fallback / always behind video) ---- */
.scene{ position:absolute; inset:0; overflow:hidden; }
.scene__sky{
  position:absolute; inset:0;
  background:linear-gradient(180deg,
    #1f0d3a 0%,
    #5a2150 28%,
    #b8434f 50%,
    #ef6f3c 70%,
    #ffab47 86%,
    #ffd98a 100%);
  animation:skyShift 16s ease-in-out infinite alternate;
}
@keyframes skyShift{
  0%  { filter:brightness(.92) saturate(1); }
  100%{ filter:brightness(1.08) saturate(1.12); }
}
.scene__sun{
  position:absolute; left:50%; bottom:20%;
  width:min(46vw,360px); aspect-ratio:1; border-radius:50%;
  transform:translateX(-50%);
  background:radial-gradient(circle at 50% 50%,
    #fff7e0 0%, #ffe39a 26%, #ffb24a 55%, #ff7e3a 78%, rgba(255,126,58,0) 80%);
  filter:blur(.5px);
  animation:sunBreath 9s ease-in-out infinite;
}
@keyframes sunBreath{
  0%,100%{ transform:translateX(-50%) scale(1); opacity:.96; }
  50%    { transform:translateX(-50%) scale(1.05); opacity:1; }
}
.scene__glow{
  position:absolute; left:50%; bottom:8%; transform:translateX(-50%);
  width:120vw; height:60vh;
  background:radial-gradient(ellipse at 50% 100%,
    rgba(255,178,74,.55) 0%, rgba(255,126,58,.25) 35%, rgba(255,126,58,0) 65%);
  pointer-events:none;
}
.scene__rays{
  position:absolute; left:50%; bottom:12%; transform:translateX(-50%);
  width:160vw; height:120vh;
  background:conic-gradient(from 200deg at 50% 100%,
    transparent 0deg, rgba(255,224,160,.10) 6deg, transparent 12deg,
    rgba(255,224,160,.10) 20deg, transparent 26deg,
    rgba(255,224,160,.08) 36deg, transparent 42deg,
    rgba(255,224,160,.10) 52deg, transparent 60deg);
  mix-blend-mode:screen; opacity:.7;
  animation:raysTurn 40s linear infinite;
  pointer-events:none;
}
@keyframes raysTurn{ to{ transform:translateX(-50%) rotate(8deg);} }

.cloud{
  position:absolute; border-radius:100px; filter:blur(14px);
  background:linear-gradient(90deg, rgba(58,26,58,.0), rgba(45,20,48,.55), rgba(58,26,58,0));
  opacity:.7;
}
.cloud--1{ top:24%; left:-30%; width:60%; height:46px; animation:drift1 38s linear infinite; }
.cloud--2{ top:38%; left:-40%; width:48%; height:38px; opacity:.55; animation:drift2 52s linear infinite; }
.cloud--3{ top:16%; left:-25%; width:40%; height:30px; opacity:.45; animation:drift1 64s linear infinite; }
.cloud--4{ top:52%; left:-50%; width:70%; height:56px; opacity:.6;
  background:linear-gradient(90deg, rgba(120,40,60,0), rgba(150,55,70,.5), rgba(120,40,60,0));
  animation:drift2 44s linear infinite; }
@keyframes drift1{ to{ transform:translateX(180vw);} }
@keyframes drift2{ to{ transform:translateX(200vw);} }

.scene__haze{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(31,13,58,.35) 0%, transparent 30%, transparent 60%, rgba(255,171,71,.18) 100%);
  pointer-events:none;
}
.scene__skyline{
  position:absolute; left:0; right:0; bottom:0; width:100%; height:42%;
}
.scene__vignette{
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 30%, transparent 40%, rgba(15,7,22,.55) 100%);
}
.scene__grain{
  position:absolute; inset:0; pointer-events:none; opacity:.06; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* darken overlay so text reads over the scene */
.hero__media::after{
  content:''; position:absolute; inset:0; z-index:3; pointer-events:none;
  background:
    linear-gradient(180deg,
      rgba(15,7,22,.55) 0%,
      rgba(15,7,22,.34) 30%,
      rgba(15,7,22,.40) 55%,
      rgba(15,7,22,.80) 82%,
      rgba(15,7,22,.96) 100%),
    linear-gradient(95deg,
      rgba(15,7,22,.55) 0%,
      rgba(15,7,22,.12) 55%,
      transparent 78%);
}

.hero__content{ position:relative; z-index:5; max-width:760px; }
.hero__eyebrow{
  font-size:.82rem; font-weight:600; letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold); margin-bottom:22px;
}
.hero__title{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(2.7rem,7vw,5.6rem); line-height:1.02; letter-spacing:-.02em;
  text-shadow:0 4px 40px rgba(0,0,0,.35);
}
.hero__title span{
  font-style:italic; font-weight:500;
  background:linear-gradient(120deg,var(--gold),#fff,var(--amber));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__sub{
  margin-top:26px; font-size:clamp(1.05rem,1.6vw,1.28rem);
  color:rgba(255,246,236,.94); max-width:56ch; line-height:1.65;
  text-shadow:0 1px 20px rgba(0,0,0,.55);
}
.hero__actions{ margin-top:38px; display:flex; flex-wrap:wrap; gap:16px; }

.hero__stats{
  position:relative; z-index:5; display:flex; flex-wrap:wrap; gap:clamp(28px,5vw,72px);
  margin-top:clamp(48px,7vw,90px);
}
.hero__stat strong{
  display:block; font-family:var(--font-display); font-weight:600;
  font-size:clamp(2rem,3.4vw,2.8rem); line-height:1; color:#fff;
}
.hero__stat span{ font-size:.85rem; letter-spacing:.04em; color:rgba(255,246,236,.75); }

.hero__scroll{
  position:absolute; left:50%; bottom:28px; transform:translateX(-50%); z-index:5;
  width:26px; height:42px; border:2px solid rgba(255,255,255,.6); border-radius:14px;
}
.hero__scroll span{
  position:absolute; left:50%; top:8px; width:4px; height:8px; border-radius:4px;
  background:#fff; transform:translateX(-50%); animation:scrollDot 1.8s ease-in-out infinite;
}
@keyframes scrollDot{ 0%,100%{ opacity:0; transform:translate(-50%,0);} 50%{ opacity:1; transform:translate(-50%,12px);} }

/* ============================================================
   TRUST BAR
   ============================================================ */
.trust{ background:var(--ink); color:var(--cream); }
.trust__inner{
  max-width:var(--maxw); margin-inline:auto; padding:18px clamp(20px,5vw,48px);
  display:flex; flex-wrap:wrap; justify-content:center; gap:14px;
  font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; font-weight:500;
}
.trust .dot{ color:var(--coral); }

/* ============================================================
   SERVICES
   ============================================================ */
.services__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px;
}
.card{
  position:relative; overflow:hidden;
  background:#fff; border:1px solid var(--line); border-radius:22px;
  padding:34px 30px 32px;
  box-shadow:0 1px 2px rgba(24,16,24,.03);
  transition:transform .45s var(--ease), box-shadow .45s var(--ease);
}
.card::before{
  content:''; position:absolute; inset:0 0 auto 0; height:4px;
  background:linear-gradient(90deg,var(--amber),var(--coral));
  transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease);
}
.card:hover{ transform:translateY(-10px); box-shadow:0 34px 60px -30px rgba(61,35,72,.42); }
.card:hover::before{ transform:scaleX(1); }

.card__icon{
  display:grid; place-items:center;
  width:60px; height:60px; border-radius:18px; color:#fff;
  background:linear-gradient(135deg, var(--amber), var(--coral));
  box-shadow:0 14px 26px -12px rgba(255,107,74,.7);
  margin-bottom:24px; transition:transform .5s var(--ease);
}
.card:hover .card__icon{ transform:translateY(-2px) scale(1.06) rotate(-4deg); }
.card__icon svg{ width:28px; height:28px; }

.card__num{
  position:absolute; top:14px; right:22px;
  font-family:var(--font-display); font-weight:600; font-size:3.6rem; line-height:1;
  color:var(--plum); opacity:.08; pointer-events:none; transition:opacity .45s var(--ease);
}
.card:hover .card__num{ opacity:.15; }

.card h3{ font-family:var(--font-display); font-weight:600; font-size:1.5rem; margin:0 0 12px; }
.card p{ color:#5a4f5c; font-size:.98rem; }

.card__link{
  display:inline-flex; align-items:center; gap:.45em; margin-top:20px;
  font-size:.9rem; font-weight:600; letter-spacing:.01em; color:var(--coral);
}
.card__link i{ font-style:normal; transition:transform .3s var(--ease); }
.card:hover .card__link i{ transform:translateX(5px); }

/* ============================================================
   PROJECTS
   ============================================================ */
.projects__grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  grid-auto-rows:230px; gap:20px;
}
.project{
  position:relative; border-radius:var(--r); overflow:hidden;
  background-image:var(--p); background-size:cover; background-position:center;
  grid-column:span 2;
  display:flex; align-items:flex-end;
  transition:transform .5s var(--ease);
}
.project--tall{ grid-row:span 2; grid-column:span 2; }
.project--wide{ grid-column:span 4; }
.project::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 30%, rgba(15,7,22,.78) 100%);
  transition:opacity .4s;
}
.project:hover{ transform:scale(.99); }
.project__body{ position:relative; z-index:2; padding:28px; color:#fff; }
.project__tag{
  display:inline-block; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  font-weight:600; color:var(--gold); margin-bottom:10px;
}
.project__body h3{ font-family:var(--font-display); font-weight:600; font-size:1.45rem; line-height:1.1; }
.project__body p{ font-size:.9rem; color:rgba(255,255,255,.82); margin-top:4px; }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ }
.about__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,6vw,90px); align-items:center; }
.about__copy h2{ margin:14px 0 22px; }
.about__copy p{ color:#5a4f5c; margin-bottom:16px; max-width:54ch; }
.about__stats{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.stat{
  background:linear-gradient(160deg,var(--night),var(--plum));
  color:#fff; border-radius:var(--r); padding:34px 28px;
}
.stat:nth-child(2),.stat:nth-child(3){ background:linear-gradient(160deg,var(--plum),var(--coral)); }
.stat strong{
  display:block; font-family:var(--font-display); font-weight:600;
  font-size:clamp(2.2rem,3.6vw,3rem); line-height:1;
}
.stat span{ font-size:.86rem; color:rgba(255,246,236,.82); margin-top:8px; display:block; }

/* ============================================================
   PROCESS
   ============================================================ */
.process__track{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.step{ position:relative; padding-top:28px; border-top:2px solid var(--line); }
.step__num{
  font-family:var(--font-display); font-weight:600; font-size:2.4rem;
  background:linear-gradient(120deg,var(--amber),var(--coral));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.step h3{ font-family:var(--font-display); font-weight:600; font-size:1.4rem; margin:8px 0 10px; }
.step p{ color:#5a4f5c; font-size:.96rem; }

/* ============================================================
   QUOTES
   ============================================================ */
.quotes{ }
.quotes__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.quote{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:34px 30px; position:relative;
}
.quote::before{
  content:'\201C'; font-family:var(--font-display); font-size:4rem; line-height:1;
  color:var(--amber); opacity:.5; position:absolute; top:14px; left:22px;
}
.quote p{ font-family:var(--font-display); font-size:1.12rem; line-height:1.5; margin:28px 0 18px; color:var(--ink); }
.quote footer{ font-size:.9rem; color:var(--muted); font-weight:500; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta{ position:relative; overflow:hidden; color:#fff; text-align:center;
  background:linear-gradient(120deg,#2a1145,#b8434f 45%,#ff7e3a 80%,#ffab47);
}
.cta::after{
  content:''; position:absolute; inset:0; opacity:.5;
  background:radial-gradient(ellipse at 50% 130%, rgba(255,224,160,.6), transparent 60%);
}
.cta__inner{ position:relative; z-index:2; max-width:760px; margin-inline:auto; padding:clamp(72px,9vw,120px) clamp(20px,5vw,48px); }
.cta h2{ font-size:clamp(2.1rem,4.6vw,3.6rem); }
.cta p{ margin:18px 0 32px; font-size:1.1rem; color:rgba(255,246,236,.92); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact__grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(40px,6vw,80px); }
.contact__info h2{ margin:14px 0 16px; }
.contact__list{ list-style:none; margin-top:34px; display:grid; gap:22px; }
.contact__list li{ display:grid; gap:4px; }
.contact__list span{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--coral); font-weight:600; }
.contact__list a, .contact__list p{ font-size:1.08rem; color:var(--ink); }
.contact__list a:hover{ color:var(--coral); }

.contact__form{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:clamp(28px,4vw,40px); box-shadow:0 30px 60px -40px rgba(61,35,72,.4);
}
.field{ margin-bottom:18px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field label{ display:block; font-size:.82rem; font-weight:600; margin-bottom:7px; color:var(--ink); }
.field input, .field select, .field textarea{
  width:100%; padding:.85em 1em; border:1px solid #e4dce2; border-radius:12px;
  font-family:inherit; font-size:.98rem; background:#fdfbfb; color:var(--ink);
  transition:border-color .25s, box-shadow .25s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--coral); box-shadow:0 0 0 3px rgba(255,107,74,.14);
}
.field textarea{ resize:vertical; }
.form-note{ font-size:.82rem; color:var(--muted); text-align:center; margin-top:14px; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink); color:var(--cream); }
.footer__inner{
  max-width:var(--maxw); margin-inline:auto; padding:clamp(56px,7vw,80px) clamp(20px,5vw,48px);
  display:grid; grid-template-columns:1.2fr 2fr; gap:48px;
}
.brand__text--light{ flex-direction:row; gap:8px; align-items:baseline; }
.brand__text--light strong{ color:#fff; }
.brand__text--light em{ color:var(--gold); }
.footer__brand p{ color:rgba(255,246,236,.6); margin-top:16px; max-width:34ch; font-size:.95rem; }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.footer__cols h4{ font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.footer__cols a{ display:block; color:rgba(255,246,236,.72); font-size:.95rem; padding:5px 0; transition:color .2s; }
.footer__cols a:hover{ color:#fff; }
.footer__bar{
  border-top:1px solid rgba(255,255,255,.1);
  max-width:var(--maxw); margin-inline:auto; padding:22px clamp(20px,5vw,48px);
  display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px;
  font-size:.82rem; color:rgba(255,246,236,.55);
}
.footer__bar a{ color:var(--gold); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .services__grid{ grid-template-columns:1fr 1fr; }
  .quotes__grid{ grid-template-columns:1fr; }
  .about__grid{ grid-template-columns:1fr; }
  .process__track{ grid-template-columns:1fr 1fr; }
  .contact__grid{ grid-template-columns:1fr; }
  .footer__inner{ grid-template-columns:1fr; gap:32px; }
  .projects__grid{ grid-template-columns:1fr 1fr; grid-auto-rows:200px; }
  .project, .project--tall, .project--wide{ grid-column:span 2; grid-row:auto; }
}
@media (max-width:680px){
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:26px;
    background:var(--ink); padding:40px; transform:translateX(100%);
    transition:transform .4s var(--ease); box-shadow:-20px 0 60px rgba(0,0,0,.4);
  }
  .nav__links.open{ transform:translateX(0); }
  .nav__links a{ color:#fff !important; font-size:1.1rem; }
  .nav__toggle{ display:flex; z-index:110; }
  .nav__toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); background:#fff; }
  .nav__toggle.open span:nth-child(2){ opacity:0; }
  .nav__toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); background:#fff; }
  .services__grid, .process__track{ grid-template-columns:1fr; }
  .about__stats{ grid-template-columns:1fr 1fr; }
  .field-row{ grid-template-columns:1fr; }
  .hero__stats{ gap:28px; }
  /* billboard is now cropped out of the source clip, so the video just covers normally */
  .hero__video{ object-position:50% 40%; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
}
