:root {
  --clr-deep: #091413;
  --clr-forest: #285A48;
  --clr-teal: #408A71;
  --clr-mint: #B0E4CC;
  --clr-ice: #e9f7f0;
  --clr-white: #f9fdfb;
  --font-display: "Sora", sans-serif;
  --font-body: "Space Grotesk", sans-serif;
  --fs-xs: 0.75rem;
  --fs-sm: 0.86rem;
  --fs-md: 1rem;
  --fs-lg: 1.25rem;
  --fs-xl: 1.9rem;
  --space-2xs: 0.35rem;
  --space-xs: 0.55rem;
  --space-sm: 0.85rem;
  --space-md: 1.2rem;
  --space-lg: 1.8rem;
  --space-xl: 2.6rem;
  --radius-sm: 0.55rem;
  --radius-md: 1rem;
  --radius-lg: 1.4rem;
  --shadow-soft: 0 0.55rem 1.4rem rgba(9, 20, 19, 0.16);
  --shadow-deep: 0 1.1rem 2.2rem rgba(9, 20, 19, 0.28);
  --trans: 220ms ease;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: linear-gradient(145deg, var(--clr-deep) 0%, #0f2420 45%, #17352f 100%);
  color: var(--clr-white);
  font-size: clamp(0.84rem, 0.78rem + 0.2vw, 0.95rem);
  line-height: 1.5;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; border-radius: var(--radius-md); }
.page-shell { width: min(94%, 75rem); margin: 0 auto; }
.site-header {
  margin-top: var(--space-md);
  border: 1px solid rgba(176, 228, 204, 0.3);
  border-radius: var(--radius-md);
  background: rgba(8, 15, 14, 0.7);
  padding: var(--space-sm);
}
.site-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}
.site-logo {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  color: var(--clr-mint);
}
.site-toggle {
  display: none;
  border: 1px solid rgba(176, 228, 204, 0.4);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--clr-white);
  padding: 0.3rem 0.6rem;
  font-size: 1.15rem;
  line-height: 1;
  text-align: center;
  z-index: 9999999999999999999999999;
}
.site-nav {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
  margin-top: var(--space-sm);
  justify-content: center;
}
.site-nav a {
  padding: 0.35rem 0.7rem;
  border-radius: var(--radius-sm);
  background: rgba(176, 228, 204, 0.1);
  min-height: 2.2rem;
  display: inline-flex;
  align-items: center;
}
.site-nav a:hover,
.site-nav a:focus-visible {
  background: rgba(176, 228, 204, 0.25);
}
.banner-wrap { position: relative; margin-top: var(--space-md); border: 1px solid rgba(176, 228, 204, 0.45); border-radius: var(--radius-lg); background: rgba(176, 228, 204, 0.06); backdrop-filter: blur(0.35rem); }
.topline { display: flex; align-items: center; justify-content: space-between; gap: var(--space-sm); padding: var(--space-sm) var(--space-md); }
.logo-text { font-family: var(--font-display); font-size: var(--fs-lg); letter-spacing: 0.04em; color: var(--clr-mint); }
.domain-flag { color: var(--clr-mint); font-size: var(--fs-xs); border: 1px solid rgba(176, 228, 204, 0.35); padding: 0.25rem 0.5rem; border-radius: var(--radius-sm); }
.menu-button { display: none; border: 1px solid rgba(176, 228, 204, 0.5); background: transparent; color: var(--clr-white); border-radius: var(--radius-sm); padding: 0.3rem 0.55rem; font-size: var(--fs-md); }
.menu-list { display: flex; gap: var(--space-sm); align-items: center; padding: 0 var(--space-md) var(--space-sm); flex-wrap: wrap; }
.menu-list a { border-radius: 99rem; padding: 0.3rem 0.7rem; background: rgba(176, 228, 204, 0.12); transition: var(--trans); }
.menu-list a:hover, .menu-list a:focus-visible { background: rgba(176, 228, 204, 0.3); }
.hero-zone { margin-top: var(--space-lg); padding: var(--space-lg) var(--space-md); border-radius: var(--radius-lg); position: relative; overflow: hidden; min-height: 24rem; border: 1px solid rgba(176, 228, 204, 0.2); background: radial-gradient(circle at 80% 12%, rgba(176, 228, 204, 0.26), transparent 35%), rgba(9, 20, 19, 0.6); }
.hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-copy { position: relative; z-index: 2; max-width: 36rem; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); margin: 0 0 var(--space-sm); line-height: 1.2; }
h1 { font-size: clamp(1.45rem, 1.1rem + 1.2vw, 2rem); }
h2 { font-size: clamp(1.15rem, 0.95rem + 0.8vw, 1.5rem); }
p { margin: 0 0 var(--space-sm); }
.dual-action { display: flex; gap: var(--space-xs); flex-wrap: wrap; margin-top: var(--space-md); }
.btn-chip { border: none; border-radius: 99rem; padding: 0.45rem 0.9rem; font-size: var(--fs-sm); background: var(--clr-mint); color: var(--clr-deep); transition: var(--trans); cursor: pointer; min-height: 2.2rem; display: inline-flex; align-items: center; justify-content: center; }
.btn-chip:hover, .btn-chip:focus-visible { transform: translateY(-0.08rem); box-shadow: var(--shadow-soft); }
.btn-ghost { background: rgba(176, 228, 204, 0.08); color: var(--clr-white); border: 1px solid rgba(176, 228, 204, 0.35); }
.cluster-flow { margin-top: var(--space-lg); display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--space-md); }
.panel-card { background: rgba(176, 228, 204, 0.07); border-radius: var(--radius-md); border: 1px solid rgba(176, 228, 204, 0.3); padding: var(--space-md); box-shadow: var(--shadow-soft); }
.span-eight { grid-column: span 8; }
.span-four { grid-column: span 4; }
.photo-wave { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-sm); align-items: start; }
.photo-wave figure { margin: 0; }
.photo-wave img { min-height: 14rem; object-fit: cover; }
.skew-wrap { margin-top: var(--space-xl); transform: rotate(-1.4deg); }
.skew-pane { transform: rotate(1.4deg); }
.path-zig { margin-top: var(--space-lg); position: relative; }
.path-zig .panel-card:nth-child(1) { margin-right: 20%; }
.path-zig .panel-card:nth-child(2) { margin-left: 24%; margin-top: -0.8rem; }
.path-zig .panel-card:nth-child(3) { margin-right: 17%; margin-top: -0.8rem; }
.product-rail { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-sm); }
.price-tag { display: inline-block; margin-top: var(--space-xs); color: var(--clr-mint); border: 1px solid rgba(176, 228, 204, 0.35); border-radius: 99rem; padding: 0.22rem 0.55rem; }
.contact-stage { margin-top: var(--space-lg); display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
form { display: grid; gap: var(--space-xs); }
label { display: grid; gap: 0.25rem; }
input, textarea { border-radius: var(--radius-sm); border: 1px solid rgba(176, 228, 204, 0.35); background: rgba(8, 15, 14, 0.65); color: var(--clr-white); padding: 0.5rem 0.65rem; font-size: var(--fs-sm); font-family: var(--font-body); }
textarea { min-height: 7rem; resize: vertical; }
.consent-row { display: flex; align-items: flex-start; gap: 0.45rem; }
.map-shell iframe { width: 100%; min-height: 14rem; border: 0; border-radius: var(--radius-md); }
.footline { margin: var(--space-xl) auto var(--space-md); border-top: 1px solid rgba(176, 228, 204, 0.2); padding-top: var(--space-sm); display: flex; justify-content: space-between; gap: var(--space-sm); flex-wrap: wrap; font-size: var(--fs-xs); }
.policy-pop { position: fixed; right: var(--space-sm); bottom: var(--space-sm); width: min(92%, 22rem); background: rgba(8, 15, 14, 0.94); border: 1px solid rgba(176, 228, 204, 0.45); border-radius: var(--radius-md); padding: var(--space-sm); box-shadow: var(--shadow-deep); z-index: 25; }
.policy-pop.hidden { display: none; }
.utility-hero { margin-top: var(--space-lg); }
.utility-hero .panel-card { min-height: 12rem; }
.legal-stack { display: grid; gap: var(--space-md); margin-top: var(--space-lg); }
@media (min-width: 90rem) {
  .page-shell { width: min(90%, 82rem); }
  .hero-copy { max-width: 40rem; }
}
@media (max-width: 75rem) {
  .page-shell { width: min(95%, 70rem); }
}
@media (max-width: 64rem) {
  .hero-zone { min-height: 21rem; }
  .cluster-flow { gap: var(--space-sm); }
  .contact-stage { gap: var(--space-sm); }
}
@media (max-width: 58rem) {
  .span-eight, .span-four { grid-column: span 12; }
  .product-rail, .contact-stage, .photo-wave { grid-template-columns: 1fr; }
  .path-zig .panel-card:nth-child(1), .path-zig .panel-card:nth-child(2), .path-zig .panel-card:nth-child(3) { margin: 0; }
  .site-toggle { display: inline-flex; }
  .site-nav {
    display: none;
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100dvh;
    z-index: 90;
    padding: 5.2rem var(--space-md) var(--space-md);
    margin: 0;
    background: rgba(9, 20, 19, 0.98);
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: var(--space-sm);
    overflow-y: auto;
  }
  .site-nav a {
    width: 100%;
    justify-content: center;
    font-size: 1rem;
    min-height: 2.7rem;
  }
  .site-nav.open { display: flex; }
  .site-header { position: relative; z-index: 100; }
}
@media (max-width: 48rem) {
  .page-shell { width: min(96%, 48rem); }
  .hero-zone { min-height: 19rem; padding: var(--space-md); }
  .panel-card { padding: var(--space-sm); }
  .footline { margin-top: var(--space-lg); }
}
@media (max-width: 36rem) {
  :root { --space-md: 1rem; --space-lg: 1.35rem; --space-xl: 2rem; }
  .site-header { padding: 0.7rem; }
  .site-logo { font-size: 1.1rem; }
  .hero-zone { min-height: 17.5rem; }
  .photo-wave img { min-height: 11rem; }
  .map-shell iframe { min-height: 12rem; }
  input, textarea { font-size: 0.84rem; }
  .btn-chip { width: 100%; }
  .dual-action .btn-chip { width: auto; }
}
@media (max-width: 25rem) {
  .page-shell { width: min(97%, 25rem); }
  .hero-zone { min-height: 16rem; padding: 0.9rem; }
  .site-nav a { padding: 0.4rem 0.5rem; }
  .panel-card { border-radius: 0.8rem; }
  .footline { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 28rem) {
  :root { --fs-xl: 1.5rem; --space-md: 1rem; --space-lg: 1.35rem; }
  .hero-zone { min-height: 15.5rem; }
}
@media (max-width: 22.5rem) {
  :root { --space-xs: 0.45rem; --space-sm: 0.7rem; --space-md: 0.9rem; }
  .page-shell { width: min(98%, 22.5rem); }
  .site-header { margin-top: 0.7rem; padding: 0.6rem; }
  .site-logo { font-size: 1rem; }
  .site-toggle { padding: 0.25rem 0.5rem; }
  .hero-zone { min-height: 14.5rem; padding: 0.75rem; border-radius: 1rem; }
  .panel-card { padding: 0.7rem; }
  .photo-wave img { min-height: 9.5rem; }
  .map-shell iframe { min-height: 10rem; }
}
@media (max-width: 20rem) {
  :root { --space-xs: 0.4rem; --space-sm: 0.65rem; --space-md: 0.8rem; }
  body { font-size: 0.82rem; }
  h1 { font-size: 1.28rem; }
  h2 { font-size: 1.05rem; }
  .hero-zone { min-height: 13.5rem; }
  .btn-chip, .site-nav a { min-height: 2rem; }
}
@media (max-height: 32rem) and (orientation: landscape) {
  .hero-zone { min-height: 12rem; }
  .site-nav.open { max-height: 52vh; overflow-y: auto; }
}
