:root {
  color-scheme: light;
  --forest-950: #071a14;
  --forest-900: #0d2a21;
  --forest-800: #123a2d;
  --forest-700: #1b4b39;
  --forest-600: #2e624d;
  --sage-500: #7f987f;
  --sage-200: #ccd8cd;
  --gold-600: #b88c3e;
  --gold-500: #c9a45d;
  --gold-300: #dec792;
  --stone-100: #f4f2ed;
  --stone-200: #e9e6df;
  --stone-300: #d9d5cc;
  --ink: #17211c;
  --muted: #667069;
  --surface: #ffffff;
  --surface-2: #f7f6f2;
  --surface-inverse: #0d2a21;
  --line: rgba(13, 42, 33, .14);
  --line-strong: rgba(13, 42, 33, .24);
  --emergency: #9f2c2c;
  --emergency-dark: #761d1d;
  --shadow-sm: 0 8px 24px rgba(7, 26, 20, .08);
  --shadow-md: 0 18px 56px rgba(7, 26, 20, .14);
  --shadow-lg: 0 30px 90px rgba(4, 18, 13, .22);
  --radius-sm: 12px;
  --radius-md: 20px;
  --radius-lg: 32px;
  --radius-pill: 999px;
  --container: 1240px;
  --header-offset: 116px;
  --ease: cubic-bezier(.2, .75, .25, 1);
}

html[data-theme="dark"] {
  color-scheme: dark;
  --ink: #f4f4ee;
  --muted: #aeb9b2;
  --surface: #0c211a;
  --surface-2: #102a21;
  --stone-100: #132c23;
  --stone-200: #1a342a;
  --stone-300: #2b473b;
  --line: rgba(240, 244, 236, .13);
  --line-strong: rgba(240, 244, 236, .23);
  --shadow-sm: 0 8px 24px rgba(0, 0, 0, .2);
  --shadow-md: 0 18px 56px rgba(0, 0, 0, .28);
  --shadow-lg: 0 30px 90px rgba(0, 0, 0, .38);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 118px; }
body {
  margin: 0;
  min-width: 320px;
  color: var(--ink);
  background: var(--surface);
  font-family: Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  transition: color .3s ease, background-color .3s ease;
}
body.menu-open { overflow: hidden; }
img, picture { display: block; max-width: 100%; }
img { height: auto; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }
svg { width: 1.1em; height: 1.1em; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
::selection { color: var(--forest-950); background: var(--gold-300); }

h1, h2, h3, p, figure, blockquote { margin-top: 0; }
h1, h2, h3 { font-weight: 540; letter-spacing: -.045em; line-height: 1.02; }
h1 { font-size: clamp(3.15rem, 12vw, 6.75rem); }
h2 { margin-bottom: 1.25rem; font-size: clamp(2.45rem, 8vw, 4.85rem); }
h3 { font-size: 1.3rem; }
h1 em, h2 em { color: var(--gold-500); font-style: normal; font-weight: 350; }
p { color: var(--muted); }
strong { font-weight: 650; }

.container { width: min(calc(100% - 36px), var(--container)); margin-inline: auto; }
.section { position: relative; padding: clamp(5.5rem, 11vw, 9.5rem) 0; }
.section--stone { background: var(--stone-100); }
.section--dark { color: #fff; background: var(--forest-950); }
.section--dark p { color: rgba(255, 255, 255, .65); }

.svg-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.skip-link {
  position: fixed;
  z-index: 9999;
  top: 10px;
  left: 10px;
  padding: .75rem 1rem;
  color: #fff;
  background: var(--forest-900);
  border-radius: 8px;
  transform: translateY(-160%);
}
.skip-link:focus { transform: none; }
:focus-visible { outline: 3px solid var(--gold-500); outline-offset: 4px; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  margin-bottom: 1rem;
  color: var(--forest-700);
  font-size: .72rem;
  font-weight: 760;
  letter-spacing: .15em;
  line-height: 1.2;
  text-transform: uppercase;
}
html[data-theme="dark"] .eyebrow { color: var(--gold-300); }
.eyebrow--light { color: var(--gold-300); }
.eyebrow__line { width: 32px; height: 1px; background: currentColor; }
.section-heading { max-width: 760px; }
.section-heading p { max-width: 570px; }
.section-heading--center { margin-inline: auto; text-align: center; }
.section-heading--split { display: grid; gap: 1.5rem; margin-bottom: 2.75rem; max-width: none; }
.section-heading--split > p { margin-bottom: 0; align-self: end; }
.section-heading--light h2 { color: #fff; }
.section-heading--light .eyebrow { color: var(--gold-300); }
.lead { color: var(--ink); font-size: clamp(1.06rem, 2vw, 1.25rem); line-height: 1.7; }
.micro-note { color: var(--muted); font-size: .78rem; font-weight: 620; letter-spacing: .08em; text-transform: uppercase; }
.fine-print { margin: 1.5rem 0 0; font-size: .75rem; }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .7rem;
  min-height: 52px;
  padding: .92rem 1.35rem;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  cursor: pointer;
  font-size: .88rem;
  font-weight: 720;
  line-height: 1.15;
  transition: transform .25s var(--ease), background-color .25s ease, border-color .25s ease, color .25s ease, box-shadow .25s ease;
}
.button:hover { transform: translateY(-2px); }
.button svg { flex: 0 0 auto; transition: transform .25s var(--ease); }
.button:hover svg { transform: translateX(3px); }
.button--small { min-height: 44px; padding: .72rem 1.05rem; font-size: .78rem; }
.button--gold { color: var(--forest-950); background: var(--gold-500); box-shadow: 0 12px 30px rgba(201, 164, 93, .22); }
.button--gold:hover { background: var(--gold-300); box-shadow: 0 15px 36px rgba(201, 164, 93, .31); }
.button--primary { color: #fff; background: var(--forest-700); }
.button--ghost { color: var(--ink); border-color: var(--line-strong); background: transparent; }
.button--glass { color: #fff; border-color: rgba(255,255,255,.35); background: rgba(255,255,255,.1); backdrop-filter: blur(14px); }
.button--glass:hover { background: rgba(255,255,255,.18); }
.button--white { color: var(--emergency-dark); background: #fff; }
.button--outline { color: var(--forest-900); border-color: var(--forest-900); background: transparent; }
html[data-theme="dark"] .button--outline { color: #fff; border-color: rgba(255,255,255,.5); }
.button--full { width: 100%; }
.text-link {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  color: var(--forest-700);
  font-size: .9rem;
  font-weight: 720;
}
.text-link svg { transition: transform .25s var(--ease); }
.text-link:hover svg { transform: translateX(4px); }
.text-link--light { color: #fff; }
.icon-button {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--surface);
  cursor: pointer;
  transition: transform .2s ease, background-color .2s ease, border-color .2s ease;
}
.icon-button:hover { transform: translateY(-1px); border-color: var(--gold-500); }

.site-header { position: fixed; z-index: 1000; inset: 0 0 auto; color: #fff; transition: color .25s ease, background-color .25s ease, box-shadow .25s ease; }
.site-header.is-scrolled { color: var(--ink); background: color-mix(in srgb, var(--surface) 93%, transparent); box-shadow: 0 10px 35px rgba(5, 24, 17, .09); backdrop-filter: blur(18px); }
.emergency-bar { background: linear-gradient(90deg, var(--emergency-dark), var(--emergency), var(--emergency-dark)); }
.emergency-bar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  color: #fff;
  font-size: .64rem;
  font-weight: 760;
  letter-spacing: .085em;
  text-transform: uppercase;
}
.emergency-bar__inner > span { display: inline-flex; align-items: center; gap: .55rem; }
.emergency-bar__inner > a { display: none; align-items: center; gap: .4rem; }
.pulse-dot { position: relative; display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: #fff; box-shadow: 0 0 0 0 rgba(255,255,255,.5); animation: pulse 2s infinite; }
.nav { display: flex; align-items: center; justify-content: space-between; min-height: 78px; gap: 1rem; }
.brand { display: inline-flex; align-items: center; gap: .75rem; min-width: max-content; }
.brand__mark { width: 37px; height: 37px; color: var(--gold-500); stroke-width: 2; }
.brand__type { display: grid; line-height: .86; }
.brand__type strong { font-size: 1.02rem; letter-spacing: .16em; }
.brand__type small { margin-top: .42rem; font-size: .55rem; font-weight: 640; letter-spacing: .31em; opacity: .76; }
.nav__links, .nav__actions { display: none; }
.nav__menu-button { color: var(--forest-950); border-color: rgba(255,255,255,.23); background: rgba(255,255,255,.88); }
.site-header.is-scrolled .nav__menu-button { color: var(--ink); border-color: var(--line); background: var(--surface); }
.mobile-menu { position: fixed; z-index: 1100; inset: 0; background: rgba(4, 17, 13, .58); backdrop-filter: blur(8px); }
.mobile-menu__panel {
  position: absolute;
  inset: 0 0 0 auto;
  display: flex;
  flex-direction: column;
  width: min(88vw, 430px);
  padding: 1.25rem 1.3rem max(1.5rem, env(safe-area-inset-bottom));
  color: var(--ink);
  background: var(--surface);
  box-shadow: var(--shadow-lg);
  animation: menuIn .35s var(--ease) both;
}
.mobile-menu__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 2rem; }
.mobile-menu__top .eyebrow { margin: 0; }
.mobile-menu__panel > a { padding: 1rem .2rem; border-bottom: 1px solid var(--line); font-size: 1.25rem; font-weight: 600; letter-spacing: -.02em; }
.mobile-menu__actions { display: grid; gap: .8rem; margin-top: auto; padding-top: 2rem; }
.theme-icon--moon { display: none; }
html[data-theme="dark"] .theme-icon--sun { display: none; }
html[data-theme="dark"] .theme-icon--moon { display: block; }

.hero { position: relative; isolation: isolate; display: flex; align-items: flex-end; min-height: 100svh; overflow: hidden; padding: calc(var(--header-offset) + 3rem) 0 5.8rem; color: #fff; background: var(--forest-950); }
.hero__media { position: absolute; z-index: -3; inset: -5% 0; transform: translate3d(0, var(--parallax-y, 0), 0) scale(1.05); will-change: transform; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; object-position: 54% 50%; }
.hero__veil {
  position: absolute;
  z-index: -2;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(5, 24, 17, .92) 0%, rgba(5, 24, 17, .72) 48%, rgba(5, 24, 17, .26) 100%),
    linear-gradient(0deg, rgba(5, 24, 17, .75) 0%, transparent 48%);
}
.hero__content { display: grid; gap: 2.5rem; align-items: end; }
.hero__copy { max-width: 900px; }
.hero h1 { max-width: 920px; margin-bottom: 1.4rem; color: #fff; text-wrap: balance; }
.hero h1 em { color: var(--gold-300); }
.hero__copy > p { max-width: 670px; margin-bottom: 1.9rem; color: rgba(255,255,255,.78); font-size: clamp(1rem, 2.3vw, 1.2rem); }
.hero__buttons { display: flex; flex-direction: column; gap: .8rem; align-items: stretch; max-width: 520px; }
.hero__locations { display: flex; flex-wrap: wrap; gap: .75rem 1.2rem; margin-top: 1.5rem; color: rgba(255,255,255,.75); font-size: .72rem; font-weight: 720; letter-spacing: .1em; text-transform: uppercase; }
.hero__locations span { display: inline-flex; align-items: center; gap: .4rem; }
.hero__locations svg { color: var(--gold-300); }
.hero-card {
  max-width: 410px;
  padding: 1.35rem;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--radius-md);
  background: rgba(6, 26, 19, .54);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
}
.hero-card__top, .hero-card__footer { display: flex; align-items: center; justify-content: space-between; }
.hero-card__kicker { color: var(--gold-300); font-size: .66rem; font-weight: 760; letter-spacing: .14em; text-transform: uppercase; }
.hero-card__monogram { display: grid; place-items: center; width: 36px; height: 36px; color: var(--forest-950); border-radius: 50%; background: var(--gold-500); font-size: .9rem; font-weight: 800; }
.hero-card__metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: .65rem; margin: 1.15rem 0; padding: 1rem 0; border-top: 1px solid rgba(255,255,255,.14); border-bottom: 1px solid rgba(255,255,255,.14); }
.hero-card__metrics div { display: grid; gap: .35rem; }
.hero-card__metrics strong { color: #fff; font-size: 1.55rem; line-height: 1; }
.hero-card__metrics span { color: rgba(255,255,255,.62); font-size: .62rem; line-height: 1.35; }
.hero-card__footer p { margin: 0; color: rgba(255,255,255,.67); font-size: .66rem; line-height: 1.45; text-align: right; }
.hero-card__avatars { display: flex; padding-left: .5rem; }
.hero-card__avatars span { display: grid; place-items: center; width: 32px; height: 32px; margin-left: -.5rem; color: #fff; border: 2px solid rgba(5,24,17,.8); border-radius: 50%; background: var(--forest-600); font-size: .56rem; font-weight: 800; }
.hero-card__avatars span:nth-child(2) { background: #6d805e; }
.hero-card__avatars span:nth-child(3) { background: var(--gold-600); }
.hero__scroll { position: absolute; bottom: 1rem; left: 50%; display: none; align-items: center; gap: .7rem; color: rgba(255,255,255,.65); font-size: .58rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; transform: translateX(-50%) rotate(90deg); transform-origin: center; }
.hero__scroll-line { width: 42px; height: 1px; background: rgba(255,255,255,.5); }

.service-ribbon { overflow: hidden; color: #fff; background: var(--forest-900); }
.service-ribbon__track { display: flex; align-items: center; gap: 1.2rem; width: max-content; min-height: 62px; padding-inline: 1.2rem; animation: marquee 32s linear infinite; }
.service-ribbon__track span { font-size: .68rem; font-weight: 680; letter-spacing: .12em; text-transform: uppercase; white-space: nowrap; }
.service-ribbon__track i { width: 4px; height: 4px; border-radius: 50%; background: var(--gold-500); }

.about__grid { display: grid; gap: 4.2rem; }
.about__media { position: relative; min-height: 420px; }
.about__image { overflow: hidden; border-radius: var(--radius-md); box-shadow: var(--shadow-md); }
.about__image img { width: 100%; height: 100%; object-fit: cover; }
.about__image--main { width: 88%; height: min(68vw, 460px); }
.about__image--small { position: absolute; right: 0; bottom: -2rem; width: 48%; height: min(44vw, 280px); border: 7px solid var(--surface); }
.about__seal { position: absolute; top: 1.2rem; right: 0; display: grid; place-items: center; width: 108px; aspect-ratio: 1; color: var(--forest-950); border: 1px solid rgba(255,255,255,.6); border-radius: 50%; background: var(--gold-300); box-shadow: var(--shadow-md); line-height: 1.1; text-align: center; }
.about__seal span { font-size: .55rem; font-weight: 760; letter-spacing: .13em; text-transform: uppercase; }
.about__seal strong { font-size: 1.05rem; letter-spacing: -.02em; }
.about__copy p { max-width: 720px; }
.about__actions { display: flex; flex-direction: column; gap: 1rem; align-items: flex-start; margin-top: 1.8rem; }

.services__grid { display: grid; gap: .8rem; }
.service-card { overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--surface); transition: border-color .25s ease, transform .25s var(--ease), box-shadow .25s ease; }
.service-card:hover { border-color: var(--gold-500); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.service-card[open] { border-color: color-mix(in srgb, var(--gold-500) 72%, var(--line)); box-shadow: var(--shadow-sm); }
.service-card summary { display: grid; grid-template-columns: 48px 1fr 28px; gap: .9rem; align-items: center; min-height: 112px; padding: 1.05rem; cursor: pointer; list-style: none; }
.service-card summary::-webkit-details-marker { display: none; }
.service-card__icon { display: grid; place-items: center; width: 48px; height: 48px; color: var(--forest-700); border-radius: 50%; background: var(--stone-100); }
.service-card__icon svg { width: 22px; height: 22px; }
.service-card__text { display: grid; gap: .35rem; }
.service-card__text strong { color: var(--ink); font-size: .96rem; line-height: 1.25; }
.service-card__text small { color: var(--muted); font-size: .73rem; line-height: 1.4; }
.service-card__toggle { position: relative; width: 24px; height: 24px; border: 1px solid var(--line); border-radius: 50%; }
.service-card__toggle::before, .service-card__toggle::after { position: absolute; top: 50%; left: 50%; width: 9px; height: 1px; content: ""; background: currentColor; transform: translate(-50%, -50%); transition: transform .2s ease; }
.service-card__toggle::after { transform: translate(-50%, -50%) rotate(90deg); }
.service-card[open] .service-card__toggle::after { transform: translate(-50%, -50%) rotate(0); }
.service-card__detail { padding: 0 1.05rem 1.2rem 4.95rem; }
.service-card__detail p { margin-bottom: .9rem; font-size: .82rem; }
.service-card__detail a { display: inline-flex; align-items: center; gap: .4rem; color: var(--forest-700); font-size: .74rem; font-weight: 760; letter-spacing: .04em; text-transform: uppercase; }
html[data-theme="dark"] .service-card__detail a { color: var(--gold-300); }
.service-card--featured { background: linear-gradient(135deg, color-mix(in srgb, var(--gold-300) 14%, var(--surface)), var(--surface)); }
.service-card--emergency { color: #fff; border-color: transparent; background: linear-gradient(135deg, var(--emergency-dark), var(--emergency)); }
.service-card--emergency .service-card__icon { color: #fff; background: rgba(255,255,255,.14); }
.service-card--emergency .service-card__text strong, .service-card--emergency .service-card__detail a { color: #fff; }
.service-card--emergency .service-card__text small, .service-card--emergency .service-card__detail p { color: rgba(255,255,255,.72); }
.service-card--emergency .service-card__toggle { border-color: rgba(255,255,255,.3); }

.storm-cta { padding-top: 0; padding-bottom: 0; background: var(--stone-100); }
.storm-cta__shell { position: relative; display: grid; gap: 1.5rem; overflow: hidden; padding: 2rem 1.35rem; color: #fff; border-radius: var(--radius-lg); background: radial-gradient(circle at 90% 15%, rgba(255,255,255,.13), transparent 30%), linear-gradient(135deg, var(--emergency-dark), var(--emergency)); box-shadow: var(--shadow-md); }
.storm-cta__shell::after { position: absolute; right: -80px; bottom: -120px; width: 280px; height: 280px; content: ""; border: 1px solid rgba(255,255,255,.14); border-radius: 50%; box-shadow: 0 0 0 38px rgba(255,255,255,.05), 0 0 0 75px rgba(255,255,255,.03); }
.storm-cta__icon { display: grid; place-items: center; width: 64px; height: 64px; border: 1px solid rgba(255,255,255,.23); border-radius: 50%; background: rgba(255,255,255,.11); }
.storm-cta__icon svg { width: 30px; height: 30px; }
.storm-cta__copy, .storm-cta__actions { position: relative; z-index: 1; }
.storm-cta__copy h2 { max-width: 760px; margin-bottom: .9rem; color: #fff; font-size: clamp(2rem, 7vw, 3.7rem); }
.storm-cta__copy p { max-width: 730px; margin-bottom: 0; color: rgba(255,255,255,.72); }
.storm-cta__actions { display: flex; flex-direction: column; align-items: flex-start; gap: 1rem; }

.portfolio__filters { display: flex; gap: .55rem; overflow-x: auto; margin: 0 -18px 1.8rem; padding: .2rem 18px .8rem; scrollbar-width: none; }
.portfolio__filters::-webkit-scrollbar { display: none; }
.filter-chip { flex: 0 0 auto; min-height: 42px; padding: .65rem 1rem; color: var(--muted); border: 1px solid var(--line); border-radius: var(--radius-pill); background: transparent; cursor: pointer; font-size: .75rem; font-weight: 700; transition: all .2s ease; }
.filter-chip:hover, .filter-chip.is-active { color: #fff; border-color: var(--forest-700); background: var(--forest-700); }
.portfolio__grid { display: grid; gap: .85rem; }
.project-card { position: relative; isolation: isolate; min-height: 340px; overflow: hidden; padding: 0; border: 0; border-radius: var(--radius-md); background: var(--forest-950); cursor: zoom-in; text-align: left; }
.project-card[hidden] { display: none; }
.project-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease), filter .4s ease; }
.project-card::after { position: absolute; z-index: 1; inset: 0; content: ""; background: linear-gradient(0deg, rgba(5,24,17,.86), rgba(5,24,17,.06) 65%); }
.project-card:hover img { transform: scale(1.045); }
.project-card__overlay { position: absolute; z-index: 2; inset: auto 0 0; display: grid; gap: .25rem; padding: 1.25rem; color: #fff; }
.project-card__tag { margin-bottom: .25rem; color: var(--gold-300); font-size: .62rem; font-weight: 760; letter-spacing: .12em; text-transform: uppercase; }
.project-card__overlay strong { padding-right: 3rem; font-size: 1.15rem; letter-spacing: -.02em; line-height: 1.2; }
.project-card__overlay small { color: rgba(255,255,255,.64); font-size: .7rem; }
.project-card__open { position: absolute; right: 1.2rem; bottom: 1.2rem; display: grid; place-items: center; width: 42px; height: 42px; border: 1px solid rgba(255,255,255,.3); border-radius: 50%; background: rgba(255,255,255,.08); backdrop-filter: blur(10px); transition: background-color .2s ease, transform .2s ease; }
.project-card:hover .project-card__open { color: var(--forest-950); background: var(--gold-300); transform: rotate(8deg); }

.compare-grid { display: grid; gap: 1.2rem; }
.compare-card { overflow: hidden; border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-md); background: rgba(255,255,255,.05); }
.compare { position: relative; aspect-ratio: 4 / 3; overflow: hidden; background: #13251f; }
.compare img { width: 100%; height: 100%; object-fit: cover; }
.compare__after { position: absolute; inset: 0; }
.compare__before { position: absolute; z-index: 1; inset: 0 auto 0 0; width: var(--compare-position); overflow: hidden; }
.compare__before img { width: calc(100% / (var(--compare-position) / 100)); max-width: none; }
.compare__range { position: absolute; z-index: 5; inset: 0; width: 100%; height: 100%; margin: 0; opacity: 0; cursor: ew-resize; }
.compare__line { position: absolute; z-index: 3; top: 0; bottom: 0; left: var(--compare-position); width: 2px; background: #fff; transform: translateX(-50%); pointer-events: none; }
.compare__line span { position: absolute; top: 50%; left: 50%; display: grid; place-items: center; width: 46px; height: 46px; color: var(--forest-950); border: 4px solid #fff; border-radius: 50%; background: var(--gold-300); box-shadow: 0 7px 20px rgba(0,0,0,.28); transform: translate(-50%, -50%); }
.compare__line svg { width: 20px; height: 20px; }
.compare__label { position: absolute; z-index: 4; top: 1rem; padding: .45rem .72rem; color: #fff; border: 1px solid rgba(255,255,255,.24); border-radius: var(--radius-pill); background: rgba(5,24,17,.58); backdrop-filter: blur(8px); font-size: .62rem; font-weight: 760; letter-spacing: .12em; text-transform: uppercase; pointer-events: none; }
.compare__label--before { left: 1rem; }
.compare__label--after { right: 1rem; }
.compare-card__caption { display: flex; gap: 1rem; align-items: center; padding: 1.1rem 1.2rem 1.3rem; }
.compare-card__caption > span { color: var(--gold-300); font-size: .65rem; font-weight: 800; letter-spacing: .12em; }
.compare-card__caption div { display: grid; gap: .25rem; }
.compare-card__caption strong { color: #fff; font-size: .96rem; }
.compare-card__caption small { color: rgba(255,255,255,.55); font-size: .7rem; }

.why__grid { display: grid; gap: 3.5rem; }
.why__list { display: grid; gap: .7rem; margin-top: 1.8rem; }
.why__list > div { display: flex; align-items: center; gap: .75rem; padding: .8rem 0; border-bottom: 1px solid var(--line); }
.why__list span { display: grid; place-items: center; flex: 0 0 auto; width: 28px; height: 28px; color: var(--forest-700); border-radius: 50%; background: var(--stone-100); }
.why__list span svg { width: 14px; height: 14px; stroke-width: 2.6; }
.why__list strong { font-size: .88rem; }
.why__visual { position: relative; min-height: 470px; }
.why__visual > img { width: 88%; height: 430px; margin-left: auto; object-fit: cover; border-radius: var(--radius-md); box-shadow: var(--shadow-md); }
.why__visual::before { position: absolute; z-index: -1; top: 8%; left: 0; width: 76%; height: 82%; content: ""; border-radius: var(--radius-md); background: var(--stone-100); }
.why__badge { position: absolute; display: flex; align-items: center; gap: .75rem; padding: .9rem 1rem; border: 1px solid rgba(255,255,255,.45); border-radius: var(--radius-sm); background: color-mix(in srgb, var(--surface) 89%, transparent); box-shadow: var(--shadow-md); backdrop-filter: blur(14px); }
.why__badge--experience { top: 1rem; left: 0; }
.why__badge--experience strong { color: var(--gold-600); font-size: 2rem; line-height: 1; }
.why__badge--experience span { color: var(--muted); font-size: .62rem; font-weight: 700; line-height: 1.25; text-transform: uppercase; }
.why__badge--bbb { right: 0; bottom: 3.5rem; }
.why__grade { display: grid; place-items: center; width: 48px; height: 48px; color: var(--forest-950); border-radius: 50%; background: var(--gold-300); font-size: 1.15rem; font-weight: 820; }
.why__badge--bbb div { display: grid; }
.why__badge--bbb strong { font-size: .82rem; }
.why__badge--bbb small { color: var(--muted); font-size: .62rem; }
.why__quote { position: absolute; bottom: 0; left: 0; max-width: 250px; padding: 1.1rem; color: #fff; border-radius: var(--radius-sm); background: var(--forest-800); box-shadow: var(--shadow-md); }
.why__quote svg { color: var(--gold-300); }
.why__quote p { margin: .55rem 0 0; color: #fff; font-size: .83rem; font-weight: 600; line-height: 1.45; }

.process__grid { display: grid; gap: .9rem; margin-top: 2.7rem; }
.process-step { position: relative; overflow: hidden; min-height: 250px; padding: 1.35rem; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface); }
.process-step > span { position: absolute; top: .85rem; right: 1rem; color: var(--stone-300); font-size: 3.4rem; font-weight: 760; line-height: 1; letter-spacing: -.08em; }
.process-step__icon { position: relative; z-index: 1; display: grid; place-items: center; width: 54px; height: 54px; margin-bottom: 2.3rem; color: var(--forest-700); border-radius: 50%; background: var(--stone-100); }
.process-step h3 { position: relative; z-index: 1; margin-bottom: .7rem; }
.process-step p { position: relative; z-index: 1; margin-bottom: 0; font-size: .84rem; }

.areas__grid { display: grid; gap: 3rem; align-items: center; }
.area-chips { display: flex; flex-wrap: wrap; gap: .55rem; margin: 1.5rem 0; }
.area-chips button { padding: .58rem .8rem; color: var(--muted); border: 1px solid var(--line); border-radius: var(--radius-pill); background: var(--surface); cursor: pointer; font-size: .72rem; font-weight: 700; transition: all .2s ease; }
.area-chips button:hover, .area-chips button.is-active { color: #fff; border-color: var(--forest-700); background: var(--forest-700); }
.area-detail { display: grid; gap: .35rem; margin-bottom: 1.5rem; padding: 1rem 1.1rem; border-left: 3px solid var(--gold-500); background: var(--stone-100); }
.area-detail span { color: var(--muted); font-size: .6rem; font-weight: 760; letter-spacing: .12em; text-transform: uppercase; }
.area-detail strong { font-size: 1.2rem; }
.area-detail p { margin: 0; font-size: .8rem; }
.service-map { position: relative; min-height: 570px; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius-lg); background: linear-gradient(145deg, var(--stone-100), var(--stone-200)); box-shadow: var(--shadow-sm); }
.service-map > svg { position: absolute; inset: 5% 6% 5% 3%; width: 76%; height: 90%; }
.service-map__county { fill: color-mix(in srgb, var(--sage-500) 31%, var(--surface)); stroke: var(--forest-700); stroke-width: 2; }
.service-map__river { fill: none; stroke: color-mix(in srgb, var(--forest-700) 48%, transparent); stroke-dasharray: 4 8; stroke-width: 3; }
.service-map__ocean { position: absolute; inset: 0 0 0 76%; color: #7397a6; background: repeating-linear-gradient(0deg, rgba(118,168,186,.11) 0 1px, transparent 1px 13px), linear-gradient(180deg, rgba(133,190,211,.2), rgba(92,150,172,.08)); }
.service-map__ocean span { position: absolute; top: 50%; left: 50%; font-size: .55rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; transform: translate(-50%, -50%) rotate(90deg); white-space: nowrap; }
.map-pin { position: absolute; display: flex; align-items: center; gap: .4rem; padding: .4rem .55rem; border: 0; border-radius: var(--radius-pill); background: color-mix(in srgb, var(--surface) 90%, transparent); box-shadow: var(--shadow-sm); cursor: pointer; font-size: .62rem; font-weight: 720; transition: transform .2s ease, background-color .2s ease, color .2s ease; }
.map-pin span { width: 9px; height: 9px; border: 2px solid var(--surface); border-radius: 50%; background: var(--forest-700); box-shadow: 0 0 0 3px rgba(27,75,57,.18); }
.map-pin:hover, .map-pin.is-active { color: var(--forest-950); background: var(--gold-300); transform: translateY(-2px); }
.map-pin.is-active span { background: var(--emergency); }
.map-pin--suntree { top: 27%; left: 43%; }
.map-pin--viera { top: 33%; left: 34%; }
.map-pin--satellite { top: 39%; left: 59%; }
.map-pin--melbourne { top: 48%; left: 42%; }
.map-pin--indialantic { top: 51%; left: 59%; }
.map-pin--palm { top: 62%; left: 33%; }
.service-map__legend { position: absolute; right: 1rem; bottom: 1rem; display: flex; align-items: center; gap: .55rem; max-width: 190px; padding: .65rem .75rem; border: 1px solid var(--line); border-radius: var(--radius-sm); background: color-mix(in srgb, var(--surface) 88%, transparent); font-size: .6rem; line-height: 1.4; backdrop-filter: blur(10px); }
.service-map__legend .pulse-dot { background: var(--forest-700); box-shadow: none; }
.premium-areas { display: flex; flex-wrap: wrap; align-items: center; gap: .55rem .8rem; margin-top: 2.5rem; padding-top: 1.5rem; border-top: 1px solid var(--line); }
.premium-areas span { width: 100%; color: var(--muted); font-size: .65rem; font-weight: 720; letter-spacing: .1em; text-transform: uppercase; }
.premium-areas strong { font-size: .72rem; }
.premium-areas i { width: 3px; height: 3px; border-radius: 50%; background: var(--gold-500); }

.testimonials { background: var(--stone-100); }
.google-g { display: grid; place-items: center; width: 42px; height: 42px; color: #4285f4; border-radius: 50%; background: var(--stone-100); font-size: 1.2rem; font-weight: 800; }
.testimonials__grid { display: grid; gap: .9rem; }
.testimonial { display: flex; flex-direction: column; min-height: 275px; padding: 1.4rem; border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface); }
.testimonial > svg { width: 28px; height: 28px; color: var(--gold-600); }
.testimonial blockquote { margin: 2rem 0; color: var(--ink); font-size: clamp(1.15rem, 4vw, 1.55rem); font-weight: 520; letter-spacing: -.03em; line-height: 1.35; }
.testimonial figcaption { display: grid; gap: .2rem; margin-top: auto; }
.testimonial figcaption span { font-size: .78rem; font-weight: 760; }
.testimonial figcaption small { color: var(--muted); font-size: .64rem; }
.testimonial--featured { color: #fff; border-color: transparent; background: var(--forest-800); box-shadow: var(--shadow-md); }
.testimonial--featured blockquote { color: #fff; }
.testimonial--featured figcaption small { color: rgba(255,255,255,.55); }
.testimonial-source { margin: 1.2rem 0 0; font-size: .68rem; }

.contact { overflow: hidden; color: #fff; background: var(--forest-950); }
.contact::before { position: absolute; top: -20%; right: -15%; width: 620px; aspect-ratio: 1; content: ""; border-radius: 50%; background: radial-gradient(circle, rgba(201,164,93,.18), transparent 67%); }
.contact__shell { position: relative; z-index: 1; display: grid; gap: 2.5rem; }
.contact__copy h2 { color: #fff; }
.contact__copy > p { max-width: 570px; color: rgba(255,255,255,.67); }
.contact__methods { display: grid; gap: .7rem; margin: 2rem 0; }
.contact__methods > a { display: flex; align-items: center; gap: .85rem; padding: .8rem; border: 1px solid rgba(255,255,255,.13); border-radius: var(--radius-sm); background: rgba(255,255,255,.04); transition: border-color .2s ease, background-color .2s ease, transform .2s ease; }
.contact__methods > a:hover { border-color: var(--gold-500); background: rgba(255,255,255,.08); transform: translateX(3px); }
.contact__methods > a > span { display: grid; place-items: center; width: 44px; height: 44px; color: var(--gold-300); border-radius: 50%; background: rgba(255,255,255,.08); }
.contact__methods > a > div { display: grid; gap: .15rem; }
.contact__methods small { color: rgba(255,255,255,.5); font-size: .62rem; font-weight: 650; letter-spacing: .08em; text-transform: uppercase; }
.contact__methods strong { color: #fff; font-size: .9rem; }
.contact__hours { display: flex; gap: .65rem; align-items: flex-start; }
.contact__hours .pulse-dot { flex: 0 0 auto; margin-top: .45rem; background: var(--gold-300); }
.contact__hours p { margin: 0; color: rgba(255,255,255,.6); font-size: .76rem; }
.contact__hours strong { color: #fff; }
.proposal-form { padding: 1.2rem; color: var(--ink); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-lg); background: var(--surface); box-shadow: var(--shadow-lg); }
.proposal-form__header { display: grid; gap: .25rem; margin-bottom: 1.3rem; padding-bottom: 1rem; border-bottom: 1px solid var(--line); }
.proposal-form__header span { color: var(--forest-700); font-size: .62rem; font-weight: 760; letter-spacing: .13em; text-transform: uppercase; }
.proposal-form__header strong { font-size: 1.35rem; letter-spacing: -.03em; }
.form-grid { display: grid; gap: .9rem; }
.field { display: grid; gap: .4rem; }
.field > span { color: var(--ink); font-size: .68rem; font-weight: 720; }
.field input, .field select, .field textarea { width: 100%; min-height: 50px; padding: .78rem .85rem; color: var(--ink); border: 1px solid var(--line); border-radius: 10px; outline: none; background: var(--surface-2); transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease; }
.field textarea { min-height: 130px; resize: vertical; }
.field input::placeholder, .field textarea::placeholder { color: color-mix(in srgb, var(--muted) 68%, transparent); }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--gold-500); background: var(--surface); box-shadow: 0 0 0 4px rgba(201,164,93,.13); }
.consent { display: flex; gap: .65rem; align-items: flex-start; margin: 1rem 0; color: var(--muted); font-size: .64rem; line-height: 1.45; }
.consent input { flex: 0 0 auto; width: 16px; height: 16px; margin-top: .1rem; accent-color: var(--forest-700); }
.form-honeypot { position: absolute; left: -9999px; }
.form-status { min-height: 1.1rem; margin: .75rem 0 0; color: var(--forest-700); font-size: .72rem; font-weight: 650; text-align: center; }
.proposal-form__privacy { margin: .45rem 0 0; font-size: .6rem; text-align: center; }

.financing-bar { padding: 3.3rem 0; background: var(--gold-300); }
.financing-bar__inner { display: grid; gap: 1.1rem; align-items: center; }
.financing-bar .eyebrow { margin-bottom: .55rem; color: var(--forest-900); }
.financing-bar h2 { margin: 0; color: var(--forest-950); font-size: clamp(1.55rem, 5vw, 2.4rem); }
.financing-bar p { margin: 0; color: rgba(7,26,20,.68); font-size: .82rem; }

.faq__grid { display: grid; gap: 2rem; }
.faq__items details { border-bottom: 1px solid var(--line); }
.faq__items summary { display: grid; grid-template-columns: 1fr 28px; gap: 1rem; align-items: center; padding: 1.25rem 0; cursor: pointer; list-style: none; font-weight: 650; line-height: 1.35; }
.faq__items summary::-webkit-details-marker { display: none; }
.faq__items summary span { position: relative; width: 28px; height: 28px; border: 1px solid var(--line); border-radius: 50%; }
.faq__items summary span::before, .faq__items summary span::after { position: absolute; top: 50%; left: 50%; width: 9px; height: 1px; content: ""; background: currentColor; transform: translate(-50%, -50%); }
.faq__items summary span::after { transform: translate(-50%, -50%) rotate(90deg); transition: transform .2s ease; }
.faq__items details[open] summary span::after { transform: translate(-50%, -50%); }
.faq__items p { margin-bottom: 1.2rem; font-size: .85rem; }

.site-footer { padding: 4rem 0 calc(5.8rem + env(safe-area-inset-bottom)); color: rgba(255,255,255,.72); background: #061812; }
.site-footer__grid { display: grid; gap: 2.5rem; }
.brand--footer { color: #fff; }
.site-footer__brand > p { max-width: 390px; margin: 1.2rem 0; color: rgba(255,255,255,.52); font-size: .82rem; }
.site-footer__proud { color: var(--gold-300); font-size: .7rem; letter-spacing: .08em; text-transform: uppercase; }
.site-footer__grid > div:not(.site-footer__brand) { display: grid; align-content: start; gap: .65rem; }
.site-footer h3 { margin-bottom: .55rem; color: #fff; font-size: .75rem; letter-spacing: .12em; text-transform: uppercase; }
.site-footer a, .site-footer span { font-size: .75rem; }
.site-footer a:hover { color: var(--gold-300); }
.site-footer__grid > div > span { color: rgba(255,255,255,.52); }
.site-footer__bottom { display: flex; flex-direction: column; gap: .8rem; margin-top: 3rem; padding-top: 1.2rem; border-top: 1px solid rgba(255,255,255,.1); }
.site-footer__bottom > span { color: rgba(255,255,255,.4); font-size: .64rem; }
.site-footer__bottom div { display: flex; flex-wrap: wrap; gap: .8rem 1rem; }
.site-footer__bottom a { color: rgba(255,255,255,.55); font-size: .64rem; }

.mobile-actions { position: fixed; z-index: 900; right: 0; bottom: 0; left: 0; display: grid; grid-template-columns: 1fr 1fr; padding-bottom: env(safe-area-inset-bottom); color: #fff; background: var(--forest-950); box-shadow: 0 -10px 30px rgba(0,0,0,.15); }
.mobile-actions a { display: flex; align-items: center; justify-content: center; gap: .5rem; min-height: 58px; font-size: .72rem; font-weight: 740; }
.mobile-actions a + a { color: var(--forest-950); background: var(--gold-500); }

.lightbox { width: min(94vw, 1180px); max-width: none; max-height: 92vh; padding: 0; overflow: visible; border: 0; border-radius: var(--radius-md); background: #071a14; box-shadow: var(--shadow-lg); }
.lightbox::backdrop { background: rgba(2, 11, 8, .86); backdrop-filter: blur(7px); }
.lightbox__close { position: absolute; z-index: 2; top: .8rem; right: .8rem; color: #fff; border-color: rgba(255,255,255,.22); background: rgba(5,24,17,.55); }
.lightbox figure { margin: 0; }
.lightbox img { width: 100%; max-height: 78vh; object-fit: contain; border-radius: var(--radius-md) var(--radius-md) 0 0; }
.lightbox figcaption { padding: 1rem 1.2rem; color: rgba(255,255,255,.75); font-size: .78rem; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .75s var(--ease), transform .75s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
.reveal--hero { animation: heroIn .9s .12s var(--ease) forwards; }
.reveal--hero-delay { animation: heroIn .9s .34s var(--ease) forwards; }

@keyframes heroIn { to { opacity: 1; transform: none; } }
@keyframes pulse { 70% { box-shadow: 0 0 0 8px rgba(255,255,255,0); } 100% { box-shadow: 0 0 0 0 rgba(255,255,255,0); } }
@keyframes menuIn { from { transform: translateX(100%); } to { transform: none; } }
@keyframes marquee { to { transform: translateX(-50%); } }

@media (min-width: 700px) {
  :root { --header-offset: 122px; }
  .container { width: min(calc(100% - 64px), var(--container)); }
  .emergency-bar__inner { justify-content: space-between; }
  .emergency-bar__inner > a { display: inline-flex; }
  .hero { padding-bottom: 7rem; }
  .hero__buttons { flex-direction: row; max-width: none; }
  .hero__buttons .button { min-width: 230px; }
  .about__media { min-height: 550px; }
  .about__image--main { height: 520px; }
  .about__image--small { width: 42%; height: 300px; }
  .about__seal { width: 126px; }
  .about__actions { flex-direction: row; align-items: center; gap: 1.5rem; }
  .services__grid { grid-template-columns: repeat(2, 1fr); }
  .storm-cta__shell { padding: 2.6rem; }
  .portfolio__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .project-card--wide { grid-column: span 2; }
  .compare-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .why__list { grid-template-columns: repeat(2, minmax(0, 1fr)); column-gap: 1.5rem; }
  .process__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .testimonials__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .form-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .field--wide { grid-column: 1 / -1; }
  .financing-bar__inner { grid-template-columns: minmax(0, 1.3fr) minmax(240px, .8fr); }
  .financing-bar__inner .button { grid-column: 1 / -1; justify-self: start; }
  .site-footer__grid { grid-template-columns: 1.6fr repeat(3, 1fr); }
  .site-footer__brand { grid-column: 1 / -1; }
  .site-footer__bottom { flex-direction: row; justify-content: space-between; }
}

@media (min-width: 1020px) {
  :root { --header-offset: 126px; }
  .nav__menu-button { display: none; }
  .nav__links { display: flex; align-items: center; gap: clamp(1rem, 2.1vw, 2rem); margin-left: auto; }
  .nav__links a { position: relative; padding: .9rem 0; font-size: .72rem; font-weight: 650; letter-spacing: .025em; }
  .nav__links a::after { position: absolute; right: 0; bottom: .55rem; left: 0; height: 1px; content: ""; background: var(--gold-500); transform: scaleX(0); transform-origin: right; transition: transform .3s var(--ease); }
  .nav__links a:hover::after { transform: scaleX(1); transform-origin: left; }
  .nav__actions { display: flex; align-items: center; gap: .7rem; }
  .nav__phone { display: none; align-items: center; gap: .35rem; font-size: .76rem; font-weight: 720; }
  .site-header:not(.is-scrolled) .theme-toggle { color: #fff; border-color: rgba(255,255,255,.22); background: rgba(255,255,255,.08); }
  .hero { align-items: center; padding-bottom: 4.5rem; }
  .hero__content { grid-template-columns: minmax(0, 1fr) 340px; gap: 4rem; }
  .hero-card { justify-self: end; }
  .hero__scroll { display: flex; }
  .section-heading--split { grid-template-columns: minmax(0, 1.1fr) minmax(300px, .65fr); align-items: end; margin-bottom: 3.6rem; }
  .about__grid { grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); gap: clamp(4rem, 8vw, 7rem); align-items: center; }
  .about__media { min-height: 620px; }
  .about__image--main { height: 570px; }
  .about__image--small { height: 300px; }
  .services__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
  .service-card summary { min-height: 120px; padding: 1.15rem 1.25rem; }
  .service-card__detail { padding-right: 1.25rem; padding-bottom: 1.35rem; }
  .storm-cta__shell { grid-template-columns: 82px minmax(0, 1fr) auto; gap: 1.7rem; align-items: center; padding: 3rem; }
  .storm-cta__actions { align-items: flex-end; }
  .portfolio__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); grid-auto-rows: 245px; }
  .project-card { min-height: 0; }
  .project-card--tall { grid-row: span 2; }
  .project-card--wide { grid-column: span 2; }
  .why__grid { grid-template-columns: minmax(0, 1fr) minmax(420px, .86fr); gap: clamp(4rem, 8vw, 7rem); align-items: center; }
  .process__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .areas__grid { grid-template-columns: minmax(0, .85fr) minmax(470px, 1.15fr); gap: clamp(4rem, 7vw, 7rem); }
  .contact__shell { grid-template-columns: minmax(0, .78fr) minmax(520px, 1.05fr); gap: clamp(4rem, 8vw, 7rem); align-items: start; }
  .proposal-form { padding: 1.6rem; }
  .financing-bar__inner { grid-template-columns: minmax(0, 1.15fr) minmax(280px, .75fr) auto; gap: 2rem; }
  .financing-bar__inner .button { grid-column: auto; justify-self: end; }
  .faq__grid { grid-template-columns: minmax(300px, .65fr) minmax(0, 1fr); gap: clamp(4rem, 8vw, 8rem); }
  .site-footer { padding-bottom: 2.2rem; }
  .site-footer__grid { grid-template-columns: 1.65fr repeat(3, .75fr); }
  .site-footer__brand { grid-column: auto; }
  .mobile-actions { display: none; }
}

@media (min-width: 1180px) {
  .nav__phone { display: inline-flex; }
  .hero__content { grid-template-columns: minmax(0, 1fr) 370px; }
  .hero-card { padding: 1.55rem; }
  .services__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .service-card--featured { grid-column: span 2; }
  .service-card--emergency { grid-column: span 2; }
}

@media (min-width: 1380px) {
  .hero__media img { object-position: center 48%; }
  .hero__content { grid-template-columns: minmax(0, 1fr) 390px; }
}

@media (max-width: 430px) {
  .brand__type strong { font-size: .88rem; }
  .brand__type small { font-size: .48rem; }
  .hero h1 { font-size: clamp(3rem, 14vw, 4rem); }
  .hero-card__metrics span { font-size: .56rem; }
  .compare__label { top: .65rem; }
  .compare__label--before { left: .65rem; }
  .compare__label--after { right: .65rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
  .hero__media { transform: none !important; }
  .service-ribbon__track { animation: none; }
}

.brand--logo{display:flex;width:178px;height:68px;padding:4px 8px;border-radius:14px;background:#fff;box-shadow:0 8px 25px rgba(4,18,13,.14);overflow:hidden}
.brand--logo img{width:100%;height:100%;object-fit:contain}
.brand--footer-logo{display:block;width:min(290px,100%);padding:8px 10px;border-radius:16px;background:#fff}
.brand--footer-logo img{width:100%;height:auto}
.hero--leadgen{min-height:900px;padding-top:calc(var(--header-offset) + 2.25rem)}
.hero--leadgen .hero__content{align-items:center}
.hero--leadgen .hero__copy{max-width:760px}
.hero--leadgen .hero__copy h1{font-size:clamp(3rem,7vw,6.3rem)}
.hero--leadgen .hero__copy>p{max-width:650px}
.hero-form{position:relative;z-index:3;width:100%;padding:1.2rem;border-color:rgba(255,255,255,.2);box-shadow:0 35px 90px rgba(3,16,11,.38)}
.hero-form .form-grid{gap:.7rem}
.hero-form .field input,.hero-form .field select,.hero-form .field textarea{min-height:46px;padding:.67rem .72rem}
.hero-form .field textarea{min-height:76px}
.hero-form__logo{width:136px;height:55px;object-fit:contain;margin-bottom:.55rem}
.hero-form__micro{margin:.65rem 0 0;font-size:.62rem;text-align:center}
.trust-pills{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.2rem}
.trust-pill{display:inline-flex;align-items:center;gap:.42rem;padding:.48rem .68rem;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:rgba(255,255,255,.08);font-size:.66rem;font-weight:700;backdrop-filter:blur(12px)}
.home-about-grid,.split-grid{display:grid;gap:3rem;align-items:center}
.image-stack{position:relative;min-height:530px}
.image-stack__main{width:88%;height:500px;margin-left:auto;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.image-stack__small{position:absolute;left:0;bottom:0;width:48%;height:245px;object-fit:cover;border:9px solid var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin:2rem 0}
.stat-card{padding:1rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2)}
.stat-card strong{display:block;color:var(--forest-700);font-size:1.65rem;line-height:1}
.stat-card span{display:block;margin-top:.45rem;color:var(--muted);font-size:.66rem;text-transform:uppercase;letter-spacing:.08em}
.image-service-grid{display:grid;gap:1rem}
.image-service-card{position:relative;min-height:360px;overflow:hidden;border-radius:var(--radius-md);background:var(--forest-950);box-shadow:var(--shadow-sm);isolation:isolate}
.image-service-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .65s var(--ease)}
.image-service-card:after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(5,24,17,.05) 20%,rgba(5,24,17,.92) 100%)}
.image-service-card:hover img{transform:scale(1.05)}
.image-service-card__body{position:absolute;left:0;right:0;bottom:0;padding:1.35rem;color:#fff}
.image-service-card__body span{color:var(--gold-300);font-size:.63rem;font-weight:760;letter-spacing:.12em;text-transform:uppercase}
.image-service-card__body h3{margin:.35rem 0 .55rem;color:#fff;font-size:1.45rem}
.image-service-card__body p{margin:0;color:rgba(255,255,255,.7);font-size:.78rem}
.image-service-card__arrow{position:absolute;right:1rem;top:1rem;display:grid;place-items:center;width:44px;height:44px;color:var(--forest-950);border-radius:50%;background:#fff;transition:transform .25s ease,background .25s ease}
.image-service-card:hover .image-service-card__arrow{transform:rotate(45deg);background:var(--gold-300)}
.view-all-row{display:flex;justify-content:center;margin-top:2rem}
.emergency-panel{padding:2rem;border-radius:var(--radius-lg);color:#fff;background:linear-gradient(135deg,#741b21,#b52a34);box-shadow:var(--shadow-md)}
.emergency-panel__grid{display:grid;gap:1.5rem;align-items:center}
.emergency-panel h2{color:#fff;font-size:clamp(2rem,4vw,3.7rem)}
.emergency-panel p{color:rgba(255,255,255,.75)}
.portfolio-grid{display:grid;gap:1rem}
.location-card-grid{display:grid;gap:.8rem}
.location-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.location-card:hover{transform:translateY(-2px);border-color:var(--gold-500);box-shadow:var(--shadow-sm)}
.location-card strong{display:block}
.location-card small{color:var(--muted)}
.page-hero{position:relative;isolation:isolate;min-height:570px;display:flex;align-items:flex-end;padding:calc(var(--header-offset) + 4rem) 0 4.6rem;overflow:hidden;color:#fff;background:var(--forest-950)}
.page-hero__media{position:absolute;z-index:-3;inset:0}
.page-hero__media img{width:100%;height:100%;object-fit:cover}
.page-hero__veil{position:absolute;z-index:-2;inset:0;background:linear-gradient(90deg,rgba(4,20,14,.94),rgba(4,20,14,.72) 55%,rgba(4,20,14,.24)),linear-gradient(0deg,rgba(4,20,14,.7),transparent 65%)}
.page-hero__content{max-width:910px}
.page-hero h1{margin-bottom:1.1rem;color:#fff;font-size:clamp(2.85rem,6.8vw,5.8rem)}
.page-hero p{max-width:760px;margin-bottom:0;color:rgba(255,255,255,.76);font-size:clamp(1rem,2vw,1.2rem)}
.breadcrumbs{display:flex;flex-wrap:wrap;gap:.55rem;align-items:center;margin-bottom:1.35rem;color:rgba(255,255,255,.62);font-size:.68rem;font-weight:700}
.breadcrumbs a:hover{color:var(--gold-300)}
.breadcrumbs i{opacity:.55}
.page-hero__badges{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.3rem}
.page-hero__badges span{padding:.5rem .7rem;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:rgba(255,255,255,.08);font-size:.65rem;font-weight:700}
.content-section{padding:clamp(4.5rem,8vw,7rem) 0}
.content-layout{display:grid;gap:3.4rem;align-items:start}
.article{min-width:0}
.article>p,.article li{color:var(--muted)}
.article .lead{font-size:clamp(1.1rem,2vw,1.28rem)}
.article h2{margin-top:3rem;font-size:clamp(2rem,4vw,3.5rem)}
.article h3{margin-top:2.2rem;font-size:1.45rem}
.article h2:first-child{margin-top:0}
.article-image{width:100%;aspect-ratio:16/9;margin:2.5rem 0;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.check-list{display:grid;gap:.75rem;margin:1.4rem 0;padding:0;list-style:none}
.check-list li{display:grid;grid-template-columns:28px 1fr;gap:.75rem;align-items:start}
.check-list li:before{content:"✓";display:grid;place-items:center;width:28px;height:28px;color:var(--forest-950);border-radius:50%;background:var(--gold-300);font-weight:900}
.content-callout{margin:2.4rem 0;padding:1.5rem;border-left:4px solid var(--gold-500);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:var(--stone-100)}
.content-callout h3{margin:0 0 .55rem}
.content-callout p{margin:0}
.process-list{display:grid;gap:.85rem;margin:1.4rem 0}
.process-list>div{display:grid;grid-template-columns:48px 1fr;gap:1rem;padding:1rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface)}
.process-list span{display:grid;place-items:center;width:48px;height:48px;color:var(--forest-950);border-radius:50%;background:var(--gold-300);font-weight:800}
.process-list h3{margin:0 0 .35rem;font-size:1rem}
.process-list p{margin:0;font-size:.82rem}
.sidebar{display:grid;gap:1rem}
.sidebar__sticky{display:grid;gap:1rem}
.proposal-form--sidebar{border-color:var(--line)}
.proposal-form--sidebar .form-grid{grid-template-columns:1fr}
.proposal-form--sidebar .field--wide{grid-column:auto}
.proposal-form--sidebar .field textarea{min-height:90px}
.sidebar-call{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.1rem;color:#fff;border-radius:var(--radius-sm);background:var(--forest-900)}
.sidebar-call small{display:block;color:rgba(255,255,255,.55);font-size:.62rem;text-transform:uppercase;letter-spacing:.08em}
.sidebar-call strong{display:block;color:#fff}
.sidebar-call span:last-child{display:grid;place-items:center;width:43px;height:43px;color:var(--forest-950);border-radius:50%;background:var(--gold-300)}
.related-grid{display:grid;gap:.8rem;margin-top:1.2rem}
.related-card{display:flex;align-items:center;gap:.85rem;padding:.8rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface)}
.related-card img{width:90px;height:70px;object-fit:cover;border-radius:10px}
.related-card strong{display:block;font-size:.84rem;line-height:1.25}
.related-card small{color:var(--muted);font-size:.67rem}
.service-index-grid{display:grid;gap:1rem}
.service-index-card{display:grid;grid-template-rows:220px auto;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.service-index-card:hover{transform:translateY(-4px);border-color:var(--gold-500);box-shadow:var(--shadow-md)}
.service-index-card img{width:100%;height:100%;object-fit:cover}
.service-index-card__body{padding:1.25rem}
.service-index-card h2,.service-index-card h3{margin:0 0 .65rem;font-size:1.35rem}
.service-index-card p{font-size:.78rem}
.service-index-card .text-link{margin-top:.4rem}
.area-index-grid{display:grid;gap:.8rem}
.area-index-card{padding:1.2rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface)}
.area-index-card h2,.area-index-card h3{margin:0 0 .55rem;font-size:1.25rem}
.area-index-card p{font-size:.76rem}
.area-index-card__links{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.8rem}
.area-index-card__links a{padding:.42rem .6rem;border-radius:999px;background:var(--stone-100);font-size:.65rem;font-weight:700}
.matrix-grid{display:grid;gap:.7rem;margin-top:1.3rem}
.matrix-link{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface)}
.matrix-link:hover{border-color:var(--gold-500)}
.matrix-link strong{font-size:.8rem}
.local-context{padding:1.4rem;border-radius:var(--radius-md);background:linear-gradient(135deg,color-mix(in srgb,var(--sage-200) 45%,var(--surface)),var(--stone-100));border:1px solid var(--line)}
.local-context h3{margin:0 0 .6rem}
.local-context p{margin:0}
.notice{padding:1rem;border:1px solid #efd3d6;border-radius:var(--radius-sm);color:#7c2028;background:#fff2f3}
.notice strong{display:block}
.generic-card{padding:clamp(1.4rem,4vw,2.4rem);border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm)}
.contact-grid{display:grid;gap:2rem}
.contact-methods{display:grid;gap:.8rem}
.contact-method{display:flex;align-items:center;gap:1rem;padding:1.1rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface)}
.contact-method__icon{display:grid;place-items:center;width:48px;height:48px;color:var(--forest-950);border-radius:50%;background:var(--gold-300)}
.contact-method small{display:block;color:var(--muted);font-size:.64rem;text-transform:uppercase;letter-spacing:.08em}
.contact-method strong{display:block}
.not-found{min-height:100svh;display:grid;place-items:center;padding:8rem 1.5rem;color:#fff;background:var(--forest-950);text-align:center}
.not-found h1{font-size:clamp(5rem,20vw,11rem);color:var(--gold-300)}
.not-found h2{color:#fff}
.component-preview{display:grid;gap:1.5rem}
.component-block{padding:1.4rem;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface)}

@media (min-width:700px){
  .image-service-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .portfolio-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .location-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .service-index-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .area-index-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .matrix-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contact-grid{grid-template-columns:minmax(0,.8fr) minmax(420px,1.2fr);align-items:start}
}
@media (min-width:1020px){
  .hero--leadgen .hero__content{grid-template-columns:minmax(0,1fr) 430px;gap:4rem}
  .home-about-grid,.split-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(4rem,7vw,7rem)}
  .image-service-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .image-service-card:first-child,.image-service-card:nth-child(8){grid-column:span 2}
  .portfolio-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .emergency-panel__grid{grid-template-columns:minmax(0,1fr) auto}
  .content-layout{grid-template-columns:minmax(0,1fr) 380px;gap:clamp(3.5rem,6vw,6rem)}
  .sidebar__sticky{position:sticky;top:130px}
  .service-index-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .area-index-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .location-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (min-width:1280px){.hero--leadgen .hero__content{grid-template-columns:minmax(0,1fr) 455px}.hero-form{padding:1.35rem}}
@media (max-width:1019px){.brand--logo{width:158px;height:62px}.hero--leadgen{min-height:auto;padding-bottom:4rem}.hero--leadgen .hero__content{gap:2rem}.page-hero{min-height:500px}}
@media (max-width:699px){.brand--logo{width:145px;height:58px}.hero--leadgen{padding-top:calc(var(--header-offset) + 1.5rem)}.hero-form{margin-top:.4rem}.stat-row{grid-template-columns:1fr}.image-stack{min-height:430px}.image-stack__main{height:400px;width:94%}.image-stack__small{height:190px}.page-hero{min-height:480px;padding-bottom:3rem}.related-card img{width:76px;height:62px}}

.nav__mobile-phone{display:none}
.proposal-form{position:relative;overflow:hidden}
.proposal-form:before{position:absolute;inset:0 0 auto;height:4px;content:"";background:linear-gradient(90deg,var(--gold-600),var(--gold-300),var(--gold-600))}
.proposal-form__privacy a{color:var(--forest-700);font-weight:750;text-decoration:underline;text-underline-offset:2px}
.image-service-card img,.service-index-card img,.project-card img{transition:transform .65s var(--ease),filter .4s ease}
.image-service-card:hover img,.service-index-card:hover img,.project-card:hover img{transform:scale(1.035);filter:saturate(1.06)}
.local-project-note{border-left-color:var(--forest-700);background:linear-gradient(135deg,color-mix(in srgb,var(--sage-200) 32%,var(--surface)),var(--surface))}
.supplemental-content{margin-top:2.5rem}

@media (max-width:1019px){
  :root{--header-offset:128px}
  .site-header,.site-header.is-scrolled{color:var(--ink);background:transparent;box-shadow:none;backdrop-filter:none}
  .nav.container{width:calc(100% - 24px);min-height:72px;margin:10px auto 0;padding:7px 9px 7px 13px;gap:8px;border:1px solid rgba(13,42,33,.1);border-radius:20px;background:rgba(255,255,255,.97);box-shadow:0 16px 44px rgba(3,20,14,.18);backdrop-filter:blur(18px)}
  .brand--logo{flex:0 1 178px;width:178px;height:56px;min-width:0;padding:0;border-radius:0;background:transparent;box-shadow:none;overflow:visible}
  .brand--logo img{width:100%;height:100%;object-fit:contain;object-position:left center}
  .nav__mobile-phone{display:grid;place-items:center;flex:0 0 42px;width:42px;height:42px;margin-left:auto;color:var(--forest-800);border:1px solid var(--line);border-radius:50%;background:var(--stone-100)}
  .nav__menu-button,.site-header.is-scrolled .nav__menu-button{display:grid!important;flex:0 0 44px;width:44px;height:44px;color:#fff;border:0;background:var(--forest-900);box-shadow:0 8px 18px rgba(7,26,20,.18)}
  .content-layout{display:flex;flex-direction:column;gap:2.4rem}
  .sidebar{order:-1;width:100%}
  .sidebar__sticky{width:100%}
  .proposal-form--sidebar{box-shadow:var(--shadow-md)}
  .article{order:0}
}

@media (max-width:699px){
  :root{--header-offset:124px}
  .container{width:min(calc(100% - 28px),var(--container))}
  .emergency-bar__inner{min-height:38px;padding:0 8px;font-size:.58rem;letter-spacing:.07em;white-space:nowrap}
  .nav.container{width:calc(100% - 20px);margin-top:8px;padding-left:11px;border-radius:18px}
  .brand--logo{flex-basis:164px;width:164px;height:54px}
  .hero--leadgen{padding-top:calc(var(--header-offset) + 1rem);padding-bottom:4.5rem}
  .hero--leadgen .hero__content{gap:1rem;align-items:start}
  .hero--leadgen .hero__copy h1{margin-bottom:1rem;font-size:clamp(2.85rem,13.5vw,4.15rem);line-height:.94;letter-spacing:-.055em}
  .hero--leadgen .hero__copy>p{margin-bottom:0;font-size:1rem;line-height:1.55}
  .hero__buttons,.hero__locations{display:none}
  .hero-form{margin-top:.2rem;padding:1rem;border-radius:24px;box-shadow:0 26px 70px rgba(0,0,0,.34)}
  .hero-form .proposal-form__header{margin-bottom:1rem;padding-bottom:.8rem}
  .hero-form .proposal-form__header strong{font-size:1.2rem}
  .hero-form .field textarea{min-height:86px}
  .hero-form .consent{font-size:.62rem}
  .page-hero{min-height:470px;padding-top:calc(var(--header-offset) + 3rem)}
  .page-hero h1{font-size:clamp(2.55rem,12vw,4rem)}
  .content-section{padding-top:2.25rem}
  .proposal-form--sidebar{border-radius:24px}
  .mobile-actions a{min-height:60px}
}

@media (max-width:390px){
  .brand--logo{flex-basis:145px;width:145px;height:50px}
  .nav__mobile-phone{width:40px;height:40px;flex-basis:40px}
  .nav__menu-button,.site-header.is-scrolled .nav__menu-button{width:42px;height:42px;flex-basis:42px}
  .emergency-bar__inner{font-size:.54rem;letter-spacing:.055em}
}

@media (min-width:1020px){
  .sidebar{order:0}
  .site-header.is-scrolled .brand--logo{height:60px}
}
@media (max-width:699px){.home-page .trust-pills{display:none}}
.page-hero .content-callout{max-width:820px;margin:2rem 0 0;padding:1.25rem 1.4rem;border:1px solid rgba(255,255,255,.16);border-left:4px solid var(--gold-500);border-radius:0 18px 18px 0;background:rgba(5,31,22,.72);box-shadow:0 18px 50px rgba(0,0,0,.2);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.page-hero .content-callout h2,.page-hero .content-callout h3{margin:0 0 .55rem;color:#fff;font-size:clamp(1.45rem,2.4vw,2.15rem);line-height:1.12}
.page-hero .content-callout p{max-width:760px;margin:0;color:rgba(255,255,255,.78);font-size:clamp(.86rem,1.25vw,.98rem);line-height:1.7}
@media(max-width:699px){.page-hero .content-callout{margin-top:1.55rem;padding:1.05rem 1.1rem}.page-hero .content-callout h2,.page-hero .content-callout h3{font-size:1.5rem}.page-hero .content-callout p{font-size:.84rem;line-height:1.62}}
