/* ============================================================
   H&H CONSTRUCTION — luxury general contracting
   Design system + page styles
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ink:#13100b;          /* warm espresso near-black */
  --charcoal:#1a160f;     /* dark sections */
  --graphite:#231e16;     /* raised dark surface */
  --hairline:rgba(243,233,214,.13);
  --hairline-dark:rgba(28,22,14,.13);

  --bone:#f3efe6;         /* warm off-white sections */
  --bone-2:#e9e2d4;       /* slightly deeper bone */
  --paper:#faf7f0;

  --bronze:#b0844c;       /* primary accent */
  --bronze-2:#cba56b;     /* lighter accent / hover */
  --bronze-soft:rgba(176,132,76,.13);

  --text-on-dark:#f1ece1;
  --muted-on-dark:#a59c89;
  --text-on-light:#1b170f;
  --muted-on-light:#6b6253;

  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);

  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--text-on-dark);
  font-size:17px;
  line-height:1.65;
  overflow-x:hidden;
  font-feature-settings:"kern" 1,"liga" 1,"calt" 1;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--bronze);color:#fff}
:focus-visible{outline:2px solid var(--bronze-2);outline-offset:3px;border-radius:1px}

/* ---------- Type helpers ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:12px;
  font-weight:600;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--bronze);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{
  content:"";
  width:26px;height:1px;
  background:var(--bronze);
  display:inline-block;
  opacity:.7;
}
.eyebrow.center::after{
  content:"";
  width:26px;height:1px;
  background:var(--bronze);
  display:inline-block;
  opacity:.7;
}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.04;letter-spacing:-.012em;font-feature-settings:"kern" 1,"liga" 1,"dlig" 1}
.display{
  font-size:clamp(40px,5.8vw,92px);
  font-weight:500;
  letter-spacing:-.018em;
}
.h2{
  font-size:clamp(34px,4.6vw,68px);
  font-weight:500;
}
.lede{
  font-size:clamp(17px,1.4vw,20px);
  color:var(--muted-on-dark);
  max-width:54ch;
  line-height:1.7;
}
.section{padding:clamp(80px,11vh,150px) 0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.on-light{background:var(--bone);color:var(--text-on-light)}
.on-light .lede{color:var(--muted-on-light)}
.on-light .eyebrow{color:var(--bronze)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-size:14px;font-weight:600;
  letter-spacing:.04em;
  padding:15px 28px;
  border-radius:2px;
  cursor:pointer;border:1px solid transparent;
  transition:all .4s var(--ease);
  position:relative;white-space:nowrap;
}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--bronze);color:#13110d}
.btn-primary:hover{background:var(--bronze-2)}
.btn-ghost{border-color:var(--hairline);color:var(--text-on-dark);background:transparent}
.btn-ghost:hover{border-color:var(--bronze);color:var(--bronze-2)}
.on-light .btn-ghost{border-color:var(--hairline-dark);color:var(--text-on-light)}
.on-light .btn-ghost:hover{border-color:var(--bronze);color:var(--bronze)}
.btn-dark{background:var(--ink);color:var(--text-on-dark)}
.btn-dark:hover{background:var(--graphite)}

/* ---------- Image base — cohesive warm grade + graceful fallback ---------- */
.img{
  background-color:var(--graphite);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  position:relative;
  filter:saturate(.9) contrast(1.03) brightness(.99);
}
.img::before{ /* unified warm art-direction cast over every photo */
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(155deg,rgba(125,84,38,.20),rgba(19,16,11,.12) 70%);
  mix-blend-mode:multiply;
}
.img::after{ /* subtle texture when no photo loads */
  content:"";position:absolute;inset:0;z-index:0;
  background:
    linear-gradient(135deg,rgba(203,165,107,.05),transparent 42%),
    repeating-linear-gradient(45deg,rgba(203,165,107,.02) 0 12px,transparent 12px 24px);
  pointer-events:none;
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .5s var(--ease),border-color .5s var(--ease),backdrop-filter .5s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(13,13,15,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--hairline);
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;padding:18px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:13px}
.brand-mark{
  width:46px;height:46px;border:1px solid var(--bronze);
  display:flex;align-items:center;justify-content:center;flex:none;
  font-family:var(--serif);font-size:17px;font-weight:600;color:var(--text-on-dark);
  letter-spacing:.01em;line-height:1;
}
.brand-mark .amp{font-style:italic;font-weight:500;color:var(--bronze-2);margin:0 .01em}
.brand-name{font-family:var(--serif);font-size:21px;font-weight:600;letter-spacing:.04em;white-space:nowrap;line-height:1.05}
.brand-name small{display:block;font-family:var(--sans);font-size:9.5px;font-weight:600;
  letter-spacing:.32em;color:var(--muted-on-dark);text-transform:uppercase;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:14px;font-weight:500;color:var(--text-on-dark);letter-spacing:.02em;
  position:relative;padding:4px 0;opacity:.85;transition:opacity .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--bronze);transition:width .35s var(--ease)}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:22px}
.nav-phone{font-size:14px;font-weight:600;letter-spacing:.02em;color:var(--text-on-dark);
  display:flex;align-items:center;gap:8px;white-space:nowrap}
.nav-phone .dot{width:6px;height:6px;border-radius:50%;background:#5fbf7d;box-shadow:0 0 0 3px rgba(95,191,125,.18)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--text-on-dark);display:block;transition:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  overflow:hidden;padding-top:clamp(104px,13vh,150px);padding-bottom:clamp(40px,7vh,90px)}
.hero-bg{position:absolute;inset:0;z-index:0;will-change:transform}
.hero-bg .img{position:absolute;inset:-8% 0;height:116%}
.hero-scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(13,13,15,.62) 0%,rgba(13,13,15,.20) 32%,rgba(13,13,15,.55) 72%,rgba(13,13,15,.96) 100%),
    linear-gradient(90deg,rgba(13,13,15,.55),transparent 60%);}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.hero h1{margin:22px 0 0;max-width:16ch}
.hero h1 em{font-style:italic;color:inherit;font-weight:500}
.hero-sub{margin-top:26px;max-width:46ch;font-size:clamp(16px,1.3vw,19px);color:#d9d4ca;line-height:1.7}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:32px}
.hero-trust{display:flex;flex-wrap:wrap;align-items:center;gap:14px 30px;margin-top:40px;
  padding-top:26px;border-top:1px solid var(--hairline)}
.hero-trust .t{display:flex;align-items:center;gap:10px;font-size:13.5px;color:#cfc9bf;letter-spacing:.02em}
.hero-trust .t b{font-family:var(--serif);font-size:22px;font-weight:600;color:#fff;line-height:1}
.hero-trust .stars{color:var(--bronze-2);letter-spacing:2px;font-size:14px}
.hero-trust .sep{width:1px;height:30px;background:var(--hairline)}
.scroll-cue{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:2;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-on-dark);
  display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-cue .line{width:1px;height:46px;background:linear-gradient(var(--bronze),transparent);
  animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}
  50.01%{transform-origin:bottom}100%{transform:scaleY(.3);transform-origin:bottom}}

/* ============================================================
   MARQUEE / credibility strip
   ============================================================ */
.strip{background:var(--charcoal);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
  overflow:hidden;padding:22px 0}
.marquee{display:flex;gap:54px;width:max-content;animation:slide 52s linear infinite}
.marquee span{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--muted-on-dark);
  white-space:nowrap;display:flex;align-items:center;gap:54px}
.marquee span::after{content:"";width:4px;height:4px;border-radius:50%;background:var(--bronze);font-style:normal;opacity:.8}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============================================================
   STATS — open editorial columns (no card box)
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--hairline-dark);padding-top:50px}
.stat{padding:0 clamp(20px,2.6vw,44px);position:relative}
.stat+.stat{border-left:1px solid var(--hairline-dark)}
.stat:first-child{padding-left:0}
.stat .num{font-family:var(--serif);font-size:clamp(54px,6vw,86px);font-weight:500;line-height:.92;
  color:var(--ink);display:flex;align-items:baseline;gap:.08em;letter-spacing:-.02em}
.stat .num .suf{font-size:.42em;color:var(--bronze);font-weight:500;letter-spacing:0}
.stat .lab{margin-top:20px;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-on-light);font-weight:600}
.stat .desc{margin-top:8px;font-size:14.5px;color:var(--muted-on-light);line-height:1.5;max-width:22ch}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;
  margin-bottom:clamp(40px,6vh,76px)}
.sec-head .left{max-width:60ch}
.sec-head h2{margin-top:18px}
.sec-head .right{max-width:34ch;padding-bottom:8px}
@media(max-width:820px){.sec-head{flex-direction:column;align-items:flex-start;gap:20px}}

/* ============================================================
   SERVICES — open hairline grid (no filled tiles / chips)
   ============================================================ */
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hairline-dark)}
.svc{background:var(--bone);padding:clamp(40px,4vw,60px) clamp(28px,3vw,52px);position:relative;
  overflow:hidden;min-height:280px;display:flex;flex-direction:column}
.svc::before{content:"";position:absolute;left:0;top:0;height:2px;width:0;background:var(--bronze);transition:width .6s var(--ease)}
.svc:hover::before{width:100%}
.svc .idx{font-family:var(--serif);font-size:clamp(20px,2vw,26px);color:var(--bronze);font-style:italic;line-height:1}
.svc h3{font-size:clamp(28px,2.6vw,34px);margin:16px 0 0;color:var(--ink);font-weight:600;letter-spacing:-.01em}
.svc p{margin-top:14px;color:var(--muted-on-light);font-size:15.5px;line-height:1.64;max-width:42ch}
.svc .tags{margin-top:auto;padding-top:26px;display:flex;flex-wrap:wrap;gap:7px 0;align-items:center;
  font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--muted-on-light)}
.svc .tag{position:relative}
.svc .tag+.tag{padding-left:18px}
.svc .tag+.tag::before{content:"";position:absolute;left:8px;top:50%;width:3px;height:3px;border-radius:50%;
  background:var(--bronze);transform:translateY(-50%);opacity:.7}
.svc .go{position:absolute;top:clamp(40px,4vw,60px);right:clamp(28px,3vw,52px);color:var(--ink);
  opacity:0;transform:translate(-6px,6px);transition:.45s var(--ease)}
.svc:hover .go{opacity:1;transform:none;color:var(--bronze)}

/* ============================================================
   BEFORE / AFTER
   ============================================================ */
.ba-wrap{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.ba{position:relative;aspect-ratio:16/10;overflow:hidden;user-select:none;
  border:1px solid var(--hairline);cursor:ew-resize;background:var(--graphite)}
.ba .layer{position:absolute;inset:0}
.ba .after{z-index:1}
.ba .before{z-index:2;clip-path:inset(0 50% 0 0)}
.ba .layer .img{width:100%;height:100%}
.ba .tag{position:absolute;top:18px;z-index:4;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:700;padding:7px 13px;background:rgba(13,13,15,.7);backdrop-filter:blur(6px);color:#fff;border-radius:2px}
.ba .tag.b{left:18px}
.ba .tag.a{right:18px;background:var(--bronze);color:#13110d}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;z-index:3;transform:translateX(-1px);pointer-events:none}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:4;
  width:54px;height:54px;border-radius:50%;background:#fff;display:grid;place-items:center;
  box-shadow:0 8px 30px rgba(0,0,0,.4);pointer-events:none}
.ba-knob svg{color:#13110d}
.ba-side h3{font-size:clamp(30px,3.4vw,46px);color:inherit;margin:16px 0 0}
.ba-side .meta{display:flex;gap:26px;margin-top:26px;flex-wrap:wrap}
.ba-side .meta .m .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-on-dark);font-weight:600}
.ba-side .meta .m .v{font-family:var(--serif);font-size:21px;margin-top:4px}
.ba-side p{margin-top:24px;color:var(--muted-on-dark);max-width:42ch;line-height:1.7}
.ba-hint{margin-top:22px;font-size:12.5px;letter-spacing:.04em;color:var(--bronze-2);display:flex;align-items:center;gap:9px}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:38px}
.filter{font-size:13px;font-weight:600;letter-spacing:.03em;padding:11px 20px;border-radius:2px;
  min-height:44px;display:inline-flex;align-items:center;
  border:1px solid var(--hairline);color:var(--muted-on-dark);background:transparent;cursor:pointer;
  transition:.35s var(--ease)}
.filter:hover{color:var(--text-on-dark);border-color:var(--hairline)}
.filter.active{background:var(--bronze);border-color:var(--bronze);color:#13110d}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card{position:relative;overflow:hidden;background:var(--graphite);cursor:pointer;
  transition:transform .6s var(--ease),opacity .5s var(--ease)}
.card .img{width:100%;height:100%;transition:transform 1s var(--ease)}
.card:hover .img{transform:scale(1.06)}
.card::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(13,13,15,.85));opacity:.85;transition:opacity .5s}
.card-body{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:26px;
  transform:translateY(8px);opacity:.92;transition:.5s var(--ease)}
.card:hover .card-body{transform:none;opacity:1}
.card-body .cat{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--bronze-2);font-weight:700}
.card-body h3{font-size:24px;margin-top:8px;color:#fff;font-weight:600}
.card-body .loc{font-size:13px;color:var(--muted-on-dark);margin-top:4px}
.card .plus{position:absolute;top:20px;right:20px;z-index:2;width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);display:grid;place-items:center;color:#fff;
  opacity:0;transform:scale(.8);transition:.45s var(--ease);background:rgba(13,13,15,.3);backdrop-filter:blur(4px)}
.card:hover .plus{opacity:1;transform:none}
/* spans */
.card.tall{grid-column:span 5;aspect-ratio:4/5}
.card.wide{grid-column:span 7;aspect-ratio:16/11}
.card.half{grid-column:span 6;aspect-ratio:16/10}
.card.third{grid-column:span 4;aspect-ratio:4/5}
.card.hide{display:none}
@media(max-width:900px){
  .card.tall,.card.wide,.card.half,.card.third{grid-column:span 12;aspect-ratio:16/10}
}

/* ============================================================
   PROCESS
   ============================================================ */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--hairline-dark)}
.step{padding:42px 30px 42px 0;border-top:0;position:relative}
.step::before{content:"";position:absolute;top:-1px;left:0;width:0;height:2px;background:var(--bronze);
  transition:width 1s var(--ease)}
.step.in::before{width:60%}
.step .n{font-family:var(--serif);font-size:15px;color:var(--bronze);letter-spacing:.1em}
.step h3{font-size:26px;margin:22px 0 0;color:var(--ink);font-weight:600}
.step p{margin-top:12px;color:var(--muted-on-light);font-size:15px;line-height:1.6;max-width:30ch}
@media(max-width:900px){.process{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.process{grid-template-columns:1fr}}

/* ============================================================
   ABOUT
   ============================================================ */
.about{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,84px);align-items:center}
.about-media{position:relative}
.about-media .img{aspect-ratio:4/5;width:100%}
.about-media .badge{position:absolute;right:-22px;bottom:-22px;background:var(--ink);color:var(--text-on-dark);
  padding:26px 30px;border:1px solid var(--hairline);max-width:220px}
.about-media .badge .big{font-family:var(--serif);font-size:42px;line-height:1;color:var(--bronze-2)}
.about-media .badge .small{font-size:13px;color:var(--muted-on-dark);margin-top:8px;line-height:1.45}
.about h2{margin:16px 0 0}
.about .body{margin-top:26px;color:var(--muted-on-light);line-height:1.75;max-width:48ch}
.about .body p+p{margin-top:18px}
.creds{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:34px}
.cred{display:flex;gap:14px;align-items:flex-start}
.cred .ic{flex:none;width:38px;height:38px;border:1px solid var(--hairline-dark);display:grid;place-items:center;color:var(--bronze)}
.cred .k{font-weight:600;color:var(--ink);font-size:15px}
.cred .v{font-size:13.5px;color:var(--muted-on-light);margin-top:2px}
.signature{margin-top:36px;display:flex;align-items:center;gap:18px}
.signature .sig{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--ink)}
.signature .who{font-size:13px;color:var(--muted-on-light);line-height:1.4}
.signature .who b{color:var(--ink);font-weight:600;display:block;font-size:14px}
@media(max-width:860px){.about{grid-template-columns:1fr}.about-media .badge{right:18px}}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,56px)}
.quote{background:transparent;border:0;border-top:1px solid var(--hairline);padding:30px 0 0;display:flex;flex-direction:column}
.quote .stars{color:var(--bronze-2);letter-spacing:3px;font-size:14px}
.quote p{font-family:var(--serif);font-size:22px;line-height:1.46;margin:20px 0 0;color:#efece5;font-weight:500}
.quote .who{margin-top:auto;padding-top:28px;display:flex;align-items:center;gap:14px}
.quote .av{width:46px;height:46px;border-radius:50%;background:var(--bronze-soft);border:1px solid var(--hairline);
  display:grid;place-items:center;font-family:var(--serif);font-size:18px;color:var(--bronze-2)}
.quote .who .k{font-weight:600;font-size:15px;color:#fff}
.quote .who .v{font-size:13px;color:var(--muted-on-dark);margin-top:2px}
@media(max-width:920px){.quotes{grid-template-columns:1fr}}

/* ============================================================
   CTA + CONTACT
   ============================================================ */
.cta{position:relative;overflow:hidden;background:var(--charcoal)}
.cta-bg{position:absolute;inset:0;z-index:0;opacity:.28}
.cta-bg .img{width:100%;height:100%}
.cta-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,var(--ink) 30%,rgba(13,13,15,.55))}
.cta-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.cta h2{margin:18px 0 0;max-width:14ch}
.cta .lede{margin-top:24px}
.cta-contact{margin-top:38px;display:grid;gap:2px}
.cta-contact a{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--hairline);
  transition:.35s var(--ease)}
.cta-contact a:hover{padding-left:8px;color:var(--bronze-2)}
.cta-contact .ic{color:var(--bronze);flex:none}
.cta-contact .k{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-on-dark);font-weight:600}
.cta-contact .v{font-size:17px;font-weight:500;margin-top:2px;white-space:nowrap}
.cta-contact a:last-child .v{white-space:normal}
/* form */
.form{background:var(--paper);padding:clamp(30px,4vw,46px);color:var(--text-on-light)}
.form h3{font-size:28px;color:var(--ink);font-weight:600}
.form .sub{color:var(--muted-on-light);font-size:14.5px;margin-top:8px}
.field{margin-top:20px}
.field label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--muted-on-light)}
.field input,.field select,.field textarea{
  width:100%;margin-top:9px;padding:14px 16px;border:1px solid var(--hairline-dark);background:#fff;
  font-family:var(--sans);font-size:15.5px;color:var(--ink);border-radius:2px;transition:border-color .3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--bronze)}
.field textarea{resize:vertical;min-height:96px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .btn{width:100%;justify-content:center;margin-top:26px}
.form .fine{font-size:12.5px;color:var(--muted-on-light);margin-top:16px;text-align:center}
.form-success{display:none;text-align:center;padding:40px 10px}
.form-success.show{display:block}
.form-success .ck{width:62px;height:62px;border-radius:50%;border:1px solid var(--bronze);color:var(--bronze);
  display:grid;place-items:center;margin:0 auto 22px}
.form-success h3{margin-bottom:10px}
@media(max-width:860px){.cta-inner{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);border-top:1px solid var(--hairline);padding:70px 0 34px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.foot-brand .brand{margin-bottom:20px}
.foot-brand p{color:var(--muted-on-dark);font-size:14.5px;max-width:32ch;line-height:1.6}
.foot-col h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--bronze);font-weight:700;margin-bottom:18px}
.foot-col a,.foot-col p{display:block;color:var(--muted-on-dark);font-size:14.5px;padding:6px 0;transition:color .3s}
.foot-col a:hover{color:var(--text-on-dark)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  margin-top:54px;padding-top:26px;border-top:1px solid var(--hairline);
  font-size:13px;color:var(--muted-on-dark)}
.foot-bottom .socials{display:flex;gap:10px}
.foot-bottom .socials a{width:36px;height:36px;border:1px solid var(--hairline);display:grid;place-items:center;
  color:var(--muted-on-dark);transition:.35s var(--ease)}
.foot-bottom .socials a:hover{border-color:var(--bronze);color:var(--bronze)}
@media(max-width:860px){.foot-top{grid-template-columns:1fr 1fr}}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  .reveal.d1{transition-delay:.08s}
  .reveal.d2{transition-delay:.16s}
  .reveal.d3{transition-delay:.24s}
  .reveal.d4{transition-delay:.32s}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1080px){
  .stats{grid-template-columns:1fr 1fr;row-gap:42px}
  .stat{border-left:0;padding-left:0}
  .stat:nth-child(even){border-left:1px solid var(--hairline-dark);padding-left:clamp(20px,2.6vw,44px)}
  .services{grid-template-columns:1fr}
  .ba-wrap{grid-template-columns:1fr}
}
@media(max-width:880px){
  .nav-links,.nav-phone{display:none}
  .burger{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--ink);padding:24px var(--gutter);gap:18px;border-bottom:1px solid var(--hairline)}
}
@media(max-width:560px){
  .stats{grid-template-columns:1fr;row-gap:36px}
  .stat,.stat:nth-child(even){border-left:0;padding-left:0}
  .quotes{grid-template-columns:1fr}
}

/* Mobile nav drawer (when toggled) */
.nav.open{background:rgba(19,16,11,.96);backdrop-filter:blur(14px)}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-hero{position:relative;overflow:hidden;background:var(--charcoal);
  padding:calc(clamp(104px,13vh,150px) + 36px) 0 clamp(54px,9vh,96px)}
.contact-hero .img{position:absolute;inset:0;opacity:.22;z-index:0}
.contact-hero .scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(118deg,var(--ink) 34%,rgba(19,16,11,.5))}
.contact-hero .wrap{position:relative;z-index:2}
.contact-hero h1{font-size:clamp(40px,5.6vw,82px);font-weight:500;margin-top:20px;max-width:16ch;letter-spacing:-.018em}
.contact-hero h1 em{font-style:italic}
.contact-hero .lede{margin-top:24px}

.contact-main{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(36px,5vw,84px);align-items:start}
.info-list{margin-top:26px}
.info-row{display:flex;gap:16px;align-items:flex-start;padding:22px 0;border-bottom:1px solid var(--hairline-dark)}
.info-row:first-child{border-top:1px solid var(--hairline-dark)}
.info-row .ic{color:var(--bronze);flex:none;margin-top:1px}
.info-row .k{font-size:11.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted-on-light);font-weight:600}
.info-row .v{font-size:17px;font-weight:500;margin-top:5px;color:var(--text-on-light);display:block}
.info-row a.v:hover{color:var(--bronze)}
.hours{margin-top:34px}
.hours .hh{font-size:11.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--bronze);font-weight:600;margin-bottom:10px}
.hours .row{display:flex;justify-content:space-between;gap:20px;padding:9px 0;
  border-bottom:1px solid var(--hairline-dark);font-size:14.5px;color:var(--muted-on-light)}
.hours .row b{color:var(--text-on-light);font-weight:600}

.faq-sec{background:var(--bone-2)}
.faq{border-top:1px solid var(--hairline-dark);max-width:880px}
.faq details{border-bottom:1px solid var(--hairline-dark)}
.faq summary{list-style:none;cursor:pointer;padding:26px 0;display:flex;justify-content:space-between;
  gap:24px;align-items:center;font-family:var(--serif);font-size:clamp(20px,2.2vw,27px);
  color:var(--ink);font-weight:600;letter-spacing:-.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{flex:none;width:24px;height:24px;position:relative}
.faq summary .pl::before,.faq summary .pl::after{content:"";position:absolute;background:var(--bronze);transition:.4s var(--ease)}
.faq summary .pl::before{top:50%;left:0;right:0;height:1.5px;transform:translateY(-50%)}
.faq summary .pl::after{left:50%;top:0;bottom:0;width:1.5px;transform:translateX(-50%)}
.faq details[open] summary .pl::after{transform:translateX(-50%) scaleY(0)}
.faq details p{color:var(--muted-on-light);line-height:1.72;max-width:64ch;padding:0 0 28px;font-size:15.5px}
@media(max-width:860px){.contact-main{grid-template-columns:1fr}}
