/* ==========================================================================
   DAVIS MADE BUILDING — Premium monochrome design system
   Palette (from brand guide): Black #231F20 · Dark Grey #76777A ·
   Light Grey #BBBABA · White #FFFFFF
   ========================================================================== */

:root{
  --black:#231F20;
  --ink:#1b1819;
  --dark-grey:#76777a;
  --light-grey:#bbbaba;
  --line:#cecece;
  --paper:#e6e6e6;
  --paper-2:#d9d9d9;
  --white:#ffffff;
  --max:1240px;
  --gutter:clamp(20px,5vw,64px);
  --ff-head:"Archivo",-apple-system,"Segoe UI",sans-serif;
  --ff-body:"Inter",-apple-system,"Segoe UI",Helvetica,Arial,sans-serif;
  --t:.45s cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:17px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--ff-head);font-weight:600;line-height:1.08;color:var(--black);letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,6vw,4.6rem);font-weight:700}
h2{font-size:clamp(1.9rem,4vw,3.1rem)}
h3{font-size:clamp(1.3rem,2.2vw,1.7rem)}
p{margin-bottom:1.1em}
p:last-child{margin-bottom:0}

.eyebrow{
  font-family:var(--ff-head);
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:.72rem;
  font-weight:600;
  color:var(--dark-grey);
  display:inline-block;
  margin-bottom:1.4rem;
  padding-left:.34em;
}
.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:#313131;line-height:1.65}

/* ---------- Layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding-inline:var(--gutter)}
section{padding-block:clamp(64px,9vw,140px)}
.bg-paper{background:var(--paper-2)}
.bg-white{background:var(--white)}
.bg-ink{background:var(--ink);color:#d7d7d7}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}
.bg-ink .eyebrow{color:var(--light-grey)}
.center{text-align:center}
.measure{max-width:62ch}
.measure-sm{max-width:46ch}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--ff-head);font-weight:600;
  text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;
  padding:1.15em 2.1em;border:1px solid var(--black);
  background:var(--black);color:#fff;cursor:pointer;
  transition:background var(--t),color var(--t),border-color var(--t),transform .2s;
}
.btn:hover{background:transparent;color:var(--black);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--black)}
.btn--ghost:hover{background:var(--black);color:#fff}
.btn--light{border-color:#fff;background:#fff;color:var(--ink)}
.btn--light:hover{background:transparent;color:#fff}
.btn--outline-light{background:transparent;border-color:rgba(255,255,255,.5);color:#fff}
.btn--outline-light:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn .arr{transition:transform var(--t)}
.btn:hover .arr{transform:translateX(4px)}

.link-arrow{
  font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.16em;
  font-size:.76rem;font-weight:600;display:inline-flex;align-items:center;gap:.6em;
  border-bottom:1px solid currentColor;padding-bottom:.35em;
}
.link-arrow .arr{transition:transform var(--t)}
.link-arrow:hover .arr{transform:translateX(5px)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  background:rgba(230,230,230,.9);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:background var(--t),border-color var(--t),padding var(--t);
}
.site-header.scrolled{border-bottom-color:var(--line);padding-block:12px}
.site-header.on-dark{background:transparent}
.site-header.on-dark .nav a,.site-header.on-dark .nav-tel{color:#fff}
.site-header.on-dark .logo-dark{display:none}
.site-header.on-dark .logo-white{display:block}
.site-header.on-dark.scrolled{background:rgba(27,24,25,.9)}
.brand img{height:38px;width:auto}
.logo-white{display:none}
.nav{display:flex;align-items:center;gap:clamp(14px,1.5vw,24px)}
.nav a{
  font-family:var(--ff-head);font-weight:500;font-size:.84rem;line-height:1;
  text-transform:uppercase;letter-spacing:.06em;color:var(--black);
  display:inline-flex;align-items:center;
  position:relative;padding:.45em 0;white-space:nowrap;transition:opacity var(--t);
}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:currentColor;transition:width var(--t)}
.nav a:hover::after,.nav a.active::after{width:100%}
.nav-tel{
  font-family:var(--ff-head);font-weight:600;letter-spacing:.02em;line-height:1;
  display:inline-flex;align-items:center;gap:.4em;font-size:.84rem;white-space:nowrap;
  margin-left:clamp(4px,.6vw,12px);
}
.nav-cta{font-family:var(--ff-head);font-weight:600;text-transform:uppercase;letter-spacing:.09em;font-size:.84rem;line-height:1;display:inline-flex;align-items:center;border:1px solid currentColor;padding:1.1em 2.25em;white-space:nowrap;transition:background var(--t),color var(--t),border-color var(--t)}
.nav-cta:hover{background:var(--black);color:#fff}
.site-header.on-dark .nav-cta:hover{background:#fff;color:var(--ink)}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;position:relative;z-index:101}
.menu-toggle span{width:26px;height:2px;background:currentColor;display:block;transition:var(--t)}
.site-header.on-dark .menu-toggle span{background:#fff}

/* ---------- Nav dropdown (Services) ---------- */
.nav-dd{position:relative;display:inline-flex;align-items:center}
.nav-dd-toggle{font-family:var(--ff-head);font-weight:500;font-size:.84rem;line-height:1;text-transform:uppercase;letter-spacing:.06em;color:var(--black);background:none;border:0;cursor:pointer;padding:.45em 0;display:inline-flex;align-items:center;gap:.45em;white-space:nowrap;position:relative}
.site-header.on-dark .nav-dd-toggle{color:#fff}
.nav-dd-toggle::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:currentColor;transition:width var(--t)}
.nav-dd:hover .nav-dd-toggle::after,.nav-dd-toggle.active::after{width:calc(100% - 1.1em)}
.dd-caret{font-size:.6em;transition:transform var(--t)}
.nav-dd:hover .dd-caret,.nav-dd.open .dd-caret{transform:rotate(180deg)}
.nav-dd-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);min-width:210px;background:var(--ink);padding:12px 0;display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity var(--t),transform var(--t),visibility var(--t);z-index:120;box-shadow:0 24px 50px -18px rgba(0,0,0,.45)}
.nav-dd:hover .nav-dd-menu,.nav-dd.open .nav-dd-menu,.nav-dd:focus-within .nav-dd-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(2px)}
.nav-dd-menu a{color:#fff;padding:.72em 26px;font-size:.78rem;letter-spacing:.1em;white-space:nowrap}
.nav-dd-menu a::after{display:none}
.nav-dd-menu a:hover{background:rgba(255,255,255,.09)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,18,18,.55) 0%,rgba(20,18,18,.15) 38%,rgba(20,18,18,.82) 100%)}
.hero__inner{width:100%;padding-bottom:clamp(56px,8vw,110px);padding-top:140px}
.hero h1{color:#fff;max-width:16ch}
.hero .lead{color:rgba(255,255,255,.86);max-width:48ch;margin-top:1.6rem}
.hero__cta{margin-top:2.4rem;display:flex;gap:16px;flex-wrap:wrap}
.hero__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin-top:clamp(40px,6vw,72px);padding-top:36px;border-top:1px solid rgba(255,255,255,.22);max-width:760px;
}
.stat .num{font-family:var(--ff-head);font-weight:700;font-size:clamp(1.8rem,3vw,2.5rem);color:#fff;line-height:1}
.stat .lbl{font-size:.86rem;color:rgba(255,255,255,.72);margin-top:.6em;line-height:1.4}

.page-hero{padding-top:clamp(150px,18vw,220px);padding-bottom:clamp(50px,7vw,90px)}
.page-hero--img{position:relative;overflow:hidden;color:#fff;padding-bottom:clamp(60px,8vw,100px)}
.page-hero--img .hero-bg{position:absolute;inset:0;z-index:0}
.page-hero--img .hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero--img::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,18,18,.74) 0%,rgba(20,18,18,.52) 45%,rgba(20,18,18,.8) 100%)}
.page-hero--img .wrap{position:relative;z-index:2}
.page-hero--img h1{color:#fff}
.page-hero--img .eyebrow{color:var(--light-grey)}
.page-hero--img .breadcrumb{color:rgba(255,255,255,.72)}
.page-hero--img .breadcrumb a:hover{color:#fff}
.page-hero--img p{color:rgba(255,255,255,.9)}
.page-hero .eyebrow{margin-bottom:1.1rem}
.page-hero h1{max-width:18ch}
.page-hero p{margin-top:1.4rem}
.breadcrumb{font-size:.78rem;letter-spacing:.04em;color:var(--dark-grey);margin-bottom:2rem;font-family:var(--ff-head);text-transform:uppercase}
.breadcrumb a:hover{color:var(--black)}

/* ---------- Generic grids / cards ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.split--media-first .media{order:-1}
.media-frame{position:relative;overflow:hidden;background:var(--paper-2)}
.media-frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.media-frame:hover img{transform:scale(1.04)}
.ratio-4-5{aspect-ratio:4/5}
.ratio-3-2{aspect-ratio:3/2}
.ratio-1-1{aspect-ratio:1/1}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,34px)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,4vw,56px)}

.feature{padding:38px 34px;background:var(--white);border:1px solid var(--line);height:100%;transition:transform var(--t),box-shadow var(--t)}
.bg-paper .feature{background:#fff}
.feature:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(0,0,0,.28)}
.feature .idx{font-family:var(--ff-head);font-weight:700;font-size:.8rem;letter-spacing:.2em;color:var(--light-grey);display:block;margin-bottom:1.6rem}
.feature h3{margin-bottom:.7rem}
.feature p{font-size:.96rem;color:#474747}

/* ---------- Process steps ---------- */
.steps{display:grid;gap:0;border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:120px 1fr;gap:clamp(20px,4vw,60px);padding:clamp(30px,4vw,52px) 0;border-bottom:1px solid var(--line);align-items:start}
.step .no{font-family:var(--ff-head);font-weight:700;font-size:clamp(2rem,4vw,3rem);color:var(--light-grey);line-height:1}
.step h3{margin-bottom:.6rem}
.step p{color:#474747;max-width:60ch}
.bg-ink .steps,.bg-ink .step{border-color:rgba(255,255,255,.16)}
.bg-ink .step p{color:#b6b6b6}
.bg-ink .step .no{color:#575757}

/* ---------- Process timeline ---------- */
.timeline{position:relative}
.timeline::before{content:"";position:absolute;left:34px;top:38px;bottom:38px;width:1.5px;background:var(--line)}
.tl-step{position:relative;display:grid;grid-template-columns:68px 1fr;gap:clamp(22px,4vw,46px);padding-bottom:clamp(34px,5vw,58px)}
.tl-step:last-child{padding-bottom:0}
.tl-node{width:68px;height:68px;border-radius:50%;border:1px solid var(--line);background:var(--white);display:flex;align-items:center;justify-content:center;position:relative;z-index:2;transition:transform var(--t),background var(--t),border-color var(--t)}
.tl-node .feat-ic{width:30px;height:30px;margin:0;color:var(--black);transition:color var(--t)}
.tl-step:hover .tl-node{background:var(--black);border-color:var(--black);transform:scale(1.06)}
.tl-step:hover .tl-node .feat-ic{color:#fff}
.tl-num{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:var(--dark-grey);font-weight:600;display:block;margin-bottom:.5rem}
.tl-body{padding-top:.55rem}
.tl-body h3{margin-bottom:.5rem}
.tl-body p{color:#474747;max-width:64ch}
.bg-ink .timeline::before{background:rgba(255,255,255,.2)}
.bg-ink .tl-node{background:var(--ink);border-color:rgba(255,255,255,.28)}
.bg-ink .tl-node .feat-ic{color:#fff}
.bg-ink .tl-step:hover .tl-node{background:#fff;border-color:#fff}
.bg-ink .tl-step:hover .tl-node .feat-ic{color:var(--ink)}
.bg-ink .tl-num{color:var(--light-grey)}
.bg-ink .tl-body p{color:#b6b6b6}
@media(max-width:640px){
  .tl-step{grid-template-columns:52px 1fr;gap:18px}
  .tl-node{width:52px;height:52px}
  .tl-node .feat-ic{width:24px;height:24px}
  .timeline::before{left:26px;top:30px;bottom:30px}
}

/* ---------- Project cards ---------- */
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,30px)}
.proj-card{position:relative;display:block;overflow:hidden;aspect-ratio:3/2;background:var(--paper-2)}
.proj-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.proj-card:hover img{transform:scale(1.05)}
.proj-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(20,18,18,.72));z-index:1}
.proj-card__cap{position:absolute;left:0;bottom:0;z-index:2;padding:clamp(20px,2.6vw,34px);color:#fff}
.proj-card__cap .loc{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:rgba(255,255,255,.82);display:block;margin-bottom:.4em}
.proj-card__cap h3{color:#fff;font-size:clamp(1.3rem,2vw,1.85rem)}
.proj-card__cap .view{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:600;margin-top:.7em;display:inline-flex;align-items:center;gap:.5em;opacity:0;transform:translateY(8px);transition:var(--t)}
.proj-card:hover .view{opacity:1;transform:none}
.proj-card .view .arr{transition:transform var(--t)}
.proj-card:hover .view .arr{transform:translateX(4px)}
@media(max-width:640px){.proj-grid{grid-template-columns:1fr}}

/* ---------- Project photo gallery (masonry) ---------- */
.photo-grid{columns:3;column-gap:clamp(12px,1.5vw,18px)}
.photo-grid a{display:block;margin:0 0 clamp(12px,1.5vw,18px);overflow:hidden;break-inside:avoid;background:var(--paper-2)}
.photo-grid img{width:100%;display:block;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.photo-grid a:hover img{transform:scale(1.04)}
@media(max-width:900px){.photo-grid{columns:2}}
@media(max-width:560px){.photo-grid{columns:1}}

/* ---------- Portfolio ---------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.5vw,20px)}
.gallery a{position:relative;overflow:hidden;display:block;background:var(--paper-2)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.gallery a:hover img{transform:scale(1.05)}
.gallery .cap{position:absolute;left:0;bottom:0;padding:18px 20px;color:#fff;font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;z-index:2;opacity:0;transform:translateY(8px);transition:var(--t)}
.gallery a::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(20,18,18,.55));opacity:0;transition:var(--t)}
.gallery a:hover::after,.gallery a:hover .cap{opacity:1;transform:none}
.col-8{grid-column:span 8}.col-7{grid-column:span 7}.col-6{grid-column:span 6}.col-5{grid-column:span 5}.col-4{grid-column:span 4}.col-12{grid-column:span 12}
.gtall{aspect-ratio:4/5}.gwide{aspect-ratio:16/10}.gsq{aspect-ratio:1/1}

/* ---------- Quote / testimonial ---------- */
.quote{max-width:60ch;margin:0 auto;text-align:center}
.quote blockquote{font-family:var(--ff-head);font-weight:500;font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.35;color:var(--black)}
.bg-ink .quote blockquote{color:#fff}
.quote cite{display:block;margin-top:1.8rem;font-style:normal;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dark-grey);font-family:var(--ff-head)}
.bg-ink .quote cite{color:var(--light-grey)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,32px)}
.testi{padding:36px 32px;border:1px solid var(--line);background:#fff}
.testi p{font-size:1rem;color:#383838;font-style:italic;margin-bottom:1.4rem}
.testi cite{font-style:normal;font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--black);font-weight:600}
.testi cite span{display:block;color:var(--dark-grey);letter-spacing:.1em;margin-top:.3em}

/* ---------- Stat band ---------- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.statband .num{font-family:var(--ff-head);font-weight:700;font-size:clamp(2.2rem,4vw,3.4rem);line-height:1;color:var(--black)}
.bg-ink .statband .num{color:#fff}
.statband .lbl{font-size:.84rem;color:var(--dark-grey);margin-top:.8em;text-transform:uppercase;letter-spacing:.1em;font-family:var(--ff-head)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;padding-block:clamp(54px,7vw,88px)}
.cta-band .wrap{position:relative;z-index:2;text-align:center}
.cta-band h2{max-width:20ch;margin:0 auto 1.4rem}
.cta-band p{max-width:50ch;margin:0 auto 2.2rem;color:#b6b6b6}
section:has(.statband){padding-block:clamp(46px,6vw,80px)}
section:has(.statband)+.cta-band{padding-top:clamp(8px,1.5vw,18px)}

/* ---------- Areas list ---------- */
.areas{display:flex;flex-wrap:wrap;gap:10px}
.areas a,.areas span{
  font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.1em;font-size:.76rem;font-weight:500;
  border:1px solid var(--line);padding:.7em 1.2em;transition:var(--t)
}
.areas a:hover{background:var(--black);color:#fff;border-color:var(--black)}
.areas span{color:var(--dark-grey)}
.bg-ink .areas a{border-color:rgba(255,255,255,.22);color:#cdcdcd}
.bg-ink .areas a:hover{background:#fff;color:var(--ink)}

/* ---------- Contact rows ---------- */
.contact-rows{display:grid;gap:0;margin-top:2rem;border-top:1px solid var(--line)}
.contact-row{display:flex;align-items:center;gap:22px;padding:20px 4px;border-bottom:1px solid var(--line);transition:opacity var(--t)}
a.contact-row:hover{opacity:.6}
.contact-row .feat-ic{width:32px;height:32px;margin:0;flex:none;color:var(--black)}
.contact-row>div{display:flex;flex-direction:column}
.contact-row span{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.12em;font-size:.68rem;color:var(--dark-grey);margin-bottom:.25em}
.contact-row strong{font-weight:600;font-family:var(--ff-head);font-size:1.05rem;color:var(--black);letter-spacing:.01em}

/* ---------- Forms ---------- */
.form{display:grid;gap:20px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field label{display:block;font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;font-weight:600;color:var(--dark-grey);margin-bottom:.6em}
.field input,.field select,.field textarea{
  width:100%;padding:.95em 1.1em;border:1px solid var(--line);background:#fff;font-family:var(--ff-body);font-size:1rem;color:var(--ink);transition:border-color var(--t)
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--black)}
.field textarea{min-height:140px;resize:vertical}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#a5a5a5;padding-block:clamp(44px,5vw,68px) 32px}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(30px,4vw,60px);padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand img{height:42px;margin-bottom:24px}
.footer-brand p{font-size:.92rem;max-width:34ch;color:#989898}
.fcol h4{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;color:#fff;margin-bottom:1.4rem;font-weight:600}
.fcol a,.fcol p{display:block;font-size:.92rem;color:#a5a5a5;margin-bottom:.7em;transition:color var(--t)}
.fcol a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding-top:28px;font-size:.8rem;color:#7a7a7a}
.footer-bottom .socials{display:flex;gap:18px}
.footer-bottom a:hover{color:#fff}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ---------- Misc ---------- */
.divider{height:1px;background:var(--line);border:0;margin:0}
.kicker-row{display:flex;align-items:baseline;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:clamp(36px,5vw,64px)}
.kicker-row .measure{max-width:46ch}
.prose p{margin-bottom:1.2em}
.prose h2{margin:2.2em 0 .7em}
.prose h3{margin:1.8em 0 .5em}
.prose ul{margin:0 0 1.4em 1.1em}
.prose li{margin-bottom:.6em}
.checklist{list-style:none;margin:0;padding:0}
.checklist li{position:relative;padding-left:2em;margin-bottom:1em;color:#3d3d3d}
.checklist li::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:8px;border-left:2px solid var(--black);border-bottom:2px solid var(--black);transform:rotate(-45deg)}
.bg-ink .checklist li{color:#cdcdcd}
.bg-ink .checklist li::before{border-color:#fff}

/* ---------- Icons ---------- */
.feat-ic{width:36px;height:36px;display:block;margin-bottom:1.5rem;color:var(--black)}
.feat-ic svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.bg-ink .feat-ic{color:#fff}
.feature:hover .feat-ic{color:var(--black)}
.ic-inline{width:1.05em;height:1.05em;display:inline-block;vertical-align:-.15em;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.step .no-ic{width:40px;height:40px;color:var(--light-grey)}
.step .no-ic svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.bg-ink .step .no-ic{color:#6c6c6c}

/* ---------- Partners / affiliations ---------- */
.partners{display:flex;flex-wrap:wrap;gap:18px 40px;align-items:center;justify-content:center}
.partners span{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;font-weight:600;color:var(--dark-grey)}
.partners span:not(:last-child)::after{content:"";display:inline-block;width:5px;height:5px;background:var(--light-grey);border-radius:50%;margin-left:40px;vertical-align:middle}

/* ---------- Values row ---------- */
.values{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(16px,1.6vw,24px)}
.value{background:var(--white);border:1px solid var(--line);padding:clamp(26px,2vw,34px) clamp(22px,1.8vw,28px);height:100%;transition:transform var(--t),box-shadow var(--t)}
.value:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(0,0,0,.28)}
.value .feat-ic{width:32px;height:32px;margin-bottom:1.2rem}
.value h3{font-size:1.1rem;margin-bottom:.5rem}
.value p{font-size:.92rem;color:#474747}
.bg-ink .value p{color:#b6b6b6}

/* ---------- Team portraits ---------- */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px)}
.team-card .media-frame{margin-bottom:26px}
.team-card .role{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.14em;font-size:.76rem;color:var(--dark-grey);margin:.3em 0 1.1em}

/* ---------- Meet / video band ---------- */
.meet{position:relative;overflow:hidden;background:var(--ink);color:#fff}
.meet__media{position:absolute;inset:0;z-index:0}
.meet__media video,.meet__media img{width:100%;height:100%;object-fit:cover}
.meet::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(20,18,18,.86) 0%,rgba(20,18,18,.62) 45%,rgba(20,18,18,.25) 100%)}
.meet .wrap{position:relative;z-index:2}
.meet h2{color:#fff}
.meet .lead{color:rgba(255,255,255,.85)}
.meet__inner{max-width:42ch}

/* ---------- FAQ accordion ---------- */
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:1.4em 0;display:flex;justify-content:space-between;align-items:center;gap:24px;font-family:var(--ff-head);font-weight:600;font-size:1.05rem;color:var(--black)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.6rem;font-weight:400;line-height:1;color:var(--dark-grey);transition:transform var(--t)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-a{padding:0 0 1.7em;color:#474747;max-width:70ch}
.faq-a p{margin:0 0 1em}
.faq-a p:last-child{margin-bottom:0}
.faq-a ol,.faq-a ul{margin:.4em 0 .4em 1.3em;padding:0}
.faq-a li{margin-bottom:.6em}
.faq-a a{border-bottom:1px solid currentColor}
.faq-cat{font-size:.8rem}

/* ---------- Map embed ---------- */
.map-embed{position:relative;width:100%;aspect-ratio:16/7;border:1px solid var(--line);overflow:hidden;background:var(--paper-2)}
.map-embed iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(1) contrast(.92) opacity(.92)}
@media(max-width:640px){.map-embed{aspect-ratio:4/5}}

/* ---------- Portrait reel ---------- */
.reel{position:relative;width:100%;max-width:340px;aspect-ratio:1080/2048;overflow:hidden;background:var(--paper-2);box-shadow:0 34px 64px -30px rgba(0,0,0,.4)}
.reel video{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- Embedded video player ---------- */
.video-embed{position:relative;overflow:hidden;background:#000;aspect-ratio:16/9;cursor:pointer}
.video-embed video{width:100%;height:100%;object-fit:cover;display:block}
.video-embed.playing .video-embed__poster,.video-embed.playing .video-embed__play{opacity:0;pointer-events:none}
.video-embed__poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .5s}
.video-embed__play{position:absolute;inset:0;z-index:3;display:flex;align-items:center;justify-content:center;transition:opacity .4s;background:rgba(20,18,18,.18)}
.video-embed__play span{width:84px;height:84px;border-radius:50%;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;transition:transform var(--t)}
.video-embed__play span::after{content:"";margin-left:5px;border-left:22px solid var(--ink);border-top:13px solid transparent;border-bottom:13px solid transparent}
.video-embed:hover .video-embed__play span{transform:scale(1.08)}

/* ---------- Nav collapse ---------- */
@media(max-width:1160px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(86vw,380px);background:var(--ink);flex-direction:column;justify-content:center;align-items:flex-start;gap:22px;padding:90px 44px;transform:translateX(100%);transition:transform var(--t);z-index:99;overflow-y:auto}
  .nav.open{transform:none}
  .nav a{font-size:1.05rem;letter-spacing:.14em;color:#fff!important}
  .nav-tel{font-size:1.05rem;color:#fff!important;margin-top:.6rem}
  .nav-cta{font-size:.82rem;background:#fff;color:var(--ink);border-color:#fff;margin-top:.4rem;padding:.95em 1.6em}
  .nav-dd{width:100%}
  .nav-dd-toggle{color:#fff;font-size:1.05rem;letter-spacing:.14em;padding:.1em 0;width:100%;justify-content:flex-start}
  .nav-dd-toggle::after{display:none}
  .dd-caret{display:none}
  .nav-dd-menu{position:static;transform:none;opacity:1;visibility:visible;background:none;box-shadow:none;padding:.5em 0 0 1.1em;min-width:0}
  .nav-dd-menu a{color:#fff!important;padding:.4em 0;font-size:.96rem;opacity:.82}
  .menu-toggle{display:flex}
  .menu-toggle.open span{background:#fff}
  .menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-toggle.open span:nth-child(2){opacity:0}
  .menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ---------- Responsive ---------- */
@media(max-width:1080px){
  .split{grid-template-columns:1fr;gap:36px}
  .split--media-first .media{order:0}
  .grid-3,.testi-grid{grid-template-columns:1fr 1fr}
  .values{grid-template-columns:1fr 1fr 1fr}
  .team-grid{grid-template-columns:1fr;gap:48px}
  .footer-top{grid-template-columns:1fr 1fr}
  .statband{grid-template-columns:1fr 1fr;gap:40px 20px}
}
@media(max-width:640px){
  body{font-size:16px}
  .header-cta{display:none}
  .hero__stats{grid-template-columns:1fr;gap:18px}
  .grid-3,.grid-2,.testi-grid{grid-template-columns:1fr}
  .values{grid-template-columns:1fr 1fr}
  .partners{gap:14px 22px}
  .partners span:not(:last-child)::after{margin-left:22px}
  .form .row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .step{grid-template-columns:60px 1fr;gap:18px}
  .gallery>*{grid-column:span 12!important}
  .kicker-row{flex-direction:column}
}


/* ---------- Testimonial video ---------- */
.testi-video{max-width:940px;margin-inline:auto}
.testi-video__play{position:relative;display:block;width:100%;aspect-ratio:16/9;border:0;padding:0;margin:0;cursor:pointer;overflow:hidden;background-color:var(--ink);background-size:cover;background-position:center;color:#fff}
.testi-video__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,18,.05) 0%,rgba(20,18,18,.12) 45%,rgba(20,18,18,.64) 100%);transition:background var(--t)}
.testi-video__play:hover .testi-video__scrim{background:linear-gradient(180deg,rgba(20,18,18,.12) 0%,rgba(20,18,18,.24) 45%,rgba(20,18,18,.72) 100%)}
.testi-video__btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:clamp(64px,8vw,88px);height:clamp(64px,8vw,88px);border-radius:50%;background:rgba(255,255,255,.94);display:flex;align-items:center;justify-content:center;z-index:2;transition:transform .25s cubic-bezier(.2,.7,.2,1),background var(--t)}
.testi-video__btn svg{width:36%;height:36%;color:var(--black);margin-left:6%}
.testi-video__play:hover .testi-video__btn{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.testi-video__cap{position:absolute;left:0;right:0;bottom:0;z-index:2;text-align:left;padding:clamp(20px,3vw,34px)}
.testi-video__ey{display:block;font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:rgba(255,255,255,.82);margin-bottom:.55em}
.testi-video__name{display:block;font-family:var(--ff-head);font-weight:600;font-size:clamp(1.05rem,2.1vw,1.42rem);color:#fff;letter-spacing:-.01em;line-height:1.1}
.testi-video.playing .testi-video__play{display:none}
.testi-video__frame{position:relative;width:100%;aspect-ratio:16/9;background:var(--ink)}
.testi-video__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
