:root{
  --bg:#0d0f10;
  --white:#ffffff;
  --text:#1f2937;
  --muted:#6b7280;
  --brand:#a97b52;
  --brand-2:#8a623f;
  --topbar:#7c5a36;
  --surface:#f6f1ea;
  --container:1180px;
  --ease:cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:#fff;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}

.container{width:min(var(--container), calc(100% - 2rem)); margin-inline:auto}
.sr-only{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link{
  position:absolute;left:1rem;top:1rem;z-index:1000;
  background:#fff;color:#111;padding:.6rem .8rem;border-radius:.5rem;
  transform:translateY(-200%);
}
.skip-link:focus{transform:translateY(0);transition:transform 180ms var(--ease)}

/* Header */
.site-header{position:relative;z-index:50}
.topbar{
  background:var(--topbar);
  color:rgba(255,255,255,.95);
  font-size:.85rem;
}
.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.55rem 0;
}
.topbar__left{display:flex;align-items:center;gap:1rem;min-width:0}
.topbar__item{display:flex;align-items:center;gap:.55rem;white-space:nowrap;opacity:.95}
.topbar__item:hover{opacity:1}
.topbar__sep{width:1px;height:18px;background:rgba(255,255,255,.35)}
.topbar__right{display:flex;align-items:center;gap:1.25rem}
.topbar__link{opacity:.9}
.topbar__link:hover{opacity:1}
.icon{width:18px;height:18px;display:inline-grid;place-items:center;color:#fff;opacity:.95}
.icon svg{width:18px;height:18px}

.mainbar{background:#f6f1ea}
.mainbar__inner{
  display:grid;
  grid-template-columns: 190px 1fr auto;
  align-items:center;
  gap:1.25rem;
  padding: .8rem 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:.8rem;
  position:relative;
  height:54px;
  overflow:visible;
}
.brand__logo{
  height:120px;
  width:auto;
  max-width:190px;
  object-fit:contain;
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
}

@keyframes logoBounceIn{
  0%{opacity:0; transform:translateY(-50%) translateY(-18px) scale(.98)}
  55%{opacity:1; transform:translateY(-50%) translateY(8px) scale(1.01)}
  75%{transform:translateY(-50%) translateY(-6px) scale(1)}
  100%{transform:translateY(-50%) translateY(0) scale(1)}
}

.nav{display:flex;justify-content:center;gap:1.75rem;align-items:center}
.nav__link{
  position:relative;
  font-weight:500;
  color:#4b5563;
  padding:.65rem .1rem;
  transition:color 180ms var(--ease);
}
.nav__link:hover{color:#111827}
.nav__link::after{
  content:"";
  position:absolute;
  left:0;
  bottom:.35rem;
  height:2px;
  width:0;
  background:var(--brand);
  transition:width 220ms var(--ease);
}
.nav__link:hover::after{width:100%}
.nav__link--has-caret::before{
  content:"\25BE";
  position:absolute;
  right:-.85rem;
  top:50%;
  transform:translateY(-55%);
  font-size:.75rem;
  opacity:.75;
}

.call{
  display:flex;
  align-items:center;
  gap:.85rem;
  justify-self:end;
}
.call__icon{
  width:46px;height:46px;border-radius:999px;
  background:var(--brand);
  color:#fff;
  display:grid;place-items:center;
  transition:transform 220ms var(--ease), background 220ms var(--ease);
}
.call__icon svg{width:22px;height:22px}
.call:hover .call__icon{transform:translateY(-1px) scale(1.03); background:var(--brand-2)}
.call__text{display:flex;flex-direction:column;line-height:1.1}
.call__label{font-size:.8rem;color:#6b7280}
.call__number{font-weight:700;color:#111827}

/* Mobile nav */
.nav-toggle{display:none;justify-self:end;background:transparent;border:0;padding:.6rem .4rem;cursor:pointer}
.nav-toggle__lines{
  width:26px;height:18px;display:block;position:relative;
}
.nav-toggle__lines::before,
.nav-toggle__lines::after,
.nav-toggle__lines{background:transparent}
.nav-toggle__lines::before,
.nav-toggle__lines::after{
  content:"";
  position:absolute;
  left:0;
  width:26px;
  height:2px;
  background:#4b5563;
  transition:transform 220ms var(--ease), top 220ms var(--ease), opacity 220ms var(--ease);
}
.nav-toggle__lines::before{top:4px}
.nav-toggle__lines::after{top:12px}

[data-nav-open="true"] .nav-toggle__lines::before{top:8px;transform:rotate(45deg)}
[data-nav-open="true"] .nav-toggle__lines::after{top:8px;transform:rotate(-45deg)}

/* Hero */
.hero{
  position:relative;
  min-height: calc(100vh - 120px);
  display:grid;
  place-items:center;
  overflow:hidden;
  background:var(--bg);
}
.hero__slider{position:absolute;inset:0}
.hero__slide{
  position:absolute;
  inset:0;
  background-image: var(--bg);
  background-size:cover;
  background-position:center;
  transform:scale(1.06);
  opacity:0;
  transition:opacity 700ms var(--ease);
  animation: kenburns 14s var(--ease) infinite;
}
.hero__slide.is-active{opacity:1}
@keyframes kenburns{
  0%{transform:scale(1.06) translate3d(0,0,0)}
  50%{transform:scale(1.12) translate3d(-1%, -1%, 0)}
  100%{transform:scale(1.06) translate3d(0,0,0)}
}

.hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.52), rgba(0,0,0,.22) 45%, rgba(0,0,0,.38));
}

.hero__content{
  position:relative;
  color:#fff;
  text-align:center;
  padding: 7.5rem 0 6.5rem;
}
.hero__kicker{
  letter-spacing:.38em;
  font-size:.95rem;
  font-weight:600;
  opacity:.92;
  margin-bottom:1rem;
}
.hero__title{
  margin:0 0 1.7rem;
  font-size: clamp(2.4rem, 5vw, 4.6rem);
  line-height:1.02;
  font-weight:800;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 190px;
  padding: .95rem 1.35rem;
  border-radius: .2rem;
  background: var(--brand);
  color:#fff;
  font-weight:600;
  border:1px solid rgba(255,255,255,.12);
  transition: transform 220ms var(--ease), background 220ms var(--ease), box-shadow 220ms var(--ease);
}
.btn:hover{
  transform: translateY(-2px);
  background: var(--brand-2);
  box-shadow: 0 16px 40px rgba(0,0,0,.25);
}

.hero__dots{
  position:absolute;
  left:50%;
  bottom:1.4rem;
  transform:translateX(-50%);
  display:flex;
  gap:.55rem;
  z-index:2;
}
.dot{
  width:10px;height:10px;border-radius:999px;
  border:0;
  background:rgba(255,255,255,.55);
  cursor:pointer;
  transition:transform 200ms var(--ease), background 200ms var(--ease);
}
.dot:hover{transform:scale(1.08)}
.dot.is-active{background:rgba(255,255,255,.95)}

/* Load + reveal animations */
[data-reveal]{
  opacity:0;
  transform: translateY(18px);
  transition: opacity 650ms var(--ease), transform 650ms var(--ease);
}
body.is-loaded [data-reveal]{
  opacity:1;
  transform: translateY(0);
}

body.is-loaded .brand__logo{
  animation: logoBounceIn 850ms var(--ease) both;
  will-change: transform, opacity;
}

/* Scroll reveal */
[data-reveal-on-scroll]{
  opacity:0;
  transform: translateY(18px);
  transition: opacity 650ms var(--ease), transform 650ms var(--ease);
}
[data-reveal-on-scroll].is-inview{
  opacity:1;
  transform: translateY(0);
}
[data-stagger]{
  transition-delay: var(--stagger, 0ms);
}

/* Feature strip */
.feature-strip{
  background:
    linear-gradient(0deg, rgba(246,241,234,.92), rgba(246,241,234,.92)),
    repeating-linear-gradient(135deg, rgba(169,123,82,.12) 0 1px, transparent 1px 22px);
  padding: 1.6rem 0;
}
.feature-strip__inner{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  align-items:stretch;
}
.feature{
  position:relative;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(17,24,39,.06);
  border-radius:.6rem;
  padding: 1.2rem 1.1rem 1.05rem;
  overflow:hidden;
  transform: translateZ(0);
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease);
}
.feature:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(17,24,39,.10);
}
.feature__badge{
  position:absolute;
  top:.8rem;
  left:.95rem;
  font-weight:600;
  font-size:.8rem;
  color: rgba(17,24,39,.40);
}
.feature__icon{
  width:56px;height:56px;
  border-radius:.9rem;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(169,123,82,.20);
  color:var(--brand);
  display:grid;
  place-items:center;
  margin: .25rem auto .75rem;
}
.feature__icon svg{width:28px;height:28px}
.feature__title{
  margin:.1rem 0 .35rem;
  text-align:center;
  font-size:1.05rem;
  font-weight:700;
  color:#111827;
}
.feature__text{
  margin:0;
  text-align:center;
  color:#6b7280;
  font-size:.95rem;
  line-height:1.55;
}

/* Intro section */
.intro{
  padding: 4.5rem 0;
  background:#fff;
}
.intro__grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(1.6rem, 4vw, 3.2rem);
  align-items:center;
}
.intro__media{
  position:relative;
  min-height: 520px;
}
.intro__frame{
  position:absolute;
  left: 18%;
  top: 10%;
  width: 56%;
  height: 78%;
  border: 2px solid rgba(169,123,82,.65);
  border-radius:.2rem;
  pointer-events:none;
}
.intro__img{
  position:absolute;
  border-radius:.35rem;
  box-shadow: 0 22px 70px rgba(17,24,39,.16);
  object-fit:cover;
}
.intro__img--left{
  left: 2%;
  top: 14%;
  width: 42%;
  height: 76%;
  filter:saturate(1.02);
}
.intro__img--main{
  right: 6%;
  top: 6%;
  width: 58%;
  height: 88%;
}
.intro__content{
  max-width: 560px;
}
.eyebrow{
  display:flex;
  align-items:center;
  gap:.8rem;
  color:#6b7280;
  font-weight:500;
  font-size:.95rem;
}
.eyebrow__dash{
  height:2px;
  width: 44px;
  background: var(--brand);
  opacity:.95;
}
.eyebrow--dark{color:rgba(255,255,255,.72)}
.eyebrow--dark .eyebrow__dash{background: rgba(169,123,82,.95)}
.intro__title{
  margin: .8rem 0 1rem;
  font-size: clamp(2rem, 3.4vw, 3rem);
  line-height:1.08;
  color:#111827;
}
.intro__lead{
  margin:0 0 1.2rem;
  color:#6b7280;
  line-height:1.7;
  font-size:1rem;
}

.checklist{list-style:none; padding:0; margin: 0 0 1.6rem; display:grid; gap:.7rem}
.checklist__item{
  position:relative;
  padding-left: 1.8rem;
  font-weight:600;
  color:#111827;
  font-size:.98rem;
}
.checklist__item::before{
  content:"";
  position:absolute;
  left:0;
  top:.18rem;
  width:18px;height:18px;
  border-radius:999px;
  border:2px solid rgba(169,123,82,.65);
  background:rgba(169,123,82,.08);
}
.checklist__item::after{
  content:"";
  position:absolute;
  left:5px;
  top:8px;
  width:7px;height:4px;
  border-left:2px solid var(--brand);
  border-bottom:2px solid var(--brand);
  transform:rotate(-45deg);
}

.skills{display:grid; gap: 1.1rem; margin: 0 0 1.8rem}
.skill__row{display:flex; align-items:baseline; justify-content:space-between; margin-bottom:.55rem}
.skill__name{font-weight:700; color:#111827}
.skill__value{color:#6b7280; font-weight:600; font-size:.9rem}
.skill__bar{
  height: 6px;
  border-radius:999px;
  background: rgba(17,24,39,.10);
  overflow:hidden;
}
.skill__fill{
  display:block;
  height:100%;
  width: 0%;
  border-radius:999px;
  background: var(--brand);
  transform-origin:left;
  transition: width 900ms var(--ease);
}
.skills.is-animated .skill__fill{width: var(--pct, 0%)}

/* Generic section */
.section{padding: 3rem 0; background: var(--surface)}
.section__inner{display:grid; gap:.55rem}
.section__title{margin:0; font-size:1.8rem; color:#111827}
.section__text{margin:0; color:#6b7280; line-height:1.7}

/* Offerings (Services) */
.offerings{
  background: var(--surface);
  padding: 4.6rem 0 5.2rem;
}
.offerings__header{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(1.3rem, 3vw, 3rem);
  align-items:start;
  margin-bottom: 2.2rem;
}
.offerings__title{
  margin: .7rem 0 0;
  font-size: clamp(2.2rem, 4.2vw, 3.2rem);
  line-height:1.04;
  font-weight:800;
  color:#111827;
}
.offerings__blurb{
  margin: 2.4rem 0 0;
  color:#6b7280;
  line-height:1.75;
  font-size:1rem;
}
.offerings__grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.6rem;
}

.service-card{
  --tiltX: 0deg;
  --tiltY: 0deg;
  --lift: 0px;
  background: rgba(255,255,255,.35);
  border: 1px solid rgba(17,24,39,.06);
  border-radius: .7rem;
  overflow:hidden;
  transform: perspective(900px) rotateX(var(--tiltX)) rotateY(var(--tiltY)) translateY(var(--lift));
  transform-style: preserve-3d;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease);
  box-shadow: 0 18px 50px rgba(17,24,39,.06);
}
.service-card:hover{
  --lift: -6px;
  box-shadow: 0 28px 75px rgba(17,24,39,.12);
}
.service-card__media{
  position:relative;
  height: 320px;
  overflow:hidden;
  background:#e7e0d7;
}
.service-card__media::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.12));
  opacity:.6;
  pointer-events:none;
}
.service-card__img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform: scale(1.02);
  transition: transform 600ms var(--ease), filter 600ms var(--ease);
  filter: saturate(1.02) contrast(1.02);
}
.service-card:hover .service-card__img{transform: scale(1.08)}
.service-card__body{
  background: rgba(246,241,234,.75);
  padding: 1.4rem 1.35rem 1.55rem;
  border-top: 1px solid rgba(17,24,39,.06);
}
.service-card__title{
  margin: 0 0 .55rem;
  font-size: 1.12rem;
  font-weight:800;
  color:#111827;
}
.service-card__text{
  margin:0 0 1.15rem;
  color:#6b7280;
  line-height:1.65;
  font-size:.95rem;
}

.btn--soft{
  background: rgba(255,255,255,.92);
  color:#111827;
  border: 1px solid rgba(17,24,39,.10);
  min-width: 130px;
  padding: .72rem 1.05rem;
  box-shadow:none;
}
.btn--soft:hover{
  background: var(--brand);
  border-color: rgba(255,255,255,.12);
  color:#fff;
  box-shadow: 0 16px 40px rgba(0,0,0,.18);
}

/* Peace banner */
.peace{padding: 0 0 3.2rem; background:#fff}
.peace__wrap{
  display:grid;
  grid-template-columns: 1.55fr .95fr;
  border-radius: 0;
  overflow:hidden;
  border-top: 1px solid rgba(17,24,39,.08);
  border-bottom: 1px solid rgba(17,24,39,.08);
  box-shadow: 0 26px 80px rgba(17,24,39,.08);
}
.peace__wrap.container{width:100%; max-width:none; margin:0}
.peace__media{position:relative; min-height: 520px; background:#e7e0d7}
.peace__media img{width:100%; height:100%; object-fit:cover; display:block; transform:scale(1.02); transition:transform 900ms var(--ease)}
.peace__wrap:hover .peace__media img{transform:scale(1.06)}
.peace__panel{
  background: #0b0c0d;
  color:#fff;
  padding: clamp(1.9rem, 3.6vw, 3.1rem);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap: .9rem;
}
.peace__title{margin:0; font-size: clamp(2rem, 3.3vw, 3rem); line-height:1.06; font-weight:800}
.peace__accent{margin:0; color: rgba(169,123,82,.98); font-weight:700; line-height:1.35}
.peace__text{margin:0 0 .6rem; color: rgba(255,255,255,.72); line-height:1.75}
.peace .btn{align-self:flex-start}

/* Residential / Commercial */
.segments{padding: 3.0rem 0 5.2rem; background:#fff}
.segments__grid{display:grid; grid-template-columns: repeat(2, 1fr); gap: 1.8rem; align-items:stretch}
.segment{
  display:grid;
  grid-template-columns: .9fr 1.6fr;
  border-radius: .9rem;
  overflow:hidden;
  border: 1px solid rgba(17,24,39,.08);
  box-shadow: 0 18px 55px rgba(17,24,39,.08);
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease);
}
.segment:hover{transform: translateY(-4px); box-shadow: 0 30px 90px rgba(17,24,39,.12)}
.segment__media{background:#e7e0d7}
.segment__media img{width:100%; height:100%; min-height: 260px; object-fit:cover; display:block; transform:scale(1.02); transition:transform 700ms var(--ease)}
.segment:hover .segment__media img{transform:scale(1.07)}
.segment__panel{
  background: var(--panel, var(--brand));
  color:#fff;
  padding: 2.6rem 2.5rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap: .75rem;
}
.segment__icon{width:44px;height:44px; display:grid; place-items:center; color: rgba(255,255,255,.92)}
.segment__icon svg{width:32px;height:32px}
.segment__title{margin:0; font-size:1.75rem; font-weight:800}
.segment__text{margin:0; color: rgba(255,255,255,.78); line-height:1.7}

/* Recent projects (Portfolio) */
.projects{padding: 1.0rem 0 5.6rem; background: var(--surface)}
.projects__head{display:grid; justify-items:center; text-align:center; gap:.6rem; margin-bottom: 2.2rem}
.projects__eyebrow{display:flex; align-items:center; gap:.8rem; color:#6b7280; font-weight:500; font-size:.95rem}
.projects__dash{height:2px; width: 44px; background: var(--brand); opacity:.95}
.projects__title{margin:0; font-size: clamp(2.1rem, 4vw, 3.2rem); line-height:1.06; font-weight:800; color:#111827}

.projects__grid{display:grid; grid-template-columns: repeat(3, 1fr); gap: 1.8rem; align-items:stretch}

.project-card{
  position:relative;
  border-radius: .9rem;
  overflow:hidden;
  border: 1px solid rgba(17,24,39,.08);
  box-shadow: 0 18px 60px rgba(17,24,39,.08);
  transform: perspective(900px) rotateX(var(--tiltX, 0deg)) rotateY(var(--tiltY, 0deg)) translateY(var(--lift, 0px));
  transform-style: preserve-3d;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease);
  min-height: 420px;
}
.project-card:hover{--lift: -6px; box-shadow: 0 30px 95px rgba(17,24,39,.12)}

.project-card__media{position:absolute; inset:0; display:block}
.project-card__media img{
  width:100%; height:100%; object-fit:cover; display:block;
  transform: scale(1.02);
  transition: transform 900ms var(--ease), filter 900ms var(--ease);
  filter: saturate(1.02) contrast(1.03);
}
.project-card:hover .project-card__media img{transform: scale(1.08)}

.project-card__overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.22) 55%, rgba(0,0,0,.72) 100%);
}

.project-card__content{
  position:absolute;
  left: 1.35rem;
  bottom: 1.25rem;
  right: 1.35rem;
  color:#fff;
}
.project-card__tag{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-weight:600;
  font-size:.9rem;
  opacity:.9;
}
.project-card__tag::before{
  content:"";
  width:18px;height:2px;
  background: rgba(169,123,82,.95);
  border-radius:999px;
}
.project-card__name{margin:.35rem 0 0; font-size: clamp(1.55rem, 2vw, 2.05rem); line-height:1.1; font-weight:800}

/* Request quote */
.quote{
  padding: 5.8rem 0;
  background: #fff;
}
.quote__grid{
  display:grid;
  grid-template-columns: minmax(340px, 610px) 1fr;
  gap: 2.5rem;
  align-items:stretch;
}

.quote__card{
  background:
    radial-gradient(900px 480px at 20% 10%, rgba(255,255,255,.07), transparent 55%),
    linear-gradient(180deg, rgba(13,15,16,.92), rgba(13,15,16,.96));
  color: rgba(255,255,255,.92);
  border-radius: 1.4rem;
  padding: 3.4rem 3.2rem;
  box-shadow: 0 28px 90px rgba(17,24,39,.18);
  border: 1px solid rgba(255,255,255,.08);
}

.quote__title{margin:0 0 1.25rem; font-size: clamp(2.3rem, 3.5vw, 3.2rem); line-height:1.06; font-weight:800; letter-spacing:-.01em}
.quote__subtitle{margin:0 0 1.45rem; font-weight:600; opacity:.9}

.quote-form{margin-top:.25rem}
.quote-form__grid{display:grid; grid-template-columns: 1fr 1fr; gap: 1.05rem}
.quote-field--full{grid-column: 1 / -1}

.quote-field input,
.quote-field select,
.quote-field textarea{
  width:100%;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.98);
  color: #111827;
  border-radius: 999px;
  padding: .98rem 1.25rem;
  font: inherit;
  outline: none;
  transition: transform 180ms var(--ease), box-shadow 200ms var(--ease), border-color 200ms var(--ease);
}
.quote-field textarea{border-radius: 1.1rem; resize: vertical; min-height: 150px; padding: 1.05rem 1.25rem}
.quote-field select{appearance:none; background-image:
  linear-gradient(45deg, transparent 50%, rgba(17,24,39,.65) 50%),
  linear-gradient(135deg, rgba(17,24,39,.65) 50%, transparent 50%);
  background-position: calc(100% - 1.25rem) calc(50% - 4px), calc(100% - 1.12rem) calc(50% - 4px);
  background-size: 7px 7px, 7px 7px;
  background-repeat: no-repeat;
  padding-right: 2.6rem;
}

.quote-field input::placeholder,
.quote-field textarea::placeholder{color: rgba(17,24,39,.55)}

.quote-field input:focus,
.quote-field select:focus,
.quote-field textarea:focus{
  border-color: rgba(169,123,82,.55);
  box-shadow: 0 0 0 5px rgba(169,123,82,.25);
  transform: translateY(-1px);
}

.quote__btn{
  width:100%;
  margin-top: 1.2rem;
  border:0;
  border-radius: 999px;
  padding: 1.05rem 1.35rem;
  cursor:pointer;
  background: var(--brand);
  color:#fff;
  font-weight:800;
  letter-spacing:.01em;
  position:relative;
  overflow:hidden;
  transition: transform 180ms var(--ease), box-shadow 220ms var(--ease), background 220ms var(--ease);
}
.quote__btn::after{
  content:"";
  position:absolute;
  inset:-40% -30%;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.35) 35%, transparent 70%);
  transform: translateX(-35%) rotate(10deg);
  opacity:0;
  transition: opacity 200ms var(--ease);
}
.quote__btn:hover{transform: translateY(-2px); box-shadow: 0 18px 48px rgba(169,123,82,.38); background: var(--brand-2)}
.quote__btn:hover::after{opacity:1; animation: quoteSheen 900ms var(--ease) both}
.quote__btn:active{transform: translateY(0)}

@keyframes quoteSheen{
  from{transform: translateX(-45%) rotate(10deg)}
  to{transform: translateX(35%) rotate(10deg)}
}

.quote__map{
  border-radius: 1.15rem;
  overflow:hidden;
  border: 1px solid rgba(17,24,39,.08);
  box-shadow: 0 22px 80px rgba(17,24,39,.12);
  min-height: 640px;
  background: rgba(255,255,255,.6);
}
.quote__map iframe{width:100%; height:100%; border:0; display:block; min-height: 640px}

/* Testimonials */
.testimonials{padding: 5.2rem 0; background: var(--surface)}
.testimonials__head{display:grid; justify-items:center; text-align:center; gap:.6rem; margin-bottom: 2.2rem}
.testimonials__title{margin:0; font-size: clamp(2.1rem, 4vw, 3.2rem); line-height:1.06; font-weight:800; color:#111827}
.testimonials__lead{margin:.15rem 0 0; color:#6b7280; max-width: 62ch}

.testimonials__grid{display:grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; align-items:stretch}

.t-card{
  position:relative;
  border-radius: 1.1rem;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(17,24,39,.06);
  box-shadow: 0 18px 60px rgba(17,24,39,.08);
  padding: 1.75rem 1.65rem 1.6rem;
  overflow:hidden;
  transform: perspective(900px) rotateX(var(--tiltX, 0deg)) rotateY(var(--tiltY, 0deg)) translateY(var(--lift, 0px));
  transform-style: preserve-3d;
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease);
  min-height: 300px;
}
.t-card::before{
  content:"";
  position:absolute;
  inset:-40% -35% auto;
  height: 140px;
  background: radial-gradient(closest-side, rgba(169,123,82,.18), transparent 70%);
  transform: rotate(-8deg);
  pointer-events:none;
}
.t-card:hover{--lift:-6px; box-shadow: 0 30px 95px rgba(17,24,39,.12)}

.t-card__top{display:flex; align-items:flex-start; justify-content:space-between; gap: 1rem; margin-bottom: .65rem}
.t-card__rating{font-weight:800; letter-spacing:.08em; color: var(--brand); font-size: .95rem}
.t-card__stamp{font-size: 3.2rem; line-height:1; color: rgba(169,123,82,.28); transform: translateY(-.25rem)}

.t-card__quote{margin:.1rem 0 1.25rem; color:#111827; line-height:1.8}

.t-card__person{display:flex; align-items:center; gap: .85rem; margin-top:auto}
.t-card__avatar{
  width: 46px; height: 46px; border-radius: 999px;
  display:grid; place-items:center;
  background: linear-gradient(180deg, rgba(169,123,82,.95), rgba(138,98,63,.95));
  color:#fff;
  font-weight:900;
}
.t-card__name{font-weight:800; color:#111827}
.t-card__role{color:#6b7280; font-size:.95rem}

/* Responsive */
@media (max-width: 980px){
  .topbar__right{display:none}
  .mainbar__inner{grid-template-columns: 1fr auto; grid-template-areas: "brand toggle" "nav nav";}
  .brand{grid-area:brand}
  .nav-toggle{grid-area:toggle; display:block}
  .call{display:none}

  .nav{
    grid-area:nav;
    justify-content:flex-start;
    gap:0;
    display:none;
    flex-direction:column;
    align-items:stretch;
    padding: .35rem 0 .8rem;
  }
  [data-nav-open="true"] .nav{display:flex}
  .nav__link{padding:.85rem .25rem;border-top:1px solid rgba(17,24,39,.08)}
  .nav__link::after{display:none}
  .nav__link--has-caret::before{right:.2rem}

  .feature-strip__inner{grid-template-columns:1fr; gap:.9rem}

  .intro{padding: 3.4rem 0}
  .intro__grid{grid-template-columns:1fr;}
  .intro__media{min-height: 420px; order:2}
  .intro__content{max-width:none; order:1}
  .intro__img--left{width:44%; height: 68%; left:0; top:18%}
  .intro__img--main{width:60%; height: 84%; right:0; top:6%}
  .intro__frame{left:14%; width:62%; height:82%}

  .offerings{padding: 3.4rem 0 3.9rem}
  .offerings__header{grid-template-columns:1fr}
  .offerings__blurb{margin:.1rem 0 0}
  .offerings__grid{grid-template-columns:1fr; gap:1.05rem}
  .service-card__media{height: 250px}

  .peace{padding: 0 0 2.2rem}
  .peace__wrap{grid-template-columns:1fr; border-radius:0}
  .peace__media{min-height: 280px}

  .segments{padding: 2.4rem 0 3.9rem}
  .segments__grid{grid-template-columns:1fr}
  .segment{grid-template-columns: 1fr}
  .segment__media{height: 240px}
  .segment__media img{min-height: 240px}
  .segment__panel{padding: 1.8rem 1.6rem; min-height: 220px}

  .projects{padding: .4rem 0 4.2rem}
  .projects__grid{grid-template-columns:1fr; gap: 1.25rem}
  .project-card{min-height: 360px}

  .quote{padding: 3.6rem 0}
  .quote__grid{grid-template-columns:1fr; gap: 1.4rem}
  .quote__card{padding: 2.4rem 1.7rem; border-radius: 1.25rem}
  .quote-form__grid{grid-template-columns:1fr}
  .quote__map{min-height: 360px}
  .quote__map iframe{min-height: 360px}

  .testimonials{padding: 4.0rem 0}
  .testimonials__grid{grid-template-columns:1fr; gap: 1.1rem}

  .brand__logo{height:100px; max-width:220px}
}

@media (max-width: 620px){
  .topbar__left{flex-direction:column;align-items:flex-start;gap:.35rem}
  .topbar__sep{display:none}

  .mainbar__inner{padding: 1.05rem 0}
  .brand{height: 72px}
  .brand__logo{
    height: 190px;
    max-width: min(340px, calc(100vw - 96px));
    top: 56%;
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{transition:none !important; animation:none !important}
}

.anchors{height:1px;overflow:hidden}

/* Footer */
.site-footer{
  position:relative;
  background: var(--bg);
  color: rgba(255,255,255,.84);
  overflow:hidden;
}
.site-footer::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(1200px 520px at 18% 30%, rgba(169,123,82,.14), transparent 62%),
    radial-gradient(900px 520px at 82% 18%, rgba(255,255,255,.06), transparent 58%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 1px, transparent 1px 28px);
  opacity:.9;
  pointer-events:none;
  transform: translateZ(0);
  background-size: 100% 100%, 100% 100%, 360px 360px;
  animation: footerDrift 18s linear infinite;
}
.site-footer::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.06), transparent 55%);
  opacity:.22;
  pointer-events:none;
}

@keyframes footerDrift{
  from{background-position: 0 0, 0 0, 0 0}
  to{background-position: 0 0, 0 0, 360px 360px}
}

.footer__grid{
  position:relative;
  z-index:1;
  padding: 4.4rem 0 3.2rem;
  display:grid;
  grid-template-columns: 1.45fr 1fr 1fr 1.25fr;
  gap: 2.6rem;
  align-items:start;
}

.footer__brand{max-width: 48ch}
.footer__mark{
  width: auto;
  height: auto;
  border-radius: 0;
  background: transparent;
  border: 0;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  overflow: visible;
  margin-bottom: 1.2rem;
  box-shadow: none;
}
.footer__mark img{width: 180px; max-width: 220px; height: auto; object-fit: contain; filter: drop-shadow(0 16px 34px rgba(0,0,0,.6))}

.footer__tagline{margin:0; font-size: 1.15rem; line-height:1.6; color: rgba(255,255,255,.9)}

.footer__title{margin: .2rem 0 1.05rem; font-size: 1.15rem; font-weight:800; color:#fff}

.footer__links{display:grid; gap: .65rem}
.footer__links a{
  color: rgba(255,255,255,.72);
  transition: color 200ms var(--ease), transform 200ms var(--ease);
  width: fit-content;
}
.footer__links a:hover{color:#fff; transform: translateX(2px)}

.footer__contact{margin:0; padding:0; list-style:none; display:grid; gap: .95rem}
.footer__contact li{display:flex; align-items:flex-start; gap: .75rem}
.footer__contact a{color: rgba(255,255,255,.78); transition: color 200ms var(--ease)}
.footer__contact a:hover{color:#fff}
.footer__icon{
  width: 34px; height: 34px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(169,123,82,.95);
  flex: 0 0 auto;
}
.footer__icon svg{width:18px;height:18px}

.footer__bottom{
  position:relative;
  z-index:1;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.55);
}
.footer__bottom-inner{
  padding: 1.25rem 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1.25rem;
}
.footer__copy{color: rgba(255,255,255,.62)}

.footer__social{display:flex; align-items:center; gap: .55rem}
.social{
  width: 40px; height: 40px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.86);
  transition: transform 180ms var(--ease), background 200ms var(--ease), border-color 200ms var(--ease), color 200ms var(--ease);
}
.social svg{width:18px;height:18px}
.social:hover{
  transform: translateY(-2px) scale(1.03);
  background: rgba(169,123,82,.20);
  border-color: rgba(169,123,82,.35);
  color:#fff;
}

@media (max-width: 980px){
  .footer__grid{grid-template-columns: 1fr 1fr; gap: 1.6rem; padding: 3.4rem 0 2.5rem}
  .footer__bottom-inner{flex-direction:column; align-items:flex-start}

  .footer__mark img{width: 160px; max-width: 200px}
}

@media (max-width: 620px){
  .footer__grid{grid-template-columns: 1fr}
}
