:root{
  --font-display:"Inter",system-ui,-apple-system,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
  /* Clearstyle brand palette, sourced from book.clearstyle.com.au */
  --ink:#063231;--ink2:#0A4A40;--slate:#3A4D48;--line:#E1E8E6;--paper:#F6F7F7;--paper2:#E9EFED;
  --accent:#B4F625;--accent-dark:#4F6B16;--on-accent:#063231;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;font-size:125%}
@media(max-width:480px){html{font-size:112.5%}}
html,body{overflow-x:hidden}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none;padding:0;margin:0}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
.cs-container{max-width:1280px;margin:0 auto;padding:0 1.25rem}
@media (min-width:768px){.cs-container{padding:0 2rem}}

.font-display{font-family:var(--font-display);letter-spacing:-0.02em}

/* Buttons */
.btn-primary,.btn-ghost,.btn-accent{display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem;font-family:var(--font-display);font-weight:700;font-size:.92rem;letter-spacing:.02em;
  text-transform:uppercase;padding:.95rem 1.5rem;border-radius:999px;transition:all .22s ease;border:1px solid transparent}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:hover{background:var(--accent);color:var(--on-accent);border-color:var(--accent);transform:translateY(-2px);
  box-shadow:0 16px 30px -10px rgba(180,246,37,.5)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-accent{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.btn-accent:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px);
  box-shadow:0 16px 30px -10px rgba(6,50,49,.4)}
.btn-white-outline{display:inline-flex;align-items:center;gap:.5rem;padding:.95rem 1.5rem;border-radius:999px;
  border:1px solid rgba(255,255,255,.3);color:#fff;font-family:var(--font-display);font-weight:700;
  text-transform:uppercase;font-size:.92rem;letter-spacing:.02em;transition:all .22s}
.btn-white-outline:hover{background:#fff;color:var(--ink);border-color:#fff}

.eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.22em;
  font-size:.72rem;font-weight:700;color:var(--accent-dark)}
.section-title{font-family:var(--font-display);font-weight:800;letter-spacing:-0.025em;
  font-size:clamp(2rem,4.5vw,3.5rem);line-height:1.04;margin:.75rem 0 0}

/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:50;transition:all .3s ease;background:transparent}
header.scrolled{background:rgba(247,246,242,.78);backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);border-bottom:1px solid rgba(15,23,42,.07);
  box-shadow:0 4px 30px rgba(15,23,42,.06)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
@media(min-width:768px){.nav-inner{height:80px}}
.logo-img{height:52px;width:auto;transition:filter .3s}
@media(min-width:768px){.logo-img{height:60px}}
header:not(.scrolled) .logo-img{filter:brightness(0) invert(1)}
.nav-desktop{display:none}
@media(min-width:1024px){.nav-desktop{display:flex;gap:1.4rem;align-items:center}}
.nav-link{font-size:.85rem;font-weight:500;color:var(--slate);position:relative;padding:.25rem 0}
.nav-link::after{content:"";position:absolute;left:0;bottom:-4px;height:2px;width:0;background:var(--accent);transition:width .3s}
.nav-link:hover{color:var(--ink)}
.nav-link:hover::after{width:100%}
header:not(.scrolled) .nav-link{color:rgba(255,255,255,.85)}
header:not(.scrolled) .nav-link:hover{color:#fff}
.header-ctas{display:flex;align-items:center;gap:.5rem}
@media(min-width:768px){.header-ctas{gap:.75rem}}
.header-call{display:none;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:700;font-size:.92rem;white-space:nowrap}
@media(min-width:640px){.header-call{display:inline-flex}}
header:not(.scrolled) .header-call{color:#fff}
header.scrolled .header-call{color:var(--ink)}
.header-quote{padding:.65rem 1.1rem;font-size:.78rem}
@media(min-width:768px){.header-quote{padding:.78rem 1.25rem;font-size:.88rem}}
.mobile-toggle{padding:.5rem;color:var(--ink)}
header:not(.scrolled) .mobile-toggle{color:#fff}
@media(min-width:1024px){.mobile-toggle{display:none}}

.mobile-menu{display:none;background:rgba(247,246,242,.95);backdrop-filter:blur(18px);
  border-top:1px solid var(--line)}
.mobile-menu.open{display:block}
.mobile-menu .cs-container{padding-top:1rem;padding-bottom:1rem}
.mobile-menu .nav-link{display:block;padding:.85rem 0;font-size:1rem;color:var(--ink);border-bottom:1px solid var(--line)}
.mobile-menu .nav-link:last-of-type{border-bottom:0}

/* Hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;padding:6rem 0 3rem;color:#fff;overflow:hidden;isolation:isolate}
@media(min-width:768px){.hero{padding-bottom:5rem}}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,50,49,.78) 0%,rgba(6,50,49,.34) 44%,rgba(6,50,49,.06) 100%)}
.hero-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(180,246,37,.12),transparent 60%)}
.hero .cs-container{position:relative;z-index:1}
.hero-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border-radius:999px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(8px);
  font-size:.82rem;color:rgba(255,255,255,.9);margin-bottom:1.5rem}
.hero-pill svg{width:14px;height:14px;color:var(--accent)}
.hero h1{font-family:var(--font-display);font-weight:800;letter-spacing:-0.03em;line-height:.98;
  font-size:clamp(2.1rem,5vw,3.85rem);margin:0;max-width:54rem;text-shadow:0 2px 30px rgba(6,50,49,.5)}
.hero h1 .accent{color:var(--accent);text-shadow:0 2px 18px rgba(6,50,49,.55)}
.hero p.lead{margin:1.5rem 0 0;font-size:clamp(1.05rem,1.6vw,1.25rem);max-width:42rem;color:rgba(255,255,255,.85);font-weight:300;line-height:1.55}
.hero p.lead b{font-weight:500;color:#fff}
.hero-ctas{display:flex;flex-direction:column;gap:.75rem;margin-top:2.25rem}
@media(min-width:640px){.hero-ctas{flex-direction:row}}
.hero-stats{display:flex;flex-wrap:wrap;align-items:center;gap:1.25rem;margin-top:2.5rem;color:rgba(255,255,255,.8)}
.hero-stats .star-row{display:flex;align-items:center;gap:.15rem}
.hero-stats svg{width:16px;height:16px;color:var(--accent);fill:var(--accent)}
.hero-stats .star-row svg.gstar{width:19px;height:19px;fill:#FBBC04;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}
.hero-stats .sep{height:16px;width:1px;background:rgba(255,255,255,.2);display:none}
@media(min-width:640px){.hero-stats .sep{display:block}}
.hero-stats span{font-size:.88rem;font-weight:500}

/* Mobile: tighten hero so all CTAs (incl. Watch Customer Videos) fit above the sticky bar */
@media(max-width:767px){
  .hero{align-items:center;padding:5rem 0 4rem}
  .hero-pill{margin-bottom:1rem}
  .hero h1{font-size:clamp(1.9rem,8.4vw,2.6rem);line-height:1.02}
  .hero p.lead{margin-top:.9rem;font-size:1rem;line-height:1.45}
  .hero-ctas{margin-top:1.4rem;gap:.6rem}
  /* Call Paul is already in the sticky bottom bar on mobile — hide the
     redundant hero button so "Watch Customer Videos" stays above the fold */
  .hero-ctas .hero-call{display:none}
  .hero-stats{margin-top:1.4rem;gap:.9rem}
}

/* Trust bar */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;padding:2.5rem 0 3rem}
.trust-top{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}
@media(min-width:768px){.trust-top{flex-direction:row;align-items:center;justify-content:space-between}}
.trust-top h2{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--ink);max-width:32rem;line-height:1.15;margin:.5rem 0 0}
.trust-stats{display:grid;grid-template-columns:repeat(3,auto);gap:0 1.75rem}
.trust-stats div{text-align:center}
@media(min-width:768px){.trust-stats div{text-align:left}}
.trust-stats .num{font-family:var(--font-display);font-weight:800;font-size:clamp(1.5rem,3vw,2rem);color:var(--ink)}
.trust-stats .lbl{font-family:var(--font-display);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--accent-dark);margin-top:.25rem}
.trust-slider{position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(to right,transparent,#000 7%,#000 93%,transparent)}
.trust-track{display:flex;width:max-content;align-items:center;gap:2.5rem;animation:trustScroll 34s linear infinite}
@media(min-width:768px){.trust-track{gap:4.5rem}}
.trust-slider:hover .trust-track{animation-play-state:paused}
.trust-track li{flex:0 0 auto;display:flex;align-items:center;justify-content:center;height:120px;
  filter:grayscale(1);opacity:.85;transition:all .3s}
@media(min-width:768px){.trust-track li{height:170px}}
.trust-track li:hover{filter:none;opacity:1}
.trust-track img{max-height:100%;width:auto;max-width:none;object-fit:contain}
@keyframes trustScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.trust-track{animation:none;flex-wrap:wrap;justify-content:center;width:100%}}

/* Generic section */
section.pad{padding:5rem 0}
@media(min-width:768px){section.pad{padding:7rem 0}}
@media(min-width:1024px){section.pad{padding:8rem 0}}

/* Why */
.why-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center}
@media(min-width:1024px){.why-grid{grid-template-columns:5fr 7fr;gap:4rem}}
.why-portrait{position:relative;aspect-ratio:4/5;border-radius:1rem;overflow:hidden;background:var(--paper2)}
.why-portrait img{width:100%;height:100%;object-fit:cover}
.why-portrait-overlay{position:absolute;inset:auto 0 0 0;padding:1.5rem;
  background:linear-gradient(to top,rgba(6,50,49,.9),transparent);color:#fff}
.why-portrait-overlay .name{font-family:var(--font-display);font-weight:700;font-size:1.25rem}
.why-portrait-overlay .role{font-size:.88rem;color:rgba(255,255,255,.75)}
.why-stat-card{display:none;position:absolute;bottom:-2rem;right:-1.5rem;background:#fff;
  border:1px solid var(--line);border-radius:1rem;padding:1.25rem;box-shadow:0 20px 40px -15px rgba(0,0,0,.15);width:14rem}
@media(min-width:768px){.why-stat-card{display:block}}
.why-stat-card a{display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--ink);margin-top:.25rem}
.why-stat-card a:hover{color:var(--accent-dark)}
.why-points{display:grid;grid-template-columns:1fr;gap:1rem 1.5rem;margin-top:2rem}
@media(min-width:640px){.why-points{grid-template-columns:1fr 1fr}}
.why-points li{display:flex;gap:.75rem;color:var(--slate)}
.why-points svg{width:18px;height:18px;color:var(--accent-dark);flex-shrink:0;margin-top:4px}
.why-points span{font-size:.98rem;line-height:1.5}

/* Services */
.services{background:#fff}
.services-head{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}
@media(min-width:768px){.services-head{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.services-head p{max-width:28rem;color:var(--slate);font-size:1rem}
@media(min-width:768px){.services-head p{font-size:1.1rem}}
.services-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:640px){.services-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.services-grid{grid-template-columns:repeat(3,1fr);gap:1.75rem}}
.svc-card{position:relative;overflow:hidden;border-radius:1rem;border:1px solid var(--line);
  background:#fff;transition:all .5s}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 25px 50px -12px rgba(0,0,0,.15)}
.svc-card .img-box{aspect-ratio:4/3;overflow:hidden;background:var(--paper2)}
.svc-card .img-box img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.svc-card:hover .img-box img{transform:scale(1.05)}
.svc-card .tag{position:absolute;top:1rem;left:1rem;background:var(--accent);color:var(--on-accent);
  font-family:var(--font-display);font-weight:700;font-size:.62rem;letter-spacing:.15em;
  text-transform:uppercase;padding:.3rem .65rem;border-radius:999px}
.svc-card .body{padding:1.5rem}
.svc-card .head{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}
.svc-card h3{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--ink);margin:0;line-height:1.2}
.svc-card .arrow{color:var(--slate);transition:all .3s}
.svc-card:hover .arrow{color:var(--accent);transform:rotate(12deg)}
.svc-card .blurb{color:var(--slate);font-size:.88rem;line-height:1.55;margin:.5rem 0 0}
.svc-card .pricing{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:baseline;gap:.75rem}
.svc-card .from{font-family:var(--font-display);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--accent-dark)}
.svc-card .price{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--ink)}
.svc-card .value{font-size:.78rem;color:var(--accent-dark);font-weight:500}
.services-cta{margin-top:3rem;text-align:center}
.services-cta .small{margin-top:1rem;font-size:.88rem;color:var(--slate)}

/* Testimonials */
.testimonials{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.testimonials::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at top left,rgba(180,246,37,.16),transparent 55%);pointer-events:none}
.testimonials .cs-container{position:relative}
.testimonials-head{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}
@media(min-width:768px){.testimonials-head{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.testimonials-head .eyebrow{color:var(--accent)}
.testimonials-head h2{color:#fff}
.testimonials-head p{margin-top:1rem;color:rgba(255,255,255,.7);max-width:32rem}
.testimonials-head p .gold{color:var(--accent);font-weight:500}
.t-nav{display:flex;gap:.5rem}
.t-nav button{width:48px;height:48px;border-radius:999px;border:1px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;transition:all .25s;color:#fff}
.t-nav button:hover{background:#fff;color:var(--ink)}
.testimonial-card{display:grid;grid-template-columns:1fr;gap:2rem;align-items:stretch}
@media(min-width:768px){.testimonial-card{grid-template-columns:4fr 8fr;gap:3.5rem}}
.t-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:1rem;
  padding:2rem;display:flex;flex-direction:column;justify-content:space-between}
.t-stat .quote-icon{width:40px;height:40px;color:var(--accent)}
.t-stat .num{font-family:var(--font-display);font-weight:800;font-size:clamp(2.5rem,5vw,3.75rem);color:var(--accent);line-height:1;margin-top:2rem}
.t-stat .num-label{color:rgba(255,255,255,.75);font-size:.88rem;margin-top:.5rem}
.t-stat .stars{display:flex;align-items:center;gap:.25rem;margin-top:1.5rem}
.t-stat .stars svg{width:16px;height:16px;color:var(--accent);fill:var(--accent)}
.t-stat .stars small{margin-left:.5rem;color:rgba(255,255,255,.6);font-size:.78rem}
.t-body{display:flex;flex-direction:column;justify-content:center}
.t-body h3{font-family:var(--font-display);font-weight:800;font-size:clamp(1.5rem,3vw,2.25rem);color:#fff;line-height:1.18;margin:0;letter-spacing:-0.02em}
.t-body p.quote{margin-top:1.5rem;color:rgba(255,255,255,.8);font-size:1.05rem;line-height:1.6;max-width:42rem}
.t-meta{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}
.t-meta .who{font-family:var(--font-display);font-weight:700;color:#fff}
.t-meta .where{font-size:.88rem;color:rgba(255,255,255,.6)}
.t-meta .ix{color:rgba(255,255,255,.5);font-size:.88rem}
.t-dots{margin-top:2.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}
.t-dots button{height:6px;border-radius:999px;width:16px;background:rgba(255,255,255,.2);transition:all .3s}
.t-dots button.active{width:40px;background:var(--accent)}
.reviews-live{margin-top:3.5rem;padding-top:3rem;border-top:1px solid rgba(255,255,255,.1)}
.reviews-live-head{text-align:center;margin-bottom:2rem}
.reviews-live-head .eyebrow{color:var(--accent)}
.reviews-live-head h3{font-family:var(--font-display);font-weight:800;letter-spacing:-0.02em;color:#fff;
  font-size:clamp(1.4rem,3vw,2rem);line-height:1.15;margin:.6rem 0 0}

/* Projects */
.projects-head{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}
@media(min-width:768px){.projects-head{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.projects-head p{max-width:28rem;color:var(--slate)}
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:200px;gap:.75rem}
@media(min-width:768px){.proj-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:1.25rem}}
.proj-tile{position:relative;overflow:hidden;border-radius:1rem;background:var(--paper2)}
.proj-tile.big{grid-column:span 2;grid-row:span 2}
.proj-tile img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.proj-tile:hover img{transform:scale(1.05)}
.proj-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,50,49,.85),transparent 55%)}
.proj-meta{position:absolute;left:0;right:0;bottom:0;padding:1rem;color:#fff;z-index:1}
@media(min-width:768px){.proj-meta{padding:1.5rem}}
.proj-meta .where{display:flex;align-items:center;gap:.35rem;font-family:var(--font-display);font-weight:700;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.proj-meta .where svg{width:12px;height:12px}
.proj-meta .what{margin-top:.4rem;font-family:var(--font-display);font-weight:700;font-size:1rem}
@media(min-width:768px){.proj-meta .what{font-size:1.1rem}}
.projects-cta{margin-top:3rem;text-align:center}

/* Process */
.process{background:#fff}
.process-head{max-width:32rem;margin-bottom:3.5rem}
.process-head p{margin-top:1rem;color:var(--slate);font-size:1rem}
@media(min-width:768px){.process-head p{font-size:1.1rem}}
.process-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:768px){.process-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.process-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem}}
.process-card{background:var(--paper);border:1px solid var(--line);border-radius:1rem;padding:1.75rem;
  transition:all .5s}
.process-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px -10px rgba(0,0,0,.1)}
.process-card .top{display:flex;justify-content:space-between;align-items:center}
.process-card .n{font-family:var(--font-display);font-weight:800;font-size:1.75rem;color:var(--accent)}
.process-card .icon{color:var(--slate);width:24px;height:24px}
.process-card h3{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--ink);margin:1.5rem 0 0}
.process-card .dur{font-family:var(--font-display);font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--accent-dark);margin-top:.25rem}
.process-card p{font-size:.88rem;color:var(--slate);line-height:1.6;margin:.75rem 0 0}


/* FAQ */
.faq-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:1024px){.faq-grid{grid-template-columns:4fr 8fr;gap:4rem}}
.faq-left p{margin-top:1.25rem;color:var(--slate);font-size:1rem}
@media(min-width:768px){.faq-left p{font-size:1.1rem}}
.faq-left a.phone{display:inline-flex;align-items:center;font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--ink);margin-top:1.25rem}
.faq-left a.phone:hover{color:var(--accent-dark)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;
  font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--ink);padding:1.25rem 0}
@media(min-width:768px){.faq-q{font-size:1.1rem}}
.faq-q svg{width:18px;height:18px;flex-shrink:0;transition:transform .3s}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--slate);font-size:1rem;line-height:1.6}
.faq-item.open .faq-a{max-height:600px;padding-bottom:1.25rem}

/* Areas */
.areas{background:#fff}
.areas-head{max-width:32rem;margin-bottom:3rem}
.areas-head p{margin-top:1rem;color:var(--slate);font-size:1rem}
@media(min-width:768px){.areas-head p{font-size:1.1rem}}
.areas-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:768px){.areas-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.areas-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem}}
.area-card{position:relative;border-radius:1rem;padding:1.75rem;border:1px solid var(--line);background:var(--paper);transition:all .5s}
.area-card.primary{background:var(--paper2);border-color:rgba(180,246,37,.4)}
.area-card:hover{transform:translateY(-4px)}
.area-card .top{display:flex;align-items:center;justify-content:space-between}
.area-card .pin{width:40px;height:40px;border-radius:999px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.area-card .pin svg{width:16px;height:16px;color:var(--accent-dark)}
.area-card .badge{font-family:var(--font-display);font-weight:700;font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent-dark);background:#fff;padding:.25rem .65rem;border-radius:999px;border:1px solid rgba(180,246,37,.45)}
.area-card h3{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--ink);margin:1.25rem 0 0}
.area-card p{margin:.5rem 0 0;color:var(--slate);font-size:.88rem;line-height:1.55}

/* Contact */
.contact-section{background:var(--paper2)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:1024px){.contact-grid{grid-template-columns:5fr 7fr;gap:3.5rem}}
.contact-left p.lead{margin-top:1.25rem;color:var(--slate);font-size:1rem;max-width:30rem}
@media(min-width:768px){.contact-left p.lead{font-size:1.1rem}}
.contact-cards{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}
.contact-card{display:flex;align-items:flex-start;gap:1rem;background:#fff;border-radius:1rem;
  padding:1.25rem;border:1px solid var(--line);transition:all .3s}
.contact-card:hover{border-color:var(--accent)}
.contact-card .icon-wrap{width:44px;height:44px;border-radius:999px;background:var(--ink);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s}
.contact-card:hover .icon-wrap{background:var(--accent);color:var(--on-accent)}
.contact-card .icon-wrap svg{width:20px;height:20px}
.contact-card .lbl{font-family:var(--font-display);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--accent-dark)}
.contact-card .v{font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:var(--ink);margin-top:.25rem;word-break:break-word}
.contact-card .sub{font-size:.78rem;color:var(--slate);margin-top:.15rem}
.map-wrap{margin-top:1.5rem;border:1px solid var(--line);border-radius:1rem;overflow:hidden;background:#fff}
.map-wrap iframe{display:block;width:100%;height:260px;border:0}
.form-card{background:#fff;border:1px solid var(--line);border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px rgba(0,0,0,.05)}
@media(min-width:768px){.form-card{padding:2rem}}
@media(min-width:1024px){.form-card{padding:2.5rem}}
.form-card h3{font-family:var(--font-display);font-weight:800;font-size:clamp(1.5rem,2.5vw,2rem);color:var(--ink);line-height:1.2;margin:0}
.form-card p{margin-top:.5rem;font-size:.94rem;color:var(--slate)}
.elfsight-wrap{min-height:540px;margin-top:1.5rem}
.form-fine{margin-top:1rem;font-size:.7rem;color:var(--slate);line-height:1.55}

/* Footer */
footer{background:var(--ink);color:#fff;padding:4rem 0 2.5rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:768px){.footer-grid{grid-template-columns:5fr 3fr 4fr}}
.footer-logo{height:40px;filter:brightness(0) invert(1);margin-bottom:1.25rem}
footer p.intro{max-width:22rem;font-size:.88rem;line-height:1.6;color:rgba(255,255,255,.65)}
.footer-contacts{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}
.footer-contacts a{display:flex;align-items:center;gap:.75rem;color:rgba(255,255,255,.85);transition:color .25s;font-size:.92rem}
.footer-contacts a:hover{color:var(--accent)}
.footer-contacts a svg{width:16px;height:16px}
footer .col h4{font-family:var(--font-display);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.22em;color:var(--accent);margin:0}
footer .col ul{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}
footer .col li,footer .col a{font-size:.88rem;color:rgba(255,255,255,.75)}
footer .col a:hover{color:#fff}
.license-note{margin-top:1.5rem;font-size:.78rem;color:rgba(255,255,255,.55);line-height:1.5}
.footer-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);
  display:flex;flex-direction:column;justify-content:space-between;gap:1rem;font-size:.78rem;color:rgba(255,255,255,.5)}
@media(min-width:768px){.footer-bottom{flex-direction:row;align-items:center}}

/* Sticky mobile CTA */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:40;background:var(--ink);
  border-top:1px solid rgba(255,255,255,.1);padding:.6rem .75rem;display:grid;grid-template-columns:1fr 1fr;gap:.5rem;
  box-shadow:0 -10px 30px rgba(0,0,0,.18)}
@media(min-width:768px){.sticky-cta{display:none}}
.sticky-cta a{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;border-radius:999px;
  font-family:var(--font-display);font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}
.sticky-cta a.call{background:#fff;color:var(--ink)}
.sticky-cta a.quote{background:var(--accent);color:var(--on-accent)}
.sticky-cta svg{width:16px;height:16px}

body{padding-bottom:0}
@media(max-width:767px){body{padding-bottom:72px}}

/* Reveal */
@keyframes csFadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.cs-reveal{animation:csFadeUp .9s cubic-bezier(.22,1,.36,1) both}
.d1{animation-delay:.12s}.d2{animation-delay:.24s}.d3{animation-delay:.36s}.d4{animation-delay:.48s}

/* Quote popup modal */
.qp-overlay{position:fixed;inset:0;z-index:100;display:none;align-items:flex-start;justify-content:center;
  padding:1.25rem;background:rgba(6,50,49,.62);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);overflow-y:auto}
.qp-overlay.open{display:flex}
.qp-modal{position:relative;background:#fff;width:100%;max-width:560px;margin:auto;border-radius:1.25rem;
  box-shadow:0 40px 90px -20px rgba(0,0,0,.55);animation:qpIn .45s cubic-bezier(.22,1,.36,1) both;overflow:hidden}
@keyframes qpIn{from{opacity:0;transform:translateY(26px) scale(.98)}to{opacity:1;transform:none}}
.qp-head{padding:1.85rem 1.85rem 1.15rem;background:var(--ink);color:#fff}
.qp-head .eyebrow{color:var(--accent)}
.qp-head h3{font-family:var(--font-display);font-weight:800;letter-spacing:-0.02em;
  font-size:clamp(1.4rem,3vw,1.95rem);line-height:1.15;margin:.5rem 0 0}
.qp-head p{margin:.5rem 0 0;font-size:.92rem;color:rgba(255,255,255,.78);line-height:1.5}
.qp-body{padding:1.5rem 1.85rem 1.85rem;min-height:200px}
.qp-fine{margin-top:1rem;font-size:.7rem;color:var(--slate);line-height:1.55}
.qp-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:999px;
  background:rgba(255,255,255,.14);color:#fff;display:flex;align-items:center;justify-content:center;
  transition:all .25s;z-index:2}
.qp-close:hover{background:#fff;color:var(--ink);transform:rotate(90deg)}
.qp-close svg{width:20px;height:20px}
body.qp-locked{overflow:hidden}
@media(min-width:768px){.qp-overlay{align-items:center}}

/* Video testimonials */
.video-testimonials{background:#fff}
.vt-head{max-width:34rem;margin:0 auto 3rem;text-align:center}
.vt-head p{margin-top:1rem;color:var(--slate);font-size:1rem}
@media(min-width:768px){.vt-head p{font-size:1.1rem}}
.vt-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:760px;margin:0 auto}
@media(min-width:560px){.vt-grid{grid-template-columns:1fr 1fr}}
.vt-card{position:relative;border-radius:1.25rem;overflow:hidden;background:var(--ink);
  box-shadow:0 28px 55px -22px rgba(6,50,49,.45)}
.vt-card wistia-player{display:block;border-radius:1.25rem;overflow:hidden}
.vt-overlay{position:absolute;left:0;right:0;top:0;padding:1.1rem 1.2rem;z-index:2;pointer-events:none;
  background:linear-gradient(to bottom,rgba(6,50,49,.78),transparent)}
.vt-badge{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-display);font-weight:700;
  font-size:.6rem;letter-spacing:.13em;text-transform:uppercase;color:var(--on-accent);background:var(--accent);
  padding:.3rem .6rem;border-radius:999px}
.vt-badge svg{width:12px;height:12px}
.vt-cap{margin-top:.55rem;font-family:var(--font-display);font-weight:700;color:#fff;
  font-size:.92rem;text-shadow:0 1px 4px rgba(0,0,0,.4)}
/* Wistia swatch placeholders (blur-up before player defines) */
wistia-player[media-id='5vf0guwmgg']:not(:defined){background:center / contain no-repeat url('https://fast.wistia.com/embed/medias/5vf0guwmgg/swatch');display:block;filter:blur(5px);padding-top:177.78%}
wistia-player[media-id='zsp9xk9zue']:not(:defined){background:center / contain no-repeat url('https://fast.wistia.com/embed/medias/zsp9xk9zue/swatch');display:block;filter:blur(5px);padding-top:177.78%}
