/* =================================================================
   BANI VENTURE — Design System
   Adapted from Coinbase institutional pattern:
   White canvas, single brand-blue accent, pill CTAs, editorial calm,
   dark/light band rhythm, generous 96px section pacing.
   ================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;600;700&family=Inter:wght@400;500;600;700&family=Space+Mono:wght@400;500;700&display=swap');

:root{
  /* Brand — Deep Steel Blue is the single "voltage" */
  --primary:#364D68;
  --primary-active:#2B3F56;
  --primary-disabled:#8594A2;
  /* Ink & body */
  --ink:#0a0b0d;
  --body:#4B5563;
  --body-strong:#1F1217;
  --muted:#6B7280;
  --muted-soft:#9AA3AE;
  /* Surfaces */
  --canvas:#ffffff;
  --surface-soft:#F5F7FA;
  --surface-card:#ffffff;
  --surface-strong:#EEF2F6;
  --surface-dark:#364D68;
  --surface-dark-deep:#2D4058;
  --on-primary:#ffffff;
  --on-dark:#ffffff;
  --on-dark-soft:#BCD0E0;
  /* Hairlines */
  --hairline:#E2E8F0;
  --hairline-soft:#EEF2F6;
  /* Semantic */
  --up:#3BB273;
  --warn:#F7931E;
  --blue:#00AEEF;
  /* Spacing */
  --sp-xs:8px;--sp-sm:12px;--sp-base:16px;--sp-md:20px;--sp-lg:24px;--sp-xl:32px;--sp-xxl:48px;--sp-section:96px;
  /* Radii — pill for CTAs, xl for cards */
  --r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-pill:100px;--r-full:9999px;
  /* Fonts */
  --display:'Sora',system-ui,sans-serif;
  --text:'Inter',system-ui,sans-serif;
  --mono:'Space Mono',monospace;
  /* Shadow — single tier */
  --shadow-soft:0 4px 12px rgba(0,0,0,.04);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--text);color:var(--body);background:var(--canvas);line-height:1.5;font-size:16px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 var(--sp-lg)}

/* ---- Typography (editorial calm: display at 400) ---- */
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);line-height:1.05;letter-spacing:-.02em}
h1{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:400}
h2{font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:400}
h3{font-size:1.25rem;font-weight:600;font-family:var(--text)}
h4{font-size:1.1rem;font-weight:600;font-family:var(--text)}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);font-weight:500}

/* ---- Buttons — all pills ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--text);font-weight:600;font-size:1rem;padding:12px 24px;height:44px;border-radius:var(--r-pill);transition:background .15s,transform .15s;cursor:pointer;border:none;line-height:1.15}
.btn:focus-visible{outline:3px solid var(--primary);outline-offset:3px}
.btn-primary{background:var(--primary);color:var(--on-primary)}
.btn-primary:hover{background:var(--primary-active);transform:translateY(-1px)}
.btn-wa{background:var(--up);color:#fff}
.btn-wa:hover{background:#2F9A62;transform:translateY(-1px)}
.btn-secondary{background:var(--surface-strong);color:var(--ink)}
.btn-secondary:hover{background:var(--hairline)}
.btn-outline{background:transparent;color:var(--on-dark);border:1px solid rgba(255,255,255,.3)}
.btn-outline:hover{border-color:#fff}
.btn-dark{background:var(--surface-dark-deep);color:var(--on-dark)}
.btn-dark:hover{background:var(--primary)}
.btn-hero{height:56px;padding:16px 32px;font-size:1.05rem}
.btn-text{background:none;border:none;color:var(--primary);font-weight:600;font-family:var(--text);cursor:pointer;padding:0}

/* ---- Header ---- */
header{position:sticky;top:0;z-index:60;background:#0a0b0d;border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(12px)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:.5rem}
.brand img.logo{height:36px;width:auto}
.navlinks{display:flex;gap:var(--sp-lg);align-items:center}
.navlinks a{color:rgba(255,255,255,.75);font-size:.875rem;font-weight:500;transition:color .15s}
.navlinks a:hover,.navlinks a.active{color:#fff}
.nav-cta{display:flex;align-items:center;gap:var(--sp-sm)}
.phone-top{font-family:var(--mono);color:rgba(255,255,255,.6);font-weight:500;font-size:.85rem;white-space:nowrap}
.menu-btn{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;line-height:1}
#mobnav{display:none;background:#0a0b0d;border-bottom:1px solid rgba(255,255,255,.08)}
#mobnav.open{display:block}
#mobnav a{display:block;padding:14px var(--sp-lg);color:rgba(255,255,255,.7);border-top:1px solid rgba(255,255,255,.06);font-weight:500;font-size:.95rem}
#mobnav a:hover{color:#fff}

/* ---- Hero (full-width bg image) ---- */
.hero-photo{
  position:relative;
  height:100vh;
  min-height:640px;
  display:flex;align-items:center;
  background:
    url('hero-bg.png') right center / 50% auto no-repeat,
    #0a0b0d;
  background-attachment: fixed, fixed;
  overflow:hidden;
}
/* dark overlay so text stays readable */
.hero-photo::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(
    to right,
    rgba(10,11,13,1) 0%,
    rgba(10,11,13,.92) 45%,
    rgba(10,11,13,.55) 70%,
    rgba(10,11,13,.2) 100%
  );
  z-index:1;pointer-events:none;
}
/* animated glow */
.hero-photo::after{
  content:"";
  position:absolute;
  top:-100px;left:-60px;
  width:600px;height:600px;
  background:radial-gradient(ellipse at 30% 40%,rgba(54,77,104,.45) 0%,rgba(59,178,115,.06) 55%,transparent 75%);
  animation:heroGlow 8s ease-in-out infinite alternate;
  pointer-events:none;z-index:1;
}
@keyframes heroGlow{
  0%{transform:translate(0,0) scale(1);}
  100%{transform:translate(40px,30px) scale(1.12);}
}
.hero-content{
  position:relative;z-index:2;
  max-width:600px;
  margin-left:auto;margin-right:auto;
  padding:var(--sp-section) var(--sp-lg);
  width:100%;
  max-width:1200px;
  padding-left:var(--sp-lg);
}
.hero-photo h1{
  color:#fff;font-weight:700;
  font-size:clamp(2.4rem,5vw,3.8rem);
  margin:var(--sp-sm) 0 0;
  line-height:1.08;
  max-width:14em;
}
.tnb-inline{
  height:.85em;width:auto;
  display:inline-block;
  vertical-align:middle;
  margin:0 6px;
  position:relative;top:-1px;
  filter:brightness(0) invert(1);
  opacity:.9;
}
.hero-photo .lead{color:rgba(255,255,255,.7);font-size:1.1rem;max-width:34em;margin:var(--sp-md) 0 0;line-height:1.65}
.hero-cta{display:flex;gap:var(--sp-sm);flex-wrap:wrap;margin-top:var(--sp-xl)}
.badges{display:flex;gap:var(--sp-xs);flex-wrap:wrap;margin-top:var(--sp-xl)}
.badge{font-family:var(--mono);font-size:.72rem;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-pill);padding:6px 14px;display:flex;align-items:center;gap:6px;transition:border-color .2s,color .2s}
.badge:hover{border-color:rgba(59,178,115,.4);color:rgba(255,255,255,.85)}
.badge b{color:var(--up)}

/* ---- Finder (right column of hero) ---- */
.finder{background:var(--surface-dark-deep);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);padding:var(--sp-lg)}
.finder h3{color:#fff;font-size:1.15rem;margin-bottom:4px}
.finder .sub{color:var(--on-dark-soft);font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--sp-base)}
.finder-opts{display:grid;gap:var(--sp-xs)}
.fopt{display:flex;align-items:center;gap:var(--sp-sm);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);padding:13px 15px;cursor:pointer;transition:.15s;color:#E7ECF2;font-weight:500;font-size:.94rem}
.fopt:hover{background:rgba(59,178,115,.1);border-color:var(--up);transform:translateX(2px)}
.fopt .ic{font-size:1.2rem;flex:none}.fopt .lab{flex:1}.fopt .arr{color:var(--up);font-family:var(--mono);font-weight:700}
.finder .fwa{margin-top:var(--sp-base);width:100%;justify-content:center}

/* ---- Section shell ---- */
section.block{padding:var(--sp-section) 0;background:var(--canvas)}
section.block.tight{padding:var(--sp-xxl) 0}

/* Section background tokens — Apple-style alternating rhythm */
.s-gray{background:#F5F7FA!important}
.s-dark{background:#0a0b0d!important}
.s-accent{background:linear-gradient(135deg,var(--primary) 0%,#2B3F56 60%,#1e2f45 100%)!important}
.s-white{background:#ffffff!important}
.sec-head{max-width:42em;margin-bottom:var(--sp-xxl)}
.sec-head .eyebrow{display:inline-block;margin-bottom:var(--sp-sm)}
.sec-head h2{margin-top:0}
.sec-head p{color:var(--body);margin-top:var(--sp-md);font-size:1.05rem;line-height:1.65}

/* ---- Service grid ---- */

.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-base)}
.svc{
  background:var(--surface-card);
  border:1px solid var(--hairline);
  border-radius:var(--r-xl);
  padding:var(--sp-xl);
  transition:border-color .2s,box-shadow .2s,transform .2s;
  display:flex;flex-direction:column;min-height:200px;
  position:relative;overflow:hidden;
  translate:0 var(--py,0px);
  will-change:translate;
}
/* left accent bar — slides in on hover */
.svc::before{
  content:"";
  position:absolute;left:0;top:16px;bottom:16px;
  width:3px;border-radius:0 2px 2px 0;
  background:var(--primary);
  transform:scaleY(0);
  transform-origin:center;
  transition:transform .22s ease;
}
.svc:hover{border-color:var(--primary);box-shadow:0 4px 20px rgba(54,77,104,.1);transform:translateY(-2px)}
.svc:hover::before{transform:scaleY(1)}
.svc .tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--muted);font-weight:500;text-transform:uppercase}
.svc h3{font-size:1.08rem;margin:10px 0 8px;color:var(--ink);transition:color .15s}
.svc:hover h3{color:var(--primary)}
.svc p{font-size:.9rem;color:var(--body);flex:1}
.svc .go{font-weight:600;font-size:.85rem;color:var(--primary);margin-top:var(--sp-sm);display:inline-flex;align-items:center;gap:4px;transition:gap .15s}
.svc:hover .go{gap:8px}

/* ---- Process (light grey) ---- */
.process{
  background:#F5F7FA!important;
  color:var(--ink);
  position:relative;
  overflow:hidden;
}
.process::before{content:none}
.process .wrap{position:relative}
.process .eyebrow{color:var(--primary)}
.process .sec-head h2{color:var(--ink)}
.process .sec-head p{color:var(--body)}
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:var(--sp-xl);counter-reset:step;
  position:relative;
}
/* connecting line between steps */
.steps::before{
  content:"";
  position:absolute;
  top:26px;left:calc(12.5% + 26px);right:calc(12.5% + 26px);
  height:1px;
  background:linear-gradient(to right,var(--primary) 0%,rgba(54,77,104,.1) 100%);
  pointer-events:none;
}
.step{position:relative;padding-top:0}
/* numbered circle */
.step::before{
  counter-increment:step;
  content:"0" counter(step);
  font-family:var(--mono);font-weight:700;
  font-size:.82rem;letter-spacing:.06em;
  color:#fff;
  width:52px;height:52px;
  border-radius:50%;
  background:var(--primary);
  border:1px solid rgba(54,77,104,.2);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:var(--sp-lg);
  position:relative;z-index:1;
  box-shadow:0 4px 16px rgba(54,77,104,.18);
}
.step h3{font-size:1.08rem;margin-bottom:6px;color:var(--ink);font-weight:600}
.step p{color:var(--body);font-size:.9rem;line-height:1.6}

/* ---- Trust section (light — logos show on white/gray) ---- */
.trust{background:#F5F7FA;padding:var(--sp-section) 0}
.trust .wrap{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--sp-xxl)}
.trust .t-main{font-family:var(--display);font-weight:400;font-size:clamp(1.6rem,3vw,2.2rem);color:var(--ink)}
.trust .t-sub{font-family:var(--mono);font-size:.82rem;color:var(--muted);letter-spacing:.06em;margin-top:var(--sp-xs)}
.trust .t-regs{display:flex;gap:var(--sp-xl);flex-wrap:wrap;justify-content:center;align-items:center}
.trust .reg{background:var(--primary);color:#fff;font-family:var(--mono);font-size:.75rem;font-weight:500;padding:6px 14px;border-radius:var(--r-pill);letter-spacing:.04em}
.reg-logo{
  display:flex;align-items:center;justify-content:center;
  min-width:180px;
  background:#fff;
  border-radius:var(--r-xl);
  padding:var(--sp-lg) var(--sp-xl);
  border:1px solid var(--hairline);
  box-shadow:0 2px 12px rgba(0,0,0,.04);
  transition:box-shadow .2s,transform .2s;
}
.reg-logo:hover{box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-2px)}
.reg-logo img{height:80px;width:auto;max-width:260px;object-fit:contain;display:block}
.reg-logo:first-child img{height:120px}

/* ---- Estimator ---- */
.est{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-xl);padding:var(--sp-xl);display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-xl);align-items:center}
.est .controls{display:grid;gap:var(--sp-base)}
.est .ctl label{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px}
.est .seg{display:flex;gap:4px;background:var(--surface-soft);border:1px solid var(--hairline);border-radius:var(--r-md);padding:4px}
.est .seg button{flex:1;border:none;background:none;font-family:var(--text);font-weight:600;font-size:.84rem;padding:8px 6px;border-radius:var(--r-sm);cursor:pointer;color:var(--muted);transition:.15s}
.est .seg button.on{background:var(--primary);color:#fff}
.est .result{background:var(--surface-dark);color:#fff;border-radius:var(--r-xl);padding:var(--sp-xl)}
.est .result .rh{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--up);margin-bottom:var(--sp-sm)}
.est .result .line{display:flex;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.9rem;color:var(--on-dark-soft)}
.est .result .line b{color:#fff;font-family:var(--mono);font-weight:500}
.est .result .total{display:flex;justify-content:space-between;align-items:baseline;margin-top:var(--sp-base)}
.est .result .total span{font-weight:600}
.est .result .total .v{font-family:var(--mono);color:var(--up);font-size:1.4rem;font-weight:700}
.est .note{font-size:.76rem;color:var(--on-dark-soft);margin-top:var(--sp-sm);line-height:1.5}

/* ---- Coverage ---- */
.coverage-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-xl);align-items:center;margin-top:var(--sp-xl)}
.coverage-map{border-radius:var(--r-xl);overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.12);border:1px solid var(--hairline)}
.coverage-map iframe{display:block;width:100%;height:440px}
.ms-state{fill:url(#stateGrad);stroke:#1e3a5a;stroke-width:1;transition:fill .25s,stroke .25s;cursor:default}
.ms-state:hover{fill:#5aa8f0;stroke:#7DC4FF;stroke-width:1.5}
.state-lines line{stroke:#1a3a5c;stroke-width:.6;fill:none}
.city-dot{filter:drop-shadow(0 0 4px currentColor)}
.city-pulse{animation:mapPulse 2s ease-in-out infinite}
@keyframes mapPulse{0%,100%{opacity:.25;r:9}50%{opacity:.5;r:12}}
.city-label{font-family:var(--mono);font-size:7px;fill:#94b8d8;letter-spacing:.04em}
.map-legend{font-family:var(--sans);font-size:8px;fill:#7DD3A8;letter-spacing:.03em}
.coverage-list{display:flex;flex-direction:column;gap:var(--sp-lg)}
.states{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-xs)}
.state{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);padding:14px 12px;text-align:center;font-weight:600;font-size:.9rem;color:var(--ink);transition:.15s;display:flex;flex-direction:column;gap:4px;align-items:center}
.state:hover{border-color:var(--primary);color:var(--primary)}
.state .pin{font-family:var(--mono);font-size:.62rem;color:var(--muted);letter-spacing:.1em}
.coverage-note{color:var(--muted);font-size:.85rem;display:flex;align-items:center;gap:.5rem}
.coverage-note .tick{color:var(--up);font-size:1rem}

/* ---- Gallery ---- */
.gallery-section{background:#fff;padding:var(--sp-section) 0;overflow:hidden}
.gallery-section .sec-head{margin-bottom:var(--sp-xxl)}
.gallery-section .eyebrow{color:var(--primary)}

.gallery-social{margin-top:var(--sp-xxl);padding-top:var(--sp-xl);display:flex;flex-direction:column;align-items:center;gap:var(--sp-lg);text-align:center}
.gallery-social-text{color:var(--body);font-size:1rem;max-width:420px}
.gallery-social-links{display:flex;gap:var(--sp-md);flex-wrap:wrap;justify-content:center}
.soc-btn{display:inline-flex;align-items:center;gap:.55rem;padding:.7rem 1.4rem;border-radius:var(--r-pill);border:1px solid var(--hairline);color:var(--ink);font-size:.9rem;font-weight:600;text-decoration:none;background:var(--surface-card);transition:background .2s,border-color .2s,transform .2s,color .2s}
.soc-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.soc-btn:nth-child(1):hover{background:rgba(24,119,242,.08);border-color:#1877f2;color:#1877f2}
.soc-btn:nth-child(2):hover{background:rgba(225,48,108,.08);border-color:#e1306c;color:#e1306c}
.soc-btn:nth-child(3):hover{background:rgba(0,0,0,.06);border-color:#000;color:#000}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:repeat(5,240px);
  gap:6px;
  border-radius:var(--r-xl);
  overflow:hidden;
  margin-top:var(--sp-xxl);
}

/* Asymmetric placement */
.gitem:nth-child(1){grid-column:1/3;grid-row:1/2}
.gitem:nth-child(2){grid-column:3/4;grid-row:1/2}
.gitem:nth-child(3){grid-column:4/5;grid-row:1/3}
.gitem:nth-child(4){grid-column:1/2;grid-row:2/3}
.gitem:nth-child(5){grid-column:2/4;grid-row:2/3}
.gitem:nth-child(6){grid-column:1/3;grid-row:3/4}
.gitem:nth-child(7){grid-column:3/5;grid-row:3/4}
.gitem:nth-child(8){grid-column:1/2;grid-row:4/6}
.gitem:nth-child(9){grid-column:2/4;grid-row:4/5}
.gitem:nth-child(10){grid-column:4/5;grid-row:4/5}
.gitem:nth-child(11){grid-column:2/3;grid-row:5/6}
.gitem:nth-child(12){grid-column:3/5;grid-row:5/6}

.gitem{
  position:relative;overflow:hidden;cursor:pointer;
  background:#111;
}
.gitem img{
  width:100%;height:115%;
  margin-top:-7.5%;
  object-fit:cover;object-position:center;
  display:block;
  scale:1;
  translate:0 var(--py,0px);
  transition:scale .7s cubic-bezier(.25,.1,0,1);
  will-change:translate;
}
.gitem:hover img{scale:1.06}

/* Overlay */
.gitem-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.3) 50%,transparent 100%);
  opacity:0;
  transition:opacity .45s cubic-bezier(.25,.1,0,1);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;
}
.gitem:hover .gitem-overlay{opacity:1}

.gitem-tag{
  font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--up);font-weight:500;
  transform:translateY(10px);
  transition:transform .4s cubic-bezier(.25,.1,0,1) .05s;
  margin-bottom:4px;
}
.gitem:hover .gitem-tag{transform:none}

.gitem-title{
  font-family:var(--display);font-size:1rem;font-weight:600;
  color:#fff;line-height:1.25;
  transform:translateY(12px);
  transition:transform .4s cubic-bezier(.25,.1,0,1) .08s;
  margin-bottom:4px;
}
.gitem:hover .gitem-title{transform:none}

.gitem-loc{
  font-family:var(--mono);font-size:.68rem;color:rgba(255,255,255,.6);
  display:flex;align-items:center;gap:4px;
  transform:translateY(10px);
  transition:transform .4s cubic-bezier(.25,.1,0,1) .1s;
}
.gitem:hover .gitem-loc{transform:none}
.gitem-loc::before{content:"📍";font-size:.6rem}

/* Mobile gallery */
@media(max-width:960px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(8,200px)}
  .gitem:nth-child(1){grid-column:1/3;grid-row:1}
  .gitem:nth-child(2){grid-column:1/2;grid-row:2}
  .gitem:nth-child(3){grid-column:2/3;grid-row:2/4}
  .gitem:nth-child(4){grid-column:1/2;grid-row:3}
  .gitem:nth-child(5){grid-column:1/3;grid-row:4}
  .gitem:nth-child(6){grid-column:1/2;grid-row:5}
  .gitem:nth-child(7){grid-column:2/3;grid-row:5}
  .gitem:nth-child(8){grid-column:1/3;grid-row:6}
  .gitem:nth-child(9){grid-column:1/2;grid-row:7}
  .gitem:nth-child(10){grid-column:2/3;grid-row:7}
  .gitem:nth-child(11){grid-column:1/2;grid-row:8}
  .gitem:nth-child(12){grid-column:2/3;grid-row:8}
}
@media(max-width:560px){
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(9,160px)}
  .gitem:nth-child(1){grid-column:1/3;grid-row:1}
  .gitem:nth-child(3){grid-row:2}
  .gitem:nth-child(5){grid-column:1/3;grid-row:4}
  .gitem:nth-child(8){grid-column:1/3;grid-row:6}
}

/* ---- Reviews (light grey) ---- */
.reviews-section{
  background:#F5F7FA;
  padding:var(--sp-section) 0;
}
.reviews-section .eyebrow{color:var(--primary)}
.reviews-section h2{color:var(--ink)}
.reviews-section .wrap{position:relative}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-base)}
@media(min-width:1024px){.reviews-grid{grid-template-columns:repeat(5,1fr)}}
.reviews-summary{margin-top:var(--sp-md);display:flex;align-items:center;justify-content:center;gap:10px}
.reviews-score{font-family:var(--display);font-weight:800;font-size:2rem;color:var(--ink);line-height:1}
.reviews-stars{color:#F59E0B;font-size:1.3rem;letter-spacing:2px;line-height:1}
.reviews-count{color:var(--muted);font-family:var(--mono);font-size:.82rem}
.review-card{
  background:#fff;
  border:1px solid var(--hairline);
  border-radius:14px;padding:24px;
  display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s,border-color .2s;
  text-decoration:none;cursor:pointer;
}
.review-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08);border-color:var(--primary)}
.review-card-stars{color:#F59E0B;font-size:1.1rem;letter-spacing:2px;margin-bottom:10px}
.review-card-text{color:var(--body);font-size:.96rem;line-height:1.55;margin-bottom:14px;flex:1}
.review-card-author{display:flex;align-items:center;gap:10px}
.review-name{font-weight:700;font-size:.88rem;color:var(--ink)}
.review-meta{font-family:var(--mono);font-size:.68rem;color:var(--muted)}
.review-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--primary);color:#fff;
  display:grid;place-items:center;
  font-weight:700;font-size:.85rem;
  flex:none;
}

/* ---- Blog ---- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-md)}
.post-card{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;transition:.18s;text-decoration:none}
.post-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.1);border-color:var(--primary)}
.post-thumb{height:200px;position:relative;overflow:hidden;background:var(--surface-dark)}
.post-thumb img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .6s cubic-bezier(.25,.1,0,1)}
.post-card:hover .post-thumb img{transform:scale(1.06)}
.post-thumb-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.3) 100%)}
.post-body{padding:var(--sp-lg);flex:1;display:flex;flex-direction:column}
.post-body .cat{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--primary);text-transform:uppercase;font-weight:500}
.post-body h3{font-size:1.05rem;margin:8px 0;line-height:1.3;color:var(--ink)}
.post-body p{color:var(--body);font-size:.88rem;flex:1}
.post-body .meta{font-family:var(--mono);font-size:.72rem;color:var(--muted);margin-top:var(--sp-sm)}

/* ---- CTA band (lives inside .s-dark section — no card, open layout) ---- */
.cta-band{
  color:#fff;
  padding:var(--sp-xl) 0;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-band::before{
  content:"";
  position:absolute;
  top:-100px;left:50%;transform:translateX(-50%);
  width:700px;height:400px;
  background:radial-gradient(ellipse at 50% 40%,rgba(59,178,115,.18) 0%,transparent 65%);
  pointer-events:none;
}
.cta-band h2{color:#fff;position:relative;font-size:clamp(1.8rem,3.5vw,2.8rem)}
.cta-band p{color:rgba(255,255,255,.6);margin:var(--sp-sm) auto var(--sp-xl);max-width:34em;position:relative;font-size:1.05rem;line-height:1.65}
.cta-band .hero-cta{justify-content:center;position:relative}

/* ---- Page hero (inner pages) ---- */
.page-hero{background:var(--surface-dark);color:var(--on-dark);position:relative;overflow:hidden;padding:56px 0 64px}
/* page-hero entrance — fires via JS on DOMContentLoaded */
.page-hero .eyebrow,
.page-hero h1,
.page-hero p,
.page-hero .crumb{
  opacity:0;
  transform:translateY(24px);
  filter:blur(6px);
  transition:
    opacity .9s cubic-bezier(.25,.1,0,1) calc(var(--pi,0) * 120ms),
    transform .9s cubic-bezier(.25,.1,0,1) calc(var(--pi,0) * 120ms),
    filter .8s cubic-bezier(.25,.1,0,1) calc(var(--pi,0) * 120ms);
}
.page-hero.in .eyebrow,
.page-hero.in h1,
.page-hero.in p,
.page-hero.in .crumb{opacity:1;transform:none;filter:blur(0)}
.page-hero::after{content:"";position:absolute;top:-140px;right:-100px;width:420px;height:420px;background:radial-gradient(circle,rgba(59,178,115,.1),transparent 65%);pointer-events:none}
.page-hero h1{color:#fff;margin-top:var(--sp-sm);position:relative}
.page-hero p{color:var(--on-dark-soft);max-width:42em;margin-top:var(--sp-sm);font-size:1.05rem;position:relative}
.crumb{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:var(--on-dark-soft);position:relative}
.crumb a:hover{color:var(--up)}.crumb span{color:var(--up)}

/* ---- Prose / article ---- */
.layout{display:grid;grid-template-columns:1fr 300px;gap:var(--sp-xxl);align-items:start}
.prose h2{font-size:1.6rem;font-weight:400;margin:38px 0 14px;color:var(--ink)}
.prose h3{font-size:1.2rem;margin:28px 0 10px;color:var(--ink)}
.prose p{color:var(--body);margin-bottom:14px}
.prose ul,.prose ol{margin:0 0 16px 0;padding-left:0;list-style:none}
.prose li{color:var(--body);position:relative;padding-left:28px;margin-bottom:10px}
.prose ul li::before{content:"";position:absolute;left:6px;top:9px;width:7px;height:7px;border-radius:2px;background:var(--primary);transform:rotate(45deg)}
.prose ol{counter-reset:n}.prose ol li{counter-increment:n}
.prose ol li::before{content:counter(n);position:absolute;left:0;top:1px;width:22px;height:22px;background:var(--primary);color:#fff;font-family:var(--mono);font-size:.72rem;font-weight:500;border-radius:var(--r-sm);display:grid;place-items:center}
.prose strong{color:var(--ink)}
.prose a{color:var(--primary);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.prose img{border-radius:var(--r-lg);border:1px solid var(--hairline);margin:18px 0}
.callout{background:var(--surface-soft);border:1px solid var(--hairline);border-left:3px solid var(--primary);border-radius:var(--r-md);padding:var(--sp-md) var(--sp-lg);margin:var(--sp-lg) 0}
.callout .lbl{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;color:var(--primary);text-transform:uppercase;font-weight:500}
.callout.live{border-left-color:var(--up)}.callout.live .lbl{color:var(--up)}
.callout p{margin:6px 0 0;color:var(--body)}

/* ---- Sidebar ---- */
.aside{position:sticky;top:84px;display:flex;flex-direction:column;gap:var(--sp-base)}
.aside-card{background:var(--surface-dark);color:#fff;border-radius:var(--r-xl);padding:var(--sp-lg)}
.aside-card h4{font-size:1.05rem;margin-bottom:8px;color:#fff}
.aside-card p{color:var(--on-dark-soft);font-size:.9rem;margin-bottom:var(--sp-base)}
.aside-list{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-xl);padding:var(--sp-xs)}
.aside-list .h{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;padding:12px 14px 6px}
.aside-list a{display:block;padding:9px 14px;border-radius:var(--r-sm);font-size:.9rem;font-weight:500;color:var(--ink)}
.aside-list a:hover{background:var(--surface-soft);color:var(--primary)}
.aside-list a.active{background:var(--primary);color:#fff}

/* ---- FAQ ---- */
.faq details{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);margin-bottom:var(--sp-sm);overflow:hidden}
.faq summary{cursor:pointer;padding:18px var(--sp-md);font-family:var(--text);font-weight:600;font-size:1rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--primary);font-size:1.3rem;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--body);padding:0 var(--sp-md) var(--sp-md)}

/* ---- Tables ---- */
.tbl{width:100%;border-collapse:collapse;margin:var(--sp-lg) 0;font-size:.92rem;background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);overflow:hidden}
.tbl th,.tbl td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--hairline)}
.tbl th{background:var(--surface-dark);color:#fff;font-family:var(--text);font-size:.8rem;font-weight:600;letter-spacing:.02em}
.tbl tr:last-child td{border-bottom:none}
.tbl td.num{font-family:var(--mono);font-weight:500}

/* ---- Cross-links ---- */
.xl{display:block;background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);padding:var(--sp-base);font-weight:600;font-size:.92rem;transition:.15s}
.xl:hover{border-color:var(--primary);color:var(--primary)}
.xl span{display:block;font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-bottom:4px}

/* ---- Cards (info/doc) ---- */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-base)}
.cards2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-base)}
.icard{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-xl);padding:var(--sp-lg)}
.icard .num{font-family:var(--mono);color:var(--primary);font-weight:500;font-size:.8rem;letter-spacing:.1em}
.icard h3{font-size:1.08rem;margin:8px 0;color:var(--ink)}
.icard p{color:var(--body);font-size:.92rem}
.icard ul{list-style:none;margin-top:10px}
.icard li{color:var(--body);font-size:.9rem;padding-left:22px;position:relative;margin-bottom:7px}
.icard li::before{content:"✓";position:absolute;left:0;color:var(--up);font-weight:700}

/* ---- Contact form ---- */
.form{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-xl);padding:var(--sp-xl)}
.form label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px;color:var(--ink)}
.form .field{margin-bottom:var(--sp-base)}
.form input,.form textarea,.form select{width:100%;border:1px solid var(--hairline);border-radius:var(--r-md);padding:14px 16px;font-family:var(--text);font-size:.95rem;background:var(--canvas)}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(54,77,104,.15)}
.contact-cards{display:flex;flex-direction:column;gap:var(--sp-sm)}
.ccard{background:var(--surface-dark);color:#fff;border-radius:var(--r-xl);padding:var(--sp-lg)}
.ccard .lbl{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;color:var(--up);text-transform:uppercase}
.ccard .val{font-size:1.05rem;font-weight:600;margin-top:4px}
.ccard a:hover{color:var(--up)}

/* ---- Footer ---- */
footer.contact{background:#0a0b0d;color:var(--on-dark);padding:72px 0 0;border-top:1px solid rgba(255,255,255,.08)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.foot-brand .brand{margin-bottom:var(--sp-sm)}
.foot-brand p{color:var(--on-dark-soft);font-size:.9rem;max-width:26em}
.foot-col h4{font-size:.75rem;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--up);margin-bottom:var(--sp-sm)}
.foot-col a{display:block;color:var(--on-dark-soft);font-size:.9rem;margin-bottom:9px}
.foot-col a:hover{color:#fff}
.foot-col p{color:var(--on-dark-soft);font-size:.88rem;margin-bottom:12px;line-height:1.5}
.socials{display:flex;gap:var(--sp-sm);margin-top:var(--sp-xs)}
.socials a{width:40px;height:40px;border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.15);display:grid;place-items:center;color:#fff;transition:.15s;font-weight:700}
.socials a:hover{background:var(--up);color:#fff;border-color:var(--up)}
.fbar{border-top:1px solid rgba(255,255,255,.1);margin-top:var(--sp-xxl);padding:var(--sp-lg) 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.8rem;color:var(--on-dark-soft);font-family:var(--mono)}

/* ================================================================
   Apple-style scroll motion system
   Signature: blur-dissolve + scale materialisation + cinematic pace
   Easing: cubic-bezier(0.25, 0.1, 0, 1) — Apple's own curve
   ================================================================ */

/* --- Base section reveal: scale + fade + blur-dissolve --- */
.reveal{
  opacity:0;
  transform:translateY(40px) scale(.97);
  filter:blur(8px);
  transition:
    opacity 1s cubic-bezier(.25,.1,0,1),
    transform 1s cubic-bezier(.25,.1,0,1),
    filter .9s cubic-bezier(.25,.1,0,1);
  will-change:opacity,transform,filter;
}
.reveal.in{opacity:1;transform:none;filter:blur(0)}

/* --- Child stagger: blur up one by one --- */
.reveal-child{
  opacity:0;
  transform:translateY(28px);
  filter:blur(6px);
  transition:
    opacity .85s cubic-bezier(.25,.1,0,1) calc(var(--i,0) * 110ms),
    transform .85s cubic-bezier(.25,.1,0,1) calc(var(--i,0) * 110ms),
    filter .75s cubic-bezier(.25,.1,0,1) calc(var(--i,0) * 110ms);
  will-change:opacity,transform,filter;
}
.reveal-child.in{opacity:1;transform:none;filter:blur(0)}

/* --- Slide from left (headings) --- */
.reveal-left{
  opacity:0;
  transform:translateX(-32px) translateY(12px);
  filter:blur(6px);
  transition:
    opacity .9s cubic-bezier(.25,.1,0,1),
    transform .9s cubic-bezier(.25,.1,0,1),
    filter .8s cubic-bezier(.25,.1,0,1);
  will-change:opacity,transform,filter;
}
.reveal-left.in{opacity:1;transform:none;filter:blur(0)}

/* --- Scale materialise (cards, estimator, cta) --- */
.reveal-scale{
  opacity:0;
  transform:scale(.93) translateY(20px);
  filter:blur(10px);
  transition:
    opacity 1.1s cubic-bezier(.25,.1,0,1),
    transform 1.1s cubic-bezier(.25,.1,0,1),
    filter 1s cubic-bezier(.25,.1,0,1);
  will-change:opacity,transform,filter;
}
.reveal-scale.in{opacity:1;transform:none;filter:blur(0)}

/* --- Word/line split reveal (applied via JS) --- */
.word{
  display:inline-block;
  opacity:0;
  transform:translateY(60%) rotate(2deg);
  filter:blur(4px);
  transition:
    opacity .7s cubic-bezier(.25,.1,0,1) calc(var(--wi,0) * 55ms),
    transform .7s cubic-bezier(.25,.1,0,1) calc(var(--wi,0) * 55ms),
    filter .6s cubic-bezier(.25,.1,0,1) calc(var(--wi,0) * 55ms);
  will-change:opacity,transform,filter;
}
.word.in{opacity:1;transform:none;filter:blur(0)}

/* --- Scroll-scrubbed section pin overlay --- */
.pin-section{position:relative}

/* --- Section transition fade-out as next enters --- */
section{transition:opacity .3s ease}


/* ---- Floating buttons ---- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:80;width:56px;height:56px;border-radius:var(--r-full);background:var(--up);color:#fff;display:grid;place-items:center;box-shadow:0 10px 26px rgba(59,178,115,.4);font-size:1.6rem;transition:transform .15s}
.wa-float:hover{transform:scale(1.08)}
.to-top{position:fixed;right:21px;bottom:84px;z-index:80;width:44px;height:44px;border-radius:var(--r-pill);background:var(--primary);color:#fff;border:none;display:grid;place-items:center;cursor:pointer;font-size:1.1rem;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s}
.to-top.show{opacity:1;visibility:visible;transform:none}

/* ---- Responsive ---- */
@media(max-width:960px){
  .hero-photo{grid-template-columns:1fr;min-height:auto}
  .hero-photo{
    height:100svh;
    background-attachment:scroll,scroll;
    background-position:center bottom;
    background-size:cover,auto;
  }
  .hero-photo::before{background:linear-gradient(to bottom,rgba(10,11,13,.85) 0%,rgba(10,11,13,.7) 100%)}
  .hero-content{padding:var(--sp-xxl) var(--sp-lg)}
  .hero-grid{grid-template-columns:1fr;gap:var(--sp-xl)}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .steps::before{display:none}
  .coverage-layout{grid-template-columns:1fr}
  .states{grid-template-columns:repeat(4,1fr)}
  .layout{grid-template-columns:1fr;gap:var(--sp-xl)}.aside{position:static}
  .cards3,.blog-grid,.reviews-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .navlinks,.phone-top{display:none}.menu-btn{display:block}
  .est{grid-template-columns:1fr}
}
@media(max-width:560px){
  .svc-grid,.steps,.states,.cards3,.cards2,.blog-grid,.foot-grid,.reviews-grid{grid-template-columns:1fr}
  .coverage-layout{grid-template-columns:1fr}
  .cta-band{padding:var(--sp-xxl) var(--sp-lg)}
  .trust .wrap{flex-direction:column;align-items:flex-start}
  h1{font-size:2rem}
}
@media(max-width:768px){
  .gitem{background-attachment:scroll}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}.fopt:hover{transform:none}.gitem{background-attachment:scroll}}
