/* ============================================================
   Down to Detail - shared marketing site stylesheet
   Brand tokens mirror the official brand kit (Cyan #5dc1b9,
   Coral #ff0076, Pink #fe599d) plus the PWA's complementary palette.
   ============================================================ */
:root{
  --bg:#fbfcfc;
  --ink:#0e1a1f;
  --ink-2:#1a2e2d;
  --muted:#5b7372;
  --line:#e8f0ef;
  --surface:#ffffff;
  --soft:#f4f9f8;

  /* Official brand colors */
  --teal:#5dc1b9;
  --teal-2:#3fa39a;
  --teal-soft:#e8f7f6;
  --teal-light:#b8f0ed;

  --coral:#ff0076;
  --coral-2:#ff5096;
  --coral-soft:#fff0f5;

  --pink:#fe599d;
  --pink-soft:#ffe5ef;

  --violet:#8b5cf6;
  --violet-2:#6d28d9;
  --violet-soft:#f5f3ff;

  --gold:#f59e0b;

  --r-sm:10px;
  --r:18px;
  --r-lg:28px;
  --r-xl:40px;

  --shadow-1: 0 1px 2px rgba(14,26,31,.04), 0 2px 6px rgba(14,26,31,.04);
  --shadow-2: 0 10px 30px rgba(14,26,31,.08), 0 2px 6px rgba(14,26,31,.04);
  --shadow-3: 0 30px 80px rgba(14,26,31,.18);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);scroll-behavior:smooth}
body{
  font-family:'Geist','SF Pro Display',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-feature-settings:'ss01','cv11';
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:opacity .2s ease, color .2s ease}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:rgba(93,193,185,.28);color:var(--ink)}
*:focus-visible{outline:2px solid rgba(93,193,185,.85);outline-offset:3px;border-radius:6px}

.serif{font-family:'Instrument Serif',Georgia,serif;font-weight:400;font-style:italic;letter-spacing:-.01em}

/* Container */
.wrap{max-width:1240px;margin:0 auto;padding:0 24px}
@media (min-width:768px){.wrap{padding:0 40px}}

/* ============================================================
   NAV with Services dropdown
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  padding:14px 0;
  transition:background .3s ease, box-shadow .3s ease, padding .25s ease;
}
.nav.scrolled,
.nav.solid{
  background:rgba(251,252,252,.78);
  backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  box-shadow:0 1px 0 rgba(14,26,31,.06);
  padding:10px 0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:18px}
@media (min-width:768px){.nav-inner{gap:24px}}

/* Brand - small star icon + clean wordmark text. The cyan square with white
   star inside from the brand kit, paired with "Down to Detail" set in Geist
   700. Small, professional, no overpowering. */
.brand{
  display:flex;align-items:center;gap:10px;flex-shrink:0;
  color:var(--ink);line-height:1.05;
  transition:opacity .18s ease, transform .12s ease;
}
.brand:hover{opacity:.82}
.brand:active{transform:scale(.97)}
.brand-icon{
  width:36px;height:36px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.brand-icon img{width:100%;height:100%;display:block;object-fit:contain}
.brand-text{display:flex;flex-direction:column;gap:2px}
/* Brand name uses Playfair Display italic - luxury serif feel.
   Pairs with the hand-drawn star icon for a "premium service business" wordmark. */
.brand-text strong{
  font-family:'Playfair Display','Instrument Serif',Georgia,serif;
  font-style:italic;font-weight:600;
  font-size:20px;letter-spacing:-.02em;
  white-space:nowrap;line-height:1;
}
.brand-text small{
  display:block;font-weight:500;font-size:9.5px;color:var(--muted);
  letter-spacing:.18em;text-transform:uppercase;line-height:1;
  margin-top:3px;
}
/* Scrolled state: trim down */
.nav.scrolled .brand-icon,
.nav.solid .brand-icon{width:32px;height:32px}
.nav.scrolled .brand-text strong,
.nav.solid .brand-text strong{font-size:18px}

/* On very small phones, hide tagline but keep wordmark */
@media (max-width:480px){
  .brand-text small{display:none}
}
@media (max-width:380px){
  .brand-text strong{font-size:17px}
}

/* Footer uses the pink-variant star on dark surface */
.brand-footer{display:inline-flex;align-items:center;gap:12px;color:#fff}
.brand-footer .brand-text strong{color:#fff;font-size:22px}
.brand-footer .brand-text small{color:#7a8e8c}
.brand-footer .brand-icon{width:42px;height:42px}

.nav-links{display:none;gap:4px;align-items:center}
@media (min-width:960px){.nav-links{display:flex}}
.nav-links > a,
.nav-links > .nav-item > button{
  padding:9px 14px;border-radius:10px;font-size:14.5px;font-weight:500;color:var(--ink-2);
  transition:background .2s, color .2s;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;
  background:transparent;border:none;font-family:inherit;
}
.nav-links > a:hover,
.nav-links > .nav-item > button:hover{background:var(--soft);color:var(--ink)}
.nav-links a.current,
.nav-links a[aria-current="page"]{color:var(--teal-2);background:var(--teal-soft)}

/* Dropdown - click-to-open (NOT hover) so it doesn't disappear when mouse moves into it */
.nav-item{position:relative}
.nav-item > button{position:relative;z-index:2}
.nav-item > button svg{width:13px;height:13px;transition:rotate .25s ease}
.nav-item[data-open="true"] > button{background:var(--ink);color:#fff}
.nav-item[data-open="true"] > button svg{rotate:180deg}
.dropdown{
  position:absolute;top:calc(100% + 10px);left:50%;translate:-50% 0;
  background:#fff;border:1px solid var(--line);border-radius:20px;
  padding:14px;min-width:600px;max-width:92vw;
  box-shadow:0 24px 60px rgba(14,26,31,.18), 0 2px 8px rgba(14,26,31,.06);
  opacity:0;pointer-events:none;transform-origin:top;transform:translateY(-8px) scale(.97);
  transition:opacity .2s cubic-bezier(.16,.84,.44,1), transform .25s cubic-bezier(.16,.84,.44,1);
  z-index:1;
}
.nav-item[data-open="true"] > .dropdown{
  opacity:1;pointer-events:auto;transform:translateY(0) scale(1);
}
.dropdown-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.dropdown a{
  display:flex;gap:14px;padding:12px 14px;border-radius:14px;align-items:flex-start;
  transition:background .15s;
}
.dropdown a:hover{background:var(--soft)}
.dropdown a:focus-visible{background:var(--teal-soft);outline:none}
.dropdown a[aria-current="page"]{background:var(--teal-soft)}
.dropdown a[aria-current="page"] .dd-meta strong{color:var(--teal-2)}
.dd-icon{
  flex-shrink:0;width:38px;height:38px;border-radius:11px;
  background:var(--teal-soft);color:var(--teal-2);
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(14,26,31,.04);
}
.dd-icon svg{width:19px;height:19px}
.dropdown a.dd-paint .dd-icon{background:var(--coral-soft);color:var(--coral)}
.dropdown a.dd-paver .dd-icon{background:var(--violet-soft);color:var(--violet-2)}
.dropdown a.dd-car .dd-icon{background:#fef3c7;color:#92400e}
.dropdown a.dd-commercial .dd-icon{background:var(--pink-soft);color:#9d174d}
.dropdown a.dd-construction .dd-icon{background:#dbeafe;color:#1e40af}
.dd-meta{display:flex;flex-direction:column;gap:3px;min-width:0}
.dd-meta strong{font-size:14.5px;font-weight:600;color:var(--ink);letter-spacing:-.005em;line-height:1.15}
.dd-meta span{font-size:12.5px;color:var(--muted);line-height:1.4}
.dropdown-foot{
  margin-top:6px;padding:14px 14px 4px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.dropdown-foot .all-services{
  font-size:13px;font-weight:600;color:var(--teal-2);display:inline-flex;align-items:center;gap:6px;
}
.dropdown-foot .all-services svg{width:14px;height:14px;transition:translate .2s}
.dropdown-foot .all-services:hover svg{translate:3px 0}
.dropdown-foot .ph{font-size:13px;color:var(--muted);font-weight:500}
.dropdown-foot .ph strong{color:var(--ink);font-weight:600}

/* Mobile dropdown - render inline below the trigger as full-width sheet */
@media (max-width:959px){
  .nav-item{position:static}
  .dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;
    width:100%;max-width:100%;min-width:0;translate:0;border-radius:24px 24px 0 0;
    padding:20px 16px calc(20px + env(safe-area-inset-bottom,0px));
    transform:translateY(20px);
  }
}

.nav-cta{display:flex;align-items:center;gap:8px}
@media (min-width:768px){.nav-cta{gap:10px}}

/* Call button - compact pill (icon + "Call") so the phone number never wraps in
   the nav. Full number is one tap away, no awkward 3-line break. */
.phone-link{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 14px;border-radius:50px;
  border:1px solid var(--line);background:#fff;
  font-weight:600;font-size:14px;color:var(--ink);
  line-height:1;white-space:nowrap;
  transition:background .15s, border-color .15s, color .15s, transform .12s;
}
.phone-link:hover{background:var(--teal-soft);border-color:var(--teal-2);color:var(--teal-2)}
.phone-link:active{transform:scale(.97)}
.phone-link svg{width:14px;height:14px;flex-shrink:0}
.phone-link .ph-num{display:none}
@media (min-width:1080px){
  .phone-link .ph-num{display:inline}
}
.nav.scrolled .phone-link,
.nav.solid .phone-link{padding:8px 13px;font-size:13.5px}

/* Hide call button on very small screens - the hamburger menu has the phone too */
@media (max-width:520px){
  .phone-link{display:none}
}

/* CTA button - let it shrink gracefully on tablet */
@media (max-width:768px){
  .nav-cta .btn-accent{padding:9px 14px;font-size:14px}
  .nav-cta .btn-accent svg{display:none}
}
@media (max-width:380px){
  .nav-cta .btn-accent{padding:8px 12px;font-size:13px}
}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:50px;
  font-weight:600;font-size:14.5px;letter-spacing:-.005em;
  transition:transform .12s ease, box-shadow .2s ease, opacity .2s ease, background .2s ease;
  white-space:nowrap;cursor:pointer;
}
.btn:active{transform:scale(.97)}
.btn-primary{
  background:var(--ink);color:#fff;
  box-shadow:0 6px 16px rgba(14,26,31,.18), inset 0 1px 0 rgba(255,255,255,.12);
}
.btn-primary:hover{background:#000;box-shadow:0 12px 28px rgba(14,26,31,.22)}
.btn-accent{
  background:linear-gradient(135deg, var(--teal) 0%, var(--teal-2) 100%);
  color:#fff;
  box-shadow:0 8px 20px rgba(93,193,185,.45), inset 0 1px 0 rgba(255,255,255,.3);
}
.btn-accent:hover{filter:brightness(1.05)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--soft)}
.btn-lg{padding:14px 22px;font-size:15.5px}

/* ============================================================
   HERO - Dark aurora canvas + letter-reveal headline
   ============================================================ */
.hero{
  position:relative;
  background:#0a1417;
  color:#f0f4f3;
  padding:120px 0 90px;
  overflow:hidden;
  isolation:isolate;
}
@media (min-width:768px){.hero{padding:160px 0 120px}}
.aurora{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.aurora::before{
  content:"";position:absolute;inset:-20%;
  background:
    radial-gradient(40% 50% at 18% 28%, rgba(93,193,185,.55) 0%, transparent 60%),
    radial-gradient(35% 45% at 82% 22%, rgba(255,0,118,.42) 0%, transparent 60%),
    radial-gradient(50% 55% at 50% 92%, rgba(139,92,246,.50) 0%, transparent 65%);
  filter:blur(40px);
  animation:auroraDrift 22s ease-in-out infinite alternate;
}
.aurora::after{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/></svg>");
  opacity:.22;mix-blend-mode:overlay;
}
@keyframes auroraDrift{
  0%{transform:translate3d(-2%,-1%,0) scale(1.02)}
  50%{transform:translate3d(2%,2%,0) scale(1.08)}
  100%{transform:translate3d(-1%,1%,0) scale(1.04)}
}
.hero-grid{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 80%);
}
.hero-inner{position:relative;z-index:2;text-align:center}
.pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px 7px 8px;border-radius:50px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  font-size:13px;color:#e3ecea;font-weight:500;
}
.pill-dot{
  width:8px;height:8px;border-radius:50%;background:#4ade80;
  box-shadow:0 0 0 4px rgba(74,222,128,.22);
  animation:pulseDot 2.2s ease-in-out infinite;
}
@keyframes pulseDot{
  0%,100%{box-shadow:0 0 0 4px rgba(74,222,128,.22)}
  50%{box-shadow:0 0 0 8px rgba(74,222,128,0)}
}
.hero h1{
  font-weight:600;letter-spacing:-.045em;line-height:.96;
  font-size:clamp(48px, 9vw, 124px);
  margin:24px 0 0;
  text-wrap:balance;
}
.hero h1 .word{display:inline-block;margin-right:.18em}
.hero h1 .ch{
  display:inline-block;opacity:0;transform:translateY(40px);filter:blur(8px);
  animation:chRise .9s cubic-bezier(.2,.8,.2,1) forwards;
  background:linear-gradient(180deg, #ffffff 0%, #c4d6d4 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero h1 .accent-word{
  display:inline-block;
  filter:drop-shadow(0 0 22px rgba(255,0,118,.32)) drop-shadow(0 0 40px rgba(139,92,246,.22));
  animation:hueWave 11s linear 1.6s infinite;
}
.hero h1 .accent-word .ch{
  background:none !important;-webkit-background-clip:initial;background-clip:initial;
  color:#ff5d97;
  text-shadow:0 0 18px rgba(255,255,255,.05);
}
.hero h1 .accent-word .ch:nth-child(1){color:#ff6aa6}
.hero h1 .accent-word .ch:nth-child(2){color:#ff3d83}
.hero h1 .accent-word .ch:nth-child(3){color:#e63a9e}
.hero h1 .accent-word .ch:nth-child(4){color:#c83cc4}
.hero h1 .accent-word .ch:nth-child(5){color:#a855f7}
.hero h1 .accent-word .ch:nth-child(6){color:#8b5cf6}
.hero h1 .accent-word .ch:nth-child(7){color:#6e74f1}
.hero h1 .accent-word .ch:nth-child(8){color:#4f8df5}
@keyframes chRise{to{opacity:1;transform:translateY(0);filter:blur(0)}}
@keyframes hueWave{
  0%   {filter:hue-rotate(0deg)   drop-shadow(0 0 22px rgba(255,0,118,.32)) drop-shadow(0 0 40px rgba(139,92,246,.22))}
  50%  {filter:hue-rotate(40deg)  drop-shadow(0 0 22px rgba(180,80,255,.32)) drop-shadow(0 0 40px rgba(80,160,255,.22))}
  100% {filter:hue-rotate(0deg)   drop-shadow(0 0 22px rgba(255,0,118,.32)) drop-shadow(0 0 40px rgba(139,92,246,.22))}
}
.hero h1 .serif{font-style:italic;font-weight:400;letter-spacing:-.02em;font-family:'Instrument Serif',Georgia,serif;color:#ffe1ec}
.hero p.lede{
  max-width:640px;margin:28px auto 0;
  color:#b6c7c6;font-size:clamp(17px,2vw,21px);line-height:1.5;text-wrap:balance;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:36px}
.btn-hero-primary{
  background:#fff;color:#0a1417;padding:16px 26px;font-size:16px;border-radius:50px;font-weight:600;
  display:inline-flex;align-items:center;gap:10px;
  box-shadow:0 12px 30px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.6);
  transition:transform .12s, box-shadow .2s;
}
.btn-hero-primary:hover{transform:translateY(-1px);box-shadow:0 18px 40px rgba(0,0,0,.5)}
.btn-hero-secondary{
  background:rgba(255,255,255,.08);color:#fff;padding:16px 24px;font-size:16px;border-radius:50px;font-weight:500;
  border:1px solid rgba(255,255,255,.18);
  display:inline-flex;align-items:center;gap:10px;backdrop-filter:blur(8px);
}
.btn-hero-secondary:hover{background:rgba(255,255,255,.14)}

/* Trust strip */
.trust{
  margin-top:60px;display:flex;gap:32px 48px;flex-wrap:wrap;justify-content:center;align-items:center;
  color:#92a5a3;font-size:13.5px;font-weight:500;letter-spacing:.01em;
}
.trust .sep{width:1px;height:14px;background:rgba(255,255,255,.16)}
.stars{display:inline-flex;gap:2px;color:#fbbf24}
.stars svg{width:15px;height:15px}

/* Hero corner badges */
.float{
  position:absolute;width:120px;height:120px;border-radius:24px;z-index:1;overflow:hidden;
  background:#16252b;box-shadow:0 30px 60px rgba(0,0,0,.4), inset 0 0 0 1px rgba(255,255,255,.06);
}
.float.tl{top:130px;left:40px;transform:rotate(-9deg);animation:floatBob 7s ease-in-out infinite}
.float.tr{top:160px;right:40px;transform:rotate(8deg);animation:floatBob 8s ease-in-out infinite reverse}
.float.bl{bottom:80px;left:60px;transform:rotate(7deg);animation:floatBob 9s ease-in-out infinite}
.float.br{bottom:60px;right:50px;transform:rotate(-6deg);animation:floatBob 10s ease-in-out infinite reverse}
@keyframes floatBob{0%,100%{translate:0 0}50%{translate:0 -10px}}
@media (max-width:1100px){.float{display:none}}
.float-content{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--teal) 0%, var(--violet) 100%);
  color:#fff;text-align:center;padding:14px;font-weight:600;font-size:13px;line-height:1.25;
}
.float.coral .float-content{background:linear-gradient(135deg, var(--coral) 0%, var(--violet) 100%)}
.float.gold .float-content{background:linear-gradient(135deg, var(--gold) 0%, var(--coral) 100%);color:#1a1300}
.float.ink .float-content{background:linear-gradient(135deg, #1a2e2d 0%, #0a1417 100%);color:#a6e9e2;border:1px solid rgba(166,233,226,.2)}
.float-content svg{width:28px;height:28px;margin-bottom:6px;display:block;margin-left:auto;margin-right:auto}

/* ============================================================
   PAGE HERO - smaller, used on all secondary pages
   ============================================================ */
.page-hero{
  position:relative;background:#0a1417;color:#f0f4f3;
  padding:140px 0 80px;overflow:hidden;isolation:isolate;
}
@media (min-width:768px){.page-hero{padding:170px 0 100px}}
.page-hero .aurora::before{
  background:
    radial-gradient(40% 60% at 20% 40%, rgba(93,193,185,.40) 0%, transparent 60%),
    radial-gradient(45% 55% at 85% 65%, rgba(255,0,118,.35) 0%, transparent 60%),
    radial-gradient(35% 45% at 75% 15%, rgba(139,92,246,.32) 0%, transparent 60%);
  filter:blur(50px);
}
.page-hero-inner{position:relative;z-index:2;max-width:880px}
.breadcrumb{display:inline-flex;align-items:center;gap:8px;color:#92a5a3;font-size:13px;margin-bottom:18px}
.breadcrumb a{color:#cbdcda;font-weight:500}
.breadcrumb a:hover{color:#fff}
.breadcrumb svg{width:12px;height:12px;color:#5b7372}
.page-hero h1{
  font-weight:600;letter-spacing:-.04em;line-height:1.02;
  font-size:clamp(40px,6vw,84px);
  margin:0;text-wrap:balance;
  background:linear-gradient(180deg, #ffffff 0%, #c4d6d4 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.page-hero h1 .serif{font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-weight:400;color:#ffd5e3;background:none;-webkit-text-fill-color:initial}
.page-hero .lede{
  color:#b6c7c6;font-size:clamp(17px,1.6vw,20px);line-height:1.55;
  margin:22px 0 0;max-width:620px;text-wrap:balance;
}
.page-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}

/* ============================================================
   RIBBON
   ============================================================ */
.ribbon{
  background:#0a1417;color:#7e928f;
  padding:18px 0;border-top:1px solid rgba(255,255,255,.06);
  overflow:hidden;position:relative;
}
.ribbon-track{
  display:flex;gap:60px;width:max-content;
  animation:slide 38s linear infinite;
  font-size:14px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  white-space:nowrap;
}
.ribbon-track span{display:inline-flex;align-items:center;gap:14px}
.ribbon-track .dot{width:5px;height:5px;border-radius:50%;background:var(--coral)}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION LAYOUT
   ============================================================ */
.section{padding:96px 0;position:relative}
@media (max-width:768px){.section{padding:64px 0}}
.section-light{background:var(--bg)}
.section-soft{background:var(--soft)}
.section-ink{background:var(--ink);color:#f0f4f3}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;color:var(--teal-2);letter-spacing:.06em;text-transform:uppercase;
  padding:6px 12px;border-radius:50px;background:var(--teal-soft);
}
.section-ink .eyebrow{background:rgba(93,193,185,.16);color:#a6e9e2}
h2.section-title{
  font-size:clamp(34px,5.4vw,64px);font-weight:600;letter-spacing:-.035em;line-height:1.02;
  margin:18px 0 0;text-wrap:balance;
}
h2.section-title .serif{font-family:'Instrument Serif',Georgia,serif;font-weight:400;font-style:italic;color:var(--coral)}
.section-ink h2.section-title .serif{color:#ffb3cc}
.section-lede{
  color:var(--muted);margin-top:16px;max-width:620px;font-size:18px;line-height:1.55;text-wrap:balance;
}
.section-ink .section-lede{color:#a8bcba}
.section-head{margin-bottom:56px}
.section-head.center{text-align:center;display:flex;flex-direction:column;align-items:center}
.section-head.center .section-lede{margin-left:auto;margin-right:auto}

/* Service-page two-column layout */
.split{display:grid;gap:48px;grid-template-columns:1fr;align-items:start}
@media (min-width:880px){.split{grid-template-columns:1.4fr 1fr;gap:80px}}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
.split-body h3{font-size:clamp(26px,3vw,36px);font-weight:600;letter-spacing:-.025em;line-height:1.1;margin:0 0 18px;text-wrap:balance}
.split-body h3 .serif{font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-weight:400;color:var(--coral)}
.split-body p{font-size:17px;line-height:1.65;color:var(--ink-2);margin:0 0 16px}
.split-body p strong{color:var(--ink);font-weight:600}

.split-card{
  position:relative;border-radius:var(--r-lg);padding:36px;overflow:hidden;
  background:linear-gradient(160deg, var(--surface) 0%, var(--soft) 100%);
  border:1px solid var(--line);
}
.split-card.dark{
  background:
    radial-gradient(70% 60% at 30% 30%, rgba(93,193,185,.35) 0%, transparent 60%),
    radial-gradient(80% 70% at 80% 80%, rgba(255,0,118,.35) 0%, transparent 60%),
    linear-gradient(160deg, #0a1417 0%, #16252b 60%, #0a1417 100%);
  color:#fff;border-color:rgba(255,255,255,.08);
}

/* ============================================================
   STATS strip
   ============================================================ */
.stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
@media (min-width:768px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{padding:36px 24px;border-right:1px solid var(--line);position:relative}
.stat:last-child{border-right:none}
.stat:nth-child(2){border-right:none}
@media (min-width:768px){
  .stat{border-right:1px solid var(--line)}
  .stat:nth-child(2){border-right:1px solid var(--line)}
  .stat:last-child{border-right:none}
}
.stat::before{
  content:"";position:absolute;top:36px;left:24px;width:24px;height:3px;border-radius:2px;
  background:var(--teal);
}
.stat:nth-child(2)::before{background:var(--coral)}
.stat:nth-child(3)::before{background:var(--violet)}
.stat:nth-child(4)::before{background:var(--gold)}
.stat-value{
  font-size:clamp(36px,5vw,56px);font-weight:600;letter-spacing:-.04em;line-height:1;
  margin-top:18px;color:var(--ink);
}
.stat-value sup{font-size:.5em;font-weight:500;color:var(--muted);margin-left:4px;vertical-align:super}
.stat-label{margin-top:8px;font-size:13.5px;color:var(--muted);letter-spacing:.02em}

/* ============================================================
   SERVICES - Bento
   ============================================================ */
.bento{display:grid;gap:16px;grid-template-columns:1fr}
@media (min-width:760px){
  .bento{grid-template-columns:repeat(12, 1fr);grid-auto-rows:minmax(180px,auto)}
}
.card{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  padding:32px;display:flex;flex-direction:column;justify-content:space-between;
  min-height:280px;
  background:var(--surface);border:1px solid var(--line);
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, border-color .25s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:rgba(93,193,185,.4)}
.card .deco{
  position:absolute;inset:auto -40px -50px auto;width:240px;height:240px;border-radius:50%;
  opacity:.15;filter:blur(0);pointer-events:none;
  transition:transform .5s ease, opacity .4s;
}
.card:hover .deco{transform:scale(1.08) rotate(8deg);opacity:.22}
.card .icon{
  width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:var(--soft);color:var(--ink);
  position:relative;z-index:1;
  box-shadow:inset 0 0 0 1px rgba(14,26,31,.06);
}
.card .icon svg{width:26px;height:26px}
.card h3{margin:24px 0 6px;font-size:24px;font-weight:600;letter-spacing:-.02em;line-height:1.15;color:var(--ink);position:relative;z-index:1}
.card p{margin:0;color:var(--muted);font-size:15px;line-height:1.5;position:relative;z-index:1}
.card .more{margin-top:24px;display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:14px;color:var(--ink);position:relative;z-index:1}
.card .more svg{width:16px;height:16px;transition:translate .25s}
.card:hover .more svg{translate:4px 0}
.card-tags{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.check-list{
  list-style:none;padding:0;margin:22px 0 0;
  display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;
  position:relative;z-index:1;
}
@media (max-width:520px){.check-list{grid-template-columns:1fr}}
.check-list li{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--ink-2);line-height:1.4;font-weight:500}
.check-list li::before{
  content:"";flex-shrink:0;margin-top:3px;
  width:18px;height:18px;border-radius:50%;
  background:var(--teal) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/11px no-repeat;
  box-shadow:0 4px 10px rgba(93,193,185,.35);
}
.check-list.single{grid-template-columns:1fr}
.tag{font-size:12px;padding:4px 10px;border-radius:50px;background:var(--soft);color:var(--ink-2);font-weight:500}

.bento .card-residential,
.bento .card-painting,
.bento .card-commercial,
.bento .card-construction,
.bento .card-detail,
.bento .card-paver,
.bento .card-watch,
.bento .card-window{grid-column:span 1}
@media (min-width:760px){
  .bento .card-residential{grid-column:span 6;grid-row:span 2;min-height:540px}
  .bento .card-painting{grid-column:span 6;grid-row:span 2;min-height:540px}
  .bento .card-commercial{grid-column:span 3}
  .bento .card-construction{grid-column:span 3}
  .bento .card-detail{grid-column:span 3}
  .bento .card-paver{grid-column:span 3}
  .bento .card-watch{grid-column:span 12;min-height:260px}
  .bento .card-window{grid-column:span 12;min-height:240px}
}
.bento .card-residential{
  background:
    radial-gradient(120% 80% at 100% 100%, rgba(93,193,185,.28) 0%, transparent 55%),
    radial-gradient(80% 80% at 0% 0%, rgba(255,0,118,.10) 0%, transparent 55%),
    linear-gradient(160deg, #ffffff 0%, #f1faf9 100%);
  border-color:rgba(93,193,185,.22);
}
.bento .card-residential h3{font-size:30px}
.bento .card-residential .deco{background:radial-gradient(circle, var(--teal) 0%, transparent 70%)}
.bento .card-painting{
  background:
    radial-gradient(110% 70% at 110% 110%, rgba(255,0,118,.32) 0%, transparent 55%),
    radial-gradient(70% 60% at -10% -10%, rgba(139,92,246,.28) 0%, transparent 55%),
    linear-gradient(140deg, #0a1417 0%, #16252b 60%, #1a2329 100%);
  color:#f0f4f3;border-color:rgba(255,255,255,.08);
}
.bento .card-painting h3{color:#fff;font-size:30px}
.bento .card-painting p{color:#bdd0ce}
.bento .card-painting .icon{background:rgba(255,255,255,.10);color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.bento .card-painting .more{color:#fff}
.bento .card-painting .tag{background:rgba(255,255,255,.10);color:#dbe7e5}
.bento .card-painting .deco{background:radial-gradient(circle, var(--coral) 0%, transparent 70%);opacity:.45}
.bento .card-painting .check-list li{color:#dbe7e5;font-weight:500}
.bento .card-painting .check-list li::before{background-color:var(--coral);box-shadow:0 4px 10px rgba(255,0,118,.4)}
.bento .card-detail{
  background:
    radial-gradient(90% 90% at 100% 0%, rgba(245,158,11,.18) 0%, transparent 60%),
    linear-gradient(160deg, #fffdf6 0%, #fff7e8 100%);
  border-color:rgba(245,158,11,.28);
}
.bento .card-detail .icon{background:#fef3c7;color:#92400e}
.bento .card-detail .deco{background:radial-gradient(circle, var(--gold) 0%, transparent 70%)}
.badge-new{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px 4px 8px;border-radius:50px;
  background:var(--ink);color:#fff;margin-bottom:14px;
  position:relative;z-index:1;
}
.badge-new::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(245,158,11,.3)}
.bento .card-paver{
  background:
    radial-gradient(90% 90% at 0% 100%, rgba(139,92,246,.18) 0%, transparent 60%),
    radial-gradient(80% 80% at 100% 0%, rgba(93,193,185,.16) 0%, transparent 60%),
    linear-gradient(160deg, #f6fbfa 0%, #eef5f4 100%);
  border-color:rgba(139,92,246,.22);
}
.bento .card-paver .icon{background:var(--violet-soft);color:var(--violet-2)}
.bento .card-paver .deco{background:radial-gradient(circle, var(--violet) 0%, transparent 70%)}
.bento .card-commercial .icon{background:var(--pink-soft);color:#9d174d}
.bento .card-commercial .deco{background:radial-gradient(circle, var(--pink) 0%, transparent 70%)}
.bento .card-construction .icon{background:#dbeafe;color:#1e40af}
.bento .card-construction .deco{background:radial-gradient(circle, #60a5fa 0%, transparent 70%)}

/* Window Cleaning - premium full-width card (light glass aesthetic) */
.bento .card-window{
  position:relative;
  background:
    radial-gradient(80% 100% at 0% 0%, rgba(93,193,185,.35) 0%, transparent 55%),
    radial-gradient(70% 90% at 100% 100%, rgba(96,165,250,.32) 0%, transparent 55%),
    linear-gradient(140deg, #f0fafa 0%, #e3f3f4 60%, #dfeef6 100%);
  border-color:rgba(93,193,185,.28);
  overflow:hidden;
}
.bento .card-window h3{color:var(--ink);font-size:30px;letter-spacing:-.02em}
.bento .card-window p{color:var(--ink-2);font-size:15px;max-width:540px}
.bento .card-window .icon{background:#fff;color:var(--teal-2);box-shadow:0 2px 8px rgba(93,193,185,.18)}
.bento .card-window .more{color:var(--teal-2)}
.bento .card-window .deco{background:radial-gradient(circle, var(--teal) 0%, transparent 70%);opacity:.28}
.bento .card-window .badge-new{background:var(--ink);color:#fff}
.bento .card-window .badge-new::before{background:var(--teal);box-shadow:0 0 0 3px rgba(93,193,185,.3)}
/* light-mode side panel for window cleaning card */
.bento .card-window .cw-side{
  background:rgba(255,255,255,.7);
  border:1px solid rgba(93,193,185,.18);
  backdrop-filter:blur(8px);
}
.bento .card-window .cw-side .cw-price{color:var(--ink)}
.bento .card-window .cw-side .cw-price .num{color:var(--ink)}
.bento .card-window .cw-side .cw-price .unit,
.bento .card-window .cw-side .cw-price .from{color:var(--muted)}
.bento .card-window .cw-side li{color:var(--ink-2)}
.bento .card-window .cw-tags .tag{background:rgba(93,193,185,.14);color:var(--ink-2)}

/* Home Watch - premium full-width card */
.bento .card-watch{
  position:relative;
  background:
    radial-gradient(80% 90% at 100% 0%, rgba(93,193,185,.32) 0%, transparent 55%),
    radial-gradient(70% 80% at 0% 100%, rgba(139,92,246,.22) 0%, transparent 55%),
    linear-gradient(140deg, #0a1417 0%, #14242a 60%, #18272d 100%);
  color:#f0f4f3;
  border-color:rgba(255,255,255,.08);
  overflow:hidden;
}
.bento .card-watch h3{color:#fff;font-size:30px;letter-spacing:-.02em}
.bento .card-watch p{color:#bdd0ce;font-size:15px;max-width:540px}
.bento .card-watch .icon{background:rgba(255,255,255,.10);color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.bento .card-watch .more{color:#fff}
.bento .card-watch .deco{background:radial-gradient(circle, var(--teal) 0%, transparent 70%);opacity:.45}
.bento .card-watch .badge-new{background:var(--teal);color:#0a1417}
.bento .card-watch .badge-new::before{background:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.3)}
.cw-inner{display:grid;gap:24px;grid-template-columns:1fr;align-items:center;position:relative;z-index:1}
@media (min-width:760px){.cw-inner{grid-template-columns:1.4fr 1fr;gap:40px}}
.cw-body{display:flex;flex-direction:column;gap:14px}
.cw-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.cw-tags .tag{background:rgba(255,255,255,.10);color:#dbe7e5;font-size:12px;padding:6px 12px;border-radius:50px;font-weight:500}
.cw-side{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;padding:24px;
  display:flex;flex-direction:column;gap:14px;
}
.cw-side .cw-price{display:flex;align-items:baseline;gap:8px;color:#fff}
.cw-side .cw-price .num{font-size:38px;font-weight:700;letter-spacing:-.02em;color:#fff;font-family:'Instrument Serif',serif;font-style:italic}
.cw-side .cw-price .unit{font-size:14px;color:#9bb0ae;font-weight:500}
.cw-side .cw-price .from{font-size:12px;color:#9bb0ae;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.cw-side ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.cw-side li{color:#dbe7e5;font-size:14px;display:flex;align-items:flex-start;gap:8px;line-height:1.4}
.cw-side li::before{content:"";width:14px;height:14px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:3px;box-shadow:0 4px 10px rgba(93,193,185,.3);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a1417' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size:9px 9px;background-position:center;background-repeat:no-repeat}

/* ============================================================
   ORIGIN STORY
   ============================================================ */
.origin{padding:120px 0;position:relative;overflow:hidden;background:var(--bg)}
@media (max-width:768px){.origin{padding:80px 0}}
.origin-grid{display:grid;gap:60px;grid-template-columns:1fr;align-items:center}
@media (min-width:880px){.origin-grid{grid-template-columns:1.3fr 1fr;gap:80px}}
.origin h2{font-size:clamp(40px,5.5vw,68px);font-weight:600;letter-spacing:-.035em;line-height:1.02;margin:18px 0 28px;text-wrap:balance}
.origin h2 .serif{font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-weight:400;color:var(--coral)}
.origin-body p{font-size:18px;line-height:1.7;color:var(--ink-2);margin:0 0 18px;max-width:560px}
.origin-body p strong{color:var(--ink);font-weight:600}
.origin-sig{margin-top:36px;display:inline-flex;align-items:flex-end;gap:18px;padding-top:24px;border-top:1px solid var(--line)}
.origin-sig .name{font-family:'Instrument Serif',Georgia,serif;font-size:38px;font-style:italic;line-height:.9;color:var(--ink);letter-spacing:-.01em}
.origin-sig .role{font-size:12.5px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;font-weight:600;margin-top:6px}
.origin-visual{
  position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  background:
    radial-gradient(70% 55% at 25% 25%, rgba(255,0,118,.40) 0%, transparent 60%),
    radial-gradient(80% 60% at 85% 85%, rgba(93,193,185,.45) 0%, transparent 60%),
    radial-gradient(40% 50% at 90% 15%, rgba(139,92,246,.40) 0%, transparent 60%),
    linear-gradient(160deg, #0a1417 0%, #16252b 60%, #0a1417 100%);
  color:#fff;padding:42px;
  display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:0 30px 80px rgba(14,26,31,.25);
  isolation:isolate;
}
.origin-visual::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/></svg>");
  opacity:.18;mix-blend-mode:overlay;
}
.origin-visual > *{position:relative;z-index:2}
.origin-pin{
  align-self:flex-start;
  background:rgba(255,255,255,.10);
  padding:7px 14px 7px 8px;border-radius:50px;font-size:12px;color:#cbe9e5;
  border:1px solid rgba(255,255,255,.16);font-weight:500;letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:8px;
  backdrop-filter:blur(6px);
}
.origin-pin::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(245,158,11,.3)}
.origin-quote{
  font-size:clamp(24px,2.6vw,30px);line-height:1.32;font-weight:500;
  text-wrap:balance;color:#fff;letter-spacing:-.015em;margin:0;
}
.origin-quote em{font-style:italic;font-family:'Instrument Serif',Georgia,serif;font-weight:400;color:#ffd5e3}
.origin-est{
  display:flex;align-items:center;gap:16px;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.10);
  color:#a6e9e2;font-size:13.5px;letter-spacing:.04em;
}
.origin-est .icon-pin{width:32px;height:32px;border-radius:50%;background:rgba(166,233,226,.10);display:flex;align-items:center;justify-content:center}
.origin-est .icon-pin svg{width:16px;height:16px;color:#a6e9e2}

/* ============================================================
   HOW IT WORKS - Redesigned: numbered badge timeline with a soft
   connector line behind the cards on desktop. Cleaner, more modern,
   less editorial-clutter than the giant italic serif numbers.
   ============================================================ */
.steps{
  display:grid;gap:18px;grid-template-columns:1fr;
  position:relative;
}
@media (min-width:768px){
  .steps{grid-template-columns:repeat(3,1fr);gap:24px}
  .steps.four{grid-template-columns:repeat(4,1fr)}
  /* Soft connector line behind the badges */
  .steps::before{
    content:"";position:absolute;top:60px;
    left:8%;right:8%;height:2px;
    background:linear-gradient(90deg, var(--teal) 0%, var(--coral) 33%, var(--violet) 66%, var(--gold) 100%);
    opacity:.18;border-radius:2px;z-index:0;
  }
}
.step{
  padding:28px 26px;border-radius:var(--r-lg);
  background:var(--surface);border:1px solid var(--line);
  position:relative;overflow:hidden;z-index:1;
  display:flex;flex-direction:column;gap:12px;
  transition:transform .25s cubic-bezier(.16,.84,.44,1), box-shadow .25s, border-color .2s;
}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:rgba(91,191,181,.35)}
.step-num{
  font-family:'Geist',sans-serif;font-style:normal;
  font-size:18px;font-weight:700;letter-spacing:.02em;
  width:48px;height:48px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--teal) 0%, var(--teal-2) 100%);
  color:#fff;
  box-shadow:0 8px 18px rgba(91,191,181,.36), inset 0 1px 0 rgba(255,255,255,.25);
  align-self:flex-start;flex-shrink:0;
  margin-bottom:4px;
  position:relative;z-index:2;
}
/* The old markup had `<span class="small">consultation</span>` inside .step-num -
   it's redundant with the H3, and squishes inside the new 48x48 badge.
   Hide it so we don't have to touch every page. */
.step-num .small{display:none}
.step:nth-child(2) .step-num{
  background:linear-gradient(135deg, var(--coral) 0%, var(--coral-2) 100%);
  box-shadow:0 8px 18px rgba(255,0,118,.36), inset 0 1px 0 rgba(255,255,255,.25);
}
.step:nth-child(3) .step-num{
  background:linear-gradient(135deg, var(--violet) 0%, var(--violet-2) 100%);
  box-shadow:0 8px 18px rgba(139,92,246,.36), inset 0 1px 0 rgba(255,255,255,.25);
}
.step:nth-child(4) .step-num{
  background:linear-gradient(135deg, var(--gold) 0%, #d97706 100%);
  box-shadow:0 8px 18px rgba(245,158,11,.36), inset 0 1px 0 rgba(255,255,255,.25);
}
.step h3{font-size:19px;font-weight:600;letter-spacing:-.015em;margin:0;line-height:1.25}
.step p{color:var(--muted);font-size:14.5px;line-height:1.55;margin:0}
/* Remove old top-stripe (the connector replaces it) */
.step::after{display:none}

/* ============================================================
   WHY US
   ============================================================ */
.why{display:grid;gap:1px;background:var(--line);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line)}
@media (min-width:600px){.why{grid-template-columns:1fr 1fr}}
@media (min-width:900px){.why{grid-template-columns:repeat(3,1fr)}}
.why-cell{background:var(--surface);padding:34px;display:flex;flex-direction:column;gap:10px;transition:background .25s}
.why-cell:hover{background:var(--soft)}
.why-cell .ic{width:48px;height:48px;border-radius:14px;background:var(--teal-soft);color:var(--teal-2);display:flex;align-items:center;justify-content:center}
.why-cell .ic svg{width:24px;height:24px}
.why-cell:nth-child(2) .ic{background:var(--coral-soft);color:var(--coral)}
.why-cell:nth-child(3) .ic{background:var(--violet-soft);color:var(--violet-2)}
.why-cell:nth-child(4) .ic{background:#fef3c7;color:#92400e}
.why-cell:nth-child(5) .ic{background:#d1fae5;color:#065f46}
.why-cell:nth-child(6) .ic{background:#dbeafe;color:#1e40af}
.why-cell h4{margin:6px 0 0;font-size:18px;font-weight:600;letter-spacing:-.01em}
.why-cell p{margin:0;color:var(--muted);font-size:15px;line-height:1.5}

/* ============================================================
   TESTIMONIAL MARQUEE + reviews wall
   ============================================================ */
.marquee{
  position:relative;overflow:hidden;
  mask-image:linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
}
.marquee-row{display:flex;gap:18px;width:max-content;animation:slide 48s linear infinite}
.marquee:hover .marquee-row{animation-play-state:paused}
.quote-card{
  width:380px;flex-shrink:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:28px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-1);
}
.section-ink .quote-card{background:#16252b;border-color:rgba(255,255,255,.08);color:#e3ecea}
.q-stars{display:flex;gap:2px;color:#fbbf24}
.q-stars svg{width:16px;height:16px}
.q-text{font-size:16px;line-height:1.55;color:var(--ink-2);margin:0;text-wrap:balance}
.section-ink .q-text{color:#e3ecea}
.q-author{display:flex;align-items:center;gap:12px;margin-top:auto}
.q-avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg, var(--teal), var(--violet));color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.2);
}
.q-name{font-weight:600;font-size:14.5px}
.q-meta{font-size:12.5px;color:var(--muted)}
.section-ink .q-meta{color:#92a5a3}

/* Reviews wall - masonry-ish grid */
.review-wall{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:680px){.review-wall{grid-template-columns:1fr 1fr}}
@media (min-width:1000px){.review-wall{grid-template-columns:repeat(3,1fr)}}
.review-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:28px;display:flex;flex-direction:column;gap:14px;
  box-shadow:var(--shadow-1);transition:transform .25s, box-shadow .25s;
}
.review-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.review-card .q-text{font-size:15.5px}

/* Google rating widget */
.google-widget{
  display:inline-flex;align-items:center;gap:18px;padding:16px 22px;
  background:var(--surface);border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow-1);
}
.google-widget .g-logo{
  width:36px;height:36px;border-radius:10px;background:#f8f9fa;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.google-widget .g-text strong{font-size:16px;font-weight:600;letter-spacing:-.01em;display:block}
.google-widget .g-text span{font-size:13px;color:var(--muted);display:block;margin-top:2px}

/* ============================================================
   FAQ
   ============================================================ */
.faq{display:grid;gap:12px;max-width:840px;margin:0 auto}
.qa{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:border-color .2s, box-shadow .2s}
.qa[open]{border-color:rgba(93,193,185,.45);box-shadow:var(--shadow-1)}
.qa summary{
  list-style:none;cursor:pointer;
  padding:22px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px;
  font-weight:600;font-size:17px;letter-spacing:-.01em;
}
.qa summary::-webkit-details-marker{display:none}
.qa .toggle{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--soft);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s, rotate .2s;color:var(--ink);
}
.qa[open] .toggle{background:var(--teal);color:#fff;rotate:45deg}
.qa .toggle svg{width:14px;height:14px}
.qa .answer{padding:0 28px 24px;color:var(--muted);font-size:15.5px;line-height:1.6;margin:0}

/* ============================================================
   GALLERY (before/after grid)
   ============================================================ */
.gallery{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:600px){.gallery{grid-template-columns:1fr 1fr}}
@media (min-width:1000px){.gallery{grid-template-columns:repeat(3,1fr)}}
.gal-card{
  position:relative;border-radius:var(--r);overflow:hidden;
  background:var(--soft);aspect-ratio:4/3;
  display:flex;align-items:flex-end;justify-content:flex-start;
  padding:18px;color:#fff;
  border:1px solid var(--line);
  transition:transform .35s ease, box-shadow .35s ease;
}
.gal-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.gal-card .placeholder{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:600;letter-spacing:.05em;
  background:
    radial-gradient(60% 70% at 30% 30%, var(--teal) 0%, transparent 60%),
    radial-gradient(60% 70% at 80% 70%, var(--coral) 0%, transparent 60%),
    linear-gradient(135deg, #0a1417 0%, #16252b 100%);
}
.gal-card .placeholder svg{width:42px;height:42px;opacity:.6;display:block;margin-bottom:8px}
.gal-card .placeholder span{display:block;opacity:.6;text-transform:uppercase;font-size:11px;letter-spacing:.15em}
.gal-meta{position:relative;z-index:1;backdrop-filter:blur(4px);background:rgba(10,20,23,.6);border:1px solid rgba(255,255,255,.12);border-radius:50px;padding:6px 12px;font-size:12px;font-weight:600}
.gal-card:nth-child(3n+1) .placeholder{background:radial-gradient(60% 70% at 30% 30%, var(--teal) 0%, transparent 60%), radial-gradient(60% 70% at 80% 70%, var(--violet) 0%, transparent 60%), linear-gradient(135deg, #0a1417 0%, #16252b 100%)}
.gal-card:nth-child(3n+2) .placeholder{background:radial-gradient(60% 70% at 30% 30%, var(--coral) 0%, transparent 60%), radial-gradient(60% 70% at 80% 70%, var(--gold) 0%, transparent 60%), linear-gradient(135deg, #1a1300 0%, #16252b 100%)}

.gal-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.gal-filter button{
  padding:9px 16px;border-radius:50px;font-size:13.5px;font-weight:500;
  background:var(--surface);border:1px solid var(--line);color:var(--ink-2);transition:all .15s;
}
.gal-filter button:hover{background:var(--soft)}
.gal-filter button.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ============================================================
   PRICING cards
   ============================================================ */
.pricing{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:680px){.pricing{grid-template-columns:1fr 1fr}}
@media (min-width:1000px){.pricing{grid-template-columns:repeat(3,1fr)}}
.price-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:32px;display:flex;flex-direction:column;gap:18px;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.price-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:rgba(93,193,185,.3)}
.price-card.featured{
  border-color:var(--teal);background:linear-gradient(160deg, #ffffff 0%, var(--teal-soft) 100%);
  box-shadow:0 20px 50px rgba(93,193,185,.18);
}
.price-card .badge-featured{
  position:absolute;top:-10px;right:18px;background:var(--coral);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 10px;border-radius:50px;
}
.price-card{position:relative}
.price-name{font-size:14px;color:var(--muted);font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.price-tag{font-size:42px;font-weight:600;letter-spacing:-.03em;line-height:1;margin-top:-6px}
.price-tag small{font-size:14px;color:var(--muted);font-weight:500;letter-spacing:0;text-transform:none}
.price-desc{color:var(--muted);font-size:15px;line-height:1.5;margin:0}
.price-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.price-list li{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--ink-2);line-height:1.4}
.price-list li::before{
  content:"";flex-shrink:0;margin-top:3px;width:18px;height:18px;border-radius:50%;
  background:var(--teal) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/11px no-repeat;
}
.price-card .btn{margin-top:auto;width:100%;justify-content:center}

/* ============================================================
   CLOSING CTA + Quote form
   ============================================================ */
.closing{position:relative;overflow:hidden;padding:120px 0;color:#fff;isolation:isolate}
@media (max-width:768px){.closing{padding:80px 0}}
.closing-bg{position:absolute;inset:0;z-index:0;background:#0a1417}
.closing-bg::before{
  content:"";position:absolute;inset:-20%;
  background:
    radial-gradient(40% 50% at 24% 20%, rgba(93,193,185,.55) 0%, transparent 60%),
    radial-gradient(36% 48% at 78% 80%, rgba(255,0,118,.45) 0%, transparent 60%),
    radial-gradient(40% 50% at 88% 18%, rgba(139,92,246,.40) 0%, transparent 60%);
  filter:blur(40px);animation:auroraDrift 28s ease-in-out infinite alternate;
}
.closing-bg::after{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/></svg>");
  opacity:.18;mix-blend-mode:overlay;
}
.closing-inner{position:relative;z-index:2;max-width:1080px;margin:0 auto;padding:0 24px;display:grid;gap:56px;grid-template-columns:1fr;align-items:center}
@media (min-width:880px){.closing-inner{grid-template-columns:1fr 1.1fr;gap:72px;text-align:left}}
.closing-copy h2{font-size:clamp(40px,6vw,72px);font-weight:600;letter-spacing:-.04em;line-height:1;margin:0;text-wrap:balance}
.closing-copy h2 .serif{font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-weight:400;color:#ffd5e3}
.closing-copy p{margin:22px 0 0;max-width:480px;color:#cbdcda;font-size:18px;line-height:1.55}
.closing-trust{margin-top:28px;display:flex;gap:14px 24px;flex-wrap:wrap;color:#92a5a3;font-size:13.5px}
.closing-trust span{display:inline-flex;align-items:center;gap:6px}
.closing-trust svg{width:14px;height:14px;color:#a6e9e2}
.closing-or{margin-top:24px;color:#92a5a3;font-size:14px}
.closing-or a{color:#fff;font-weight:600;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.closing-or a:hover{color:#ffd5e3}

.quote-form{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-lg);padding:32px;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 30px 80px rgba(0,0,0,.4);
}
@media (max-width:768px){.quote-form{padding:24px}}
.quote-form h3{font-size:22px;font-weight:600;letter-spacing:-.015em;margin:0 0 4px;color:#fff}
.quote-form .sub{font-size:13.5px;color:#92a5a3;margin:0 0 22px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:520px){.field-row{grid-template-columns:1fr}}
.field label{font-size:12.5px;color:#cbdcda;font-weight:600;letter-spacing:.02em}
.field input,
.field textarea,
.field select{
  width:100%;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:13px 14px;
  font:inherit;font-size:14.5px;color:#fff;outline:none;transition:border-color .15s, background .15s;
}
.field input::placeholder,
.field textarea::placeholder{color:rgba(255,255,255,.35)}
.field input:focus,
.field textarea:focus,
.field select:focus{border-color:var(--teal);background:rgba(255,255,255,.10)}
.field textarea{resize:vertical;min-height:84px}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23cbdcda' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chips input{position:absolute;opacity:0;pointer-events:none}
.chips label{
  cursor:pointer;font-size:13px;font-weight:500;padding:8px 14px;border-radius:50px;letter-spacing:.005em;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  color:#dbe7e5;transition:background .15s, border-color .15s, color .15s, transform .12s;user-select:none;
}
.chips label:hover{background:rgba(255,255,255,.12)}
.chips input:checked + label{background:var(--teal);border-color:var(--teal);color:#0a1417;font-weight:600}
.chips input:focus-visible + label{outline:2px solid rgba(93,193,185,.85);outline-offset:3px}
.form-submit{
  margin-top:8px;width:100%;background:#fff;color:#0a1417;
  border-radius:50px;padding:15px 22px;font-size:15.5px;font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  box-shadow:0 10px 28px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .12s, box-shadow .25s;cursor:pointer;
}
.form-submit:hover{transform:translateY(-1px);box-shadow:0 16px 38px rgba(0,0,0,.45)}
.form-submit:active{transform:scale(.98)}
.form-foot{margin-top:14px;color:#92a5a3;font-size:12px;text-align:center}
.form-success{background:rgba(74,222,128,.10);border:1px solid rgba(74,222,128,.35);color:#a6f3c2;padding:18px;border-radius:14px;margin-bottom:14px;display:none}
.form-success.show{display:block}

/* Light-themed form (used on contact page) */
.quote-form.light{background:var(--surface);border-color:var(--line);box-shadow:var(--shadow-2);color:var(--ink)}
.quote-form.light h3{color:var(--ink)}
.quote-form.light .sub{color:var(--muted)}
.quote-form.light .field label{color:var(--ink-2)}
.quote-form.light .field input,
.quote-form.light .field textarea,
.quote-form.light .field select{background:var(--bg);border-color:var(--line);color:var(--ink)}
.quote-form.light .field input::placeholder,
.quote-form.light .field textarea::placeholder{color:var(--muted)}
.quote-form.light .chips label{background:var(--bg);border-color:var(--line);color:var(--ink-2)}
.quote-form.light .chips label:hover{background:var(--soft)}
.quote-form.light .chips input:checked + label{background:var(--teal);border-color:var(--teal);color:#fff}
.quote-form.light .form-submit{background:var(--ink);color:#fff}
.quote-form.light .form-foot{color:var(--muted)}

/* ============================================================
   LOCATIONS / SERVICE AREA
   ============================================================ */
.cities{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:600px){.cities{grid-template-columns:1fr 1fr}}
@media (min-width:1000px){.cities{grid-template-columns:repeat(4,1fr)}}
.city-card{
  padding:28px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;transition:transform .25s, box-shadow .25s, border-color .2s;
}
.city-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:rgba(93,193,185,.3)}
.city-card .icon-pin{width:32px;height:32px;border-radius:8px;background:var(--teal-soft);color:var(--teal-2);display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.city-card .icon-pin svg{width:18px;height:18px}
.city-card h3{margin:0;font-size:20px;font-weight:600;letter-spacing:-.015em}
.city-card p{margin:0;font-size:14px;color:var(--muted);line-height:1.4}
.city-card .more{margin-top:8px;font-size:13.5px;font-weight:600;color:var(--teal-2)}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:#070f12;color:#9eb1af;padding:80px 0 32px;position:relative}
.footer-grid{display:grid;gap:48px;grid-template-columns:1fr;margin-bottom:48px}
@media (min-width:760px){.footer-grid{grid-template-columns:1.4fr repeat(3, 1fr)}}
footer h5{color:#fff;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 18px;font-weight:600}
footer a{display:block;padding:5px 0;font-size:14.5px;color:#9eb1af}
footer a:hover{color:#fff}
.footer-brand p{margin:18px 0 22px;max-width:340px;font-size:14.5px;line-height:1.55;color:#9eb1af}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.04);
  display:inline-flex;align-items:center;justify-content:center;
  padding:0;transition:background .2s,transform .15s;
}
.footer-social a:hover{background:rgba(255,255,255,.10);transform:translateY(-2px)}
.footer-social svg{width:18px;height:18px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.06);padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-size:13px;color:#6e8482;
}
.footer-bottom a{display:inline;padding:0;color:#6e8482}
.footer-bottom a:hover{color:#fff}

/* ============================================================
   MOBILE NAV
   ============================================================ */
.menu-btn{display:inline-flex;width:40px;height:40px;border-radius:11px;background:var(--soft);align-items:center;justify-content:center;flex-shrink:0}
.menu-btn:hover{background:var(--teal-soft);color:var(--teal-2)}
.menu-btn svg{width:20px;height:20px}
@media (min-width:960px){.menu-btn{display:none}}

/* Mobile menu - tightened spacing. Was 22px / 14px gap / 80px top.
   Now: 19px / 4px gap / 64px top - feels purposeful, not spaced-out. */
.mobile-menu{
  position:fixed;inset:0;z-index:80;
  background:rgba(10,20,23,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;flex-direction:column;
  padding:64px 24px 32px;
  padding-bottom:calc(32px + env(safe-area-inset-bottom,0px));
  gap:2px;
  opacity:0;pointer-events:none;transition:opacity .22s ease;
  overflow-y:auto;
}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{
  color:#fff;font-size:18px;font-weight:500;
  padding:13px 0;line-height:1.2;
  border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:space-between;
}
.mobile-menu a::after{
  content:"›";color:rgba(255,255,255,.3);font-size:22px;font-weight:300;line-height:1;
}
.mobile-menu a:hover,
.mobile-menu a:active{color:var(--teal);background:rgba(91,191,181,.05)}
.mobile-menu .mm-section{
  margin-top:18px;margin-bottom:2px;
  color:#92a5a3;font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;
}
.mobile-menu .mm-section:first-of-type{margin-top:0}
.mobile-close{
  position:absolute;top:14px;right:20px;
  width:38px;height:38px;border-radius:10px;
  background:rgba(255,255,255,.06);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;line-height:1;
}
.mobile-close:hover{background:rgba(255,255,255,.12)}

/* Bottom CTA group in mobile menu - Call + Get a quote pair */
.mobile-menu .mm-cta{
  margin-top:24px;display:grid;gap:10px;grid-template-columns:1fr 1fr;
}
.mobile-menu .mm-cta a{
  padding:14px;border-radius:50px;font-size:14.5px;font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  border-bottom:none !important;
}
.mobile-menu .mm-cta a::after{content:""}
.mobile-menu .mm-cta .mm-call{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.16)}
.mobile-menu .mm-cta .mm-call:hover{background:rgba(255,255,255,.14)}
.mobile-menu .mm-cta .mm-quote{background:var(--teal);color:#0a1417}
.mobile-menu .mm-cta .mm-quote:hover{filter:brightness(1.05)}
.mobile-menu .mm-cta a svg{width:14px;height:14px}

/* ============================================================
   UTILS
   ============================================================ */
.text-balance{text-wrap:balance}
.center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}
.max-prose{max-width:680px}
.divider{height:1px;background:var(--line);margin:48px 0}

/* ============================================================
   SERVICE TYPES - used on cleaning, painting, etc. to show tiers
   WITHOUT prices. Industry best practice: route everyone to a
   walkthrough/photo review for honest quoting.
   ============================================================ */
.service-types{display:grid;gap:18px;grid-template-columns:1fr;margin-top:8px}
@media (min-width:640px){.service-types{grid-template-columns:repeat(2,1fr);gap:20px}}
@media (min-width:1100px){.service-types{grid-template-columns:repeat(4,1fr)}}
.st-card{
  background:var(--surface);
  border:1px solid var(--line);border-radius:24px;
  padding:28px 26px;position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:14px;
  transition:transform .28s cubic-bezier(.16,.84,.44,1), box-shadow .28s ease, border-color .2s;
}
.st-card::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(50% 50% at 100% 0%, rgba(91,191,181,.05) 0%, transparent 60%);
  pointer-events:none;opacity:0;transition:opacity .3s ease;
}
.st-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(14,26,31,.10), 0 2px 8px rgba(14,26,31,.04);border-color:rgba(91,191,181,.45)}
.st-card:hover::before{opacity:1}

/* Card header - icon + title + price block */
.st-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;position:relative;z-index:1}
.st-card .st-icon{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:var(--teal-soft);color:var(--teal-2);
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(14,26,31,.04);
}
.st-card .st-icon svg{width:20px;height:20px}
.st-card h3{margin:0;font-size:19px;font-weight:600;letter-spacing:-.012em;color:var(--ink);line-height:1.2;position:relative;z-index:1}

/* PRICE - the dominant visual element. Big mono number, small unit underneath. */
.st-price{
  display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;
  margin:2px 0;position:relative;z-index:1;
}
.st-price .num{
  font-family:'Geist',sans-serif;
  font-size:36px;font-weight:700;letter-spacing:-.025em;line-height:1;
  color:var(--ink);
  font-feature-settings:'tnum','lnum';
}
.st-price .num.compact{font-size:30px}
.st-price .unit{font-size:13.5px;color:var(--muted);font-weight:500;letter-spacing:-.005em}
.st-price .from{
  font-size:11.5px;color:var(--muted);font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  display:block;width:100%;margin-bottom:2px;line-height:1;
}

.st-card .st-body{color:var(--muted);font-size:14px;line-height:1.55;margin:0;position:relative;z-index:1}

/* FEATURE LIST - filled circle checks */
.st-card .st-list{list-style:none;padding:0;margin:0;display:grid;gap:9px;font-size:13.5px;color:var(--ink-2);position:relative;z-index:1}
.st-card .st-list li{display:flex;gap:10px;align-items:flex-start;line-height:1.4}
.st-card .st-list li::before{
  content:"";flex-shrink:0;margin-top:1px;width:17px;height:17px;border-radius:50%;
  background:var(--teal-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233fa39a' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/10px no-repeat;
  box-shadow:inset 0 0 0 1px rgba(91,191,181,.18);
}

/* Footer - tag + CTA */
.st-card .st-foot{
  margin-top:auto;padding-top:16px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  position:relative;z-index:1;
}
.st-card .st-tag{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase;line-height:1.2}
.st-card .quote-btn{
  font-size:13.5px;font-weight:600;color:var(--teal-2);
  display:inline-flex;align-items:center;gap:5px;
  white-space:nowrap;
}
.st-card .quote-btn svg{width:13px;height:13px;transition:translate .2s}
.st-card .quote-btn:hover svg{translate:3px 0}

/* FLAGSHIP - the headline tier, gets aurora gradient + ring + scale */
.st-card.flagship{
  background:
    radial-gradient(140% 90% at 100% 100%, rgba(91,191,181,.22) 0%, transparent 55%),
    radial-gradient(90% 70% at 0% 0%, rgba(255,26,108,.06) 0%, transparent 55%),
    linear-gradient(165deg, #ffffff 0%, #ecf8f7 60%, #e0f4f2 100%);
  border-color:rgba(91,191,181,.45);
  box-shadow:0 1px 0 rgba(91,191,181,.06), 0 12px 32px rgba(91,191,181,.10);
}
.st-card.flagship .st-icon{
  background:linear-gradient(135deg, var(--teal) 0%, var(--teal-2) 100%);
  color:#fff;
  box-shadow:0 6px 16px rgba(91,191,181,.45), inset 0 1px 0 rgba(255,255,255,.3);
}
.st-card.flagship .st-list li::before{
  background-color:var(--teal);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  box-shadow:0 3px 8px rgba(91,191,181,.4);
}
.st-card.flagship .st-price .num{
  background:linear-gradient(135deg, var(--ink) 0%, var(--teal-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* "Most popular" floating badge - overlays the top-right corner of flagship */
.st-popular{
  position:absolute;top:-1px;right:18px;z-index:2;
  background:linear-gradient(135deg, var(--coral) 0%, var(--coral-2) 100%);
  color:#fff;
  padding:6px 12px 7px;border-radius:0 0 10px 10px;
  font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 6px 14px rgba(255,0,118,.35);
  display:inline-flex;align-items:center;gap:5px;
}
.st-popular::before{content:"";width:5px;height:5px;border-radius:50%;background:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.3)}

/* Coral / violet / gold accent variants - let pages tint individual cards */
.st-card.v-coral .st-icon{background:var(--coral-soft);color:var(--coral)}
.st-card.v-coral .st-list li::before{background-color:var(--coral-soft);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FF1A6C' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");box-shadow:inset 0 0 0 1px rgba(255,26,108,.18)}
.st-card.v-violet .st-icon{background:var(--violet-soft);color:var(--violet-2)}
.st-card.v-violet .st-list li::before{background-color:var(--violet-soft);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236d28d9' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");box-shadow:inset 0 0 0 1px rgba(139,92,246,.18)}
.st-card.v-amber  .st-icon{background:#fef3c7;color:#92400e}
.st-card.v-amber .st-list li::before{background-color:#fef3c7;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2392400e' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");box-shadow:inset 0 0 0 1px rgba(245,158,11,.22)}
.st-card.v-blue   .st-icon{background:#dbeafe;color:#1e40af}
.st-card.v-blue .st-list li::before{background-color:#dbeafe;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231e40af' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");box-shadow:inset 0 0 0 1px rgba(30,64,175,.18)}
.st-card.v-green  .st-icon{background:#d1fae5;color:#065f46}
.st-card.v-green .st-list li::before{background-color:#d1fae5;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23065f46' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");box-shadow:inset 0 0 0 1px rgba(6,95,70,.18)}
.st-card.v-pink   .st-icon{background:var(--pink-soft);color:#9d174d}
.st-card.v-pink .st-list li::before{background-color:var(--pink-soft);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239d174d' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");box-shadow:inset 0 0 0 1px rgba(255,26,108,.18)}

/* "First clean required" disclaimer - bold callout above the tier grid */
.first-clean-notice{
  background:linear-gradient(135deg, var(--coral-soft) 0%, #fff5fa 100%);
  border:1px solid rgba(255,26,108,.25);border-radius:18px;
  padding:18px 24px;margin:0 0 24px;
  display:flex;gap:16px;align-items:flex-start;
}
@media (max-width:520px){.first-clean-notice{flex-direction:column;padding:18px;gap:10px}}
.first-clean-notice .fcn-icon{
  flex-shrink:0;width:36px;height:36px;border-radius:10px;
  background:var(--coral);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(255,26,108,.35);
}
.first-clean-notice .fcn-icon svg{width:18px;height:18px}
.first-clean-notice p{margin:0;color:var(--ink-2);font-size:14px;line-height:1.55}
.first-clean-notice strong{color:var(--ink);font-weight:600}

/* Walkthrough disclosure - universal "we quote on-site" pattern */
.walkthrough-notice{
  margin-top:40px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:26px 28px;display:flex;gap:20px;align-items:flex-start;
  box-shadow:0 1px 2px rgba(14,26,31,.04);
}
@media (max-width:520px){.walkthrough-notice{flex-direction:column;padding:22px;gap:14px}}
.walkthrough-notice .wt-icon{
  flex-shrink:0;width:50px;height:50px;border-radius:13px;
  background:linear-gradient(135deg, var(--teal), var(--teal-2));color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px rgba(91,191,181,.35);
}
.walkthrough-notice .wt-icon svg{width:22px;height:22px}
.walkthrough-notice h4{margin:0 0 8px;font-size:17px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.walkthrough-notice p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.6;max-width:680px}
.walkthrough-notice strong{color:var(--ink-2);font-weight:600}
.walkthrough-notice a{color:var(--teal-2);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
.walkthrough-notice a:hover{color:var(--ink)}

/* Paint product badge - used on painting.html to call out Sherwin Williams */
.product-badge{
  display:inline-flex;align-items:center;gap:12px;
  padding:10px 16px 10px 12px;border-radius:50px;
  background:#fff;border:1px solid var(--line);
  box-shadow:0 4px 12px rgba(14,26,31,.06);
  font-size:13.5px;font-weight:500;color:var(--ink-2);
}
.product-badge .pb-icon{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg, var(--coral), #c83cc4);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.product-badge .pb-icon svg{width:16px;height:16px}
.product-badge strong{color:var(--ink);font-weight:700}

/* ============================================================
   CROSS-SELL CARDS - "Already on the truck" section on service pages
   ============================================================ */
.cross-sell-grid{
  display:grid;gap:18px;
  grid-template-columns:1fr;margin-top:8px;
}
@media (min-width:600px){.cross-sell-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1080px){.cross-sell-grid{grid-template-columns:repeat(4,1fr)}}

.cross-sell-card{
  position:relative;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:22px;
  padding:28px 24px 24px;
  display:flex;flex-direction:column;gap:14px;
  overflow:hidden;
  text-decoration:none;color:var(--ink);
  transition:transform .28s cubic-bezier(.16,.84,.44,1), box-shadow .28s ease, border-color .2s;
}
/* Accent strip across the top - colored per service variant */
.cross-sell-card::before{
  content:"";position:absolute;top:0;left:24px;right:24px;height:3px;
  background:linear-gradient(90deg, var(--teal) 0%, var(--teal-2) 100%);
  border-radius:0 0 3px 3px;
  opacity:.9;
}
/* Soft radial wash that lights up on hover */
.cross-sell-card::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 70% at 100% 0%, rgba(91,191,181,.08) 0%, transparent 60%);
  opacity:0;transition:opacity .35s ease;pointer-events:none;
}
.cross-sell-card:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 50px rgba(14,26,31,.10), 0 2px 8px rgba(14,26,31,.05);
  border-color:rgba(91,191,181,.42);
}
.cross-sell-card:hover::after{opacity:1}
.cross-sell-card:active{transform:translateY(-3px)}

.cross-sell-card .cs-icon{
  width:48px;height:48px;border-radius:14px;flex-shrink:0;
  background:var(--teal-soft);color:var(--teal-2);
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(14,26,31,.03);
  position:relative;z-index:1;
}
.cross-sell-card .cs-icon svg{width:24px;height:24px}
.cross-sell-card h3{
  margin:0;font-size:19px;font-weight:600;letter-spacing:-.015em;
  color:var(--ink);line-height:1.2;
  position:relative;z-index:1;
}
.cross-sell-card p{
  margin:0;color:var(--muted);font-size:14px;line-height:1.5;
  position:relative;z-index:1;
}
.cross-sell-card .more{
  margin-top:auto;padding-top:10px;
  font-size:13.5px;font-weight:600;color:var(--teal-2);
  display:inline-flex;align-items:center;gap:6px;
  position:relative;z-index:1;
}
.cross-sell-card .more svg{width:14px;height:14px;transition:translate .25s ease}
.cross-sell-card:hover .more svg{translate:4px 0}

/* Color variants - accent strip + icon tint + "more" link match each service */
.cross-sell-card.cs-clean::before{background:linear-gradient(90deg, var(--teal) 0%, var(--teal-2) 100%)}
.cross-sell-card.cs-clean .cs-icon{background:var(--teal-soft);color:var(--teal-2)}
.cross-sell-card.cs-clean .more{color:var(--teal-2)}

.cross-sell-card.cs-paint::before{background:linear-gradient(90deg, var(--coral) 0%, var(--coral-2) 100%)}
.cross-sell-card.cs-paint .cs-icon{background:var(--coral-soft);color:var(--coral)}
.cross-sell-card.cs-paint .more{color:var(--coral)}

.cross-sell-card.cs-paver::before{background:linear-gradient(90deg, var(--violet) 0%, var(--violet-2) 100%)}
.cross-sell-card.cs-paver .cs-icon{background:var(--violet-soft);color:var(--violet-2)}
.cross-sell-card.cs-paver .more{color:var(--violet-2)}

.cross-sell-card.cs-car::before{background:linear-gradient(90deg, var(--gold) 0%, #d97706 100%)}
.cross-sell-card.cs-car .cs-icon{background:#fef3c7;color:#92400e}
.cross-sell-card.cs-car .more{color:#92400e}

.cross-sell-card.cs-commercial::before{background:linear-gradient(90deg, #ec4899 0%, var(--coral) 100%)}
.cross-sell-card.cs-commercial .cs-icon{background:var(--pink-soft);color:#9d174d}
.cross-sell-card.cs-commercial .more{color:#9d174d}

.cross-sell-card.cs-construction::before{background:linear-gradient(90deg, #3b82f6 0%, #1e40af 100%)}
.cross-sell-card.cs-construction .cs-icon{background:#dbeafe;color:#1e40af}
.cross-sell-card.cs-construction .more{color:#1e40af}

.cross-sell-card.cs-watch::before{background:linear-gradient(90deg, var(--teal) 0%, var(--violet) 100%)}
.cross-sell-card.cs-watch .cs-icon{background:linear-gradient(135deg, var(--teal-soft) 0%, var(--violet-soft) 100%);color:var(--teal-2)}
.cross-sell-card.cs-watch .more{color:var(--teal-2)}

/* Hurricane emergency callout (home-watch + pricing pages) */
.storm-callout{
  position:relative;
  margin-top:32px;
  padding:32px;
  border-radius:var(--r-lg);
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(255,0,118,.18) 0%, transparent 55%),
    radial-gradient(80% 80% at 0% 100%, rgba(139,92,246,.18) 0%, transparent 55%),
    linear-gradient(140deg, #0a1417 0%, #14242a 60%, #18272d 100%);
  color:#f0f4f3;
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
  display:grid;gap:24px;grid-template-columns:1fr;align-items:center;
}
@media (min-width:760px){.storm-callout{grid-template-columns:1.5fr 1fr;gap:36px;padding:40px}}
.storm-callout::before{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 400' fill='none' stroke='%23ffffff' stroke-opacity='.04' stroke-width='1'><circle cx='200' cy='200' r='40'/><circle cx='200' cy='200' r='90'/><circle cx='200' cy='200' r='140'/><circle cx='200' cy='200' r='190'/></svg>") center/cover no-repeat;
  pointer-events:none;
}
.storm-callout > *{position:relative;z-index:1}
.storm-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--coral);color:#fff;
  font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 14px;border-radius:50px;
  width:fit-content;
  box-shadow:0 6px 18px rgba(255,0,118,.4);
}
.storm-badge::before{content:"";width:7px;height:7px;border-radius:50%;background:#fff;
  animation:storm-pulse 1.6s ease-in-out infinite;
}
@keyframes storm-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.storm-callout h3{color:#fff;font-size:26px;font-weight:600;letter-spacing:-.02em;margin:14px 0 8px;line-height:1.2}
.storm-callout h3 .serif{color:var(--coral-2);font-style:italic}
.storm-callout p{color:#bdd0ce;font-size:15px;line-height:1.55;margin:0}
.storm-callout .req{
  margin-top:14px;
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 16px;border-radius:12px;
  background:rgba(245,158,11,.10);
  border:1px solid rgba(245,158,11,.32);
  color:#fce8be;font-size:13.5px;line-height:1.5;
}
.storm-callout .req svg{width:18px;height:18px;color:var(--gold);flex-shrink:0;margin-top:1px}
.storm-side{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;padding:24px;
  display:flex;flex-direction:column;gap:14px;text-align:center;
}
.storm-side .storm-price{display:flex;align-items:baseline;justify-content:center;gap:6px}
.storm-side .storm-price .num{font-size:46px;font-weight:700;letter-spacing:-.02em;color:#fff;font-family:'Instrument Serif',serif;font-style:italic;line-height:1}
.storm-side .storm-price .unit{font-size:13px;color:#9bb0ae;font-weight:500}
.storm-side .storm-label{font-size:11px;color:#9bb0ae;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin:0}
.storm-side .storm-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 20px;border-radius:14px;
  background:var(--coral);color:#fff;
  font-weight:700;font-size:14.5px;letter-spacing:-.005em;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease;
  box-shadow:0 8px 22px rgba(255,0,118,.35);
}
.storm-side .storm-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(255,0,118,.5)}
.storm-side .storm-btn svg{width:16px;height:16px}

/* Industry chips (commercial page) */
.industry-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:8px}
.ind-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:50px;
  background:var(--surface);
  border:1px solid var(--line);
  font-size:13.5px;font-weight:500;color:var(--ink-2);
  letter-spacing:-.005em;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  box-shadow:var(--shadow-1);
}
.ind-chip svg{width:16px;height:16px;color:var(--teal-2);flex-shrink:0}
.ind-chip:hover{transform:translateY(-2px);border-color:rgba(93,193,185,.4);box-shadow:var(--shadow-2)}

/* Commercial pricing breakdown - 4-card grid */
.cm-pricing-grid{
  display:grid;gap:18px;
  grid-template-columns:1fr;
  margin-top:8px;
}
@media (min-width:680px){.cm-pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1080px){.cm-pricing-grid{grid-template-columns:repeat(4,1fr)}}
.cm-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:28px 26px;
  display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.cm-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--teal) 0%, var(--teal-2) 100%);
  opacity:.8;
}
.cm-card.cm-featured::before{background:linear-gradient(90deg, var(--coral) 0%, var(--pink) 100%);height:4px}
.cm-card.cm-featured{border-color:rgba(255,0,118,.18);box-shadow:0 12px 32px rgba(255,0,118,.08)}
.cm-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:rgba(93,193,185,.3)}
.cm-card-head{display:flex;align-items:center;gap:12px}
.cm-card-ic{
  width:38px;height:38px;border-radius:10px;
  background:var(--teal-soft);color:var(--teal-2);
  display:flex;align-items:center;justify-content:center;
}
.cm-card-ic svg{width:20px;height:20px}
.cm-card.cm-featured .cm-card-ic{background:var(--coral-soft);color:var(--coral)}
.cm-card h4{margin:0;font-size:17px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.cm-card-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;color:var(--muted);margin:0}
.cm-rows{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.cm-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px;font-size:14px;border-bottom:1px dashed var(--line);padding-bottom:8px}
.cm-row:last-child{border-bottom:none;padding-bottom:0}
.cm-row span:first-child{color:var(--muted)}
.cm-row strong{color:var(--ink);font-weight:600;font-size:14.5px;white-space:nowrap}
.cm-card-foot{
  margin-top:6px;padding-top:14px;border-top:1px solid var(--line);
  font-size:13px;color:var(--muted);line-height:1.5;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  .hero h1 .ch{opacity:1;transform:none;filter:none}
}
