:root{
  --blue:#4482c3;--blue-deep:#2f6ba8;--blue-soft:#d9e6f1;--blue-tint:#d9e6f1;--blue-tint-2:#d9e6f1;
  --orange:#f58220;--orange-deep:#d96c12;
  --charcoal:#1c1d1c;--ink:#3a3b3a;
  --gray:#c7c8ca;--gray-soft:#eeeeee;
  --paper:#fafaf7;--white:#ffffff;
  --font-display:"Fraunces",Georgia,serif;
  --font-sans:"Inter Tight",-apple-system,BlinkMacSystemFont,sans-serif;
  --ease:cubic-bezier(0.22,1,0.36,1);
  --maxw:1360px;--nav-h:76px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);color:var(--ink);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
body.menu-open{overflow:hidden}
html.menu-open{overflow:hidden}
img{max-width:100%;display:block}
svg,video,canvas,iframe{max-width:100%;height:auto}
input,textarea,select,button{max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--charcoal);color:var(--paper)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
@media(max-width:768px){.wrap{padding:0 22px}}

/* Keep long content from forcing horizontal scroll on any page. */
h1,h2,h3,h4,p,a,li,.btn,.footer__contact-item,.contact-info__value,.review__text,.area__name{
  overflow-wrap:anywhere;
}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip{position:absolute;top:-100px;left:16px;background:var(--charcoal);color:var(--paper);padding:12px 18px;z-index:9999;border-radius:4px;font-size:13px}
.skip:focus{top:16px}

.eyebrow{font-size:11px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:28px;height:1px;background:currentColor}
.eyebrow--blue{color:var(--blue)}
.eyebrow--orange{color:var(--orange)}
.eyebrow--light{color:rgba(250,250,247,0.7)}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;letter-spacing:-0.025em;line-height:1;color:var(--charcoal);font-variation-settings:"opsz" 144}
h1{font-size:clamp(52px,7.8vw,120px);line-height:0.92;letter-spacing:-0.035em}
h2{font-size:clamp(38px,5.2vw,76px);line-height:0.98;letter-spacing:-0.03em}
h3{font-size:clamp(22px,2.4vw,32px);line-height:1.12;letter-spacing:-0.02em}
h4{font-size:18px;line-height:1.2}
em{font-style:italic;font-family:var(--font-display);font-weight:400;color:var(--blue)}

.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;font-size:13px;font-weight:500;letter-spacing:0.02em;border-radius:999px;transition:all 0.35s var(--ease);white-space:nowrap;border:1px solid transparent}
.btn svg{width:14px;height:14px;transition:transform 0.35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn--primary{background:var(--charcoal);color:var(--paper)}
.btn--primary:hover{background:var(--blue)}
.btn--accent{background:var(--orange);color:#fff}
.btn--accent:hover{background:var(--orange-deep)}
.btn--ghost{background:transparent;color:var(--charcoal);border-color:var(--charcoal)}
.btn--ghost:hover{background:var(--charcoal);color:var(--paper)}
.btn--ghost-light{background:transparent;color:var(--paper);border-color:rgba(250,250,247,0.35)}
.btn--ghost-light:hover{background:var(--paper);color:var(--charcoal);border-color:var(--paper)}
@media(max-width:520px){
  .btn{white-space:normal;text-align:center;justify-content:center}
}

/* ========== NAV ========== */
.nav{position:fixed;top:0;left:0;right:0;z-index:130;padding:18px 0;transition:background 0.4s var(--ease),border-color 0.4s var(--ease);border-bottom:1px solid transparent}
.nav.scrolled,.nav--solid{background:rgba(28,29,28,0.96);backdrop-filter:blur(12px);border-bottom-color:rgba(255,255,255,0.08)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav__brand{display:flex;align-items:center}
.nav__logo{height:50px;width:auto;display:block;transition:opacity 0.3s ease}
.nav__logo--light{display:none}
.nav.scrolled .nav__logo--dark,.nav--solid .nav__logo--dark{display:none}
.nav.scrolled .nav__logo--light,.nav--solid .nav__logo--light{display:block}
.nav__links{display:flex;align-items:center;gap:30px;font-size:13px;letter-spacing:0.05em;color:var(--ink)}
.nav.scrolled .nav__links,.nav--solid .nav__links{color:rgba(250,250,247,0.75)}
.nav__links a{transition:color 0.2s}
.nav__links a:hover{color:var(--charcoal)}
.nav.scrolled .nav__links a:hover,.nav--solid .nav__links a:hover{color:var(--paper)}
.nav__links a.active{color:var(--blue)}
.nav__cta{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;background:var(--orange);color:#fff;border-radius:999px;font-size:13px;font-weight:500;transition:background 0.25s}
.nav__cta:hover{background:var(--orange-deep)}
.nav__burger{display:none;width:40px;height:40px;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer}
.nav__burger span{width:22px;height:1.5px;background:var(--charcoal);transition:transform 0.3s,opacity 0.3s}
.nav.scrolled .nav__burger span,.nav--solid .nav__burger span{background:var(--paper)}
.nav__mobile{
  display:flex;
  position:fixed;
  top:var(--nav-h);
  left:0;
  right:0;
  bottom:0;
  background:var(--charcoal);
  z-index:120;
  flex-direction:column;
  padding:18px 24px 28px;
  gap:6px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  overflow-y:auto;
  overscroll-behavior:contain;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(-10px);
  transition:opacity 0.24s var(--ease),transform 0.24s var(--ease),visibility 0.24s;
}
.nav__mobile.open{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}
.nav__mobile a{font-family:var(--font-display);font-size:clamp(22px,5.2vw,28px);color:var(--paper);padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.08);line-height:1.2}
.nav__mobile a:last-child{border-bottom:none}
.nav__mobile-cta{
  margin-top:36px;
  margin-bottom:28px;
  align-self:center;
  width:100%;
  max-width:320px;
  margin-left:auto;
  margin-right:auto;
  font-family:var(--font-sans) !important;
  font-size:16px !important;
  line-height:1.2;
  white-space:nowrap;
  justify-content:center;
  padding:14px 20px;
}

@media(max-width:1024px){
  .nav{padding:14px 0}
  .nav,
  .nav.scrolled,
  .nav--solid{
    background:#1b1d1b;
    backdrop-filter:none;
  }
  .nav__logo{height:44px}
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__mobile{
    position:fixed;
    top:var(--nav-h);
    min-height:calc(100dvh - var(--nav-h));
    left:0;
    right:0;
    bottom:0;
    background:#1b1d1b;
    background-image:none;
    backdrop-filter:none;
    z-index:131;
    margin-top:0;
    padding-top:18px;
  }
  .nav__burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav__burger.open span:nth-child(2){opacity:0}
  .nav__burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}

/* Homepage-only seam fix: remove any hero bleed between header and mobile menu */
@media(max-width:1024px){
  .nav--home{z-index:10000}
  .nav--home .nav__mobile{
    top:var(--nav-h);
    padding-top:18px;
    background:#1b1d1b;
    background-image:none;
    opacity:1;
    backdrop-filter:none;
    z-index:10001;
  }
}

@media(min-width:1025px){
  .nav__mobile{display:none !important}
  .nav__burger{display:none !important}
  .nav__links{display:flex}
  .nav__cta{display:inline-flex}
}

/* ========== HERO ========== */
.hero{
  min-height:100vh;
  padding:calc(var(--nav-h) + 70px) 0 90px;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.hero__bg-slider{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero__slide{
  position:absolute;
  inset:0;
  opacity:0;
  transform:scale(1.04);
  transition:opacity 0.9s ease, transform 6s ease;
}
.hero__slide img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.hero__slide.is-active{
  opacity:1;
  transform:scale(1);
}
.hero__veil{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg, rgba(20,22,24,0.78) 0%, rgba(20,22,24,0.56) 40%, rgba(20,22,24,0.32) 65%, rgba(20,22,24,0.56) 100%),
    radial-gradient(80% 70% at 20% 15%, rgba(68,130,195,0.2) 0%, rgba(68,130,195,0) 62%);
}
.hero::before{display:none}
.hero__grid{
  position:relative;
  z-index:3;
  width:100%;
}
.hero__text{max-width:660px}
.hero__eyebrow{margin-bottom:24px}
.hero__eyebrow .eyebrow{color:rgba(250,250,247,0.78)}
.hero__title{
  margin-bottom:24px;
  font-size:clamp(56px, 8.2vw, 126px);
  letter-spacing:-0.04em;
  line-height:0.9;
  color:var(--paper);
}
.hero__title em{display:inline-block;color:rgb(245, 130, 32) !important}
.hero__sub{
  font-size:clamp(17px, 1.45vw, 20px);
  color:rgba(250,250,247,0.86);
  max-width:560px;
  margin-bottom:38px;
  line-height:1.66;
}
.hero__ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero__ctas .btn{
  min-height:54px;
  padding:15px 30px;
  font-weight:600;
  letter-spacing:0.01em;
}
.hero__ctas .btn--ghost{
  background:rgba(250,250,247,0.08);
  border-color:rgba(250,250,247,0.45);
  color:var(--paper);
}
.hero__ctas .btn--ghost:hover{
  background:rgba(250,250,247,0.96);
  border-color:rgba(250,250,247,0.96);
  color:var(--charcoal);
}
.hero__controls{
  position:absolute;
  right:36px;
  bottom:28px;
  z-index:3;
  display:flex;
  align-items:center;
  gap:12px;
}
.hero__arrow{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(250,250,247,0.42);
  color:var(--paper);
  background:rgba(0,0,0,0.3);
  font-size:30px;
  line-height:1;
  display:grid;
  place-items:center;
}
.hero__arrow:hover{background:rgba(250,250,247,0.2)}
.hero__dots{
  display:flex;
  align-items:center;
  gap:8px;
}
.hero__dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(250,250,247,0.35);
  border:1px solid transparent;
}
.hero__dot.is-active{
  background:var(--orange);
  border-color:rgba(250,250,247,0.8);
}

@media(max-width:900px){
  .hero{min-height:auto;padding:calc(var(--nav-h) + 26px) 0 92px}
  .hero::before{display:none}
  .hero__text{max-width:100%}
  .hero__title{font-size:clamp(46px, 12vw, 76px)}
  .hero__sub{font-size:16px;max-width:100%;margin-bottom:30px}
  .hero__ctas .btn{min-height:50px;padding:13px 22px}
  .hero__controls{left:22px;right:auto;bottom:22px}
  .hero__arrow{width:36px;height:36px;font-size:24px}
  .hero__dot{width:9px;height:9px}
}

/* ========== PAGE HERO (for interior pages) ========== */
.page-hero{padding:calc(var(--nav-h) + 80px) 0 80px;background:var(--charcoal);color:var(--paper);position:relative;overflow:hidden}
.page-hero__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:end}
.page-hero__eyebrow{color:var(--blue);margin-bottom:24px}
.page-hero__title{color:var(--paper);max-width:820px;margin-bottom:0}
.page-hero__title em{color:var(--orange)}
.page-hero__sub{font-size:16px;color:rgba(250,250,247,0.7);line-height:1.6;max-width:360px;padding-bottom:10px}
.about-hero .page-hero__sub{max-width:520px}
@media(max-width:900px){
  .page-hero{padding:calc(var(--nav-h) + 50px) 0 60px}
  .page-hero__grid{grid-template-columns:1fr;gap:30px;align-items:start}
}

/* ========== STATS ========== */
.stats{background:var(--charcoal);color:var(--paper);padding:52px 0;border-top:1px solid rgba(255,255,255,0.055);border-bottom:1px solid rgba(255,255,255,0.055)}
.stats .wrap{max-width:1280px}
.stats__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0}
.stat{min-height:156px;padding:18px clamp(28px,3vw,46px);display:flex;flex-direction:column;justify-content:center;border-left:1px solid rgba(250,250,247,0.105);transition:transform 0.35s var(--ease),opacity 0.35s var(--ease)}
.stat:first-child{border-left:0}
.stat:hover{opacity:0.88;transform:translateY(-2px)}
.stat__value{font-family:var(--font-display);font-size:clamp(34px,3.2vw,50px);font-weight:500;line-height:1;letter-spacing:-0.012em;color:var(--paper);max-width:230px}
.stat__value--text{font-size:clamp(22px,1.75vw,29px);line-height:1.08;letter-spacing:0;max-width:210px}
.stat__value--text span{display:block}
.stat__label{font-size:11px;line-height:1.35;letter-spacing:0.2em;color:rgba(250,250,247,0.52);text-transform:uppercase;font-weight:600;margin-top:24px}
@media(max-width:900px){
  .stats{padding:46px 0}
  .stats__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stat{min-height:148px;padding:24px 30px}
  .stat:nth-child(odd){border-left:0}
  .stat:nth-child(n+3){border-top:1px solid rgba(250,250,247,0.105)}
}
@media(max-width:560px){
  .stats__grid{grid-template-columns:1fr}
  .stat{min-height:120px;padding:26px 10px;border-left:0;border-top:1px solid rgba(250,250,247,0.105)}
  .stat:first-child{border-top:0}
  .stat__value{font-size:34px}
  .stat__value--text{font-size:25px;max-width:280px}
  .stat__label{margin-top:18px}
}

/* ========== SERVICES ========== */
.services-hero{padding:calc(var(--nav-h) + 80px) 0 88px;background:var(--charcoal);color:var(--paper);border-top:1px solid rgba(255,255,255,0.06)}
.services-hero__grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,0.75fr);gap:70px;align-items:end}
.services-hero__copy .eyebrow{margin-bottom:24px}
.services-hero__eyebrow{color:var(--blue)}
.services-hero__copy h1{font-size:clamp(54px,7vw,98px);max-width:900px;color:var(--paper)}
.services-hero__copy h1 em{color:var(--orange)}
.services-hero__aside{display:grid;gap:26px;justify-items:start}
.services-hero__aside p{font-size:17px;line-height:1.72;color:rgba(250,250,247,0.7);max-width:470px}

.cta--image{position:relative;overflow:hidden;background:var(--charcoal);isolation:isolate}
.cta--image::before{content:"";position:absolute;inset:0;background:url('../images/projects/126-waverly-pl/optimized/02-open-living-kitchen.jpg') center/cover;opacity:0.28;filter:saturate(0.8);z-index:-2}
.cta--image::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(28,29,28,0.94),rgba(28,29,28,0.70));z-index:-1}

.services-feature{padding:112px 0;background:var(--blue-soft);border-top:1px solid rgba(68,130,195,0.18);border-bottom:1px solid rgba(68,130,195,0.18)}
.services-feature__grid{display:grid;grid-template-columns:minmax(0,0.82fr) minmax(360px,0.78fr);gap:clamp(42px,7vw,96px);align-items:center}
.services-feature__content{display:grid;gap:24px;justify-items:start}
.services-feature .eyebrow{margin-bottom:4px}
.services-feature h2{font-size:clamp(42px,5.8vw,82px);max-width:680px}
.services-feature__content p{font-size:17px;line-height:1.78;color:var(--ink);max-width:570px}
.services-feature__media{aspect-ratio:4/3;overflow:hidden;border-radius:2px;background:var(--charcoal);min-height:360px}
.services-feature__media img{width:100%;height:100%;object-fit:cover;filter:saturate(0.88) contrast(0.98);transition:transform 0.9s var(--ease),filter 0.35s var(--ease)}
.services-feature__media:hover img{transform:scale(1.035);filter:saturate(1) contrast(1)}

.services-overview{padding:108px 0;background:var(--paper)}
.services-overview__head{display:grid;grid-template-columns:minmax(0,0.95fr) minmax(280px,0.55fr);gap:56px;align-items:end;margin-bottom:48px}
.services-overview__head .eyebrow{margin-bottom:18px}
.services-overview__head h2{font-size:clamp(36px,4.6vw,64px);max-width:760px}
.services-overview__head p{font-size:15px;line-height:1.72;color:var(--ink);max-width:420px;justify-self:end}
.services-overview .services-overview__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;align-items:stretch}
.services-overview .services-card{min-height:310px;background:#fff;border:1px solid rgba(28,29,28,0.12);border-radius:6px;padding:32px 34px;display:flex;flex-direction:column;justify-content:flex-start;box-shadow:0 1px 0 rgba(28,29,28,0.03);transition:transform 0.35s var(--ease),box-shadow 0.35s var(--ease),border-color 0.35s var(--ease),background 0.35s var(--ease)}
.services-overview .services-card:nth-child(2),.services-overview .services-card:nth-child(3){background:#fff}
.services-overview .services-card:hover{transform:translateY(-4px);background:#fff;border-color:rgba(68,130,195,0.24);box-shadow:0 18px 42px rgba(20,22,24,0.075)}
.services-card__body{display:flex;flex-direction:column;min-height:0}
.services-card__eyebrow{font-size:10px;line-height:1.2;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:16px}
.services-overview .services-card h3{font-size:clamp(28px,3vw,40px);margin-bottom:16px}
.services-overview .services-card p{font-size:15px;line-height:1.64;color:var(--ink);max-width:520px;margin-bottom:22px}
.services-card__highlights{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0 0 22px;padding:0}
.services-card__highlights li{font-size:12px;line-height:1.25;color:var(--charcoal);border:1px solid rgba(28,29,28,0.12);border-radius:999px;padding:8px 12px;background:rgba(255,255,255,0.62)}
.services-card__link{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;margin-top:0;color:var(--blue);font-size:12px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;transition:color 0.25s var(--ease)}
.services-card__link span{transition:transform 0.25s var(--ease)}
.services-card__link:hover{color:var(--orange)}
.services-card__link:hover span{transform:translateX(4px)}

.service-details{background:var(--paper)}
.service-detail-section{padding:112px 0;background:#fff;border-top:1px solid rgba(28,29,28,0.08);scroll-margin-top:calc(var(--nav-h) + 24px)}
.service-detail-section--warm{background:var(--blue-soft)}
.service-detail-section__grid{display:grid;grid-template-columns:minmax(440px,1.08fr) minmax(0,1fr);gap:clamp(40px,5vw,72px);align-items:stretch}
.service-detail-section__grid--reverse{grid-template-columns:minmax(0,1fr) minmax(440px,1.08fr)}
.service-detail-section__media{aspect-ratio:auto;min-height:520px;height:100%;overflow:hidden;border-radius:4px;background:var(--charcoal)}
.service-detail-section__media img{width:100%;height:100%;object-fit:cover;filter:saturate(0.88) contrast(0.98);transition:transform 0.9s var(--ease),filter 0.35s var(--ease)}
.service-detail-section__media:hover img{transform:scale(1.035);filter:saturate(1) contrast(1)}
.service-detail-section__content{max-width:720px}
.service-detail-section__content .eyebrow{margin-bottom:20px}
.service-detail-section__content h2{font-size:clamp(40px,5vw,72px);margin-bottom:28px}
.service-detail-section__intro{display:grid;gap:16px;margin-bottom:34px}
.service-detail-section__intro p{font-size:16px;line-height:1.78;color:var(--ink);max-width:640px}
.service-detail-section__services{margin-top:8px}
.service-detail-section__services h3{font-size:24px;margin-bottom:20px}
.service-detail-section__services ul{list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:0;padding:0}
.service-detail-section__services li{font-size:13px;line-height:1.35;color:var(--charcoal);font-weight:500;background:rgba(255,255,255,0.64);border:1px solid rgba(28,29,28,0.10);border-radius:999px;padding:10px 14px}
.service-detail-section:not(.service-detail-section--warm) .service-detail-section__services li{background:#fff}
.service-detail-section__note{margin-top:36px;padding:26px 28px;border-left:2px solid var(--blue);background:var(--blue-soft);max-width:650px}
.service-detail-section--warm .service-detail-section__note{background:#fff}
.service-detail-section__note h3{font-size:24px;margin-bottom:12px}
.service-detail-section__note p{font-size:15px;line-height:1.76;color:var(--ink)}

.services{padding:120px 0;background:var(--paper)}
.services__head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:56px}
.services__head-right{text-align:right;color:var(--ink);font-size:14px;max-width:320px;justify-self:end;line-height:1.55}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gray)}
.service{background:var(--paper);padding:36px 32px;min-height:260px;display:flex;flex-direction:column;justify-content:space-between;border-top:2px solid var(--charcoal);transition:background 0.3s var(--ease),border-color 0.3s var(--ease),transform 0.3s var(--ease)}
.service:nth-child(n+4){border-top:1px solid var(--gray)}
.service:hover{background:var(--charcoal);border-top-color:var(--orange);transform:translateY(-2px)}
.service:hover .service__arrow{transform:translateX(4px)}
.service__num{font-size:11px;color:var(--ink);letter-spacing:0.15em;margin-bottom:18px;font-weight:500;transition:color 0.3s var(--ease)}
.service__title{font-family:var(--font-display);font-size:24px;font-weight:500;margin-bottom:12px;line-height:1.15;transition:color 0.3s var(--ease)}
.service__desc{font-size:14px;color:var(--ink);line-height:1.55;margin-bottom:20px;transition:color 0.3s var(--ease)}
.service__link{font-size:12px;color:var(--blue);font-weight:500;display:inline-flex;align-items:center;gap:6px;letter-spacing:0.03em;transition:color 0.3s var(--ease)}
.service__arrow{display:inline-block;transition:transform 0.3s var(--ease)}
.service:hover .service__num{color:var(--orange)}
.service:hover .service__title{color:var(--paper)}
.service:hover .service__desc{color:rgba(250,250,247,0.7)}
.service:hover .service__link{color:var(--orange)}

.commercial-services{padding:116px 0;background:var(--paper);border-top:1px solid var(--gray-soft);border-bottom:1px solid var(--gray-soft)}
.commercial-services__grid{display:grid;grid-template-columns:minmax(280px,0.85fr) minmax(0,1.15fr);gap:64px;align-items:start}
.commercial-services__intro .eyebrow{margin-bottom:20px}
.commercial-services__intro h2{margin-bottom:22px}
.commercial-services__intro p{font-size:15px;color:var(--ink);line-height:1.7;max-width:520px}
.commercial-services__cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.commercial-card{background:rgba(255,255,255,0.74);border:1px solid rgba(28,29,28,0.08);border-radius:4px;padding:28px;min-height:210px;transition:transform 0.35s var(--ease),border-color 0.35s var(--ease),background 0.35s var(--ease)}
.commercial-card:hover{transform:translateY(-3px);background:var(--white);border-color:rgba(68,130,195,0.28)}
.commercial-card__num{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:16px}
.commercial-card h3{font-size:26px;margin-bottom:12px}
.commercial-card p{font-size:14px;color:var(--ink);line-height:1.65}
.commercial-services--home{background:var(--paper);padding-top:82px;border-top:1px solid var(--gray-soft)}

@media(max-width:900px){
  .services-hero{padding:calc(var(--nav-h) + 44px) 0 54px}
  .services-hero__copy h1{font-size:clamp(44px,11vw,70px)}
  .services-hero__grid{grid-template-columns:1fr;gap:34px}
  .services-feature{padding:78px 0}
  .services-feature__grid{grid-template-columns:1fr;gap:34px}
  .services-feature__media{min-height:0;aspect-ratio:16/10}
  .services-overview{padding:82px 0}
  .services-overview__head{grid-template-columns:1fr;gap:24px}
  .services-overview__head p{justify-self:start;max-width:620px}
  .services-overview .services-overview__grid{grid-template-columns:1fr 1fr}
  .services-overview .services-card{padding:28px;min-height:300px}
  .service-detail-section{padding:82px 0}
  .service-detail-section__grid,.service-detail-section__grid--reverse{grid-template-columns:1fr;gap:36px}
  .service-detail-section__media{aspect-ratio:16/10;min-height:0;height:auto}
  .service-detail-section__grid--reverse .service-detail-section__media{grid-row:1}
  .service-detail-section__services ul{grid-template-columns:repeat(2,minmax(0,1fr))}
  .services{padding:80px 0}
  .services__head{grid-template-columns:1fr;gap:20px;margin-bottom:40px}
  .services__head-right{text-align:left;justify-self:start}
  .services__grid{grid-template-columns:1fr 1fr}
  .commercial-services{padding:80px 0}
  .commercial-services__grid{grid-template-columns:1fr;gap:36px}
}
@media(max-width:600px){
  .services-feature{padding:56px 0}
  .services-feature__content p{font-size:15px}
  .services-overview{padding:64px 0}
  .services-overview__head{margin-bottom:30px}
  .services-overview .services-overview__grid{grid-template-columns:1fr}
  .services-overview .services-card{min-height:auto;padding:26px}
  .services-overview .services-card h3{font-size:30px}
  .service-detail-section{padding:64px 0}
  .service-detail-section__content h2{font-size:clamp(34px,11vw,48px)}
  .service-detail-section__intro p{font-size:15px}
  .service-detail-section__services ul{grid-template-columns:1fr}
  .service-detail-section__services li{border-radius:4px}
  .service-detail-section__note{padding:22px 24px}
  .services__grid{grid-template-columns:1fr}
  .commercial-services__cards{grid-template-columns:1fr}
  .commercial-card{padding:24px;min-height:auto}
}

/* ========== SERVICE AREAS (SERVICES PAGE) ========== */
.service-areas{padding:82px 0;background:var(--blue-soft);border-top:1px solid rgba(68,130,195,0.18);border-bottom:1px solid rgba(68,130,195,0.18)}
.service-areas__inner{max-width:860px}
.service-areas h2{margin-bottom:14px}
.service-areas p{font-size:15px;color:var(--ink);line-height:1.65;margin-bottom:12px}
.service-areas__list{font-size:14px;color:var(--charcoal);line-height:1.75;font-weight:500}
@media(max-width:900px){
  .service-areas{padding:56px 0}
}

/* ========== SELECTED WORK ========== */
.work{padding:126px 0;background:var(--blue-soft);border-top:1px solid rgba(68,130,195,0.18);border-bottom:1px solid rgba(68,130,195,0.18)}
.work__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
.work__left .eyebrow{margin-bottom:20px}
.work__left h2{margin-bottom:22px}
.work__left p{font-size:15px;color:var(--ink);line-height:1.65;margin-bottom:24px;max-width:520px}
.work__link{color:var(--blue);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;letter-spacing:0.02em}
.work__link:hover{color:var(--blue-deep)}
.work__tiles{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.tile{aspect-ratio:3/4;position:relative;overflow:hidden;border-radius:2px;cursor:pointer;background:var(--charcoal)}
.tile:nth-child(even){margin-top:40px}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform 0.9s var(--ease)}
.tile:hover img{transform:scale(1.06)}
.tile__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.75) 0%,rgba(0,0,0,0.1) 45%,transparent 70%);transition:background 0.4s}
.tile:hover .tile__overlay{background:linear-gradient(to top,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.25) 50%,rgba(0,0,0,0.1) 100%)}
.tile__info{position:absolute;bottom:18px;left:18px;right:18px;color:#fff}
.tile__name{font-family:var(--font-display);font-size:18px;font-weight:500;line-height:1.2;margin-bottom:4px}
.tile__meta{font-size:11px;color:rgba(255,255,255,0.75);letter-spacing:0.05em}
@media(max-width:900px){
  .work{padding:80px 0}
  .work__grid{grid-template-columns:1fr;gap:36px}
  .work__tiles{grid-template-columns:1fr 1fr;gap:12px}
  .tile:nth-child(even){margin-top:24px}
}

/* ========== PULL QUOTE ========== */
.quote{padding:120px 0;background:var(--paper)}
.quote__wrap{max-width:760px}
.quote__text{font-family:var(--font-display);font-size:clamp(24px,3vw,38px);line-height:1.28;color:var(--charcoal);font-weight:500;letter-spacing:-0.01em;margin-bottom:28px}
.quote__attrib{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--ink);letter-spacing:0.18em;font-weight:500;text-transform:uppercase}
.quote__attrib::before{content:"";width:36px;height:1px;background:var(--charcoal)}
.quote__dot{color:var(--gray)}
@media(max-width:900px){.quote{padding:80px 0}}

/* ========== REVIEWS ========== */
.reviews{padding:126px 0;background:var(--blue-soft);border-top:1px solid rgba(68,130,195,0.18);border-bottom:1px solid rgba(68,130,195,0.18)}
.reviews__head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:56px}
.reviews__left .eyebrow{margin-bottom:20px}
.reviews__left h2{margin-bottom:20px}
.reviews__left p{font-size:15px;color:var(--ink);line-height:1.6;max-width:420px}
.reviews__right{text-align:right;justify-self:end}
.reviews__stars{display:flex;gap:4px;justify-content:flex-end;margin-bottom:10px}
.reviews__stars svg{width:20px;height:20px;fill:var(--orange)}
.reviews__num{font-family:var(--font-display);font-size:76px;font-weight:500;line-height:0.9;letter-spacing:-0.03em;color:var(--charcoal);margin-bottom:8px}
.reviews__basis{font-size:13px;color:var(--ink);margin-bottom:10px}
.reviews__link{color:var(--blue);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px}
.reviews__link:hover{color:var(--blue-deep)}

.reviews__grid{display:grid;grid-template-columns:1.25fr 1fr 1fr;gap:20px;align-items:stretch}
.review{background:var(--white);border:1px solid var(--gray);border-radius:2px;padding:30px;transition:background 0.3s var(--ease),border-color 0.3s var(--ease),transform 0.3s var(--ease),color 0.3s var(--ease)}
.review:hover{background:var(--charcoal);border-color:var(--charcoal);transform:translateY(-2px)}
.review--featured{grid-row:span 2;padding:36px}
.review--featured .review__text{font-size:clamp(20px,2vw,26px);line-height:1.42}
.review__stars{display:flex;gap:3px;margin-bottom:18px}
.review__stars svg{width:14px;height:14px;fill:var(--blue);transition:fill 0.3s var(--ease)}
.review__summary{font-size:11px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--blue);margin-bottom:12px;transition:color 0.3s var(--ease)}
.review__text{font-family:var(--font-display);font-size:17px;line-height:1.5;color:var(--charcoal);font-weight:400;margin-bottom:22px;transition:color 0.3s var(--ease)}
.review__services{font-size:12px;line-height:1.55;color:var(--ink);margin:-8px 0 20px;transition:color 0.3s var(--ease)}
.review__rule{width:40px;height:1px;background:var(--gray);margin-bottom:18px;transition:background 0.3s var(--ease)}
.review__name{font-size:14px;font-weight:600;color:var(--charcoal);margin-bottom:4px;transition:color 0.3s var(--ease)}
.review__project{font-size:12px;color:var(--ink);margin-bottom:4px;transition:color 0.3s var(--ease)}
.review__date{font-size:11px;color:#9a9a95;letter-spacing:0.08em;transition:color 0.3s var(--ease)}
.review:hover .review__stars svg{fill:var(--orange)}
.review:hover .review__summary{color:var(--orange)}
.review:hover .review__text{color:var(--paper)}
.review:hover .review__services{color:rgba(250,250,247,0.72)}
.review:hover .review__rule{background:var(--orange)}
.review:hover .review__name{color:var(--paper)}
.review:hover .review__project{color:var(--orange)}
.review:hover .review__date{color:rgba(250,250,247,0.5)}

.reviews__foot{text-align:center;margin-top:48px;padding-top:36px;border-top:1px solid var(--gray-soft)}
.reviews__foot a{color:var(--blue);font-size:13px;font-weight:500;letter-spacing:0.02em}
.reviews__foot a:hover{color:var(--blue-deep)}

@media(max-width:1000px){
  .reviews__grid{grid-template-columns:1fr 1fr}
  .review--featured{grid-column:1 / -1;grid-row:auto}
}
@media(max-width:640px){
  .reviews{padding:80px 0}
  .reviews__head{grid-template-columns:1fr;gap:28px}
  .reviews__right{text-align:left;justify-self:start}
  .reviews__stars{justify-content:flex-start}
  .reviews__grid{grid-template-columns:1fr}
  .review--featured{padding:30px}
}

/* ========== PROCESS ========== */
.process{padding:120px 0;background:var(--charcoal);color:var(--paper)}
.process__head{margin-bottom:60px;max-width:720px}
.process__head .eyebrow{color:rgba(250,250,247,0.7);margin-bottom:20px}
.process__head h2{color:var(--paper)}
.process__head em{color:var(--blue)}
.process__line{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.process__line::before{content:"";position:absolute;top:16px;left:2%;right:2%;height:1px;background:linear-gradient(to right,transparent,var(--blue) 10%,var(--blue) 90%,transparent)}
.step{position:relative;padding-top:44px}
.step::before{content:"";position:absolute;top:10px;left:0;width:12px;height:12px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 5px var(--charcoal)}
.step__num{font-family:var(--font-display);font-size:15px;color:var(--blue);font-weight:500;letter-spacing:0.05em;margin-bottom:8px}
.step__title{font-family:var(--font-display);font-size:19px;font-weight:500;color:var(--paper);margin-bottom:8px;line-height:1.2}
.step__desc{font-size:13px;color:rgba(250,250,247,0.65);line-height:1.55}
@media(max-width:900px){
  .process{padding:80px 0}
  .process__line{grid-template-columns:1fr;gap:30px}
  .process__line::before{left:5px;right:auto;top:20px;bottom:20px;width:1px;height:auto;background:linear-gradient(to bottom,var(--blue) 0%,var(--blue) 100%)}
  .step{padding-top:0;padding-left:36px}
  .step::before{top:4px;left:0}
}

/* ========== FINAL CTA ========== */
.cta{padding:100px 0;background:var(--charcoal);color:var(--paper);border-top:1px solid rgba(255,255,255,0.06)}
.cta__grid{display:grid;grid-template-columns:2fr 1fr;gap:60px;align-items:center}
.cta__left .eyebrow{margin-bottom:22px}
.cta__left h2{color:var(--paper);margin-bottom:18px;max-width:560px}
.cta__left em{color:var(--orange)}
.cta__left p{color:rgba(250,250,247,0.65);font-size:15px;max-width:480px;line-height:1.6}
.cta__buttons{display:flex;flex-direction:column;gap:12px;align-items:stretch}
.cta__buttons .btn{justify-content:center}
@media(max-width:900px){
  .cta{padding:70px 0}
  .cta__grid{grid-template-columns:1fr;gap:36px}
  .cta__buttons{flex-direction:row;flex-wrap:wrap}
  .cta__buttons .btn{flex:1;min-width:200px}
}

/* ========== FOOTER ========== */
.footer{background:var(--charcoal);color:var(--paper);padding:80px 0 28px;border-top:1px solid rgba(255,255,255,0.06)}
.footer__grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:56px}
.footer__brand{display:flex;align-items:center;margin-bottom:22px}
.footer__logo{height:56px;width:auto;display:block}
.footer__tag{font-size:14px;color:rgba(250,250,247,0.55);line-height:1.55;max-width:260px;margin-bottom:24px}
.footer__socials{display:flex;gap:10px}
.footer__social{width:38px;height:38px;border:1px solid rgba(255,255,255,0.15);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:rgba(250,250,247,0.6);transition:all 0.25s}
.footer__social svg{width:16px;height:16px}
.footer__social:hover{color:var(--orange);border-color:var(--orange)}
.footer__col-h{font-size:11px;letter-spacing:0.22em;font-weight:500;color:var(--gray);text-transform:uppercase;margin-bottom:22px}
.footer__list{list-style:none;display:flex;flex-direction:column;gap:14px}
.footer__list a{font-size:14px;color:rgba(250,250,247,0.7);transition:color 0.2s}
.footer__list a:hover{color:var(--paper)}
.footer__contact{display:flex;flex-direction:column;gap:14px}
.footer__contact-item{font-size:14px;color:rgba(250,250,247,0.75)}
.footer__contact-item a:hover{color:var(--paper)}
.footer__areas-h{font-size:11px;letter-spacing:0.22em;font-weight:500;color:var(--gray);text-transform:uppercase;margin-top:22px;margin-bottom:10px}
.footer__areas{font-size:13px;color:rgba(250,250,247,0.55);line-height:1.7}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,0.08);font-size:12px;color:rgba(250,250,247,0.45);flex-wrap:wrap;gap:14px}
.footer__bottom a{margin-left:20px;transition:color 0.2s}
.footer__bottom a:hover{color:var(--paper)}
.footer__legal-note{letter-spacing:0.02em}
@media(max-width:900px){.footer__grid{grid-template-columns:1fr 1fr;gap:40px}}
@media(max-width:600px){
  .footer__grid{grid-template-columns:1fr;gap:36px}
  .footer__bottom{flex-direction:column;align-items:flex-start;text-align:left}
  .footer__bottom a{margin-left:0;margin-right:16px}
}

/* ========== PROJECTS PAGE ========== */
.projects-filter{padding:42px 0;background:var(--blue-soft);border-bottom:1px solid rgba(68,130,195,0.18);position:sticky;top:var(--nav-h);z-index:50;backdrop-filter:blur(8px);background:rgba(234,242,248,0.96)}
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.filter-label{font-size:11px;letter-spacing:0.22em;color:var(--ink);text-transform:uppercase;font-weight:500;margin-right:8px}
.filter-btn{padding:8px 16px;border:1px solid var(--gray);border-radius:999px;font-size:13px;color:var(--ink);background:transparent;cursor:pointer;transition:all 0.25s}
.filter-btn:hover{border-color:var(--charcoal);color:var(--charcoal)}
.filter-btn.active{background:var(--charcoal);border-color:var(--charcoal);color:var(--paper)}

.projects-grid{padding:90px 0 84px;background:var(--paper)}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px 24px}
.pcard{background:transparent;border-radius:2px;overflow:hidden;cursor:pointer;transition:transform 0.4s var(--ease),opacity 0.4s var(--ease)}
.pcard:hover{transform:translateY(-5px)}
.pcard.active .pcard__img{outline:1px solid var(--blue);outline-offset:4px}
.pcard__img{aspect-ratio:4/3;overflow:hidden;background:var(--gray);border-radius:3px}
.pcard__img img{width:100%;height:100%;object-fit:cover;transition:transform 0.9s var(--ease),filter 0.4s var(--ease)}
.pcard:hover .pcard__img img{transform:scale(1.05)}
.pcard:hover .pcard__img img{filter:saturate(1.04) contrast(1.02)}
.pcard__body{padding:20px 2px 0}
.pcard__tag{font-size:10px;letter-spacing:0.2em;color:var(--blue);text-transform:uppercase;font-weight:600;margin-bottom:10px}
.pcard__title{font-family:var(--font-display);font-size:clamp(22px,2.1vw,30px);font-weight:500;color:var(--charcoal);margin-bottom:14px;line-height:1.12}
.pcard__open{font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:10px;transition:color 0.25s var(--ease)}
.pcard__open::after{content:"";width:28px;height:1px;background:currentColor;transition:width 0.25s var(--ease)}
.pcard:hover .pcard__open{color:var(--blue)}
.pcard:hover .pcard__open::after{width:42px}
.pcard--priority-1{order:-6}
.pcard--priority-2{order:-5}
.pcard--priority-3{order:-4}
.pcard--priority-4{order:-3}
.pcard--priority-5{order:-2}
.pcard--priority-6{order:-1}
@media(max-width:900px){.pgrid{grid-template-columns:1fr 1fr;gap:20px}}
@media(max-width:600px){.pgrid{grid-template-columns:1fr}}

.project-gallery{position:fixed;inset:0;z-index:160;display:flex;align-items:center;justify-content:center;padding:28px;background:rgba(28,29,28,0.34);opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.28s var(--ease),visibility 0.28s;overflow:hidden}
.project-gallery.open{opacity:1;visibility:visible;pointer-events:auto}
.project-gallery__backdrop{position:absolute;inset:0}
.project-gallery__dialog{position:relative;width:min(1280px,94vw);max-height:90vh;background:var(--paper);color:var(--charcoal);border-radius:4px;padding:28px;display:grid;grid-template-rows:auto minmax(0,65vh) auto;gap:18px;box-shadow:0 22px 58px rgba(0,0,0,0.18);overflow:auto}
.project-gallery__close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:var(--charcoal);font-size:28px;line-height:1;background:rgba(28,29,28,0.055);z-index:3;transition:background 0.25s var(--ease),transform 0.25s var(--ease)}
.project-gallery__close:hover{background:rgba(28,29,28,0.1);transform:translateY(-1px)}
.project-gallery__header{display:flex;justify-content:space-between;gap:42px;align-items:end;margin-bottom:0;padding-right:52px}
.project-gallery__label,.project-gallery__count{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--blue);font-weight:700}
.project-gallery__header h2{font-size:clamp(24px,2.8vw,42px);margin-top:10px;max-width:760px}
.project-gallery__count{color:var(--ink);white-space:nowrap;padding-bottom:8px}
.project-gallery__stage{position:relative;background:var(--paper);border-radius:2px;overflow:hidden;height:min(65vh,720px);max-height:65vh;display:flex;align-items:center;justify-content:center;min-height:0}
.project-gallery__stage img{width:100%;height:100%;object-fit:contain;opacity:1;transition:opacity 0.25s var(--ease)}
.project-gallery__stage img.is-changing{opacity:0}
.project-gallery__nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(250,250,247,0.86);color:var(--charcoal);font-size:32px;line-height:1;display:grid;place-items:center;transition:background 0.25s var(--ease),opacity 0.25s var(--ease),transform 0.25s var(--ease);z-index:2}
.project-gallery__nav:hover{background:var(--white);transform:translateY(-50%) scale(1.03)}
.project-gallery__nav--prev{left:18px}
.project-gallery__nav--next{right:18px}
.project-gallery__thumbs{display:flex;justify-content:center;gap:14px;overflow-x:auto;padding:6px 0 2px;scrollbar-width:thin;min-height:0}
.project-gallery__thumb{flex:0 0 118px;aspect-ratio:4/3;border:1px solid transparent;border-radius:2px;overflow:hidden;opacity:0.54;transition:opacity 0.25s var(--ease),border-color 0.25s var(--ease),transform 0.25s var(--ease)}
.project-gallery__thumb:hover{opacity:0.9;transform:translateY(-1px)}
.project-gallery__thumb.active{opacity:1;border-color:var(--blue)}
.project-gallery__thumb img{width:100%;height:100%;object-fit:cover}
body.gallery-open{overflow:hidden}
@media(max-width:760px){
  .project-gallery{padding:12px}
  .project-gallery__dialog{width:100%;max-height:90vh;padding:18px;gap:14px;grid-template-rows:auto minmax(0,58vh) auto}
  .project-gallery__header{display:block;margin-bottom:0;padding-right:44px}
  .project-gallery__count{padding-bottom:0;margin-top:8px}
  .project-gallery__stage{height:min(58vh,520px);max-height:58vh}
  .project-gallery__nav{width:38px;height:38px;font-size:28px}
  .project-gallery__nav--prev{left:10px}
  .project-gallery__nav--next{right:10px}
  .project-gallery__thumbs{justify-content:flex-start;gap:10px;padding-top:4px}
  .project-gallery__thumb{flex-basis:86px}
}

/* ========== SERVICE DETAIL PAGE ========== */
.kb-hero{position:relative;min-height:100svh;background:var(--charcoal);overflow:hidden;color:var(--paper);display:flex;align-items:flex-end;padding:calc(var(--nav-h) + 70px) 0 82px;isolation:isolate}
.kb-hero > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:-3;filter:saturate(0.92) contrast(0.96)}
.kb-hero__veil{position:absolute;inset:0;background:linear-gradient(90deg,rgba(28,29,28,0.86) 0%,rgba(28,29,28,0.46) 48%,rgba(28,29,28,0.08) 100%),linear-gradient(to top,rgba(28,29,28,0.66),rgba(28,29,28,0.05) 52%);z-index:-2}
.kb-hero__content{display:grid;justify-items:start;gap:24px}
.kb-hero h1{color:var(--paper);font-size:clamp(58px,8.2vw,126px);max-width:1050px}
.kb-hero h1 em{color:var(--orange)}
.kb-hero p{font-size:18px;line-height:1.65;color:rgba(250,250,247,0.78);max-width:560px}

.kb-intro{padding:120px 0;background:var(--paper)}
.kb-intro__grid{display:grid;grid-template-columns:minmax(0,0.92fr) minmax(360px,1.08fr);gap:74px;align-items:center}
.kb-intro__copy .eyebrow{margin-bottom:20px}
.kb-intro__copy h2{margin-bottom:28px}
.kb-intro__copy p{font-size:17px;line-height:1.75;color:var(--ink);max-width:620px;margin-bottom:16px}
.kb-intro__image{aspect-ratio:5/4;overflow:hidden;border-radius:4px;background:var(--charcoal)}
.kb-intro__image img{width:100%;height:100%;object-fit:cover;transition:transform 0.9s var(--ease)}
.kb-intro__image:hover img{transform:scale(1.04)}

.kb-section-head{max-width:820px;margin-bottom:48px}
.kb-section-head .eyebrow{margin-bottom:18px}
.kb-gallery{padding:124px 0;background:var(--blue-soft);border-top:1px solid rgba(68,130,195,0.18);border-bottom:1px solid rgba(68,130,195,0.18)}
.kb-gallery__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;padding:16px;background:rgba(255,255,255,0.56);border:1px solid rgba(68,130,195,0.16);border-radius:6px}
.kb-shot,.kb-shot--wide,.kb-shot--tall{position:relative;overflow:hidden;border-radius:3px;background:var(--charcoal);aspect-ratio:4/3;grid-column:auto;grid-row:auto;border:1px solid rgba(255,255,255,0.72)}
.kb-shot img{width:100%;height:100%;object-fit:cover;transition:transform 0.9s var(--ease),filter 0.35s var(--ease)}
.kb-shot::after{display:none}
.kb-shot figcaption{display:none}
.kb-shot:hover img{transform:scale(1.035);filter:saturate(1.03)}

.kb-breakdown{padding:118px 0;background:var(--paper);border-top:1px solid var(--gray-soft);border-bottom:1px solid var(--gray-soft)}
.kb-breakdown__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.kb-module{background:var(--white);border:1px solid rgba(28,29,28,0.08);border-radius:4px;padding:34px;min-height:360px;display:flex;flex-direction:column;transition:transform 0.3s var(--ease),box-shadow 0.3s var(--ease),border-color 0.3s var(--ease)}
.kb-module:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(20,22,24,0.08);border-color:rgba(68,130,195,0.24)}
.kb-module span{font-family:var(--font-display);font-size:40px;color:var(--blue);line-height:1;margin-bottom:28px}
.kb-module h3{font-size:clamp(25px,2.2vw,34px);margin-bottom:24px}
.kb-module p{font-size:15px;line-height:1.7;color:var(--ink);margin-bottom:22px}
.kb-module ul{list-style:none;display:grid;gap:13px;margin-top:auto}
.kb-module li{position:relative;padding-left:18px;font-size:14px;line-height:1.55;color:var(--ink)}
.kb-module li::before{content:"";position:absolute;left:0;top:0.7em;width:6px;height:6px;border-radius:50%;background:var(--orange)}
.kb-module--dark{background:var(--charcoal);color:var(--paper);border-color:var(--charcoal)}
.kb-module--dark h3{color:var(--paper)}
.kb-module--dark p{color:rgba(250,250,247,0.72)}
.kb-module--dark li{color:rgba(250,250,247,0.76)}

.kb-process{padding:120px 0;background:var(--charcoal);color:var(--paper)}
.kb-process h2,.kb-process h3{color:var(--paper)}
.kb-process em{color:var(--orange)}
.kb-process__grid{display:grid;grid-template-columns:minmax(280px,0.78fr) minmax(0,1.22fr);gap:70px;align-items:start}
.kb-steps{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.12)}
.kb-steps article{background:var(--charcoal);padding:32px;min-height:230px}
.kb-steps span{display:block;font-family:var(--font-display);font-size:34px;color:var(--orange);line-height:1;margin-bottom:28px}
.kb-steps h3{font-size:28px;margin-bottom:12px}
.kb-steps p{font-size:14px;line-height:1.7;color:rgba(250,250,247,0.68)}

.kb-why{padding:116px 0;background:var(--paper)}
.kb-why__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.kb-why__grid article{border-top:2px solid var(--charcoal);padding:26px 0 0}
.kb-why__grid h3{font-size:24px;margin-bottom:14px}
.kb-why__grid p{font-size:14px;line-height:1.65;color:var(--ink)}
.cta--kitchen::before{background-image:url('../images/projects/29-fairway-manhasset/optimized/02-kitchen-waterfall-island.jpg')}

.svc-intro{padding:120px 0;background:var(--paper)}
.svc-intro__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.svc-intro__media{aspect-ratio:4/5;overflow:hidden;border-radius:3px;background:var(--charcoal)}
.svc-intro__media img{width:100%;height:100%;object-fit:cover}
.svc-intro__text h2{margin-bottom:24px}
.svc-intro__text p{font-size:16px;color:var(--ink);line-height:1.7;margin-bottom:18px}
.svc-intro__text p:last-child{margin-bottom:0}
@media(max-width:900px){
  .kb-hero{min-height:86svh;padding:calc(var(--nav-h) + 52px) 0 64px}
  .kb-hero h1{font-size:clamp(48px,13vw,78px)}
  .kb-intro,.kb-gallery,.kb-breakdown,.kb-process,.kb-why{padding:80px 0}
  .kb-intro__grid,.kb-process__grid{grid-template-columns:1fr;gap:40px}
  .kb-intro__image{aspect-ratio:4/3}
  .kb-gallery__grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:auto}
  .kb-breakdown__grid{grid-template-columns:1fr}
  .kb-module{min-height:auto}
  .kb-why__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:26px 18px}
  .svc-intro{padding:80px 0}
  .svc-intro__grid{grid-template-columns:1fr;gap:40px}
}

.svc-features{padding:126px 0;background:var(--blue-soft);border-top:1px solid rgba(68,130,195,0.18);border-bottom:1px solid rgba(68,130,195,0.18)}
.svc-features__head{margin-bottom:60px;max-width:680px}
.svc-features__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.feature{}
.feature__num{font-family:var(--font-display);font-size:40px;color:var(--blue);font-weight:500;line-height:1;margin-bottom:16px;letter-spacing:-0.02em}
.feature__title{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--charcoal);margin-bottom:10px;line-height:1.2}
.feature__desc{font-size:14px;color:var(--ink);line-height:1.6}
@media(max-width:900px){
  .svc-features{padding:80px 0}
  .svc-features__grid{grid-template-columns:1fr;gap:36px}
}

.svc-gallery{padding:120px 0;background:var(--paper)}
.svc-gallery__head{margin-bottom:48px}
.svc-gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.svc-gallery__img{aspect-ratio:4/5;overflow:hidden;background:var(--gray);border-radius:2px}
.svc-gallery__img:nth-child(3n+2){aspect-ratio:4/3;margin-top:30px}
.svc-gallery__img img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease)}
.svc-gallery__img:hover img{transform:scale(1.04)}
@media(max-width:900px){
  .svc-gallery{padding:80px 0}
  .svc-gallery__grid{grid-template-columns:1fr 1fr}
  .svc-gallery__img:nth-child(3n+2){margin-top:16px}
}
@media(max-width:560px){
  .kb-hero p{font-size:16px}
  .kb-gallery__grid{grid-template-columns:1fr;grid-auto-rows:auto;padding:12px;gap:12px}
  .kb-shot,.kb-shot--wide,.kb-shot--tall{grid-column:auto;grid-row:auto;aspect-ratio:4/3}
  .kb-steps{grid-template-columns:1fr}
  .kb-why__grid{grid-template-columns:1fr}
  .svc-gallery__grid{grid-template-columns:1fr}
  .svc-gallery__img:nth-child(3n+2){margin-top:0}
}

/* ========== ABOUT PAGE ========== */
.about-intro{padding:124px 0;background:var(--paper)}
.about-intro__grid{display:grid;grid-template-columns:minmax(0,0.96fr) minmax(400px,1.04fr);gap:72px;align-items:stretch}
.about-intro__copy{max-width:680px}
.about-intro__eyebrow{margin-bottom:20px}
.about-intro__title{margin-bottom:28px}
.about-intro__text{font-family:var(--font-display);font-size:22px;line-height:1.4;color:var(--charcoal);font-weight:400;margin-bottom:24px}
.about-intro__body p{font-size:15px;line-height:1.7;color:var(--ink);margin-bottom:16px}
.about-intro__body p:last-child{margin-bottom:0}
.about-intro__visual{display:flex;min-height:100%}
.about-intro__photo{overflow:hidden;border-radius:4px;background:var(--charcoal);width:100%;min-height:100%}
.about-intro__photo img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease)}
.about-intro__photo:hover img{transform:scale(1.04)}
.about-intro__stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin-top:38px;padding-top:28px;border-top:1px solid var(--gray-soft)}
.about-intro__stats div{min-width:0;padding:0 18px;border-left:1px solid rgba(28,29,28,0.08);display:flex;flex-direction:column;justify-content:flex-start}
.about-intro__stats div:first-child{padding-left:0;border-left:0}
.about-intro__stats strong{display:block;font-family:var(--font-display);font-size:clamp(28px,2.6vw,36px);line-height:1;color:var(--blue);font-weight:500;margin-bottom:12px;letter-spacing:-0.01em}
.about-intro__stats .about-intro__stat-text{font-size:clamp(18px,1.5vw,22px);line-height:1.12;max-width:150px;letter-spacing:0}
.about-intro__stats span{display:block;font-size:10px;line-height:1.35;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink);font-weight:600;margin-top:auto}
@media(max-width:900px){
  .about-intro{padding:80px 0}
  .about-intro__grid{grid-template-columns:1fr;gap:40px}
  .about-intro__copy{max-width:none}
}

.values{padding:120px 0;background:var(--charcoal);color:var(--paper)}
.values__head{margin-bottom:62px;max-width:820px}
.values__head h2{color:var(--paper)}
.values__head em{color:var(--orange)}
.values__head p{font-size:16px;line-height:1.7;color:rgba(250,250,247,0.68);max-width:560px;margin-top:24px}
.values__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.value{border:1px solid rgba(255,255,255,0.1);border-radius:4px;padding:30px;min-height:292px;background:rgba(250,250,247,0.025);transition:transform 0.35s var(--ease),border-color 0.35s var(--ease),background 0.35s var(--ease)}
.value:nth-child(4n+2),.value:nth-child(4n+3){background:rgba(250,250,247,0.04)}
.value:hover{transform:translateY(-3px);border-color:rgba(68,130,195,0.38);background:rgba(250,250,247,0.055)}
.value__num{font-size:10px;color:var(--blue);letter-spacing:0.2em;font-weight:700;margin-bottom:20px;text-transform:uppercase}
.value__num::after{content:"";display:block;width:34px;height:1px;background:rgba(68,130,195,0.65);margin-top:14px}
.value__title{font-family:var(--font-display);font-size:clamp(24px,2.2vw,32px);font-weight:500;color:var(--paper);margin-bottom:18px;line-height:1.12}
.value__desc{font-size:15px;color:rgba(250,250,247,0.68);line-height:1.72;max-width:560px}
@media(max-width:900px){
  .values{padding:80px 0}
  .values__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
  .value{padding:26px;min-height:auto}
}
@media(max-width:700px){
  .values__grid{grid-template-columns:1fr}
  .values__head{margin-bottom:42px}
  .values__head p{font-size:15px}
}

.about-work{padding:112px 0;background:var(--blue-soft);border-top:1px solid rgba(68,130,195,0.18);border-bottom:1px solid rgba(68,130,195,0.18)}
.about-work__head{display:grid;grid-template-columns:minmax(280px,0.8fr) minmax(0,1.2fr);gap:58px;align-items:end;margin-bottom:42px}
.about-work__copy .eyebrow{margin-bottom:20px}
.about-work__copy p{font-size:15px;line-height:1.7;color:var(--ink);max-width:560px}
.about-work__head h2{max-width:620px;justify-self:end}
.about-work__grid{display:grid;grid-template-columns:minmax(0,1.38fr) minmax(260px,0.82fr);grid-template-rows:1fr 1fr;gap:14px}
.about-work__photo{overflow:hidden;background:var(--charcoal);border-radius:4px;aspect-ratio:auto;min-height:0}
.about-work__photo--large{grid-row:1 / 3;aspect-ratio:auto;height:100%}
.about-work__photo img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease)}
.about-work__photo:hover img{transform:scale(1.04)}

.about-team{padding:112px 0;background:var(--paper)}
.about-team__head{display:grid;grid-template-columns:minmax(280px,0.78fr) minmax(0,1.22fr);gap:58px;align-items:end;margin-bottom:42px}
.about-team__head .eyebrow{margin-bottom:18px}
.about-team__head h2{max-width:620px}
.about-team__head p{font-size:15px;line-height:1.7;color:var(--ink);max-width:600px;justify-self:end}
.about-team__cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;align-items:stretch}
.team-card{background:var(--white);border:1px solid rgba(28,29,28,0.08);padding:14px;border-radius:4px;display:flex;flex-direction:column;min-height:100%;transition:transform 0.3s var(--ease),border-color 0.3s var(--ease),box-shadow 0.3s var(--ease),background 0.3s var(--ease)}
.team-card:hover{transform:translateY(-3px);background:var(--white);border-color:rgba(68,130,195,0.28);box-shadow:0 20px 40px rgba(20,22,24,0.08)}
.team-card__img{aspect-ratio:4/3;overflow:hidden;background:var(--gray-soft);margin-bottom:18px;position:relative;border-radius:2px}
.team-card__img img{width:100%;height:100%;object-fit:cover;filter:saturate(0.9) contrast(0.98);transition:transform 0.8s var(--ease),filter 0.3s var(--ease)}
.team-card:hover .team-card__img img{transform:scale(1.04);filter:saturate(1)}
.team-card__name{font-family:var(--font-display);font-size:22px;font-weight:500;line-height:1.2;color:var(--charcoal);margin-bottom:6px}
.team-card__role{font-size:10px;line-height:1.45;letter-spacing:0.14em;color:var(--blue);text-transform:uppercase;font-weight:700;margin-bottom:10px}
.team-card__bio{font-size:14px;line-height:1.6;color:var(--ink);margin-top:auto}
.leadership{background:var(--paper);border-top:1px solid var(--gray-soft);border-bottom:1px solid var(--gray-soft)}
.leadership__grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.leader-card{background:var(--white);border:1px solid var(--gray-soft);border-radius:4px;padding:36px;display:flex;flex-direction:column;gap:16px;min-height:100%;transition:border-color 0.3s var(--ease),box-shadow 0.3s var(--ease),transform 0.3s var(--ease)}
.leader-card:hover{border-color:rgba(68,130,195,0.22);box-shadow:0 22px 46px rgba(20,22,24,0.06);transform:translateY(-2px)}
.leader-card__role{font-size:11px;line-height:1.45;letter-spacing:0.18em;color:var(--blue);text-transform:uppercase;font-weight:700}
.leader-card h3{font-size:clamp(28px,3vw,42px);margin-bottom:2px}
.leader-card__bio{position:relative;overflow:hidden;max-height:164px;transition:max-height 0.48s var(--ease);will-change:max-height}
.leader-card__bio::after{content:"";position:absolute;left:0;right:0;bottom:0;height:72px;background:linear-gradient(to bottom,rgba(255,255,255,0),var(--white) 82%);opacity:0;pointer-events:none;transition:opacity 0.28s var(--ease)}
.leader-card__bio.is-collapsible::after,.leader-card__bio[data-expandable-bio]::after{opacity:1}
.leader-card.is-expanded .leader-card__bio::after{opacity:0}
.leader-card__bio p{font-size:15px;line-height:1.82;color:var(--ink);max-width:62ch}
.leader-card__bio p + p{margin-top:17px}
.leader-card__toggle{align-self:flex-start;border:0;background:transparent;color:var(--blue);font:inherit;font-size:12px;font-weight:700;line-height:1.2;letter-spacing:0.16em;text-transform:uppercase;padding:3px 0 4px;margin-top:2px;cursor:pointer;position:relative;transition:color 0.25s var(--ease),opacity 0.25s var(--ease)}
.leader-card__toggle::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;transform-origin:left;transform:scaleX(0.55);opacity:0.6;transition:transform 0.25s var(--ease),opacity 0.25s var(--ease)}
.leader-card__toggle:hover{color:var(--charcoal)}
.leader-card__toggle:hover::after,.leader-card__toggle:focus-visible::after{transform:scaleX(1);opacity:1}
.leader-card__toggle:focus-visible{outline:2px solid rgba(68,130,195,0.42);outline-offset:5px;border-radius:2px}
@media (prefers-reduced-motion: reduce){
  .leader-card__bio{transition:none}
}
@media(max-width:1024px){
  .about-team__cards{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:1024px){
  .about-intro__grid{grid-template-columns:1fr 0.9fr;gap:48px}
  .about-intro__stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:0}
  .about-intro__stats div{padding:22px 20px;border-top:1px solid rgba(28,29,28,0.08)}
  .about-intro__stats div:nth-child(-n+2){padding-top:0;border-top:0}
  .about-intro__stats div:nth-child(odd){padding-left:0;border-left:0}
  .about-work,.about-team{padding:86px 0}
  .about-work__head,.about-team__head{gap:36px}
  .about-work__grid{grid-template-columns:1.2fr 0.8fr}
}
@media(max-width:820px){
  .about-intro__grid,.about-work__head,.about-team__head{grid-template-columns:1fr;gap:34px}
  .about-work__head h2,.about-team__head p{justify-self:start}
  .about-work__grid{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}
  .about-work__photo--large{grid-column:1 / -1;grid-row:auto;aspect-ratio:16/9}
  .about-work__photo{aspect-ratio:4/3}
  .leadership__grid{grid-template-columns:1fr}
  .leader-card{padding:30px}
}
@media(max-width:700px){
  .about-work__grid{grid-template-columns:1fr;gap:12px}
  .about-work__photo,.about-work__photo--large{aspect-ratio:4/3}
  .about-intro__visual{min-height:auto}
  .about-intro__photo{aspect-ratio:4/3;min-height:0}
  .leader-card__bio p{font-size:14px;line-height:1.78}
}
@media(max-width:560px){
  .about-team__cards{grid-template-columns:1fr}
  .about-intro__stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:0}
  .team-card{padding:12px}
  .leader-card{padding:24px}
}
@media(max-width:430px){
  .about-intro{padding:66px 0}
  .about-work,.about-team{padding:66px 0}
  .about-intro__title,.about-work__head h2,.about-team__head h2{font-size:clamp(34px,11vw,46px)}
  .about-intro__text{font-size:20px}
  .about-intro__stats strong{font-size:28px}
  .about-intro__stats .about-intro__stat-text{font-size:20px}
  .about-intro__stats span,.team-card__role{letter-spacing:0.11em}
  .about-team__head{margin-bottom:30px}
}
@media(max-width:390px){
  .about-intro__stats{grid-template-columns:1fr}
  .about-intro__stats div{padding:20px 0;border-left:0}
  .about-intro__stats div:nth-child(2){padding-top:20px;border-top:1px solid rgba(28,29,28,0.08)}
  .about-work__copy p,.about-team__head p,.about-intro__body p{font-size:14px}
}

/* ========== CONTACT PAGE ========== */
.contact-main{padding:126px 0;background:var(--blue-soft);border-top:1px solid rgba(68,130,195,0.16)}
.contact-main__grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,1fr);gap:80px;align-items:start}
.contact-form{display:flex;flex-direction:column;gap:20px;min-width:0}
.contact-form__row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink);font-weight:500}
.field input,.field select,.field textarea{box-sizing:border-box;font-family:var(--font-sans);font-size:15px;padding:14px 16px;border:1px solid var(--gray);background:var(--white);color:var(--charcoal);border-radius:2px;transition:border-color 0.2s;width:100%;min-width:0}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field textarea{min-height:140px;resize:vertical}
.contact-form__btn{align-self:flex-start;margin-top:8px}
.contact-form [data-contact-form-status]{font-size:14px;line-height:1.55;color:var(--ink);margin:0}

.contact-info{min-width:0}
.contact-info__block{margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid var(--gray-soft)}
.contact-info__block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.contact-info__label{font-size:11px;letter-spacing:0.22em;color:var(--blue);text-transform:uppercase;font-weight:500;margin-bottom:14px}
.contact-info__value{font-family:var(--font-display);font-size:26px;color:var(--charcoal);font-weight:500;line-height:1.2;margin-bottom:6px}
.contact-info__value a{transition:color 0.2s}
.contact-info__value a:hover{color:var(--blue)}
.contact-info__sub{font-size:14px;color:var(--ink);line-height:1.6}

@media(max-width:900px){
  .contact-main{padding:80px 0}
  .contact-main__grid{grid-template-columns:1fr;gap:50px}
  .contact-form__row{grid-template-columns:1fr}
  .contact-info{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
  .contact-info__block{margin-bottom:0;padding:24px 0 0;border-bottom:0;border-top:1px solid var(--gray-soft)}
}

.service-areas{padding:108px 0;background:var(--paper)}
.service-areas__head{margin-bottom:40px;max-width:620px}
.service-areas__list{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.area{padding:24px 0;border-top:1px solid rgba(68,130,195,0.25)}
.area__name{font-family:var(--font-display);font-size:20px;font-weight:500;color:var(--charcoal);margin-bottom:6px}
.area__type{font-size:12px;color:var(--ink);letter-spacing:0.05em}
@media(max-width:900px){.service-areas__list{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.service-areas__list{grid-template-columns:1fr}}

/* ========== PROCESS PAGE (RESPONSIVE HARDENING) ========== */
.process-page-main{padding:120px 0}
.process-page-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start}
.process-page-sidebar{position:sticky;top:120px}
.process-page-intro{font-size:15px;color:var(--ink);line-height:1.7;margin-top:24px;max-width:360px}
.process-stage{
  border-top:1px solid var(--gray);
  padding:36px 0;
  display:grid;
  grid-template-columns:minmax(56px,80px) minmax(0,1fr);
  gap:clamp(16px,3vw,32px);
  align-items:start;
}
.process-stage__num{
  font-family:var(--font-display);
  font-size:clamp(34px,4vw,44px);
  color:var(--blue);
  font-weight:500;
  line-height:1;
  letter-spacing:-0.02em;
}
.process-stage h3{margin-bottom:12px}
.process-stage p{font-size:15px;color:var(--ink);line-height:1.7}
@media(max-width:1000px){
  .process-page-grid{grid-template-columns:1fr;gap:40px}
  .process-page-sidebar{position:static}
  .process-page-intro{max-width:100%}
}
@media(max-width:640px){
  .process-page-main{padding:80px 0}
  .process-stage{
    grid-template-columns:1fr;
    gap:12px;
    padding:28px 0;
  }
}

/* ========== REVEAL ANIM ========== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.9s var(--ease),transform 0.9s var(--ease)}
.reveal.is-in{opacity:1;transform:translateY(0)}
.reveal--1{transition-delay:0.08s}
.reveal--2{transition-delay:0.16s}
.reveal--3{transition-delay:0.24s}

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

/* ========== INTERACTIVE UI ========== */
.scroll-progress{
  position:fixed;
  top:0;
  left:0;
  height:3px;
  width:0;
  background:linear-gradient(90deg,var(--orange),var(--blue));
  z-index:130;
  transition:width 0.1s linear;
}

.back-to-top{
  position:fixed;
  right:24px;
  bottom:24px;
  width:46px;
  height:46px;
  border-radius:999px;
  background:var(--charcoal);
  color:var(--paper);
  border:1px solid rgba(255,255,255,0.15);
  box-shadow:0 10px 24px rgba(0,0,0,0.2);
  opacity:0;
  transform:translateY(14px);
  pointer-events:none;
  transition:opacity 0.25s var(--ease),transform 0.25s var(--ease),background 0.2s;
  z-index:120;
  font-size:20px;
  line-height:1;
}
.back-to-top.show{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.back-to-top:hover{background:var(--blue)}

.is-lightboxable{
  cursor:zoom-in;
  outline-offset:4px;
}

.img-lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.88);
  z-index:140;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:16px;
  padding:30px;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.25s ease;
}
.img-lightbox.open{
  opacity:1;
  pointer-events:auto;
}
.img-lightbox__img{
  max-width:min(1200px,92vw);
  max-height:78vh;
  border-radius:4px;
  box-shadow:0 20px 42px rgba(0,0,0,0.35);
}
.img-lightbox__caption{
  color:rgba(250,250,247,0.8);
  font-size:13px;
  letter-spacing:0.02em;
}
.img-lightbox__close{
  position:absolute;
  top:16px;
  right:16px;
  width:42px;
  height:42px;
  border-radius:999px;
  background:rgba(250,250,247,0.14);
  color:var(--paper);
  font-size:30px;
  line-height:1;
}
.img-lightbox__close:hover{background:rgba(250,250,247,0.22)}

/* ========== RESPONSIVE HARDENING ========== */
@media(max-width:1200px){
  .wrap{padding-left:32px;padding-right:32px}
  .nav__links{gap:20px}
  .work__grid,.svc-intro__grid,.contact-main__grid{gap:48px}
  .footer__grid{gap:34px}
}

@media(max-width:1024px){
  :root{--nav-h:68px}
  .wrap{padding-left:28px;padding-right:28px}
  .nav__inner{min-height:40px}
  .nav__brand{min-width:0}
  .nav__logo{max-width:172px}
  .nav__burger{
    min-width:44px;
    min-height:44px;
    margin-right:-8px;
    border-radius:999px;
  }
  .nav__burger.open{background:rgba(255,255,255,0.08)}
  .nav__mobile a{min-height:48px;display:flex;align-items:center}
  .nav__mobile-cta{min-height:52px}
  .projects-filter{top:var(--nav-h)}
}

@media(max-width:760px){
  :root{--nav-h:64px}
  .wrap{padding-left:20px;padding-right:20px}
  .skip:focus{top:10px}
  h1{font-size:clamp(42px,14vw,62px);line-height:0.96}
  h2{font-size:clamp(34px,11vw,52px);line-height:1}
  h3{font-size:clamp(22px,7vw,30px)}
  .eyebrow{gap:10px;letter-spacing:0.16em}
  .eyebrow::before{width:22px}
  .btn{width:100%;min-height:50px;padding:13px 18px}

  .nav{padding:10px 0}
  .nav__logo{height:42px;max-width:170px}
  .nav__mobile{padding:16px 20px 24px}
  .nav__mobile a{font-size:26px}
  .nav__mobile-cta{margin-top:24px;margin-bottom:18px;max-width:none}

  .hero{
    min-height:100svh;
    padding:calc(var(--nav-h) + 42px) 0 96px;
    align-items:flex-end;
  }
  .hero__slide img{object-position:center}
  .hero__veil{
    background:
      linear-gradient(180deg,rgba(20,22,24,0.46) 0%,rgba(20,22,24,0.46) 34%,rgba(20,22,24,0.86) 100%),
      radial-gradient(100% 70% at 20% 12%,rgba(68,130,195,0.16) 0%,rgba(68,130,195,0) 62%);
  }
  .hero__eyebrow{margin-bottom:18px}
  .hero__title{font-size:clamp(42px,14vw,66px);line-height:0.96;margin-bottom:18px}
  .hero__sub{font-size:15px;line-height:1.55;margin-bottom:24px}
  .hero__ctas{gap:10px}
  .hero__ctas .btn{width:100%;min-height:50px}
  .hero__controls{left:20px;bottom:20px}

  .page-hero{padding:calc(var(--nav-h) + 42px) 0 46px}
  .page-hero__grid{gap:22px}
  .page-hero__eyebrow{margin-bottom:18px}
  .page-hero__sub{max-width:none;font-size:15px;padding-bottom:0}

  .stats,.service-areas{padding:52px 0}
  .services,.work,.quote,.reviews,.process,.svc-intro,.svc-features,.svc-gallery,.about-intro,.values,.contact-main{padding:72px 0}
  .cta{padding:64px 0}
  .footer{padding:58px 0 24px}

  .stats__grid{gap:0}
  .stat__value{font-size:38px}
  .stat__value--text{font-size:27px}
  .stat__label{letter-spacing:0.16em}

  .services__head{margin-bottom:32px}
  .service{min-height:auto;padding:28px 24px}
  .service__title{font-size:23px}

  .work__tiles{grid-template-columns:1fr 1fr;gap:12px}
  .tile{aspect-ratio:4/5}
  .tile:nth-child(even){margin-top:18px}
  .tile__info{bottom:14px;left:14px;right:14px}
  .tile__name{font-size:17px}

  .reviews__num{font-size:58px}
  .review{padding:24px}

  .cta__buttons{flex-direction:column}
  .cta__buttons .btn{min-width:0}

  .projects-filter{
    padding:14px 0;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .filter-bar{
    flex-wrap:nowrap;
    gap:8px;
    width:max-content;
    min-width:100%;
    padding-bottom:2px;
  }
  .filter-label{margin-right:4px}
  .filter-btn{flex:0 0 auto;padding:8px 13px;font-size:12px}
  .projects-grid{padding:48px 0 78px}
  .pgrid{grid-template-columns:1fr 1fr;gap:18px}
  .pcard__body{padding-top:16px}
  .pcard__title{font-size:20px}

  .svc-intro__grid,.about-intro__grid,.contact-main__grid{gap:34px}
  .svc-intro__media{aspect-ratio:4/3}
  .svc-features__head,.values__head{margin-bottom:36px}
  .svc-gallery__head{margin-bottom:32px}
  .svc-gallery__grid{gap:10px}

  .contact-info__value{font-size:23px}
  .contact-form__btn{width:100%}
  .contact-info{grid-template-columns:1fr;gap:0}
  .contact-info__block{padding:26px 0;margin:0;border-top:1px solid var(--gray-soft)}
  .contact-info__block:last-child{padding-bottom:0}
  .back-to-top{right:16px;bottom:16px;width:42px;height:42px}
  .img-lightbox{padding:18px}
  .img-lightbox__img{max-width:94vw;max-height:74vh}
}

@media(max-width:560px){
  .wrap{padding-left:18px;padding-right:18px}
  .nav__logo{height:40px;max-width:160px}
  .nav__mobile a{font-size:24px}
  .hero__title{font-size:clamp(40px,15vw,58px)}
  .hero__sub{font-size:15px}
  .hero__controls{gap:9px}
  .hero__arrow{width:34px;height:34px}

  .stats__grid,.work__tiles,.pgrid,.svc-gallery__grid,.contact-form__row,.service-areas__list{grid-template-columns:1fr}
  .stat::after{display:none}
  .stat__value{font-size:34px}
  .stat__value--text{font-size:25px;max-width:280px}
  .services__grid{grid-template-columns:1fr}
  .tile:nth-child(even),.svc-gallery__img:nth-child(3n+2){margin-top:0}
  .tile{aspect-ratio:4/5}
  .pcard__img{aspect-ratio:4/3}
  .footer__logo{height:48px}
  .footer__social{width:42px;height:42px}
  .footer__bottom div:last-child{display:flex;flex-wrap:wrap;gap:10px 16px}
  .footer__bottom a{margin:0}
}

@media(max-width:640px){
  .pgrid{grid-template-columns:1fr}
}

@media(max-width:390px){
  .wrap{padding-left:16px;padding-right:16px}
  .nav__logo{max-width:146px}
  .nav__burger{margin-right:-10px}
  .hero{padding-bottom:88px}
  .hero__title{font-size:38px}
  .page-hero__title{font-size:38px}
  .filter-btn{padding:7px 11px}
  .service,.review{padding-left:18px;padding-right:18px}
}

/* About page final breakpoint tuning */
@media(max-width:768px){
  .about-intro,.about-work,.about-team{padding:72px 0}
  .about-work__head,.about-team__head{margin-bottom:34px}
  .about-team__cards{gap:16px}
}
@media(max-width:430px){
  .about-intro,.about-work,.about-team{padding:66px 0}
  .about-intro__grid,.about-work__head,.about-team__head{gap:28px}
  .about-intro__stats{margin-top:28px;padding-top:22px}
  .team-card__img{aspect-ratio:4/3}
}
@media(max-width:390px){
  .about-intro__stats{grid-template-columns:1fr}
  .about-intro__stats div{padding:20px 0;border-left:0}
  .about-intro__stats div:nth-child(2){padding-top:20px;border-top:1px solid rgba(28,29,28,0.08)}
}
