:root {
  --ice: #f8fcff;
  --ice-2: #edf9ff;
  --sky: #bae6fd;
  --sky-2: #e0f2fe;
  --aqua: #22d3ee;
  --aqua-2: #67e8f9;
  --blue: #0ea5e9;
  --blue-2: #075985;
  --navy: #06283d;
  --navy-2: #0b3550;
  --ink: #082033;
  --muted: #5e7383;
  --soft: #d6ecf8;
  --line: rgba(8, 89, 134, 0.16);
  --line-strong: rgba(8, 89, 134, 0.28);
  --glass: rgba(255, 255, 255, 0.66);
  --glass-strong: rgba(255, 255, 255, 0.86);
  --shadow-blue: 0 30px 90px rgba(7, 89, 133, 0.18);
  --shadow-soft: 0 18px 54px rgba(7, 89, 133, 0.12);
  --radius-xl: 34px;
  --radius-lg: 26px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --radius-pill: 999px;
  --container: 1180px;
  --ease-out: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out: cubic-bezier(0.77, 0, 0.175, 1);
  --cursor-x: 50vw;
  --cursor-y: 20vh;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 92px;
}

body {
  margin: 0;
  min-width: 320px;
  color: var(--ink);
  font-family: "Manrope", "Aptos", "Segoe UI Variable", "Segoe UI", Arial, sans-serif;
  line-height: 1.55;
  background:
    radial-gradient(circle at 16% 8%, rgba(103, 232, 249, 0.42), transparent 30rem),
    radial-gradient(circle at 86% 2%, rgba(14, 165, 233, 0.25), transparent 28rem),
    linear-gradient(180deg, #fbfeff 0%, var(--ice) 30%, #eef9ff 72%, #e8f7ff 100%);
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -3;
  pointer-events: none;
  opacity: 0.65;
  background:
    linear-gradient(115deg, transparent 0 48%, rgba(255, 255, 255, 0.8) 49%, transparent 50% 100%),
    radial-gradient(circle at 50% 0, rgba(255, 255, 255, 0.92), transparent 26rem);
  background-size: 160px 160px, 100% 100%;
  mask-image: linear-gradient(180deg, black, transparent 85%);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  opacity: 0.13;
  background-image:
    linear-gradient(rgba(8, 89, 134, 0.4) 1px, transparent 1px),
    linear-gradient(90deg, rgba(8, 89, 134, 0.4) 1px, transparent 1px);
  background-size: 72px 72px;
}

body.menu-open {
  overflow: hidden;
}

img,
svg {
  max-width: 100%;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid rgba(34, 211, 238, 0.52);
  outline-offset: 4px;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1,
h2,
h3 {
  color: var(--ink);
  letter-spacing: 0;
}

h1 {
  max-width: 11.2em;
  margin-bottom: 1.1rem;
  font-size: 6.35rem;
  line-height: 0.94;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

h2 {
  margin-bottom: 1rem;
  font-size: 3.9rem;
  line-height: 0.98;
}

h3 {
  margin-bottom: 0.65rem;
  font-size: 1.2rem;
  line-height: 1.15;
}

p {
  color: var(--muted);
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 200;
  padding: 0.8rem 1rem;
  border-radius: var(--radius-pill);
  background: var(--navy);
  color: #fff;
  transform: translateY(-150%);
  transition: transform 180ms var(--ease-out);
}

.skip-link:focus {
  transform: translateY(0);
}

.cursor-glow {
  position: fixed;
  left: var(--cursor-x);
  top: var(--cursor-y);
  z-index: -1;
  width: 24rem;
  height: 24rem;
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(34, 211, 238, 0.28), transparent 62%);
  filter: blur(6px);
  opacity: 0.8;
}

.container {
  width: min(var(--container), calc(100% - 2rem));
  margin: 0 auto;
}

.section-shell {
  position: relative;
  padding: clamp(4.5rem, 8vw, 7rem) 0;
}

.glass-panel {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.72);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.48)),
    rgba(255, 255, 255, 0.52);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(24px) saturate(145%);
  -webkit-backdrop-filter: blur(24px) saturate(145%);
}

.glass-panel::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  border: 1px solid rgba(255, 255, 255, 0.5);
  pointer-events: none;
}

.glass-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  transform: translateX(-120%);
  background: linear-gradient(105deg, transparent 34%, rgba(255, 255, 255, 0.56), transparent 66%);
  transition: transform 700ms var(--ease-out);
}

.glass-panel:hover::after {
  transform: translateX(120%);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.95rem;
  color: var(--blue-2);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.eyebrow::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--aqua);
  box-shadow: 0 0 0 7px rgba(34, 211, 238, 0.16), 0 0 22px rgba(34, 211, 238, 0.8);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  padding: 0.7rem 0;
  transition: padding 220ms var(--ease-out), background-color 220ms var(--ease-out);
}

.header-inner {
  min-height: 70px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.58);
  box-shadow: 0 16px 48px rgba(7, 89, 133, 0.1);
  backdrop-filter: blur(26px) saturate(155%);
  -webkit-backdrop-filter: blur(26px) saturate(155%);
}

.site-header.is-scrolled {
  padding-top: 0.38rem;
  background: rgba(248, 252, 255, 0.58);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.brand-mark {
  position: relative;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 17px;
  background: linear-gradient(145deg, #ffffff, #caf5ff);
  box-shadow: inset 0 1px 0 #fff, 0 12px 26px rgba(14, 165, 233, 0.18);
}

.brand-mark::after {
  content: "";
  position: absolute;
  inset: -4px;
  z-index: -1;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(34, 211, 238, 0.7), rgba(14, 165, 233, 0.08));
  opacity: 0.75;
}

.brand-mark img {
  width: 31px;
  height: 31px;
}

.brand-copy {
  display: grid;
  gap: 0.08rem;
}

.brand-copy strong,
.footer-brand {
  color: var(--navy);
  font-size: 1rem;
  font-weight: 850;
  line-height: 1.12;
}

.brand-copy small {
  color: var(--muted);
  font-size: 0.73rem;
}

.site-nav {
  justify-self: center;
  display: flex;
  align-items: center;
  gap: 0.18rem;
  padding: 0.28rem;
  border-radius: var(--radius-pill);
  background: rgba(232, 247, 255, 0.62);
}

.site-nav a {
  position: relative;
  padding: 0.58rem 0.8rem;
  border-radius: var(--radius-pill);
  color: #24495f;
  font-size: 0.86rem;
  font-weight: 760;
  white-space: nowrap;
  transition: color 180ms var(--ease-out), background-color 180ms var(--ease-out);
}

.site-nav a::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0.28rem;
  width: 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--aqua), transparent);
  transform: translateX(-50%);
  transition: width 240ms var(--ease-out);
}

.site-nav a:hover {
  color: var(--blue-2);
  background: rgba(255, 255, 255, 0.62);
}

.site-nav a:hover::after {
  width: 52%;
}

.header-cta {
  min-height: 44px;
  padding: 0.76rem 1.04rem;
  border-radius: var(--radius-pill);
  color: #fff;
  background: linear-gradient(135deg, var(--blue-2), var(--aqua));
  box-shadow: 0 16px 34px rgba(14, 165, 233, 0.26);
  font-weight: 820;
}

.menu-toggle {
  display: none;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255, 255, 255, 0.86);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--navy);
  cursor: pointer;
}

.menu-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 4px auto;
  border-radius: 999px;
  background: currentColor;
  transition: transform 180ms var(--ease-out);
}

.menu-toggle[aria-expanded="true"] span:first-child {
  transform: translateY(3px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"] span:last-child {
  transform: translateY(-3px) rotate(-45deg);
}

.hero {
  position: relative;
  min-height: 100dvh;
  display: grid;
  align-items: center;
  padding: clamp(2rem, 4vw, 4rem) 0 clamp(4rem, 7vw, 6rem);
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
}

.aura,
.mist,
.droplet {
  position: absolute;
  display: block;
  pointer-events: none;
}

.aura {
  border-radius: 50%;
  filter: blur(12px);
  animation: aura-drift 10s var(--ease-in-out) infinite alternate;
}

.aura-one {
  width: 42rem;
  height: 42rem;
  right: -10rem;
  top: 7rem;
  background: radial-gradient(circle, rgba(103, 232, 249, 0.44), rgba(186, 230, 253, 0.12) 48%, transparent 70%);
}

.aura-two {
  width: 35rem;
  height: 35rem;
  left: -12rem;
  top: 18rem;
  background: radial-gradient(circle, rgba(14, 165, 233, 0.18), transparent 66%);
  animation-delay: -4s;
}

.aura-three {
  width: 24rem;
  height: 24rem;
  left: 42%;
  bottom: -8rem;
  background: radial-gradient(circle, rgba(34, 211, 238, 0.18), transparent 70%);
  animation-delay: -2s;
}

.mist {
  height: 1px;
  width: 34rem;
  opacity: 0.42;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.95), transparent);
  transform: rotate(-10deg);
  animation: mist-drift 11s linear infinite;
}

.mist-one {
  top: 20%;
  left: -22rem;
}

.mist-two {
  top: 62%;
  left: -28rem;
  animation-delay: -5s;
}

.droplet {
  width: 13px;
  height: 18px;
  border-radius: 60% 60% 70% 70%;
  background:
    radial-gradient(circle at 36% 28%, rgba(255, 255, 255, 0.98), transparent 22%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(103, 232, 249, 0.44));
  box-shadow: 0 12px 26px rgba(14, 165, 233, 0.22);
  animation: droplet-float 7s var(--ease-in-out) infinite alternate;
}

.droplet-one {
  top: 18%;
  left: 45%;
}

.droplet-two {
  top: 34%;
  right: 11%;
  width: 18px;
  height: 24px;
  animation-delay: -2s;
}

.droplet-three {
  bottom: 20%;
  left: 8%;
  width: 11px;
  height: 16px;
  animation-delay: -4s;
}

.droplet-four {
  bottom: 13%;
  right: 34%;
  width: 10px;
  height: 14px;
  animation-delay: -1s;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(360px, 0.98fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: center;
}

.hero-copy {
  padding-top: 2rem;
}

.hero-title {
  display: grid;
  gap: 0.04em;
}

.hero-title > span:first-child {
  display: block;
}

.water-typewriter {
  --caret-left: 0px;
  --caret-top: 0.16em;
  position: relative;
  display: block;
  width: min(10.9em, 100%);
  min-height: var(--typewriter-height, 1.08em);
  overflow: visible;
  color: var(--blue-2);
}

.water-typewriter::before,
.water-typewriter::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.water-typewriter::before {
  left: 0;
  right: 0;
  bottom: 0.04em;
  height: 0.08em;
  border-radius: 999px;
  opacity: 0.5;
  background: linear-gradient(90deg, transparent, rgba(34, 211, 238, 0.7), transparent);
  filter: blur(0.04em);
}

.water-typewriter::after {
  inset: -0.08em -0.1em -0.02em;
  opacity: 0;
  background: linear-gradient(105deg, transparent 24%, rgba(255, 255, 255, 0.78) 46%, rgba(103, 232, 249, 0.82) 52%, transparent 72%);
  transform: translateX(-115%);
  mix-blend-mode: screen;
}

.water-typewriter.is-sweeping::after {
  animation: typewriter-sweep 980ms var(--ease-out) forwards;
}

.water-typewriter-text,
.water-typewriter-measure {
  display: block;
  width: 100%;
}

.water-typewriter-text {
  position: relative;
  z-index: 1;
}

.water-typewriter-measure {
  position: absolute;
  inset: 0 auto auto 0;
  visibility: hidden;
  pointer-events: none;
}

.tw-char {
  display: inline-block;
  opacity: 0;
  color: transparent;
  background: linear-gradient(105deg, var(--blue-2), var(--aqua), #7dd3fc, var(--blue-2));
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  filter: blur(0.32em);
  transform: translate3d(0, 0.18em, 0) scale(0.98);
  transition:
    opacity 420ms var(--ease-out),
    filter 520ms var(--ease-out),
    transform 520ms var(--ease-out),
    background-position 920ms var(--ease-out);
  transition-delay: calc(var(--char-index, 0) * 10ms);
}

.tw-word {
  display: inline-block;
  white-space: nowrap;
}

.tw-char.is-visible {
  opacity: 1;
  background-position: -80% 0;
  filter: blur(0);
  transform: translate3d(0, 0, 0) scale(1);
}

.tw-space {
  width: 0.28em;
}

.water-typewriter.is-dissolving .tw-char.is-visible {
  opacity: 0;
  filter: blur(0.28em);
  transform: translate3d(0, -0.12em, 0) scale(0.99);
  transition-delay: calc(var(--char-reverse, 0) * 15ms);
}

.water-caret {
  position: absolute;
  left: var(--caret-left);
  top: var(--caret-top);
  z-index: 2;
  width: 0.14em;
  height: 0.82em;
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 16%, #fff, transparent 30%),
    linear-gradient(180deg, var(--aqua-2), var(--blue));
  box-shadow: 0 0 22px rgba(34, 211, 238, 0.82), 0 0 3px rgba(255, 255, 255, 0.9);
  transform: translateX(0.12em);
  transition: left 180ms var(--ease-out), top 180ms var(--ease-out), opacity 180ms var(--ease-out);
}

.water-caret::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -0.18em;
  width: 0.18em;
  height: 0.24em;
  border-radius: 60% 60% 70% 70%;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.9), var(--aqua));
  transform: translateX(-50%) rotate(6deg);
  box-shadow: 0 8px 18px rgba(14, 165, 233, 0.24);
}

.water-typewriter.is-paused .water-caret {
  opacity: 0.72;
}

.shine-word {
  position: relative;
  display: inline-block;
  color: transparent;
  background: linear-gradient(100deg, var(--blue-2), var(--aqua), #7dd3fc, var(--blue-2));
  background-size: 240% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  animation: text-shimmer 4.6s linear infinite;
}

.hero-lead {
  max-width: 42rem;
  margin-bottom: 0.85rem;
  color: #254a60;
  font-size: 1.32rem;
  line-height: 1.45;
}

.hero-text {
  max-width: 43rem;
  margin-bottom: 1.8rem;
  font-size: 1rem;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.8rem;
  margin-bottom: 1.65rem;
}

.local-trust-line {
  margin: -0.5rem 0 1.1rem;
  color: var(--blue-2);
  font-size: 0.92rem;
  font-weight: 820;
}

.button {
  position: relative;
  min-height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.48rem;
  overflow: hidden;
  padding: 0.9rem 1.18rem;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  cursor: pointer;
  font-weight: 830;
  line-height: 1.1;
  isolation: isolate;
  transition: transform 170ms var(--ease-out), box-shadow 220ms var(--ease-out), border-color 220ms var(--ease-out), background-color 220ms var(--ease-out);
}

.button-primary {
  color: #fff;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.5), transparent 34%),
    linear-gradient(135deg, var(--blue-2), var(--blue) 48%, var(--aqua));
  box-shadow: 0 20px 42px rgba(14, 165, 233, 0.3);
}

.button-ghost {
  color: var(--navy);
  border-color: rgba(14, 165, 233, 0.2);
  background: rgba(255, 255, 255, 0.66);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.button-link {
  min-height: auto;
  padding: 0.5rem 0;
  color: var(--blue-2);
  background: transparent;
}

.button-mini {
  min-height: 42px;
  padding: 0.72rem 0.92rem;
  font-size: 0.86rem;
}

.button-on-dark {
  color: var(--navy);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.86), transparent 34%),
    linear-gradient(135deg, #ffffff, var(--aqua-2));
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}

.button-dark-ghost {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.26);
  background: rgba(255, 255, 255, 0.12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.liquid-button::before {
  content: "";
  position: absolute;
  inset: -2px;
  z-index: -1;
  opacity: 0;
  background: radial-gradient(circle at var(--ripple-x, 50%) var(--ripple-y, 50%), rgba(255, 255, 255, 0.72), transparent 34%);
  transform: scale(0.75);
  transition: opacity 220ms var(--ease-out), transform 420ms var(--ease-out);
}

.liquid-button:hover::before,
.liquid-button:focus-visible::before {
  opacity: 1;
  transform: scale(1);
}

.button:hover,
.header-cta:hover {
  transform: translateY(-2px);
}

.button:active,
.header-cta:active,
.contact-card:active {
  transform: scale(0.98);
}

.ripple {
  position: absolute;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  pointer-events: none;
  background: rgba(255, 255, 255, 0.55);
  transform: translate(-50%, -50%) scale(1);
  animation: button-ripple 620ms var(--ease-out) forwards;
}

.proof-strip {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.72rem;
  max-width: 49rem;
  margin: 0;
  padding: 0;
}

.proof-strip li {
  min-height: 104px;
  padding: 0.95rem;
  border: 1px solid rgba(255, 255, 255, 0.76);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.62);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82), 0 14px 34px rgba(7, 89, 133, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.proof-strip strong,
.proof-strip span {
  display: block;
}

.proof-strip strong {
  margin-bottom: 0.28rem;
  color: var(--navy);
  font-size: 0.94rem;
}

.proof-strip span {
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.35;
}

.hero-stage {
  position: relative;
  perspective: 1200px;
}

.signature-card {
  min-height: 610px;
  padding: 1.1rem;
  border-radius: 38px;
  box-shadow: var(--shadow-blue);
  transform: rotateY(-4deg) rotateX(2deg);
}

.signature-card::before {
  border-radius: 36px;
}

.card-toolbar {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 740;
}

.brand-reveal {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  min-height: 228px;
  margin: 2rem 0 1.1rem;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.98), transparent 26%),
    linear-gradient(125deg, rgba(255, 255, 255, 0.78), rgba(186, 230, 253, 0.42)),
    #e8f8ff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.98), inset 0 -12px 50px rgba(14, 165, 233, 0.08);
}

.brand-reveal::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.45;
  background-image:
    linear-gradient(90deg, rgba(8, 89, 134, 0.12) 1px, transparent 1px),
    linear-gradient(rgba(8, 89, 134, 0.12) 1px, transparent 1px);
  background-size: 42px 42px;
}

.brand-clean,
.brand-grime {
  grid-area: 1 / 1;
  max-width: 86%;
  overflow-wrap: anywhere;
  text-align: center;
  font-size: 2.8rem;
  font-weight: 900;
  line-height: 1.02;
  letter-spacing: 0;
}

.brand-clean {
  color: var(--navy);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.9), 0 16px 42px rgba(14, 165, 233, 0.18);
}

.brand-grime {
  color: rgba(62, 56, 42, 0.82);
  background:
    radial-gradient(circle at 8% 38%, rgba(64, 55, 38, 0.7) 0 4px, transparent 5px),
    radial-gradient(circle at 78% 25%, rgba(74, 63, 44, 0.55) 0 6px, transparent 7px),
    radial-gradient(circle at 48% 72%, rgba(61, 54, 39, 0.42) 0 5px, transparent 6px),
    linear-gradient(95deg, #70674f, #a09373 42%, #5d513e);
  -webkit-background-clip: text;
  background-clip: text;
  text-shadow: 0 2px 1px rgba(44, 39, 28, 0.16);
  clip-path: inset(0 0 0 0);
}

.page-ready .brand-grime {
  animation: dirt-wipe 2200ms var(--ease-in-out) 320ms forwards;
}

.spray-stream,
.pressure-line,
.nozzle,
.brand-shine {
  position: absolute;
  pointer-events: none;
}

.spray-stream {
  width: 210px;
  height: 86px;
  left: -34%;
  top: 47%;
  border-radius: 999px;
  opacity: 0;
  background:
    radial-gradient(ellipse at left, rgba(255, 255, 255, 0.98), rgba(103, 232, 249, 0.58) 46%, transparent 73%);
  filter: blur(0.6px);
  transform: translate3d(0, -50%, 0) rotate(-9deg);
}

.pressure-line {
  left: -10%;
  top: 10%;
  width: 5px;
  height: 80%;
  border-radius: 999px;
  opacity: 0;
  background: linear-gradient(180deg, transparent, #fff, rgba(34, 211, 238, 0.8), transparent);
  box-shadow: 0 0 28px rgba(34, 211, 238, 0.72);
}

.nozzle {
  left: -32%;
  top: 33%;
  width: 124px;
  height: 12px;
  border-radius: 999px;
  opacity: 0;
  background: linear-gradient(90deg, var(--navy), #3b6d83);
  transform: rotate(-13deg);
  box-shadow: 0 14px 28px rgba(6, 40, 61, 0.18);
}

.brand-shine {
  inset: 0;
  opacity: 0;
  transform: translateX(-125%);
  background: linear-gradient(105deg, transparent 42%, rgba(255, 255, 255, 0.9), transparent 58%);
}

.page-ready .spray-stream,
.page-ready .pressure-line,
.page-ready .nozzle {
  animation: washer-pass 2200ms var(--ease-in-out) 240ms forwards;
}

.page-ready .brand-shine {
  animation: shine-pass 1180ms var(--ease-out) 2050ms forwards;
}

.hero-comparison,
.showcase-comparison {
  position: relative;
  z-index: 1;
  height: 250px;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.74);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
  isolation: isolate;
}

.comparison-side {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}

.before-surface {
  filter: saturate(0.78) brightness(0.66);
}

.before-surface::after,
.after-surface::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.before-surface::after {
  background: linear-gradient(180deg, rgba(56, 48, 36, 0.16), rgba(35, 31, 26, 0.38));
}

.after-surface {
  clip-path: inset(0 0 0 var(--split));
  filter: saturate(1.12) brightness(1.12);
}

.after-surface::after {
  background: linear-gradient(120deg, rgba(255, 255, 255, 0.38), transparent 58%);
}

.surface-driveway {
  background-image: url("assets/surface-driveway.svg");
}

.surface-patio {
  background-image: url("assets/surface-patio.svg");
}

.surface-path {
  background-image: url("assets/surface-path.svg");
}

.comparison-side span {
  position: absolute;
  top: 0.9rem;
  z-index: 2;
  padding: 0.38rem 0.62rem;
  border-radius: var(--radius-pill);
  font-size: 0.74rem;
  font-weight: 850;
}

.before-surface span {
  left: 0.9rem;
  color: #fff;
  background: rgba(17, 25, 31, 0.58);
}

.after-surface span {
  right: 0.9rem;
  color: var(--blue-2);
  background: rgba(255, 255, 255, 0.9);
}

.hero-comparison::after,
.showcase-comparison::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--split);
  z-index: 4;
  width: 2px;
  background: #fff;
  box-shadow: 0 0 0 1px rgba(6, 40, 61, 0.1), 0 0 32px rgba(34, 211, 238, 0.72);
  pointer-events: none;
}

.comparison-handle {
  position: absolute;
  left: var(--split);
  top: 50%;
  z-index: 6;
  width: 48px;
  height: 48px;
  display: grid;
  grid-template-columns: repeat(2, auto);
  place-items: center;
  gap: 2px;
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 24%, rgba(255, 255, 255, 0.96), transparent 30%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.78), rgba(103, 232, 249, 0.58));
  box-shadow: 0 16px 36px rgba(6, 40, 61, 0.16), 0 0 28px rgba(34, 211, 238, 0.56);
  transform: translate(-50%, -50%);
  pointer-events: none;
  transition: transform 180ms var(--ease-out), box-shadow 180ms var(--ease-out);
}

.comparison-handle::before,
.comparison-handle::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid var(--blue-2);
  border-left: 2px solid var(--blue-2);
}

.comparison-handle::before {
  transform: translateX(3px) rotate(-45deg);
}

.comparison-handle::after {
  transform: translateX(-3px) rotate(135deg);
}

.drag-hint {
  position: absolute;
  left: 50%;
  bottom: 3.05rem;
  z-index: 5;
  padding: 0.42rem 0.64rem;
  border-radius: var(--radius-pill);
  color: var(--navy);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 12px 28px rgba(6, 40, 61, 0.12);
  font-size: 0.74rem;
  font-weight: 850;
  transform: translateX(-50%);
  pointer-events: none;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

[data-comparison].is-dragging .comparison-handle {
  box-shadow: 0 18px 42px rgba(6, 40, 61, 0.18), 0 0 40px rgba(34, 211, 238, 0.78);
  transform: translate(-50%, -50%) scale(1.08);
}

.comparison-range {
  position: absolute;
  inset: auto 1rem 1rem;
  z-index: 7;
  width: calc(100% - 2rem);
  accent-color: var(--aqua);
}

.quote-orbit {
  position: absolute;
  z-index: 4;
  right: 1.1rem;
  bottom: 1.1rem;
  width: min(282px, calc(100% - 2.2rem));
  padding: 1rem;
  border-radius: 22px;
  animation: card-float 4.2s var(--ease-in-out) infinite alternate;
}

.quote-orbit span,
.quote-orbit strong,
.quote-orbit small {
  display: block;
}

.quote-orbit span,
.quote-orbit small {
  color: var(--muted);
  font-size: 0.78rem;
}

.quote-orbit strong {
  margin: 0.16rem 0;
  color: var(--navy);
  font-size: 1.04rem;
}

.section-heading {
  max-width: 770px;
  margin-bottom: 2.2rem;
}

.section-heading p:not(.eyebrow),
.why-statement p,
.promise-panel p,
.final-cta p {
  color: var(--muted);
  font-size: 1.04rem;
}

.center-heading {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.center-heading .eyebrow {
  justify-content: center;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: minmax(225px, auto);
  gap: 1rem;
}

.service-card {
  min-height: 225px;
  padding: 1.25rem;
  border-radius: var(--radius-lg);
  transition: transform 260ms var(--ease-out), border-color 260ms var(--ease-out), box-shadow 260ms var(--ease-out);
  transform: perspective(900px) rotateX(var(--tilt-y, 0deg)) rotateY(var(--tilt-x, 0deg));
}

.service-icon {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  opacity: 0.78;
  background:
    radial-gradient(circle at 36% 28%, rgba(255, 255, 255, 0.96), transparent 23%),
    linear-gradient(145deg, rgba(103, 232, 249, 0.86), rgba(14, 165, 233, 0.26));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.76), 0 14px 28px rgba(14, 165, 233, 0.14);
}

.service-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -9px;
  width: 17px;
  height: 24px;
  border-radius: 60% 60% 72% 72%;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.8), rgba(103, 232, 249, 0.5));
  transform: translateX(-50%) rotate(4deg);
}

.service-card:hover,
.why-card:hover {
  border-color: rgba(34, 211, 238, 0.58);
  box-shadow: 0 24px 72px rgba(14, 165, 233, 0.17);
}

.service-card p {
  margin-bottom: 0;
}

.service-index {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: 1rem;
  border-radius: 15px;
  color: var(--blue-2);
  background: linear-gradient(145deg, #ffffff, var(--sky-2));
  box-shadow: inset 0 1px 0 #fff;
  font-size: 0.78rem;
  font-weight: 900;
}

.service-card-feature {
  grid-column: span 2;
  grid-row: span 2;
  min-height: 466px;
  color: #fff;
  background:
    radial-gradient(circle at 82% 16%, rgba(34, 211, 238, 0.36), transparent 34%),
    linear-gradient(145deg, rgba(6, 40, 61, 0.95), rgba(7, 89, 133, 0.88));
  border-color: rgba(255, 255, 255, 0.24);
}

.service-card-feature h3,
.service-card-feature p,
.service-card-feature .service-index {
  color: #fff;
}

.service-card-feature h3 {
  max-width: 10em;
  font-size: 2rem;
}

.service-card-feature p {
  max-width: 24rem;
  color: rgba(255, 255, 255, 0.76);
}

.service-card-feature .service-index {
  background: rgba(255, 255, 255, 0.16);
}

.service-card-feature .service-icon {
  opacity: 0.9;
  background:
    radial-gradient(circle at 36% 28%, rgba(255, 255, 255, 0.98), transparent 23%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.36), rgba(103, 232, 249, 0.3));
}

.service-visual {
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  bottom: 1.25rem;
  height: 170px;
  overflow: hidden;
  border-radius: 22px;
  opacity: 0.86;
}

.service-visual::after {
  content: "";
  position: absolute;
  inset: 0 0 0 43%;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.68));
}

.service-card-aqua {
  background:
    radial-gradient(circle at 80% 0%, rgba(34, 211, 238, 0.25), transparent 42%),
    rgba(255, 255, 255, 0.66);
}

.transformation {
  background:
    linear-gradient(180deg, transparent, rgba(186, 230, 253, 0.2) 20%, transparent),
    radial-gradient(circle at 15% 75%, rgba(34, 211, 238, 0.14), transparent 26rem);
}

.transformation-grid,
.why-grid,
.areas-grid,
.faq-grid,
.contact-grid {
  display: grid;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: start;
}

.transformation-grid {
  grid-template-columns: 0.86fr 1.14fr;
}

.showcase-card {
  position: relative;
  border-radius: var(--radius-xl);
  padding: 1rem;
}

.preview-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 8;
  padding: 0.44rem 0.68rem;
  border-radius: var(--radius-pill);
  color: var(--blue-2);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 12px 30px rgba(6, 40, 61, 0.12);
  font-size: 0.76rem;
  font-weight: 850;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.showcase-comparison {
  height: clamp(310px, 44vw, 520px);
  border-radius: 28px;
}

.showcase-footer {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1rem 0.3rem 0;
}

.showcase-footer strong,
.showcase-footer span {
  display: block;
}

.showcase-footer span {
  color: var(--muted);
  font-size: 0.9rem;
}

.process-flow {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.process-flow::before {
  content: "";
  position: absolute;
  left: 4%;
  right: 4%;
  top: 51px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--aqua), var(--blue), transparent);
  box-shadow: 0 0 28px rgba(34, 211, 238, 0.5);
}

.process-flow::after {
  content: "";
  position: absolute;
  left: 4%;
  top: 49px;
  z-index: 0;
  width: 88px;
  height: 8px;
  border-radius: 999px;
  opacity: 0.72;
  background: radial-gradient(circle, #fff, rgba(103, 232, 249, 0.84) 44%, transparent 72%);
  filter: blur(1px);
  animation: process-pulse 5.4s var(--ease-in-out) infinite;
}

.process-step {
  z-index: 1;
  min-height: 250px;
  padding: 1.1rem;
  border-radius: var(--radius-lg);
}

.process-step span {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  margin-bottom: 1rem;
  border-radius: 18px;
  color: #fff;
  background:
    radial-gradient(circle at 25% 18%, rgba(255, 255, 255, 0.55), transparent 26%),
    linear-gradient(145deg, var(--blue-2), var(--aqua));
  box-shadow: 0 16px 34px rgba(14, 165, 233, 0.24);
  font-size: 0.85rem;
  font-weight: 900;
}

.process-step p {
  margin-bottom: 0;
}

.why-grid {
  grid-template-columns: 0.86fr 1.14fr;
}

.why-statement {
  position: sticky;
  top: 108px;
  padding: 1.6rem;
  border-radius: var(--radius-xl);
}

.why-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.why-card {
  min-height: 205px;
  padding: 1.25rem;
  border-radius: var(--radius-lg);
  transition: transform 260ms var(--ease-out), box-shadow 260ms var(--ease-out), border-color 260ms var(--ease-out);
}

.why-card:nth-child(2),
.why-card:nth-child(3) {
  transform: translateY(1.2rem);
}

.why-card p {
  margin-bottom: 0;
}

.promise-panel {
  display: grid;
  grid-template-columns: 1fr 0.8fr;
  gap: 2rem;
  align-items: end;
  overflow: hidden;
  min-height: 360px;
  padding: clamp(1.4rem, 4vw, 3rem);
  border-radius: 40px;
  color: #fff;
  background:
    radial-gradient(circle at 86% 24%, rgba(255, 255, 255, 0.28), transparent 26%),
    radial-gradient(circle at 20% 86%, rgba(34, 211, 238, 0.34), transparent 34%),
    linear-gradient(135deg, #06283d, #075985 56%, #0ea5e9);
  box-shadow: 0 32px 90px rgba(6, 40, 61, 0.24);
}

.promise-panel::before {
  content: "";
  position: absolute;
  inset: auto -10% -38% -10%;
  height: 56%;
  border-radius: 50% 50% 0 0;
  background: rgba(255, 255, 255, 0.1);
  animation: wave-rise 6s var(--ease-in-out) infinite alternate;
}

.promise-panel h2,
.promise-panel p,
.promise-panel .eyebrow {
  position: relative;
  z-index: 1;
  color: #fff;
}

.promise-copy {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: start;
  gap: 1rem;
}

.promise-panel p {
  max-width: 38rem;
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.78);
}

.reviews {
  background: linear-gradient(180deg, transparent, rgba(255, 255, 255, 0.55), transparent);
}

.review-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.review-card {
  min-height: 220px;
  padding: 1.25rem;
  border-radius: var(--radius-lg);
}

.review-card span {
  display: inline-flex;
  margin-bottom: 0.78rem;
  padding: 0.38rem 0.58rem;
  border-radius: var(--radius-pill);
  color: var(--blue-2);
  background: rgba(186, 230, 253, 0.54);
  font-size: 0.75rem;
  font-weight: 800;
}

.review-card p {
  margin-bottom: 0.78rem;
}

.review-card small {
  display: block;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 760;
}

.star-row {
  display: flex;
  gap: 0.22rem;
  margin-bottom: 1.4rem;
}

.star-row i {
  width: 17px;
  height: 17px;
  display: block;
  background: linear-gradient(145deg, #fef3c7, #22d3ee);
  clip-path: polygon(50% 0, 61% 34%, 98% 34%, 68% 55%, 79% 91%, 50% 69%, 21% 91%, 32% 55%, 2% 34%, 39% 34%);
  opacity: 0.82;
}

.areas-grid {
  grid-template-columns: 0.8fr 1.2fr;
  align-items: center;
}

.map-card {
  position: relative;
  min-height: 430px;
  border-radius: 40px;
  background:
    radial-gradient(circle at 42% 44%, rgba(34, 211, 238, 0.24), transparent 16%),
    radial-gradient(circle at 65% 34%, rgba(14, 165, 233, 0.16), transparent 22%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.74), rgba(224, 242, 254, 0.42));
}

.map-card::before {
  content: "";
  position: absolute;
  inset: 1.3rem;
  border-radius: 32px;
  background-image:
    linear-gradient(rgba(8, 89, 134, 0.11) 1px, transparent 1px),
    linear-gradient(90deg, rgba(8, 89, 134, 0.11) 1px, transparent 1px);
  background-size: 52px 52px;
}

.map-rings {
  position: absolute;
  left: 52%;
  top: 50%;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background:
    radial-gradient(circle, transparent 28%, rgba(34, 211, 238, 0.22) 29% 30%, transparent 31% 52%, rgba(34, 211, 238, 0.16) 53% 54%, transparent 55%);
  animation: rings-pulse 3.6s ease-out infinite;
}

.map-pin {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  padding: 0.7rem 0.86rem;
  border-radius: var(--radius-pill);
  color: var(--navy);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 40px rgba(7, 89, 133, 0.16);
  font-weight: 850;
}

.map-pin::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--aqua);
  box-shadow: 0 0 0 7px rgba(34, 211, 238, 0.18);
}

.pin-one {
  left: 18%;
  top: 35%;
}

.pin-two {
  right: 18%;
  top: 28%;
}

.pin-three {
  left: 47%;
  bottom: 24%;
}

.faq-grid {
  grid-template-columns: 0.8fr 1.2fr;
}

.faq-list {
  display: grid;
  gap: 0.8rem;
}

.faq-item {
  border-radius: var(--radius-lg);
}

.faq-item button {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 1.2rem;
  border: 0;
  background: transparent;
  color: var(--navy);
  cursor: pointer;
  font-weight: 850;
  text-align: left;
}

.faq-item button::after {
  content: "+";
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 12px;
  color: var(--blue-2);
  background: rgba(186, 230, 253, 0.52);
  transition: transform 180ms var(--ease-out);
}

.faq-item button[aria-expanded="true"]::after {
  transform: rotate(45deg);
}

.faq-answer {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: 0fr;
  padding: 0 1.2rem;
  transition: grid-template-rows 260ms var(--ease-out), padding-bottom 260ms var(--ease-out);
}

.faq-item.is-open .faq-answer {
  grid-template-rows: 1fr;
  padding-bottom: 1.1rem;
}

.faq-answer p {
  overflow: hidden;
  margin: 0;
}

.contact {
  padding-bottom: clamp(5rem, 9vw, 8rem);
}

.contact-grid {
  grid-template-columns: 0.95fr 1.05fr;
}

.final-cta,
.quote-form {
  border-radius: 38px;
  padding: clamp(1.2rem, 3vw, 2rem);
}

.final-cta {
  min-height: 100%;
  color: #fff;
  background:
    radial-gradient(circle at 78% 10%, rgba(34, 211, 238, 0.34), transparent 32%),
    linear-gradient(145deg, rgba(6, 40, 61, 0.94), rgba(7, 89, 133, 0.86));
}

.final-cta h2,
.final-cta p,
.final-cta .eyebrow {
  color: #fff;
}

.final-cta p {
  color: rgba(255, 255, 255, 0.76);
}

.final-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
  margin: 1.35rem 0 1.55rem;
}

.contact-cards {
  display: grid;
  gap: 0.76rem;
  margin-top: 1.5rem;
}

.contact-card {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.18rem;
  padding: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.1);
  transition: transform 170ms var(--ease-out), background-color 180ms var(--ease-out);
}

.contact-card:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.16);
}

.contact-card span {
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.82rem;
}

.contact-card strong {
  color: #fff;
  overflow-wrap: anywhere;
}

.quote-form {
  display: grid;
  gap: 1rem;
}

.form-row {
  display: grid;
  gap: 0.42rem;
}

.form-row label {
  color: #214559;
  font-weight: 830;
}

.form-row input,
.form-row select,
.form-row textarea {
  width: 100%;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(8, 89, 134, 0.2);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink);
  transition: border-color 180ms var(--ease-out), box-shadow 180ms var(--ease-out), background-color 180ms var(--ease-out);
}

.form-row input::placeholder,
.form-row textarea::placeholder {
  color: #7f98a8;
}

.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus {
  border-color: rgba(34, 211, 238, 0.78);
  background: #fff;
  box-shadow: 0 0 0 5px rgba(34, 211, 238, 0.14);
}

.form-row textarea {
  min-height: 136px;
  resize: vertical;
}

.form-submit {
  width: 100%;
}

.form-status {
  min-height: 1.5rem;
  margin: 0;
  color: var(--blue-2);
  font-weight: 800;
}

.site-footer {
  padding: 3.4rem 0 1.5rem;
  color: rgba(255, 255, 255, 0.78);
  background:
    radial-gradient(circle at 80% 0%, rgba(34, 211, 238, 0.18), transparent 30%),
    linear-gradient(180deg, var(--navy-2), var(--navy));
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.3fr 0.8fr 0.9fr 0.9fr;
  gap: 2rem;
}

.footer-brand {
  display: inline-block;
  margin-bottom: 0.72rem;
  color: #fff;
}

.site-footer h2 {
  margin-bottom: 0.7rem;
  color: #fff;
  font-size: 0.98rem;
}

.site-footer p {
  margin-bottom: 0.45rem;
  color: rgba(255, 255, 255, 0.72);
}

.site-footer a {
  color: rgba(255, 255, 255, 0.82);
}

.site-footer a:hover {
  color: #fff;
}

.site-footer nav {
  display: grid;
  gap: 0.32rem;
}

.footer-bottom {
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.footer-bottom p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.9rem;
}

[data-reveal] {
  opacity: 0;
  filter: blur(16px);
  transform: translateY(24px) scale(0.985);
  transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out), filter 700ms var(--ease-out);
  transition-delay: var(--delay, 0ms);
}

[data-reveal].is-visible {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0) scale(1);
}

@keyframes text-shimmer {
  to {
    background-position: -240% 0;
  }
}

@keyframes typewriter-sweep {
  0% {
    opacity: 0;
    transform: translateX(-115%);
  }
  18% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translateX(115%);
  }
}

@keyframes aura-drift {
  from {
    transform: translate3d(0, 0, 0) scale(1);
  }
  to {
    transform: translate3d(-2rem, 1.5rem, 0) scale(1.08);
  }
}

@keyframes mist-drift {
  from {
    transform: translateX(0) rotate(-10deg);
  }
  to {
    transform: translateX(150vw) rotate(-10deg);
  }
}

@keyframes droplet-float {
  from {
    transform: translate3d(0, 0, 0) rotate(-8deg);
  }
  to {
    transform: translate3d(1rem, -1.6rem, 0) rotate(8deg);
  }
}

@keyframes dirt-wipe {
  0% {
    clip-path: inset(0 0 0 0);
  }
  55% {
    clip-path: inset(0 0 0 42%);
  }
  100% {
    clip-path: inset(0 0 0 108%);
  }
}

@keyframes washer-pass {
  0% {
    opacity: 0;
    transform: translate3d(0, -50%, 0) rotate(-9deg);
  }
  13% {
    opacity: 1;
  }
  84% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translate3d(620px, -50%, 0) rotate(-9deg);
  }
}

@keyframes shine-pass {
  0% {
    opacity: 0;
    transform: translateX(-125%);
  }
  24% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translateX(125%);
  }
}

@keyframes button-ripple {
  to {
    opacity: 0;
    transform: translate(-50%, -50%) scale(18);
  }
}

@keyframes card-float {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-8px);
  }
}

@keyframes wave-rise {
  from {
    transform: translateY(12px) rotate(-1deg);
  }
  to {
    transform: translateY(-12px) rotate(1deg);
  }
}

@keyframes rings-pulse {
  0% {
    opacity: 0.4;
    transform: translate(-50%, -50%) scale(0.92);
  }
  70% {
    opacity: 0.95;
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(1.18);
  }
}

@keyframes process-pulse {
  0% {
    left: 4%;
  }
  50% {
    left: calc(96% - 88px);
  }
  100% {
    left: 4%;
  }
}

@media (max-width: 1080px) {
  h1 {
    font-size: 5rem;
  }

  h2 {
    font-size: 3.25rem;
  }

  .site-nav {
    gap: 0;
  }

  .site-nav a {
    padding-inline: 0.65rem;
  }

  .hero-grid,
  .transformation-grid,
  .why-grid,
  .areas-grid,
  .faq-grid,
  .contact-grid {
    grid-template-columns: 1fr;
  }

  .why-statement {
    position: static;
  }

  .service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .process-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .process-flow::before,
  .process-flow::after {
    display: none;
  }

  .promise-panel {
    grid-template-columns: 1fr;
  }

  .review-grid,
  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 880px) {
  .header-inner {
    grid-template-columns: auto auto;
  }

  .menu-toggle {
    display: block;
    justify-self: end;
  }

  .site-nav {
    position: fixed;
    inset: 86px 1rem auto;
    display: grid;
    gap: 0.35rem;
    padding: 0.8rem;
    border: 1px solid rgba(255, 255, 255, 0.82);
    border-radius: 26px;
    background: rgba(248, 252, 255, 0.9);
    box-shadow: var(--shadow-blue);
    backdrop-filter: blur(26px) saturate(155%);
    -webkit-backdrop-filter: blur(26px) saturate(155%);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px) scale(0.98);
    transform-origin: top right;
    transition: opacity 190ms var(--ease-out), transform 190ms var(--ease-out), visibility 190ms var(--ease-out);
  }

  .site-nav.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
  }

  .site-nav a {
    padding: 0.92rem 1rem;
  }

  .header-cta {
    display: none;
  }

  .hero {
    min-height: auto;
    padding-top: 1.6rem;
  }

  .signature-card {
    transform: none;
  }
}

@media (max-width: 680px) {
  .container {
    width: min(100% - 1rem, var(--container));
  }

  .header-inner {
    border-radius: 24px;
  }

  .brand-copy small {
    display: none;
  }

  .section-shell {
    padding: 4.2rem 0;
  }

  h1 {
    font-size: 3.9rem;
    line-height: 0.96;
  }

  .water-typewriter {
    min-height: var(--typewriter-height, 1.95em);
  }

  h2 {
    font-size: 2.65rem;
  }

  .hero-actions,
  .final-actions,
  .showcase-footer {
    align-items: stretch;
    flex-direction: column;
  }

  .hero-actions .button,
  .final-actions .button,
  .showcase-footer .button {
    width: 100%;
  }

  .proof-strip,
  .service-grid,
  .process-flow,
  .why-cards,
  .review-grid,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .signature-card {
    min-height: auto;
    padding: 0.75rem;
    border-radius: 28px;
  }

  .brand-reveal {
    min-height: 190px;
    margin: 1.2rem 0 0.85rem;
  }

  .hero-comparison {
    height: 220px;
  }

  .comparison-handle {
    width: 42px;
    height: 42px;
  }

  .drag-hint {
    bottom: 2.9rem;
  }

  .quote-orbit {
    position: relative;
    right: auto;
    bottom: auto;
    width: 100%;
    margin-top: 0.85rem;
  }

  .service-card-feature {
    grid-column: span 1;
    grid-row: span 1;
    min-height: 390px;
  }

  .service-visual {
    height: 130px;
  }

  .showcase-comparison {
    height: 290px;
  }

  .why-card:nth-child(2),
  .why-card:nth-child(3) {
    transform: none;
  }

  .map-card {
    min-height: 360px;
  }

  .map-pin {
    font-size: 0.82rem;
  }

  .pin-one {
    left: 8%;
  }

  .pin-two {
    right: 8%;
  }

  .pin-three {
    left: 34%;
  }
}

@media (max-width: 420px) {
  h1 {
    font-size: 3.1rem;
  }

  h2 {
    font-size: 2.28rem;
  }

  .brand-copy strong {
    font-size: 0.88rem;
  }

  .brand-mark {
    width: 42px;
    height: 42px;
  }

  .card-toolbar {
    flex-direction: column;
    gap: 0.18rem;
  }
}

@media (hover: none) {
  .cursor-glow {
    display: none;
  }
}

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

  .brand-grime {
    clip-path: inset(0 0 0 108%);
  }

  .spray-stream,
  .pressure-line,
  .nozzle,
  .brand-shine,
  .mist,
  .droplet,
  .cursor-glow,
  .water-caret,
  .process-flow::after {
    display: none;
  }

  .water-typewriter::after {
    display: none;
  }

  .tw-char {
    opacity: 1;
    filter: none;
    transform: none;
  }

  [data-reveal] {
    opacity: 1;
    filter: none;
    transform: none;
  }
}
