*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,sans-serif;color:#111;background:#fff}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(calc(100% - 2rem),1300px);margin:0 auto}
.skip-link{position:absolute;left:1rem;top:-50px;background:#111;color:#fff;padding:.75rem 1rem;z-index:99}
.skip-link:focus{top:1rem}

.announcement-bar{background:#000;color:#fff;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.08)}
.announcement-track{
  display:flex;
  width:max-content;
  gap:.9rem;
  white-space:nowrap;
  padding:.5rem 0;
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  animation:marquee 20s linear infinite;
}
.announcement-track span{flex:0 0 auto}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-25%)}}

@media (max-width: 640px){
  .announcement-track{
    gap:.75rem;
    padding:.42rem 0;
    font-size:.52rem;
    letter-spacing:.04em;
  }
}
.site-header{
  position:sticky;
  top:0;
  z-index:20;
  background:#fff;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.nav{
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.brand{display:inline-flex;align-items:center}
.brand-logo{height:58px;width:auto;display:block;object-fit:contain}
.main-nav{
  display:flex;
  gap:1.5rem;
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.main-nav a{opacity:.7}
.main-nav a[aria-current="page"]{opacity:1}
.menu-toggle{
  display:none;
  width:42px;
  height:42px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  border-radius:999px;
  align-items:center;
  justify-content:center;
  gap:4px;
}
.menu-toggle span{display:block;width:16px;height:2px;background:#111}

.hero{padding:2rem 0 4rem}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:2rem;
  align-items:start;
}
.kicker,.section-kicker,.mass-kicker{
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#8e8e8e;
  margin:0 0 1rem;
  font-weight:700;
}
.hero h1{
  font-size:clamp(3rem,7vw,6.5rem);
  line-height:.9;
  letter-spacing:-.04em;
  text-transform:uppercase;
  max-width:11ch;
  margin:0 0 1rem;
}

.hero-title{
  font-size:clamp(2.7rem,6.3vw,5.8rem);
  line-height:.9;
  letter-spacing:-.05em;
  text-transform:uppercase;
  max-width:11ch;
  margin:0 0 1rem;
  display:grid;
  gap:0;
}

.hero-title span{
  display:block;
  position:relative;
  line-height:1.1;
  padding-right:0;
  white-space:nowrap;
}

.hero-title span::after{
  content:"■";
  position:relative;
  display:inline-block;
  margin-left:.08em;
  bottom:-.05em;
  font-size:.22em;
  line-height:1;
  vertical-align:baseline;
}

.hero-title.animate-in span{
  animation:heroLine .8s cubic-bezier(.16,1,.3,1) both;
}

.hero-title.animate-in span:nth-child(1){animation-delay:.11s}
.hero-title.animate-in span:nth-child(2){animation-delay:.26s}
.hero-title.animate-in span:nth-child(3){animation-delay:.39s}

@keyframes heroLine{
  from{opacity:0;transform:translateY(32px)}
  to{opacity:1;transform:translateY(0)}
}
.lead{
  max-width:48ch;
  color:#555;
  font-size:1.05rem;
}
.hero-links{
  display:flex;
  gap:1.25rem;
  flex-wrap:wrap;
  margin-top:2rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.95rem;
}
.hero-links a{
  padding-bottom:.2rem;
  border-bottom:1px solid rgba(0,0,0,.18);
}
.hero-image{
  min-height:620px;
  overflow:hidden;
  background:#fafafa;
}
.hero-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.section{
  padding:5rem 0;
  border-top:1px solid rgba(0,0,0,.08);
}
.split-grid{
  display:grid;
  grid-template-columns:.55fr 1fr;
  gap:2rem;
  align-items:end;
  margin-bottom:2rem;
}
.section-title h2,
.contact-grid h2{
  font-size:clamp(2.2rem,4vw,4rem);
  line-height:.95;
  text-transform:uppercase;
  letter-spacing:-.04em;
  margin:0;
}
.section-copy{
  max-width:42rem;
  color:#555;
  font-size:1.05rem;
}

.about-section{
  padding:5rem 0;
  border-top:1px solid rgba(0,0,0,.08);
}

.about-layout{
  display:block;
}

.about-title{
  margin-bottom:2rem;
}

.about-title span{
  display:block;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#8e8e8e;
  font-weight:700;
  margin-bottom:.6rem;
}

.about-title h2{
  font-size:clamp(3rem,8vw,6.5rem);
  line-height:.9;
  letter-spacing:-.05em;
  text-transform:uppercase;
  max-width:7ch;
  margin:0;
}

.about-body{
  width:100%;
}

.about-fullwidth-image{
  width:100%;
  height:min(72vw,840px);
  object-fit:cover;
  display:block;
  background:#f5f5f5;
}

.about-copy{
  max-width:70rem;
  margin:1.25rem 0 0 auto;
  display:grid;
  gap:1rem;
}

.about-copy p{
  margin:0;
  line-height:1.8;
  color:#444;
  max-width:62ch;
}
.gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}
.gallery figure{
  margin:0;
  aspect-ratio:4/5;
  overflow:hidden;
  background:#f5f5f5;
}
.gallery img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.contact-grid{
  display:grid;
  grid-template-columns:.65fr 1fr;
  gap:2rem;
  align-items:start;
}
.contact-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem;
  color:#444;
}

.footer{
  border-top:1px solid rgba(0,0,0,.08);
  padding:1.5rem 0 2rem;
}
.footer-row{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  font-size:.9rem;
  color:#666;
}

.service-page{background:#fff}
.service-hero{padding:4rem 0 2rem}
.service-hero-inner{
  display:grid;
  grid-template-columns:.35fr 1fr;
  gap:2rem;
  align-items:end;
}
.service-hero h1{
  font-size:clamp(4rem,8vw,7rem);
  line-height:.9;
  letter-spacing:-.04em;
  text-transform:uppercase;
  margin:0;
}
.service-intro{
  max-width:40rem;
  color:#555;
  font-size:1.05rem;
}

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:2rem;
}
.pricing-col{
  display:grid;
  gap:2rem;
}
.pricing-block h2{
  font-size:1.9rem;
  font-weight:400;
  line-height:1;
  padding-bottom:.65rem;
  margin:0 0 .5rem;
  border-bottom:1px solid rgba(0,0,0,.12);
}
.featured{
  background:#fafafa;
  padding:1rem;
  border:1px solid rgba(0,0,0,.08);
}
.pricing-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:1rem;
  align-items:start;
  padding:.82rem 0;
  border-bottom:1px dotted rgba(0,0,0,.06);
}
.pricing-item:last-child{border-bottom:none}
.pricing-item h3{
  font-size:1rem;
  line-height:1.25;
  margin:0;
  font-weight:700;
}
.pricing-item p{
  margin:.35rem 0 0;
  color:#666;
  font-size:.92rem;
  max-width:46ch;
}
.pricing-item strong{
  white-space:nowrap;
  font-size:1rem;
  font-weight:500;
}
.featured-item{padding:.15rem 0 0}

.pricing-note{
  margin-top:2.5rem;
  padding-top:1rem;
  border-top:1px solid rgba(0,0,0,.12);
  color:#666;
  font-size:.9rem;
  line-height:1.55;
  display:grid;
  gap:.25rem;
}

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:600ms cubic-bezier(.16,1,.3,1);
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

@media (max-width:980px){
  .hero-grid,
  .split-grid,
  .contact-grid,
  .service-hero-inner,
  .pricing-grid{
    grid-template-columns:1fr;
  }

  .gallery,
  .contact-list{
    grid-template-columns:1fr 1fr;
  }

  .main-nav{
    position:absolute;
    right:1rem;
    top:calc(100% + .75rem);
    display:none;
    flex-direction:column;
    gap:0;
    background:#fff;
    border:1px solid rgba(0,0,0,.12);
    padding:1rem 1.1rem;
    border-radius:14px;
    box-shadow:0 18px 50px rgba(0,0,0,.08);
    min-width:220px;
    z-index:50;
  }

  .main-nav.open{
    display:flex;
  }

  .main-nav a{
    padding:.4rem 0;
  }

  .menu-toggle{
    display:inline-flex;
    position:relative;
  }

  .menu-toggle span{
    display:block;
    width:16px;
    height:2px;
    background:#111;
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    transition:transform .2s ease, opacity .2s ease;
  }

  .menu-toggle span:nth-child(1){ top:14px; }
  .menu-toggle span:nth-child(2){ top:20px; }
  .menu-toggle span:nth-child(3){ top:26px; }

  .menu-toggle.open span:nth-child(1){
    top:20px;
    transform:translateX(-50%) rotate(45deg);
  }

  .menu-toggle.open span:nth-child(2){
    opacity:0;
  }

  .menu-toggle.open span:nth-child(3){
    top:20px;
    transform:translateX(-50%) rotate(-45deg);
  }

  .site-header .nav{
    position:relative;
  }

  .hero-image{
    min-height:420px;
  }

  .service-hero h1{
    font-size:clamp(3rem,13vw,5rem);
  }

  .about-grid{
    grid-template-columns:1fr;
  }
}