:root {
  --color-ink: #132433;
  --color-muted: #5f7180;
  --color-blue: #1f5d83;
  --color-blue-dark: #123b59;
  --color-orange: #f28b2e;
  --color-orange-soft: #fff0df;
  --color-sky: #e9f4fa;
  --color-paper: #fbf8f2;
  --color-surface: #ffffff;
  --color-line: rgba(19, 36, 51, .13);
  --shadow-soft: 0 20px 60px rgba(18, 59, 89, .13);
  --shadow-card: 0 14px 36px rgba(18, 59, 89, .11);
  --radius-sm: 12px;
  --radius-md: 20px;
  --radius-lg: 32px;
  --space-1: .25rem;
  --space-2: .5rem;
  --space-3: .75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --font-head: "Manrope", system-ui, sans-serif;
  --font-body: "Source Sans 3", system-ui, sans-serif;
  --step--1: clamp(.91rem, .88rem + .12vw, .98rem);
  --step-0: clamp(1rem, .96rem + .22vw, 1.125rem);
  --step-1: clamp(1.22rem, 1.13rem + .46vw, 1.5rem);
  --step-2: clamp(1.55rem, 1.38rem + .84vw, 2.05rem);
  --step-3: clamp(2rem, 1.66rem + 1.7vw, 3rem);
  --step-4: clamp(2.55rem, 1.92rem + 3.15vw, 4.5rem);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--step-0);
  line-height: 1.58;
  color: var(--color-ink);
  background:
    radial-gradient(circle at 12% 10%, rgba(31, 93, 131, .10), transparent 28rem),
    linear-gradient(180deg, var(--color-paper), #fff 42rem);
}
body.nav-open { overflow: hidden; }
img { max-width: 100%; display: block; height: auto; }
a { color: inherit; }

.skip-link {
  position: absolute;
  left: var(--space-4);
  top: var(--space-4);
  z-index: 100;
  padding: var(--space-2) var(--space-4);
  border-radius: 999px;
  background: var(--color-blue-dark);
  color: #fff;
  transform: translateY(-160%);
}
.skip-link:focus { transform: translateY(0); }

.container {
  width: min(1120px, calc(100% - 32px));
  margin-inline: auto;
}
.section-pad { padding: var(--space-20) 0; }
.eyebrow {
  margin: 0 0 var(--space-3);
  font: 800 .78rem/1 var(--font-head);
  text-transform: uppercase;
  letter-spacing: .13em;
  color: var(--color-blue);
}
h1, h2, h3 {
  margin: 0;
  font-family: var(--font-head);
  line-height: 1.04;
  letter-spacing: -.045em;
  text-wrap: balance;
}
h1 { font-size: var(--step-4); max-width: 11ch; }
h2 { font-size: var(--step-3); }
h3 { font-size: var(--step-1); }
p { margin: 0; color: var(--color-muted); }
.lead { font-size: var(--step-1); max-width: 34rem; color: #385262; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  width: min(1180px, calc(100% - 24px));
  margin: var(--space-3) auto 0;
  padding: var(--space-3) var(--space-4);
  border: 1px solid rgba(31, 93, 131, .13);
  border-radius: 999px;
  background: rgba(255, 255, 255, .94);
  box-shadow: 0 12px 34px rgba(18, 59, 89, .10);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
  text-decoration: none;
}
.brand img {
  width: 120px;
  height: 54px;
  object-fit: contain;
}
.brand strong {
  display: block;
  font-family: var(--font-head);
  font-size: .96rem;
  letter-spacing: -.02em;
  white-space: nowrap;
}
.brand small { display: block; color: var(--color-muted); line-height: 1.1; }
.site-nav { display: flex; align-items: center; gap: var(--space-2); }
.site-nav a {
  padding: .62rem .9rem;
  border-radius: 999px;
  color: #314b5f;
  font-weight: 700;
  text-decoration: none;
}
.site-nav a:hover, .site-nav a:focus-visible { background: var(--color-sky); color: var(--color-blue-dark); }
.nav-toggle { display: none; }

.hero { padding-top: var(--space-16); }
.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 520px);
  gap: var(--space-12);
  align-items: center;
}
.hero-copy { display: grid; gap: var(--space-6); }
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: .82rem 1.15rem;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: var(--color-orange); color: #23170d; box-shadow: 0 12px 24px rgba(242, 139, 46, .23); }
.btn-secondary { background: #fff; color: var(--color-blue-dark); border: 1px solid var(--color-line); }
.quick-facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
  margin: var(--space-2) 0 0;
}
.quick-facts div {
  padding: var(--space-4);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .76);
}
.quick-facts dt { color: var(--color-muted); font-size: .82rem; }
.quick-facts dd { margin: 0; font: 800 var(--step-1)/1 var(--font-head); color: var(--color-blue-dark); }
.quick-facts dd { font-size: clamp(1.08rem, 1.1vw, 1.28rem); line-height: 1.12; }
.hero-media {
  position: relative;
  margin: 0;
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--color-blue-dark), var(--color-blue));
  box-shadow: var(--shadow-soft);
}
.hero-media::before {
  content: "";
  position: absolute;
  inset: -18px 28px auto auto;
  width: 128px;
  height: 128px;
  border-radius: 999px;
  background: var(--color-orange);
  z-index: -1;
}
.hero-media img {
  width: 100%;
  max-height: 560px;
  object-fit: cover;
  border-radius: calc(var(--radius-lg) - 10px);
}
.hero-media figcaption {
  position: absolute;
  left: var(--space-8);
  right: var(--space-8);
  bottom: var(--space-8);
  padding: var(--space-3) var(--space-4);
  border-radius: 999px;
  background: rgba(255, 255, 255, .94);
  color: var(--color-blue-dark);
  font-weight: 800;
  text-align: center;
}

.split, .energy-grid, .workshop-grid, .contact-grid {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  gap: var(--space-12);
  align-items: start;
}
.split > *, .energy-grid > *, .workshop-grid > *, .contact-grid > * { min-width: 0; }
.copy-stack { display: grid; gap: var(--space-5); }
.copy-stack p { font-size: var(--step-1); color: #3d5363; }

.services { background: #fff; }
.section-head {
  display: grid;
  gap: var(--space-4);
  max-width: 730px;
  margin-bottom: var(--space-10);
}
.service-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-4);
}
.service-card {
  overflow: hidden;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  box-shadow: var(--shadow-card);
}
.service-card img {
  width: 100%;
  height: 172px;
  object-fit: cover;
}
.service-card div { padding: var(--space-5); display: grid; gap: var(--space-3); }
.service-card h3 { color: var(--color-blue-dark); }

.deep-dive { background: linear-gradient(180deg, #fff 0, var(--color-sky) 100%); }
.feature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
.feature-panel {
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}
.feature-panel img { width: 100%; height: 340px; object-fit: cover; }
.feature-panel > div { padding: var(--space-8); display: grid; gap: var(--space-4); }
.feature-panel.light { background: #fff; }
.feature-panel.blue { background: var(--color-blue-dark); color: #fff; }
.feature-panel.blue p, .feature-panel.blue li { color: rgba(255, 255, 255, .82); }
.feature-panel.blue .eyebrow { color: #ffd7ad; }
.check-list {
  display: grid;
  gap: var(--space-3);
  padding: 0;
  margin: var(--space-2) 0 0;
  list-style: none;
}
.check-list li {
  position: relative;
  padding-left: 1.65rem;
  color: #42586a;
}
.check-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .48em;
  width: .7rem;
  height: .7rem;
  border-radius: 50%;
  background: var(--color-orange);
}

.energy { background: var(--color-blue-dark); color: #fff; }
.energy p { color: rgba(255, 255, 255, .78); }
.energy .eyebrow { color: #ffd7ad; }
.energy-copy { display: grid; gap: var(--space-5); }
.process-card {
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .14);
}
.process-card ol { display: grid; gap: var(--space-4); padding: 0; margin: var(--space-6) 0 0; list-style: none; }
.process-card li {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: var(--space-3);
  align-items: start;
  color: rgba(255, 255, 255, .88);
}
.process-card span { color: var(--color-orange); font: 800 1rem/1 var(--font-head); }

.workshop { background: #fff; }
.workshop-grid { align-items: center; }
.workshop-grid img {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}
.text-link { color: var(--color-blue); font-weight: 800; text-decoration-thickness: 2px; text-underline-offset: 4px; }

.contact { background: var(--color-paper); }
.contact-card {
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  background: #fff;
  box-shadow: var(--shadow-card);
}
.contact-card address { margin: var(--space-6) 0; font-style: normal; color: #314b5f; }
.contact-links { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-bottom: var(--space-6); }
.contact-links a {
  padding: .64rem .86rem;
  border-radius: 999px;
  background: var(--color-sky);
  color: var(--color-blue-dark);
  font-weight: 800;
  text-decoration: none;
  overflow-wrap: anywhere;
}
.hours strong { font-family: var(--font-head); }
.hours p { margin-top: var(--space-2); }
.map-shell {
  position: relative;
  min-height: 510px;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, rgba(31, 93, 131, .10), rgba(242, 139, 46, .10)),
    #dceaf1;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .06), var(--shadow-soft);
  filter: saturate(1.05) contrast(1.02);
}
.map-shell iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; z-index: 1; }
.map-pattern {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.35) 1px, transparent 1px) 0 0 / 52px 52px,
    linear-gradient(0deg, rgba(255,255,255,.35) 1px, transparent 1px) 0 0 / 52px 52px;
}
.map-road {
  position: absolute;
  display: block;
  width: 122%;
  height: 22px;
  left: -11%;
  border-radius: 999px;
  background: rgba(255, 255, 255, .55);
  box-shadow: 0 0 0 1px rgba(31, 93, 131, .08);
}
.road-one { top: 28%; transform: rotate(-14deg); }
.road-two { top: 58%; transform: rotate(20deg); }
.road-three { top: 72%; transform: rotate(-6deg); }
.map-pin {
  position: absolute;
  left: 54%;
  top: 43%;
  width: 28px;
  height: 28px;
  border-radius: 50% 50% 50% 0;
  background: var(--color-orange);
  transform: rotate(-45deg);
  box-shadow: 0 12px 28px rgba(242, 139, 46, .32);
}
.map-pin::after {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: 50%;
  background: #fff;
}
.map-fallback {
  position: absolute;
  z-index: 2;
  left: var(--space-5);
  bottom: var(--space-5);
  max-width: calc(100% - 40px);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .94);
  box-shadow: 0 12px 30px rgba(18, 59, 89, .16);
}
.map-fallback span { display: block; color: var(--color-muted); font-size: .86rem; }
.map-fallback strong { color: var(--color-blue-dark); }
.map-fallback small { display: block; margin-top: .35rem; color: var(--color-muted); }

.site-footer {
  padding: var(--space-8) 0;
  background: #0f2638;
  color: #fff;
}
.site-footer p { margin-top: var(--space-2); color: rgba(255, 255, 255, .68); }
.footer-grid { display: flex; align-items: center; justify-content: space-between; gap: var(--space-6); }
.site-footer nav { display: flex; gap: var(--space-4); }
.site-footer a { color: #fff; text-decoration-color: rgba(255, 255, 255, .45); text-underline-offset: 4px; }

.legal-main { padding: var(--space-16) 0; }
.legal-card {
  max-width: 860px;
  margin-inline: auto;
  padding: var(--space-10);
  border-radius: var(--radius-lg);
  background: #fff;
  box-shadow: var(--shadow-card);
}
.legal-card h1 { max-width: none; margin-bottom: var(--space-6); }
.legal-card h2 { margin-top: var(--space-8); margin-bottom: var(--space-3); font-size: var(--step-1); letter-spacing: -.025em; }
.legal-card p, .legal-card li { color: #40596b; }
.legal-card ul { padding-left: 1.2rem; }
.back-link { display: inline-flex; margin-top: var(--space-8); font-weight: 800; color: var(--color-blue); }

@media (max-width: 980px) {
  .site-header { border-radius: var(--radius-md); }
  .nav-toggle {
    display: inline-flex;
    min-height: 44px;
    align-items: center;
    padding: .5rem .85rem;
    border: 0;
    border-radius: 999px;
    background: var(--color-blue-dark);
    color: #fff;
    font: 800 .95rem/1 var(--font-head);
  }
  .site-nav {
    position: fixed;
    inset: 82px 16px auto 16px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    padding: var(--space-4);
    border-radius: var(--radius-md);
    background: #fff;
    box-shadow: var(--shadow-soft);
  }
  .site-nav.is-open { display: flex; }
  .site-nav a { padding: var(--space-4); }
  .hero-grid, .split, .energy-grid, .workshop-grid, .contact-grid, .feature-grid { grid-template-columns: 1fr; }
  .service-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  h1 { max-width: 13ch; }
}

@media (max-width: 620px) {
  .container { width: min(100% - 24px, 1120px); }
  .section-pad { padding: var(--space-12) 0; }
  .site-header { width: calc(100% - 16px); margin-top: var(--space-2); padding: var(--space-2); }
  .brand img { width: 80px; height: 38px; }
  .brand strong { font-size: .82rem; white-space: normal; line-height: 1.1; }
  .brand small { font-size: .78rem; }
  .hero { padding-top: var(--space-10); }
  h1 { font-size: clamp(2.3rem, 13vw, 3.25rem); }
  .hero-grid { gap: var(--space-8); }
  .hero-media { padding: var(--space-3); }
  .hero-media::before { display: none; }
  .hero-media img { max-height: 420px; }
  .hero-media figcaption { position: static; margin-top: var(--space-3); border-radius: var(--radius-md); }
  .quick-facts { grid-template-columns: 1fr; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card img { height: 190px; }
  .feature-panel img { height: 260px; }
  .feature-panel > div, .process-card, .contact-card, .legal-card { padding: var(--space-5); }
  .map-shell { min-height: 390px; }
  .footer-grid { align-items: flex-start; flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .001ms !important; animation-duration: .001ms !important; }
}
