/* ============================================================
   PEAK ELEVATION EXTERIORS — Design System
   Direction: Alpine Editorial. White field, midnight-navy panels,
   champagne-gold ridgeline signature. Fraunces display / Archivo UI.
   ============================================================ */

:root{
  --white:#FFFFFF;
  --alabaster:#F6F5F1;
  --navy-900:#0A1C33;
  --navy-800:#122B4E;
  --navy-700:#1B3A66;
  --ink:#10233D;
  --slate:#47586E;
  --mist:#8C99AB;
  --gold:#C4A155;
  --gold-soft:#D8BC7E;
  --gold-deep:#8A6C2E;
  --hairline:#E5E2D9;
  --hairline-navy:rgba(255,255,255,.14);
  --success:#2F7A4D;
  --error:#B4452F;

  --font-display:"Fraunces", Georgia, "Times New Roman", serif;
  --font-body:"Archivo", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  --w-max:1200px;
  --w-wide:1360px;
  --w-text:70ch;

  --r-sm:8px;
  --r-md:14px;
  --r-lg:22px;

  --shadow-sm:0 1px 2px rgba(10,28,51,.06),0 2px 8px rgba(10,28,51,.05);
  --shadow-md:0 2px 6px rgba(10,28,51,.07),0 14px 34px rgba(10,28,51,.10);
  --shadow-gold:0 10px 28px rgba(196,161,85,.35);
  --shadow-gold-strong:0 14px 40px rgba(196,161,85,.48),0 4px 12px rgba(10,28,51,.12);

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

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:96px}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:1.0625rem;
  line-height:1.65;
  color:var(--slate);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:var(--navy-800);text-decoration:none}
a:hover{color:var(--gold-deep)}
ul{margin:0;padding:0;list-style:none}
p{margin:0 0 1.1em}
strong{color:var(--ink);font-weight:600}
::selection{background:var(--gold);color:var(--navy-900)}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy-900);color:#fff;padding:.8rem 1.2rem;z-index:1000;border-radius:0 0 var(--r-sm) 0}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:2px}

/* ---------- Type ---------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:520;
  color:var(--ink);
  line-height:1.2;
  letter-spacing:-.015em;
  margin:0 0 .5em;
  text-wrap:balance;
  overflow:visible;
}
h1{font-size:clamp(2.6rem,6.2vw,4.9rem);line-height:1.12}
h2{font-size:clamp(2.05rem,4.2vw,3.3rem);line-height:1.22;padding-block:.06em}
h3{font-size:clamp(1.35rem,2.4vw,1.7rem);font-weight:560;line-height:1.25}
h4{font-size:1.12rem;font-family:var(--font-body);font-weight:700;letter-spacing:-.005em}
.lead{font-size:clamp(1.12rem,1.7vw,1.32rem);line-height:1.6;color:var(--slate);max-width:var(--w-text)}
.small{font-size:.88rem}
.measure{max-width:var(--w-text)}

/* Eyebrow — survey-marker label with peak tick */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:1.1rem;
}
.eyebrow::before{
  content:"";width:14px;height:9px;flex:none;
  background:currentColor;
  clip-path:polygon(0 100%,38% 18%,55% 52%,70% 0,100% 100%);
}
.on-navy .eyebrow,.eyebrow--light{color:var(--gold-soft)}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--w-max);margin-inline:auto;padding-inline:clamp(1.25rem,4vw,2.5rem)}
.container--wide{max-width:var(--w-wide)}
.section{padding-block:clamp(4.5rem,9vw,7.5rem)}
.section--tight{padding-block:clamp(3.2rem,6vw,4.8rem)}
.section--alt{background:var(--alabaster)}
.section--navy{background:linear-gradient(168deg,var(--navy-900),var(--navy-800));color:#C7D2E2}
.section--navy h2,.section--navy h3{color:#fff}
.section--navy p{color:#C7D2E2}
.section-head{max-width:820px;margin-bottom:clamp(2.4rem,5vw,3.6rem);overflow:visible}
.section-head h2{overflow:visible}
.section-head--center{margin-inline:auto;text-align:center}
.section-head--center .eyebrow{justify-content:center}
.grid{display:grid;gap:clamp(1.1rem,2.2vw,1.75rem)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.4rem,5vw,4.5rem);align-items:center}

/* Gold ridgeline divider — the signature */
.ridge{display:block;width:100%;height:auto;color:var(--gold)}
.ridge--flip{transform:scaleY(-1)}
.ridge-wrap{line-height:0;background:var(--white)}
.ridge-wrap--navy{background:#16345C}
.hr-gold{border:0;height:1px;background:linear-gradient(90deg,var(--gold),transparent);margin:2.2rem 0;max-width:220px}

/* ---------- Buttons: huge, deliberate ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.65rem;
  font-family:var(--font-body);font-weight:700;font-size:.95rem;
  letter-spacing:.09em;text-transform:uppercase;
  padding:1.15rem 2.2rem;border-radius:var(--r-sm);
  border:1.5px solid transparent;cursor:pointer;text-align:center;
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease),color .18s var(--ease),border-color .18s var(--ease);
  will-change:transform;
}
.btn svg{width:18px;height:18px;flex:none}
.btn:active{transform:translateY(1px)}
.btn--gold{background:linear-gradient(165deg,var(--gold-soft) 0%,var(--gold) 100%);color:var(--navy-900);box-shadow:var(--shadow-gold);border-color:var(--gold-deep)}
.btn--gold:hover{background:linear-gradient(165deg,#E4CD96 0%,var(--gold-soft) 100%);color:var(--navy-900);transform:translateY(-2px);box-shadow:var(--shadow-gold-strong)}
.btn--gold:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.btn--navy{background:var(--navy-900);color:#fff}
.btn--navy:hover{background:var(--navy-800);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--ghost{border-color:rgba(255,255,255,.45);color:#fff;background:transparent}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-soft)}
.btn--outline{border-color:var(--navy-900);color:var(--navy-900);background:transparent}
.btn--outline:hover{background:var(--navy-900);color:#fff}
.btn--xl{padding:1.35rem 2.7rem;font-size:1.02rem}
.btn--block{width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}

/* ---------- Announcement microbar ---------- */
.announce{background:var(--navy-900);color:#AFC0D6;font-size:.8rem;letter-spacing:.05em}
.announce .container{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-block:.55rem}
.announce a{color:var(--gold-soft);font-weight:600}
.announce a:hover{color:#fff}
.announce-note{display:flex;align-items:center;gap:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.announce-note svg{width:13px;height:13px;flex:none;color:var(--gold)}

/* ---------- Header ---------- */
.header{
  position:sticky;top:0;z-index:120;background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .25s,box-shadow .25s;
}
.header.is-scrolled{border-bottom-color:var(--hairline);box-shadow:0 6px 24px rgba(10,28,51,.06)}
.header-bar{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;padding-block:.95rem}
.brand{display:flex;align-items:center;gap:.8rem;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand-mark{width:46px;height:46px;flex:none}
.brand-name{display:flex;flex-direction:column;line-height:1.04}
.brand-name b{font-family:var(--font-display);font-weight:600;font-size:1.22rem;letter-spacing:.01em;color:var(--ink)}
.brand-name span{font-size:.63rem;font-weight:700;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep)}
.nav{display:flex;align-items:center;gap:clamp(1rem,2vw,1.9rem)}
.nav a{font-size:.93rem;font-weight:600;color:var(--ink);position:relative;padding-block:.35rem}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:width .22s var(--ease)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.header-cta{display:flex;align-items:center;gap:1.15rem}
.header-phone{display:flex;flex-direction:column;line-height:1.15;text-align:right}
.header-phone span{font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--mist)}
.header-phone a{font-size:1.04rem;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.header-phone a:hover{color:var(--gold-deep)}
.header .btn{padding:.95rem 1.6rem;font-size:.86rem}

/* Mobile menu */
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:.5rem;margin-right:-.5rem}
.menu-toggle span{display:block;width:26px;height:2px;background:var(--ink);margin:6px 0;transition:transform .25s var(--ease),opacity .2s}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.mobile-menu{
  position:fixed;inset:0;z-index:200;background:linear-gradient(170deg,var(--navy-900) 0%,var(--navy-800) 100%);
  display:flex;flex-direction:column;padding:1.4rem clamp(1.4rem,6vw,3rem) 2.5rem;
  transform:translateX(100%);transition:transform .34s var(--ease);overflow-y:auto;
}
.mobile-menu.is-open{transform:translateX(0)}
.mobile-menu-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.4rem}
.mobile-menu-close{background:none;border:0;color:#fff;font-size:2.2rem;line-height:1;cursor:pointer;padding:.3rem .6rem}
.mobile-menu nav{display:flex;flex-direction:column;gap:.15rem;margin-bottom:2.2rem}
.mobile-menu nav a{
  font-family:var(--font-display);font-size:2rem;color:#fff;padding:.55rem 0;
  border-bottom:1px solid var(--hairline-navy);display:flex;justify-content:space-between;align-items:center;
}
.mobile-menu nav a::after{content:"→";font-size:1.1rem;color:var(--gold)}
.mobile-menu nav a:hover{color:var(--gold-soft)}
.mobile-menu .btn{margin-top:auto}
.mobile-menu-phone{color:#AFC0D6;font-size:.95rem;margin:1.6rem 0 .9rem}
.mobile-menu-phone a{color:var(--gold-soft);font-weight:700;font-size:1.3rem;display:block;margin-top:.2rem}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(180deg,var(--navy-900) 0%,var(--navy-800) 55%,#16345C 100%);color:#C7D2E2;overflow:hidden}
.hero-topo{position:absolute;inset:0;opacity:.5;pointer-events:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:center;padding-block:clamp(4.2rem,8vw,7rem)}
.hero h1{color:#fff;margin-bottom:1.3rem}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero .lead{color:#B9C7DA;margin-bottom:2.4rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.1rem 2rem;margin-top:2.6rem;padding-top:1.7rem;border-top:1px solid var(--hairline-navy)}
.hero-trust li{display:flex;align-items:center;gap:.55rem;font-size:.86rem;font-weight:600;color:#D5DEEA;letter-spacing:.02em}
.hero-trust svg{width:17px;height:17px;color:var(--gold);flex:none}
.hero-art{position:relative}
.summit-card{
  border-radius:var(--r-lg);overflow:hidden;box-shadow:0 30px 80px rgba(4,12,24,.5);
  border:1px solid rgba(255,255,255,.12);background:var(--navy-800);
}
.summit-card svg{width:100%;height:auto;display:block}
.summit-scene .summit-star,
.summit-card .summit-star{
  opacity:.55;
  animation:summit-twinkle 3.2s ease-in-out infinite;
  transform-box:fill-box;
  transform-origin:center;
}
@keyframes summit-twinkle{
  0%,100%{opacity:.2;transform:scale(.85)}
  50%{opacity:1;transform:scale(1.35)}
}
@keyframes summit-moon-glow{
  0%,100%{opacity:.65;transform:scale(1)}
  50%{opacity:1;transform:scale(1.14)}
}
@keyframes summit-moon-pulse{
  0%,100%{opacity:.88;filter:drop-shadow(0 0 8px rgba(196,161,85,.35))}
  50%{opacity:1;filter:drop-shadow(0 0 22px rgba(196,161,85,.75))}
}
@keyframes summit-wave-drift{
  0%,100%{transform:translateX(0);stroke-opacity:.12}
  50%{transform:translateX(16px);stroke-opacity:.28}
}
@keyframes summit-smoke-rise{
  0%{opacity:0;transform:translateY(0) scale(.8)}
  20%{opacity:.55}
  100%{opacity:0;transform:translateY(-18px) scale(1.15)}
}
.summit-star--1{animation-delay:0s}
.summit-star--2{animation-delay:.6s}
.summit-star--3{animation-delay:1.2s}
.summit-star--4{animation-delay:1.8s}
.summit-star--5{animation-delay:2.4s}
.summit-star--6{animation-delay:.9s}
.summit-star--7{animation-delay:1.5s}
.summit-star--8{animation-delay:2.1s}
.summit-star--9{animation-delay:2.7s}
.summit-scene .summit-moon-glow,
.summit-card .summit-moon-glow{
  transform-origin:500px 132px;
  animation:summit-moon-glow 6s ease-in-out infinite;
}
.summit-scene .summit-moon,
.summit-card .summit-moon{animation:summit-moon-pulse 6s ease-in-out infinite}
.summit-scene .summit-wave,
.summit-card .summit-wave{animation:summit-wave-drift 12s ease-in-out infinite}
.summit-wave--2{animation-delay:-5s;animation-duration:14s}
.summit-scene .summit-smoke-puff,
.summit-card .summit-smoke-puff{opacity:0;animation:summit-smoke-rise 5s ease-out infinite}
.summit-smoke-puff--2{animation-delay:1.6s}
.summit-smoke-puff--3{animation-delay:3.2s}
.float-chip{
  position:absolute;background:#fff;color:var(--ink);border-radius:12px;box-shadow:var(--shadow-md);
  padding:.75rem 1.05rem;display:flex;align-items:center;gap:.7rem;font-size:.86rem;font-weight:600;
}
.float-chip--rating{bottom:8%;left:-6%}
.float-chip--est{top:7%;right:-4%}
.float-chip .stars{color:var(--gold-deep);letter-spacing:.12em;font-size:.92rem}
.float-chip small{display:block;font-weight:500;color:var(--slate);font-size:.74rem;letter-spacing:.02em}
.chip-dot{width:34px;height:34px;border-radius:50%;background:var(--navy-900);display:grid;place-items:center;flex:none}
.chip-dot svg{width:17px;height:17px;color:var(--gold)}

/* Sub-hero (interior pages) */
.hero--sub .hero-inner{grid-template-columns:1fr;padding-block:clamp(3.6rem,6.5vw,5.2rem)}
.hero--sub h1{font-size:clamp(2.3rem,5vw,3.9rem);max-width:19ch}
.hero--sub .lead{max-width:62ch;margin-bottom:2rem}
.breadcrumb{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.8rem;letter-spacing:.06em;color:#8FA3BE;margin-bottom:1.6rem;text-transform:uppercase;font-weight:600}
.breadcrumb a{color:#B9C7DA}
.breadcrumb a:hover{color:var(--gold-soft)}
.breadcrumb li:not(:last-child)::after{content:"/";margin-left:.5rem;color:#54688A}
.breadcrumb [aria-current]{color:var(--gold-soft)}

/* ---------- Cards ---------- */
.card{
  background:var(--white);border:1px solid var(--hairline);border-radius:var(--r-md);
  padding:clamp(1.6rem,2.6vw,2.2rem);position:relative;overflow:hidden;
  transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s;
}
.card::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:3px;background:var(--gold);transition:right .3s var(--ease)}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:transparent}
.card:hover::after{right:0}
.card h3 a{color:var(--ink)}
.card h3 a::after{content:"";position:absolute;inset:0}
.card p{font-size:.98rem;margin-bottom:1rem}
.card-icon{width:56px;height:56px;border-radius:14px;background:var(--navy-900);display:grid;place-items:center;margin-bottom:1.35rem}
.card-icon svg{width:28px;height:28px;color:var(--gold)}
.card-link{font-size:.84rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);display:inline-flex;align-items:center;gap:.45rem}
.card-link::after{content:"→";transition:transform .2s var(--ease)}
.card:hover .card-link::after{transform:translateX(4px)}
.card-sub{font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--mist);margin-bottom:.55rem}

/* Value cards (About page) */
.card--value{
  cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;
  appearance:none;-webkit-appearance:none;
}
.card--value:hover,.card--value:focus-visible{
  transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--gold);
}
.card--value:focus-visible{outline:2px solid var(--gold-deep);outline-offset:3px}
.card--value .card-link{margin-top:.25rem}
.card--value p{margin-bottom:.65rem}

/* Value detail modal */
.value-modal{
  position:fixed;inset:0;z-index:280;display:flex;align-items:center;justify-content:center;
  padding:1.25rem 1rem;
}
.value-modal[hidden]{display:none}
.value-modal-backdrop{
  position:absolute;inset:0;background:rgba(6,13,25,.72);border:none;cursor:pointer;
}
.value-modal-panel{
  position:relative;z-index:1;background:var(--white);border-radius:var(--r-lg);
  max-width:min(640px,94vw);width:100%;max-height:min(82vh,720px);overflow:auto;
  padding:clamp(1.8rem,3.5vw,2.6rem);box-shadow:var(--shadow-md);
  border:1px solid var(--hairline);
}
.value-modal-close{
  position:absolute;top:.85rem;right:.85rem;width:2.4rem;height:2.4rem;border:none;border-radius:8px;
  background:var(--alabaster);color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;
  transition:background .15s var(--ease),color .15s var(--ease);
}
.value-modal-close:hover,.value-modal-close:focus-visible{
  background:var(--navy-900);color:var(--gold-soft);
}
.value-modal-body h3{
  font-size:clamp(1.35rem,2.4vw,1.65rem);margin-bottom:1.1rem;padding-right:2rem;
}
.value-modal-body p{font-size:1rem;line-height:1.65;margin-bottom:1rem;color:var(--slate)}
.value-modal-body p:last-child{margin-bottom:0}

/* Check list */
.check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem 2rem}
.check-grid li{display:flex;gap:.8rem;align-items:flex-start;font-size:1rem;color:var(--ink);font-weight:500}
.check-grid svg{width:20px;height:20px;color:var(--gold-deep);flex:none;margin-top:.2rem}

/* Option cards */
.option-card{background:var(--white);border:1px solid var(--hairline);border-radius:var(--r-md);padding:1.8rem;transition:box-shadow .22s var(--ease),transform .22s var(--ease)}
.option-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.option-card h4{margin-bottom:.5rem;color:var(--ink)}
.option-card p{font-size:.94rem;margin:0}
.option-tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);border:1px solid var(--gold);border-radius:99px;padding:.28rem .8rem;margin-bottom:.9rem}

/* Service reasons (exterior painting) */
.split--reasons{align-items:start}
.reason-photos{display:flex;flex-direction:column;gap:1rem}
.reason-photo{width:100%;height:auto;display:block;border-radius:var(--r-md);object-fit:cover;box-shadow:var(--shadow-sm)}

/* Colorado callout */
.callout{
  background:linear-gradient(150deg,var(--navy-900),var(--navy-800));color:#C7D2E2;
  border-radius:var(--r-lg);padding:clamp(2rem,4vw,3.2rem);position:relative;overflow:hidden;
}
.callout h3{color:#fff}
.callout p{color:#C0CDDF;margin:0;max-width:66ch}
.callout::before{
  content:"";position:absolute;right:-40px;top:-40px;width:240px;height:240px;border-radius:50%;
  border:1px solid rgba(196,161,85,.35);pointer-events:none;
}
.callout::after{
  content:"";position:absolute;right:8px;top:8px;width:144px;height:144px;border-radius:50%;
  border:1px solid rgba(196,161,85,.2);pointer-events:none;
}
.callout .eyebrow{color:var(--gold-soft)}
.callout--founder{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.2rem,3vw,1.8rem);align-items:start}
.founder-photo{margin:0;width:clamp(96px,22vw,132px);flex-shrink:0}
.founder-photo img{
  width:100%;height:auto;display:block;border-radius:var(--r-md);
  border:2px solid rgba(196,161,85,.35);object-fit:cover;aspect-ratio:4/5;
}

/* ---------- Stats band (Built for 5,280) ---------- */
.stat{border-left:2px solid var(--gold);padding-left:1.4rem}
.stat b{display:block;font-family:var(--font-display);font-size:clamp(2.3rem,4vw,3.4rem);font-weight:560;color:#fff;line-height:1;margin-bottom:.55rem;letter-spacing:-.02em}
.stat b sub{font-size:.36em;color:var(--gold-soft);font-family:var(--font-body);font-weight:700;letter-spacing:.14em;vertical-align:baseline}
.stat span{font-size:.95rem;color:#AFC0D6;display:block;max-width:30ch}

/* ---------- Process ---------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:start;border-top:1px solid var(--hairline)}
.process-step{padding:2rem 1.8rem 0 0;border-top:3px solid transparent;margin-top:-2px;position:relative}
.process-step:hover{border-top-color:var(--gold)}
.process-num{
  font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--gold-deep);
  display:inline-flex;align-items:baseline;gap:.4rem;margin-bottom:1rem;letter-spacing:.04em;
}
.process-num::before{
  content:"";width:12px;height:8px;background:currentColor;
  clip-path:polygon(0 100%,50% 0,100% 100%);align-self:center;
}
.process-step h3{font-size:1.28rem;margin-bottom:.5rem}
.process-step p{font-size:.95rem;margin:0}

/* Interactive process steps (How we work) */
.process--interactive{gap:1.25rem;padding-top:.25rem}
.process-step--expandable{
  appearance:none;-webkit-appearance:none;font:inherit;color:inherit;text-align:left;width:100%;
  cursor:pointer;padding:2rem 1.5rem 1.5rem;border:1px solid transparent;border-top:3px solid transparent;
  margin-top:0;border-radius:var(--r-md);background:transparent;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease),transform .25s var(--ease),background .25s;
}
.process-step--expandable:focus-visible{
  outline:2px solid var(--gold-deep);outline-offset:3px;
}
.process-step--expandable .process-summary{margin-bottom:0}
.process-detail{
  display:grid;grid-template-rows:0fr;opacity:0;
  transition:grid-template-rows .35s var(--ease),opacity .3s var(--ease),margin .35s var(--ease);
  margin-top:0;
}
.process-detail-inner{overflow:hidden}
.process-detail-inner p{
  font-size:.92rem;color:var(--slate);margin:0 0 .85rem;line-height:1.65;
}
.process-detail-inner p:last-child{margin-bottom:0}
.process-more{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold-deep);margin-top:.85rem;
  transition:opacity .2s var(--ease);
}
.process-more::after{content:"→";transition:transform .2s var(--ease)}
.process-step--expandable.is-expanded{
  border-color:var(--gold);border-top-color:var(--gold);
  box-shadow:var(--shadow-md);background:var(--white);
}
.process-step--expandable.is-expanded .process-detail{
  grid-template-rows:1fr;opacity:1;margin-top:1rem;
}
@media (hover:hover) and (pointer:fine){
  .process-step--expandable:hover{
    border-color:var(--gold);border-top-color:var(--gold);
    box-shadow:var(--shadow-md);transform:translateY(-4px);background:var(--white);
  }
  .process-step--expandable:hover .process-detail{
    grid-template-rows:1fr;opacity:1;margin-top:1rem;
  }
  .process-step--expandable:hover:not(.is-pinned) .process-more{
    opacity:0;height:0;margin:0;overflow:hidden;
  }
  .process-step--expandable:hover .process-more::after{transform:translateX(4px)}
}
.process-step--expandable.is-pinned .process-more{
  opacity:1;height:auto;margin-top:.85rem;pointer-events:auto;
}
@media (prefers-reduced-motion:reduce){
  .process-step--expandable,.process-detail,.process-more{transition:none}
  .process-step--expandable:hover{transform:none}
}

/* ---------- Projects ---------- */
.project-card{display:flex;flex-direction:column;height:100%;background:var(--white);border:1px solid var(--hairline);border-radius:var(--r-md);overflow:hidden;transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
.project-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.project-fig{aspect-ratio:16/10;position:relative;background:var(--navy-800);flex:none;overflow:hidden}
.project-fig svg,.project-fig img{width:100%;height:100%;position:absolute;inset:0}
.project-fig img{display:block;object-fit:cover;object-position:center}
.project-body{flex:1;padding:1.7rem 1.8rem 1.9rem}
.project-meta{display:flex;gap:.8rem;flex-wrap:wrap;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:.7rem}
.project-meta span+span::before{content:"·";margin-right:.8rem;color:var(--mist)}
.project-body h3{font-size:1.32rem;margin-bottom:.55rem}
.project-body p{font-size:.95rem;margin-bottom:0}
.case-row{display:grid;grid-template-columns:110px 1fr;gap:1rem;padding:.8rem 0;border-top:1px solid var(--hairline);font-size:.94rem}
.case-row b{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;padding-top:.2rem}
.project-card .case-row{grid-template-columns:1fr;gap:.35rem;padding:.65rem 0}
.project-card .case-row b{padding-top:0}

/* ---------- Reviews ---------- */
.gallery-empty{text-align:center;padding:3rem 1.5rem;border:1px dashed var(--hairline);border-radius:var(--r-md);margin-bottom:2rem}
.gallery-empty .lead{max-width:42ch;margin-inline:auto 1.5rem}
.section--alt .review-card,.section--alt .option-card,.section--alt .card{background:var(--white)}
.review-stars{color:var(--gold-deep);letter-spacing:.18em;font-size:1rem}
.review-card blockquote{margin:0;font-size:1.02rem;color:var(--ink);line-height:1.6;flex:1}
.review-card blockquote::before{content:"“";font-family:var(--font-display);font-size:2.4rem;color:var(--gold);display:block;line-height:.4;margin-bottom:.7rem}
.review-who{display:flex;align-items:center;gap:.9rem;padding-top:1rem;border-top:1px solid var(--hairline)}
.review-avatar{width:42px;height:42px;border-radius:50%;background:var(--navy-900);color:var(--gold-soft);display:grid;place-items:center;font-weight:700;font-size:.9rem;letter-spacing:.05em;flex:none}
.review-who b{display:block;color:var(--ink);font-size:.95rem}
.review-who span{font-size:.8rem;color:var(--mist)}
.rating-summary{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap;margin-bottom:2.6rem}
.rating-big{font-family:var(--font-display);font-size:4.4rem;font-weight:560;color:var(--ink);line-height:1}

/* ---------- Gallery ---------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.4rem}
.filter-btn{
  border:1px solid var(--hairline);background:var(--white);color:var(--slate);
  font-family:var(--font-body);font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:.7rem 1.35rem;border-radius:99px;cursor:pointer;transition:all .2s var(--ease);
}
.filter-btn:hover{border-color:var(--gold);color:var(--gold-deep)}
.filter-btn.is-active{background:var(--navy-900);color:#fff;border-color:var(--navy-900)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.gallery-item{border:0;padding:0;background:none;cursor:pointer;border-radius:var(--r-md);overflow:hidden;position:relative;aspect-ratio:4/3;text-align:left;display:block;width:100%}
.gallery-item svg,.gallery-item img{width:100%;height:100%;position:absolute;inset:0;transition:transform .4s var(--ease)}
.gallery-item img{object-fit:cover}
.gallery-item:hover svg,.gallery-item:hover img{transform:scale(1.04)}
.gallery-ba{display:flex;width:100%;height:100%;position:absolute;inset:0}
.gallery-ba-half{flex:1;position:relative;overflow:hidden}
.gallery-ba-half+.gallery-ba-half{border-left:2px solid rgba(255,255,255,.35)}
.gallery-ba-half img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.gallery-ba-label{
  position:absolute;top:.45rem;left:.45rem;z-index:1;padding:.2rem .55rem;border-radius:999px;
  background:rgba(6,15,29,.72);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  font-family:var(--font-body);pointer-events:none;
}
.gallery-item:hover .gallery-ba img{transform:scale(1.04)}
.gallery-item .g-cap{
  position:absolute;left:0;right:0;bottom:0;padding:2.4rem 1.2rem .95rem;
  background:linear-gradient(transparent,rgba(6,15,29,.85));color:#fff;font-size:.88rem;font-weight:600;
  font-family:var(--font-body);text-align:left;
}
.gallery-item .g-cap span{display:block;font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft)}
.gallery-item.is-hidden,.gallery-item-wrap.is-hidden{display:none}
.gallery-item-wrap{position:relative;border-radius:var(--r-md);overflow:hidden}
.gallery-item-wrap .g-case-link{
  position:absolute;left:0;right:0;bottom:0;z-index:3;padding:.55rem 1rem .75rem;
  font-size:.78rem;font-weight:700;color:var(--gold-soft);text-decoration:underline;text-underline-offset:3px;
  background:linear-gradient(180deg,transparent,rgba(10,28,51,.92) 35%);
}
.gallery-item-wrap .g-case-link:hover{color:#fff}
.project-photo-grid{margin-top:1rem}
.project-photo{position:relative;aspect-ratio:4/3;border-radius:var(--r-md);overflow:hidden}
.project-photo img{width:100%;height:100%;object-fit:cover}
.gallery-multi-badge{
  position:absolute;top:.65rem;right:.65rem;z-index:2;
  padding:.28rem .55rem;border-radius:999px;
  background:rgba(6,15,29,.72);color:#fff;
  font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid rgba(196,161,85,.35);pointer-events:none;
}
.process--3{grid-template-columns:repeat(3,1fr)}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:300;background:rgba(6,13,25,.94);
  display:none;align-items:center;justify-content:center;padding:1.25rem 1rem 1.75rem;
}
.lightbox.is-open{display:flex;overscroll-behavior:none;touch-action:none}
.lightbox-inner{position:relative;max-width:min(960px,92vw);width:100%}
.lightbox-viewport{
  overflow:hidden;width:100%;aspect-ratio:4/3;max-height:min(75vh,720px);
  touch-action:none;cursor:zoom-in;border-radius:var(--r-md);
  background:rgba(0,0,0,.28);outline:none;
}
.lightbox-viewport.is-zoomed{cursor:grab}
.lightbox-viewport.is-dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}
.lightbox-stage{
  width:100%;height:100%;transform-origin:0 0;will-change:transform;
}
.lightbox-stage svg,.lightbox-stage img{
  width:100%;height:100%;border-radius:var(--r-md);object-fit:contain;display:block;
}
.lightbox-stage .gallery-ba{
  display:flex;gap:.65rem;width:100%;height:100%;position:static;
}
.lightbox-stage .gallery-ba-half{
  flex:1;position:relative;border-radius:var(--r-sm);overflow:hidden;
}
.lightbox-stage .gallery-ba-half+.gallery-ba-half{border-left:0}
.lightbox-stage .gallery-ba-half img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:none;
}
.lightbox-stage .gallery-ba-label{top:.65rem;left:.65rem;font-size:.68rem}
.lightbox-controls{
  position:absolute;top:.55rem;right:.55rem;z-index:2;
  display:flex;flex-direction:column;gap:.35rem;
}
.lightbox-zoom-btn{
  width:2.15rem;height:2.15rem;border:none;border-radius:8px;
  background:rgba(10,28,51,.88);color:#fff;
  font-family:var(--font,Archivo,sans-serif);font-size:1.05rem;font-weight:700;line-height:1;
  cursor:pointer;backdrop-filter:blur(6px);
  border:1px solid rgba(196,161,85,.35);
  transition:background .15s var(--ease),border-color .15s var(--ease);
}
.lightbox-zoom-btn:hover,.lightbox-zoom-btn:focus-visible{
  background:rgba(27,58,102,.95);border-color:var(--gold,#C4A155);outline:none;
}
.lightbox-zoom-btn--reset{font-size:.95rem}
.lightbox-hint{
  margin:.75rem 0 0;text-align:center;pointer-events:none;
  font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.62);
}
.lightbox-cap{color:#fff;text-align:center;margin-top:.85rem;font-size:.95rem}
.lightbox-cap span{color:var(--gold-soft);font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;display:block;margin-bottom:.25rem}
.lightbox-close{
  position:absolute;top:1rem;right:1.2rem;z-index:301;
  background:rgba(10,28,51,.55);border:1px solid rgba(255,255,255,.15);
  border-radius:999px;width:2.75rem;height:2.75rem;
  color:#fff;font-size:1.85rem;cursor:pointer;line-height:1;
  transition:background .15s var(--ease),border-color .15s var(--ease);
}
.lightbox-close:hover,.lightbox-close:focus-visible{
  background:rgba(27,58,102,.9);border-color:var(--gold,#C4A155);outline:none;
}
.lightbox-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:301;
  width:2.75rem;height:2.75rem;border:none;border-radius:999px;
  background:rgba(10,28,51,.72);color:#fff;
  font-size:1.85rem;line-height:1;cursor:pointer;
  border:1px solid rgba(196,161,85,.35);
  transition:background .15s var(--ease),border-color .15s var(--ease);
}
.lightbox-nav--prev{left:.65rem}
.lightbox-nav--next{right:.65rem}
.lightbox-nav:hover,.lightbox-nav:focus-visible{
  background:rgba(27,58,102,.92);border-color:var(--gold,#C4A155);outline:none;
}
.lightbox-counter{
  margin:.55rem 0 0;text-align:center;pointer-events:none;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.72);
}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--hairline)}
.faq details{border-bottom:1px solid var(--hairline)}
.faq summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1.4rem;
  padding:1.45rem .2rem;font-family:var(--font-body);font-weight:650;font-size:1.08rem;color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:var(--font-display);font-size:1.7rem;font-weight:400;color:var(--gold-deep);
  flex:none;transition:transform .25s var(--ease);line-height:1;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details[open] summary{color:var(--gold-deep)}
.faq .faq-a{padding:0 .2rem 1.6rem;max-width:72ch;font-size:1rem}

/* ---------- Cities ---------- */
.city-group{margin-bottom:3rem}
.city-group h3{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem}
.city-group h3::after{content:"";flex:1;height:1px;background:var(--hairline)}
.city-group--mountain{
  position:relative;isolation:isolate;
  padding:clamp(1.8rem,4vw,2.8rem);
  border-radius:var(--r-lg);overflow:hidden;
  margin-bottom:3rem;
  border:1px solid var(--hairline);
  background:linear-gradient(180deg,#E8EEF5 0%,#F6F5F1 52%,#F0F2F6 100%);
  box-shadow:var(--shadow-sm);
}
.city-group--mountain::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 220' preserveAspectRatio='none'%3E%3Cpath d='M0 130 L160 72 L300 108 L460 58 L620 98 L780 48 L940 92 L1200 68 L1200 220 L0 220Z' fill='%23B8C8DA' fill-opacity='.38'/%3E%3Cpath d='M0 150 L140 98 L280 128 L430 82 L590 118 L750 76 L910 112 L1200 88 L1200 220 L0 220Z' fill='%238DA4BE' fill-opacity='.28'/%3E%3Cpath d='M0 168 L120 118 L250 142 L400 104 L560 134 L720 100 L880 138 L1200 112 L1200 220 L0 220Z' fill='%235A7299' fill-opacity='.18'/%3E%3Cpolyline points='0,130 160,72 300,108 460,58 620,98 780,48 940,92 1200,68' fill='none' stroke='%23C4A155' stroke-width='2' stroke-opacity='.42' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")
    bottom center/100% auto no-repeat;
}
.city-group--mountain::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.55) 0%,rgba(255,255,255,0) 38%,rgba(246,245,241,.25) 100%);
}
.city-group--mountain > *{position:relative;z-index:1}
.city-group--mountain h3{color:var(--ink);margin-bottom:1.4rem}
.city-group--mountain h3::after{background:var(--hairline)}
.city-group--mountain .lead{color:var(--slate)}
.city-group--mountain .lead a{color:var(--navy-800)}
.city-group--mountain .lead a:hover{color:var(--gold-deep)}
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.city-card--hero{
  position:relative;isolation:isolate;overflow:hidden;
  min-height:clamp(140px,18vw,180px);
  border-radius:var(--r-md);
  border:1px solid rgba(10,28,51,.12);
  background:linear-gradient(145deg,var(--navy-800) 0%,var(--navy-900) 100%);
  box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
}
.city-card--hero:hover{
  transform:translateY(-4px);
  border-color:rgba(196,161,85,.45);
  box-shadow:var(--shadow-md),0 0 0 1px rgba(196,161,85,.18);
}
.city-card-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:var(--city-bg);
  background-size:cover;background-position:center;background-repeat:no-repeat;
  filter:saturate(.92) contrast(1.04);
  opacity:.58;
}
.city-card--hero::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(10,28,51,.12) 0%,rgba(10,28,51,.38) 36%,rgba(10,28,51,.84) 100%),
    linear-gradient(135deg,rgba(10,28,51,.06) 0%,rgba(10,28,51,.18) 100%);
}
.city-card--fallback .city-card-bg{
  background-image:none;
  opacity:1;
  background:linear-gradient(145deg,var(--navy-800) 0%,var(--navy-900) 55%,#081528 100%);
}
.city-card-watermark{
  position:absolute;right:clamp(.85rem,3vw,1.35rem);top:50%;
  transform:translateY(-50%);
  width:clamp(52px,12vw,72px);height:clamp(52px,12vw,72px);
  opacity:.16;color:var(--gold-soft);
}
.city-card-watermark svg{display:block;width:100%;height:100%}
.city-card-body{
  position:relative;z-index:2;
  display:flex;flex-direction:column;justify-content:flex-end;
  min-height:inherit;height:100%;
  padding:clamp(1rem,2.5vw,1.35rem) clamp(1.05rem,2.8vw,1.4rem) clamp(1.05rem,2.5vw,1.3rem);
}
.city-card-body::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,transparent 0%,rgba(10,28,51,.32) 48%,rgba(10,28,51,.58) 100%);
  border-radius:0 0 calc(var(--r-md) - 1px) calc(var(--r-md) - 1px);
}
.city-card-title{
  margin:0 0 .35rem;
  font-family:var(--font-display);
  font-size:clamp(1.32rem,2.5vw,1.78rem);
  font-weight:560;line-height:1.15;letter-spacing:-.008em;
  color:var(--white);
  text-shadow:0 1px 2px rgba(0,0,0,.62),0 2px 14px rgba(10,28,51,.52),0 0 1px rgba(0,0,0,.45);
}
.city-card-title::after{
  content:"";display:block;width:2.4rem;height:2px;margin-top:.45rem;
  background:linear-gradient(90deg,var(--gold) 0%,rgba(196,161,85,.25) 100%);
  border-radius:99px;
}
.city-card-note{
  margin:0;
  font-size:clamp(.875rem,1.7vw,.9375rem);
  line-height:1.58;letter-spacing:.012em;
  color:rgba(255,255,255,.96);
  max-width:42ch;
  text-shadow:0 1px 3px rgba(0,0,0,.58),0 1px 10px rgba(10,28,51,.42);
}
.city-card-hoods{
  font-size:clamp(.8125rem,1.55vw,.875rem);
  color:rgba(255,255,255,.88);
  margin:.45rem 0 0;
  line-height:1.52;letter-spacing:.018em;
  max-width:46ch;
  text-shadow:0 1px 3px rgba(0,0,0,.55),0 1px 8px rgba(10,28,51,.38);
}
.city-group--mountain .city-card--hero{
  border-color:rgba(10,28,51,.16);
  box-shadow:0 2px 10px rgba(10,28,51,.08);
}
.chip-row{display:flex;flex-wrap:wrap;gap:.55rem}
.chip{font-size:.82rem;font-weight:600;color:var(--ink);border:1px solid var(--hairline);border-radius:99px;padding:.5rem 1.05rem;background:var(--white)}
.chip:hover{border-color:var(--gold);color:var(--gold-deep)}

/* ---------- Estimate form ---------- */
.estimate{background:var(--white);border:1px solid var(--hairline);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:clamp(1.8rem,4vw,3rem);max-width:860px;margin-inline:auto}
.form-progress{display:flex;align-items:center;gap:.4rem;margin-bottom:2.2rem}
.form-progress .peak{
  width:34px;height:20px;background:var(--hairline);
  clip-path:polygon(0 100%,50% 0,100% 100%);transition:background .3s;
}
.form-progress .peak.is-done{background:var(--gold)}
.form-progress .trail{flex:1;height:1px;background:var(--hairline)}
.form-progress .trail.is-done{background:var(--gold)}
.form-progress-label{margin-left:auto;font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--mist)}
.form-step{display:none}
.form-step.is-active{display:block;animation:stepIn .35s var(--ease)}
@keyframes stepIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.form-step legend{font-family:var(--font-display);font-size:1.7rem;font-weight:560;color:var(--ink);padding:0;margin-bottom:.4rem}
.form-step fieldset{border:0;padding:0;margin:0}
.form-hint{font-size:.95rem;color:var(--slate);margin-bottom:1.6rem}
.service-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;margin-bottom:1.8rem}
.service-pick{position:relative}
.service-pick input{position:absolute;opacity:0;inset:0;cursor:pointer}
.service-pick label{
  display:flex;flex-direction:column;align-items:flex-start;gap:.7rem;border:1.5px solid var(--hairline);
  border-radius:var(--r-md);padding:1.15rem 1.15rem 1.05rem;cursor:pointer;height:100%;
  font-weight:650;font-size:.95rem;color:var(--ink);transition:all .18s var(--ease);
}
.service-pick svg{width:26px;height:26px;color:var(--navy-800)}
.service-pick input:checked+label{border-color:var(--gold);background:rgba(196,161,85,.09);box-shadow:0 0 0 1px var(--gold)}
.service-pick input:checked+label svg{color:var(--gold-deep)}
.service-pick input:focus-visible+label{outline:3px solid var(--gold);outline-offset:2px}
.field{margin-bottom:1.35rem}
.field label{display:block;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:.5rem}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--font-body);font-size:1.02rem;color:var(--ink);
  border:1.5px solid var(--hairline);border-radius:var(--r-sm);padding:.95rem 1.1rem;background:var(--white);
  transition:border-color .18s,box-shadow .18s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,161,85,.22)}
.field textarea{min-height:110px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field .err{display:none;color:var(--error);font-size:.82rem;font-weight:600;margin-top:.4rem;letter-spacing:.01em;text-transform:none}
.field.has-error input,.field.has-error select{border-color:var(--error)}
.field.has-error .err{display:block}
.form-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;flex-wrap:wrap}
.btn--back{background:none;border:0;color:var(--slate);font-weight:700;font-size:.88rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;padding:1rem .4rem}
.btn--back:hover{color:var(--ink)}
.form-success{text-align:center;padding:2.5rem 1rem;display:none}
.form-success.is-visible{display:block;animation:stepIn .4s var(--ease)}
.form-success .chip-dot{width:64px;height:64px;margin:0 auto 1.4rem}
.form-success .chip-dot svg{width:30px;height:30px}
.form-fineprint{font-size:.78rem;color:var(--mist);margin-top:1.4rem;text-align:center}
.form-error-msg{display:none;color:var(--error);background:rgba(180,69,47,.08);border:1px solid rgba(180,69,47,.3);border-radius:var(--r-sm);padding:.9rem 1.1rem;font-size:.9rem;margin-top:1.2rem}
.form-error-msg.is-visible{display:block}
.field--checkbox{margin-top:1.5rem}
.checkbox-label{display:flex;align-items:flex-start;gap:.75rem;font-size:.92rem;font-weight:500;line-height:1.55;text-transform:none;letter-spacing:0;color:var(--slate);cursor:pointer}
.checkbox-label input[type=checkbox]{width:1.15rem;height:1.15rem;margin-top:.2rem;flex-shrink:0;accent-color:var(--gold-deep)}
.field.has-error .checkbox-label{color:var(--ink)}
.form-nav--submit{justify-content:flex-end}
.service-picker--trades{grid-template-columns:repeat(4,1fr)}

/* ---------- Calculator ---------- */
.calc{background:var(--white);border:1px solid var(--hairline);border-radius:var(--r-lg);padding:clamp(1.8rem,3.5vw,2.6rem);box-shadow:var(--shadow-sm)}
.calc-result{background:var(--alabaster);border-radius:var(--r-md);padding:1.6rem;text-align:center;margin-top:1.4rem}
.calc-result b{font-family:var(--font-display);font-size:2.9rem;font-weight:560;color:var(--ink);display:block;line-height:1.1}
.calc-result span{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--gold-deep)}
.calc-result small{display:block;color:var(--mist);font-size:.78rem;margin-top:.5rem}

/* ---------- Sticky mobile action bar ---------- */
.mobile-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:110;display:none;
  grid-template-columns:1fr 1fr 1.35fr;background:var(--navy-900);
  padding:.6rem .6rem calc(.6rem + env(safe-area-inset-bottom));gap:.55rem;
  box-shadow:0 -8px 30px rgba(6,13,25,.35);
}
.mobile-bar a{
  display:flex;align-items:center;justify-content:center;gap:.45rem;
  font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:.9rem .5rem;border-radius:var(--r-sm);color:#fff;border:1px solid var(--hairline-navy);
}
.mobile-bar a svg{width:16px;height:16px}
.mobile-bar .is-primary{
  background:linear-gradient(165deg,var(--gold-soft) 0%,var(--gold) 100%);
  color:var(--navy-900);border-color:var(--gold-deep);
  box-shadow:var(--shadow-gold);
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease);
}
.mobile-bar .is-primary:hover,
.mobile-bar .is-primary:focus-visible{
  background:linear-gradient(165deg,#E4CD96 0%,var(--gold-soft) 100%);
  box-shadow:var(--shadow-gold-strong);
  transform:translateY(-1px);
}
.mobile-bar .is-primary svg{color:var(--navy-900)}

/* ---------- CTA panel ---------- */
.cta-panel{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--navy-900),var(--navy-800));border-radius:var(--r-lg);padding:clamp(2.8rem,6vw,4.8rem);text-align:center;color:#C7D2E2}
.cta-panel h2{color:#fff;max-width:22ch;margin-inline:auto}
.cta-panel p{max-width:56ch;margin-inline:auto;margin-bottom:2.2rem}
.cta-panel .btn-row{justify-content:center}
.cta-topo{position:absolute;inset:0;opacity:.4;pointer-events:none}

/* ---------- Footer ---------- */
.footer{background:var(--navy-900);color:#9FB1C8;font-size:.94rem}
.footer a{color:#C3D0E1}
.footer a:hover{color:var(--gold-soft)}
.footer-estimate-link{
  display:inline-flex;align-items:center;gap:.35rem;
  font-weight:700;color:var(--gold-soft)!important;
  letter-spacing:.04em;
}
.footer-estimate-link::after{content:"→";font-size:.85em;opacity:.85;transition:transform .2s var(--ease)}
.footer-estimate-link:hover::after{transform:translateX(3px)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:clamp(2rem,4vw,3.5rem);padding-block:4.2rem 3rem}
.footer h4{color:#fff;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.2rem}
.footer li{margin-bottom:.6rem}
.footer-brand p{margin-top:1.1rem;max-width:34ch;font-size:.92rem}
.footer-bottom{border-top:1px solid var(--hairline-navy);padding-block:1.5rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:#7488A3}
.footer-bottom a{color:#9FB1C8}
.footer .brand-name b{color:#fff}
.footer .brand-name span{color:var(--gold-soft)}
.footer-contact li{display:flex;gap:.7rem;align-items:flex-start}
.footer-contact svg{width:16px;height:16px;color:var(--gold);flex:none;margin-top:.3rem}

/* ---------- Reveal on scroll (visible without JS; animated when JS adds html.js) ---------- */
.reveal{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js .reveal:not(.is-in){opacity:0;transform:translateY(26px)}
html.js .reveal.is-in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}

/* ---------- Service area map ---------- */
.area-map-wrap{
  position:relative;width:100%;
  border-radius:22px;overflow:hidden;
  box-shadow:0 18px 48px rgba(10,28,51,.14),0 6px 18px rgba(10,28,51,.08);
}
.area-map-viewport{
  overflow:hidden;aspect-ratio:2048/1668;
  background:var(--navy-9,#0A1C33);
  touch-action:none;cursor:grab;
}
.area-map-viewport.is-dragging{cursor:grabbing}
.area-map-viewport.is-zoomed{cursor:grab}
.area-map-stage{
  width:100%;height:100%;transform-origin:0 0;will-change:transform;
}
.area-map-wrap .area-map{
  width:100%;height:100%;display:block;border-radius:0;
  box-shadow:none;
}
.area-map-controls{
  position:absolute;top:.75rem;right:.75rem;z-index:2;
  display:flex;flex-direction:column;gap:.35rem;
}
.area-map-zoom-btn{
  width:2rem;height:2rem;border:none;border-radius:8px;
  background:rgba(10,28,51,.82);color:#fff;
  font-family:var(--font,Archivo,sans-serif);font-size:1.05rem;font-weight:700;line-height:1;
  cursor:pointer;backdrop-filter:blur(6px);
  border:1px solid rgba(196,161,85,.35);
  transition:background .15s var(--ease),border-color .15s var(--ease);
}
.area-map-zoom-btn:hover,.area-map-zoom-btn:focus-visible{
  background:rgba(27,58,102,.95);border-color:var(--gold,#C4A155);outline:none;
}
.area-map-zoom-btn--reset{font-size:.95rem}
.area-map-hint{
  position:absolute;left:0;right:0;bottom:.55rem;z-index:2;
  margin:0;text-align:center;pointer-events:none;
  font-family:var(--font,Archivo,sans-serif);font-size:.68rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.78);text-shadow:0 1px 6px rgba(10,28,51,.55);
}
.area-map-pulse{
  transform-box:fill-box;transform-origin:center;
  animation:area-map-pulse 3.2s var(--ease) infinite;
}
@keyframes area-map-pulse{
  0%,100%{opacity:.35;transform:scale(1)}
  50%{opacity:0;transform:scale(1.18)}
}
.area-map-city-link{cursor:pointer;text-decoration:none;outline:none}
.area-map-viewport.is-dragging .area-map-city-link{pointer-events:none}
.area-map-city-link:hover .area-map-city text,
.area-map-city-link:focus-visible .area-map-city text{fill:#8B6914}
.area-map-city-link:hover .area-map-city rect,
.area-map-city-link:focus-visible .area-map-city rect{
  stroke:var(--gold,#C4A155);stroke-opacity:.55;stroke-width:1.2;
}
.area-map-city-link:hover .area-map-city circle:nth-of-type(2),
.area-map-city-link:focus-visible .area-map-city circle:nth-of-type(2){
  stroke-width:2;stroke:var(--gold,#C4A155);
}
.area-map-city-link--center:hover .area-map-center circle:nth-of-type(3),
.area-map-city-link--center:focus-visible .area-map-center circle:nth-of-type(3){
  stroke-width:2.8;
}

/* ---------- Utility ---------- */
.text-center{text-align:center}
.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.badge-note{
  display:inline-flex;align-items:center;gap:.55rem;font-size:.8rem;font-weight:600;color:var(--slate);
  background:var(--alabaster);border:1px solid var(--hairline);border-radius:99px;padding:.5rem 1.1rem;
}
.badge-note svg{width:14px;height:14px;color:var(--gold-deep)}
a.badge-note--cta{
  background:linear-gradient(165deg,var(--gold-soft) 0%,var(--gold) 100%);
  color:var(--navy-900);border:1.5px solid var(--gold-deep);
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:.62rem 1.25rem;box-shadow:var(--shadow-gold);
  text-decoration:none;cursor:pointer;transform-origin:center;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
a.badge-note--cta svg{width:14px;height:14px;color:var(--navy-900);flex:none}
a.badge-note--cta .cta-chip-arrow svg{width:13px;height:13px;opacity:.75;transition:transform .22s var(--ease),opacity .22s var(--ease)}
a.badge-note--cta:hover,
a.badge-note--cta.is-proximate,
a.badge-note--cta:focus-visible{
  background:linear-gradient(165deg,#E4CD96 0%,var(--gold-soft) 100%);
  box-shadow:var(--shadow-gold-strong);
}
a.badge-note--cta:hover .cta-chip-arrow svg,
a.badge-note--cta.is-proximate .cta-chip-arrow svg,
a.badge-note--cta:focus-visible .cta-chip-arrow svg{transform:translateX(3px);opacity:1}
a.badge-note--cta:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.hero-trust-cta{
  display:inline-flex;align-items:center;gap:.55rem;
  background:linear-gradient(165deg,var(--gold-soft) 0%,var(--gold) 100%);
  color:var(--navy-900);border:1.5px solid var(--gold-deep);
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;border-radius:99px;padding:.58rem 1.05rem;
  margin:0;box-shadow:0 8px 24px rgba(196,161,85,.42);
  transform-origin:center;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.hero-trust-cta svg{width:15px;height:15px;color:var(--navy-900);flex:none}
.hero-trust-cta .cta-chip-arrow svg{width:13px;height:13px;opacity:.75;transition:transform .22s var(--ease),opacity .22s var(--ease)}
.hero-trust-cta:hover,
.hero-trust-cta.is-proximate,
.hero-trust-cta:focus-visible{
  background:linear-gradient(165deg,#E4CD96 0%,var(--gold-soft) 100%);
  box-shadow:var(--shadow-gold-strong);
}
.hero-trust-cta:hover .cta-chip-arrow svg,
.hero-trust-cta.is-proximate .cta-chip-arrow svg,
.hero-trust-cta:focus-visible .cta-chip-arrow svg{transform:translateX(3px);opacity:1}
.hero-trust-cta:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  a.badge-note--cta,.hero-trust-cta{transition:box-shadow .2s ease,background .2s ease}
  a.badge-note--cta:hover,
  a.badge-note--cta:focus-visible,
  .hero-trust-cta:hover,
  .hero-trust-cta:focus-visible{transform:scale(1.05)}
}

/* ---------- Responsive ---------- */
@media (max-width:1100px){
  .grid--3{grid-template-columns:repeat(2,1fr);align-items:stretch}
}
@media (max-width:1060px){
  .nav{display:none}
  .header-phone{display:none}
  .menu-toggle{display:block}
  .hero-inner{grid-template-columns:1fr;gap:3rem}
  .hero-art{max-width:560px}
  .split{grid-template-columns:1fr}
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(2,1fr);gap:0 2rem}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  body{padding-bottom:74px}
  .mobile-bar{display:grid}
  .callout--founder{grid-template-columns:1fr}
  .founder-photo{width:88px}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .city-grid{grid-template-columns:1fr 1fr}
  .service-picker{grid-template-columns:1fr 1fr}
  .announce-note--extra{display:none}
}
@media (max-width:600px){
  html{scroll-padding-top:82px}
  .grid--2,.grid--3,.grid--4{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .city-grid{grid-template-columns:1fr}
  .city-card--hero{min-height:158px}
  .city-card-body{padding:1.15rem 1.1rem 1.1rem}
  .city-card-title{font-size:clamp(1.38rem,5.2vw,1.62rem);line-height:1.18}
  .city-card-note{font-size:clamp(.9rem,3.8vw,.95rem);line-height:1.6;max-width:none}
  .city-card-hoods{font-size:clamp(.8125rem,3.4vw,.875rem);line-height:1.55;max-width:none}
  .check-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}
  .service-picker{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .float-chip--rating{left:4%;bottom:-4%}
  .float-chip--est{right:2%}
  .btn{width:100%}
  .btn-row{flex-direction:column;align-items:stretch}
  .lightbox{padding:.75rem .5rem 1.25rem}
  .lightbox-viewport{max-height:min(62vh,560px)}
  .lightbox-hint{font-size:.62rem;letter-spacing:.05em}
  .header .btn{width:auto;padding:.85rem 1.15rem;font-size:.78rem}
  .brand-mark{width:38px;height:38px}
  .brand-name b{font-size:1.05rem}
  .announce .container{justify-content:center}
  .announce-note--phone{display:none}
  .hero-trust{gap:.8rem 1.4rem}
  .rating-big{font-size:3.4rem}
  .project-body{padding:1.2rem 1.15rem 1.35rem}
  .project-body h3{font-size:1.15rem;margin-bottom:.4rem}
  .project-meta{margin-bottom:.5rem;font-size:.68rem}
  .case-row{padding:.55rem 0;font-size:.88rem;line-height:1.45}
  .case-row b{font-size:.65rem;letter-spacing:.14em}
  .grid--3{gap:1.15rem}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
  .reveal{opacity:1;transform:none}
  .area-map-pulse{animation:none;opacity:.25}
  .summit-scene .summit-star,.summit-card .summit-star,
  .summit-scene .summit-moon-glow,.summit-card .summit-moon-glow,
  .summit-scene .summit-moon,.summit-card .summit-moon,
  .summit-scene .summit-wave,.summit-card .summit-wave,
  .summit-scene .summit-smoke-puff,.summit-card .summit-smoke-puff{animation:none}
  .summit-scene .summit-star,.summit-card .summit-star{opacity:.55;transform:none}
  .summit-scene .summit-moon-glow,.summit-card .summit-moon-glow{opacity:.85;transform:none}
  .summit-scene .summit-moon,.summit-card .summit-moon{opacity:1;filter:none}
  .summit-scene .summit-smoke-puff,.summit-card .summit-smoke-puff{opacity:0}
}
