/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  --sky:        #0ea5e9;
  --sky-lite:   #38bdf8;
  --sky-dark:   #0284c7;
  --sky-glow:   rgba(14,165,233,0.18);
  --ink:        #0f172a;
  --ink-2:      #1e293b;
  --ink-3:      #334155;
  --muted:      #64748b;
  --border:     rgba(148,163,184,0.14);
  --surface:    #f8fafc;
  --surface-2:  #f1f5f9;
  --white:      #ffffff;
  --r:          16px;
  --r-lg:       24px;
  --ease:       cubic-bezier(0.16,1,0.3,1);
  --ease-fast:  0.2s ease;
  --sh:         0 4px 24px rgba(15,23,42,0.08);
  --sh-lg:      0 16px 64px rgba(15,23,42,0.16);
  --sh-sky:     0 8px 32px rgba(14,165,233,0.32);
}

/* ─── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;color:var(--ink);background:var(--white);
  overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font:inherit}
ul{list-style:none}

/* ─── SCROLL PROGRESS ────────────────────────────────────── */
#prog{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:1000;
  background:linear-gradient(90deg,var(--sky-dark),var(--sky-lite));
  box-shadow:0 0 12px var(--sky);transition:width .1s linear
}

/* ─── WASH SWEEP (creative scroll animation) ─────────────── */
#wash{
  position:fixed;top:0;left:-110%;width:120%;height:2px;z-index:999;
  background:linear-gradient(90deg,transparent 0%,rgba(56,189,248,.9) 40%,rgba(255,255,255,.6) 50%,rgba(56,189,248,.9) 60%,transparent 100%);
  pointer-events:none;opacity:0;transform:skewX(-8deg)
}
#wash.sweep{animation:washSweep .9s cubic-bezier(.4,0,.2,1) forwards}
@keyframes washSweep{
  0%{left:-110%;opacity:1}
  100%{left:110%;opacity:0}
}

/* ─── NAV ────────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;height:72px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 max(24px,calc((100% - 1200px)/2));
  transition:background .4s var(--ease),box-shadow .4s var(--ease)
}
.nav.scrolled{
  background:rgba(15,23,42,.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 1px 0 rgba(255,255,255,.05)
}
.nav-logo{
  display:flex;align-items:center;
}
.nav-logo img{
  height:44px;width:auto;display:block;
  filter:brightness(0) invert(1)
}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{
  color:rgba(255,255,255,.7);font-size:.875rem;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:500;
  letter-spacing:.01em;transition:color var(--ease-fast);position:relative
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;
  background:var(--sky);border-radius:2px;transition:width .3s var(--ease)
}
.nav-links a:hover{color:white}
.nav-links a:hover::after{width:100%}
.nav-cta{
  padding:10px 22px;background:var(--sky);color:white;
  border-radius:10px;font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:600;font-size:.875rem;
  transition:background var(--ease-fast),transform var(--ease-fast),box-shadow var(--ease-fast)
}
.nav-cta:hover{background:var(--sky-dark);transform:translateY(-1px);box-shadow:var(--sh-sky)}
.nav-dropdown{position:relative}
.nav-dropdown-btn{
  display:inline-flex;align-items:center;gap:5px;
  color:rgba(255,255,255,.7);font-size:.875rem;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:500;
  letter-spacing:.01em;background:none;border:none;padding:0;
  cursor:pointer;transition:color var(--ease-fast)
}
.nav-dropdown-btn:hover,.nav-dropdown.open .nav-dropdown-btn{color:white}
.nav-dropdown-chevron{transition:transform .25s var(--ease)}
.nav-dropdown.open .nav-dropdown-chevron{transform:rotate(180deg)}
.nav-dropdown-menu{
  position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);
  min-width:220px;padding:8px;
  background:rgba(15,23,42,.97);border:1px solid rgba(255,255,255,.08);
  border-radius:12px;box-shadow:var(--sh-lg);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s
}
.nav-dropdown.open .nav-dropdown-menu{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translateX(-50%) translateY(0)
}
.nav-dropdown-menu a{
  display:block;padding:10px 14px;border-radius:8px;
  color:rgba(255,255,255,.78);font-size:.84rem;white-space:nowrap
}
.nav-dropdown-menu a::after{display:none}
.nav-dropdown-menu a:hover{background:rgba(14,165,233,.12);color:white}
.nav-dropdown-menu a[aria-current="page"]{color:var(--sky-lite);background:rgba(14,165,233,.08)}
.nav-dropdown-all{
  margin-top:4px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);
  font-weight:600;color:var(--sky-lite)!important
}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.nav-burger span{display:block;width:22px;height:2px;background:white;border-radius:2px;transition:.3s var(--ease)}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu */
.nav-mob{
  display:none;position:fixed;inset:0;background:var(--ink);z-index:99;
  flex-direction:column;align-items:center;justify-content:center;gap:4px
}
.nav-mob.open{display:flex}
.nav-mob a{
  color:rgba(255,255,255,.85);font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(1.4rem,6vw,2.2rem);font-weight:600;padding:12px 24px;
  opacity:0;transform:translateY(20px);
  transition:opacity .5s var(--ease),transform .5s var(--ease),color var(--ease-fast)
}
.nav-mob.open a{opacity:1;transform:translateY(0)}
.nav-mob.open a:nth-child(1){transition-delay:.06s}
.nav-mob.open a:nth-child(2){transition-delay:.12s}
.nav-mob.open a:nth-child(3){transition-delay:.18s}
.nav-mob.open a:nth-child(4){transition-delay:.24s}
.nav-mob.open a:nth-child(5){transition-delay:.30s}
.nav-mob a:hover{color:var(--sky)}
.nav-mob-sub{
  font-size:clamp(1rem,4.5vw,1.35rem)!important;font-weight:500!important;
  color:rgba(255,255,255,.55)!important;padding:8px 24px!important
}
.nav-mob-sub:hover{color:var(--sky)!important}
.nav-mob .mob-cta{
  margin-top:20px;padding:14px 48px;background:var(--sky);color:white;
  border-radius:12px;font-weight:600;font-size:1.05rem;
  opacity:0;transform:translateY(20px);
  transition:opacity .5s var(--ease),transform .5s var(--ease),background var(--ease-fast);
  transition-delay:.36s
}
.nav-mob.open .mob-cta{opacity:1;transform:translateY(0)}
.nav-mob .mob-cta:hover{background:var(--sky-dark)}
.mob-x{
  position:absolute;top:20px;right:24px;color:rgba(255,255,255,.5);
  font-size:1.4rem;padding:8px;transition:color var(--ease-fast)
}
.mob-x:hover{color:white}

/* ─── HERO ───────────────────────────────────────────────── */
.hero{
  min-height:100vh;background:var(--ink);position:relative;
  display:flex;flex-direction:column;justify-content:center;overflow:hidden
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 55% at 65% 25%,rgba(14,165,233,.13) 0%,transparent 60%),
    radial-gradient(ellipse 45% 60% at 15% 85%,rgba(14,165,233,.07) 0%,transparent 55%)
}
/* floating water drops */
.drops{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.drop{
  position:absolute;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,rgba(56,189,248,.7),rgba(14,165,233,.2));
  animation:dropFloat var(--dur,12s) var(--del,0s) infinite ease-in-out;
  opacity:0
}
@keyframes dropFloat{
  0%{transform:translateY(0) scale(1);opacity:0}
  10%{opacity:1}
  50%{transform:translateY(-30px) scale(1.05);opacity:.6}
  90%{opacity:.3}
  100%{transform:translateY(-60px) scale(.95);opacity:0}
}
.hero-content{
  position:relative;
  padding:0 max(24px,calc((100% - 1200px)/2));
  padding-top:110px;padding-bottom:80px;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center
}
.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;
  background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.2);
  border-radius:100px;color:var(--sky-lite);
  font-size:.75rem;font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:600;letter-spacing:.07em;text-transform:uppercase;margin-bottom:22px
}
.hero-pill::before{
  content:'';width:6px;height:6px;background:var(--sky-lite);border-radius:50%;
  box-shadow:0 0 8px var(--sky-lite);animation:blip 2s infinite
}
@keyframes blip{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}}
.hero-h1{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(2.8rem,5.5vw,5rem);
  font-weight:700;color:white;line-height:1.02;
  letter-spacing:-.035em;margin-bottom:22px
}
.hero-h1 em{
  font-style:normal;
  background:linear-gradient(135deg,var(--sky) 0%,var(--sky-lite) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text
}
.hero-sub{
  font-size:1.05rem;color:rgba(255,255,255,.55);line-height:1.75;
  margin-bottom:36px;max-width:460px
}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn-p{
  display:inline-flex;align-items:center;gap:8px;padding:13px 26px;
  background:var(--sky);color:white;border-radius:11px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.9rem;
  transition:background var(--ease-fast),transform var(--ease-fast),box-shadow var(--ease-fast);
  white-space:nowrap
}
.btn-p:hover{background:var(--sky-dark);transform:translateY(-2px);box-shadow:var(--sh-sky)}
.btn-p svg,.btn-s svg{flex-shrink:0}
.btn-s{
  display:inline-flex;align-items:center;gap:8px;padding:13px 26px;
  background:rgba(255,255,255,.06);color:white;border-radius:11px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:500;font-size:.9rem;
  border:1px solid rgba(255,255,255,.1);
  transition:background var(--ease-fast),border-color var(--ease-fast);white-space:nowrap
}
.btn-s:hover{background:rgba(255,255,255,.11);border-color:rgba(255,255,255,.2)}
.hero-stats{
  display:flex;gap:36px;margin-top:44px;padding-top:36px;
  border-top:1px solid rgba(255,255,255,.06)
}
.h-stat-n{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.7rem;font-weight:700;
  color:white;letter-spacing:-.025em
}
.h-stat-l{font-size:.75rem;color:rgba(255,255,255,.38);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}
/* hero right */
.hero-right{position:relative;display:flex;align-items:center;justify-content:center}
.hero-img-wrap{
  width:100%;max-width:520px;border-radius:var(--r-lg);
  overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.45);position:relative
}
.hero-img-wrap img{width:100%;height:500px;object-fit:cover;display:block}
.hero-badge{
  position:absolute;bottom:24px;left:20px;right:20px;
  background:rgba(15,23,42,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.08);border-radius:12px;
  padding:15px 18px;display:flex;align-items:center;gap:12px
}
.hero-badge-ico{
  width:38px;height:38px;background:rgba(14,165,233,.15);border-radius:9px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0
}
.hero-badge-ico .icon{width:20px;height:20px;color:var(--sky-lite)}
.hero-pill{display:inline-flex;align-items:center;gap:8px}
.hero-pill .icon{width:14px;height:14px;color:var(--sky-lite)}
.hero-badge strong{display:block;color:white;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.85rem}
.hero-badge span{color:rgba(255,255,255,.45);font-size:.78rem}
/* floating accent card */
.hero-float{
  position:absolute;top:20px;right:16px;
  background:var(--sky);color:white;border-radius:12px;
  padding:14px 18px;text-align:center;box-shadow:var(--sh-sky);z-index:10
}
.hero-float-n{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.5rem;font-weight:700}
.hero-float-l{font-size:.72rem;opacity:.85;margin-top:1px}
/* ─── SHARED SECTION ─────────────────────────────────────── */
.s-inner{padding:96px max(24px,calc((100% - 1200px)/2))}
.s-label{
  display:inline-block;font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:600;font-size:.72rem;letter-spacing:.13em;
  text-transform:uppercase;color:var(--sky);margin-bottom:14px
}
.s-title{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(1.9rem,3.8vw,3rem);
  font-weight:700;letter-spacing:-.03em;line-height:1.1;
  color:var(--ink);margin-bottom:14px
}
.s-title.lite{color:white}
.s-sub{font-size:1rem;color:var(--muted);line-height:1.75;max-width:560px}
.s-sub.lite{color:rgba(255,255,255,.55)}

/* ─── REVEAL SYSTEM ──────────────────────────────────────── */
/* Visible by default; hidden only once JS is ready (prevents blank page if IO fails) */
html:not(.js-ready) .rv,
html:not(.js-ready) .rl,
html:not(.js-ready) .rr,
html:not(.js-ready) .sg .sg-c{opacity:1;transform:none}
html.js-ready .rv{opacity:0;transform:translateY(34px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js-ready .rv.on{opacity:1;transform:translateY(0)}
html.js-ready .rl{opacity:0;transform:translateX(-44px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js-ready .rl.on{opacity:1;transform:translateX(0)}
html.js-ready .rr{opacity:0;transform:translateX(44px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js-ready .rr.on{opacity:1;transform:translateX(0)}
/* stagger parent */
html.js-ready .sg .sg-c{opacity:0;transform:translateY(26px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
html.js-ready .sg.on .sg-c:nth-child(1){transition-delay:0s}
html.js-ready .sg.on .sg-c:nth-child(2){transition-delay:.1s}
html.js-ready .sg.on .sg-c:nth-child(3){transition-delay:.2s}
html.js-ready .sg.on .sg-c:nth-child(4){transition-delay:.3s}
html.js-ready .sg.on .sg-c:nth-child(5){transition-delay:.4s}
html.js-ready .sg.on .sg-c{opacity:1;transform:translateY(0)}

/* ─── SERVICES ───────────────────────────────────────────── */
.services{background:var(--surface)}
.svc-head{text-align:center;margin-bottom:56px}
.svc-head .s-sub{margin:0 auto}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc-card{
  display:block;background:white;border-radius:var(--r);padding:0;
  border:1px solid var(--border);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
  position:relative;overflow:hidden
}
.svc-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--sky-dark),var(--sky-lite));
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);
  z-index:1
}
.svc-card:hover{transform:translateY(-7px);box-shadow:var(--sh-lg);border-color:rgba(14,165,233,.12)}
.svc-card:hover::after{transform:scaleX(1)}
.icon{display:block;flex-shrink:0}
.icon-ok{color:#16a34a}
.icon-sm{width:14px;height:14px;flex-shrink:0}
.svc-thumb{
  aspect-ratio:4/3;overflow:hidden;background:var(--surface-2);
  border-radius:calc(var(--r) - 1px) calc(var(--r) - 1px) 0 0
}
.svc-thumb img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  transition:transform .5s var(--ease)
}
.svc-card:hover .svc-thumb img{transform:scale(1.04)}
.svc-name{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1rem;
  color:var(--ink);margin:0;padding:18px 16px 20px;text-align:center;line-height:1.35
}

/* ─── BEFORE / AFTER (SCROLL REVEAL) ─────────────────────── */
.ba{background:var(--ink);position:relative}
.ba-scroll-outer{height:280vh;position:relative}
.ba-sticky{
  position:sticky;top:0;height:100vh;box-sizing:border-box;
  display:flex;flex-direction:column;
  align-items:center;justify-content:flex-start;
  overflow-x:hidden;overflow-y:clip;
  padding:clamp(20px,3vh,36px) 24px 16px;gap:12px
}
.ba-head{text-align:center;z-index:2;flex-shrink:0}
.ba-head .s-label{line-height:1.5;color:var(--sky-lite)}
.ba-head .s-title{color:white;margin-bottom:0}
.ba-head-sub{
  color:rgba(255,255,255,.38);font-size:.8rem;
  letter-spacing:.08em;text-transform:uppercase;
  margin-top:8px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:500
}
.ba-frame{
  position:relative;width:min(900px,100%);
  max-height:min(520px,calc(100vh - 200px));
  border-radius:20px;overflow:hidden;
  box-shadow:0 40px 96px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.07);
  flex:0 1 auto;min-height:0;background:#0c141f
}
.ba-frame-img{display:block;width:100%;aspect-ratio:16/9;object-fit:cover}
.ba-frame-before{
  position:absolute;inset:0;z-index:2;
  clip-path:inset(0 10% 0 0)
}
.ba-frame-before img{width:100%;height:100%;object-fit:cover;display:block}
.ba-div{
  position:absolute;top:0;bottom:0;
  left:90%;z-index:10;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center
}
.ba-div-line{
  width:2px;flex:1;
  background:rgba(255,255,255,.92);
  box-shadow:0 0 8px rgba(56,189,248,.8),0 0 28px rgba(56,189,248,.4)
}
.ba-div-handle{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:44px;height:44px;
  background:white;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 22px rgba(0,0,0,.5),0 0 0 3px rgba(56,189,248,.3);
  color:var(--ink);gap:1px
}
.ba-div-handle svg{width:13px;height:13px;flex-shrink:0}
.ba-label{
  position:absolute;top:14px;
  padding:5px 14px;
  background:rgba(15,23,42,.8);backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);color:white;border-radius:100px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;
  font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  z-index:5;transition:opacity .6s
}
.ba-label-b{left:14px}
.ba-label-a{right:14px}
.ba-progress-track{
  width:min(900px,100%);height:2px;
  background:rgba(255,255,255,.07);border-radius:100px;overflow:hidden
}
.ba-progress-fill{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--sky-lite),var(--sky));
  border-radius:100px
}
.ba-pills{
  display:flex;flex-wrap:wrap;justify-content:center;gap:9px;
  opacity:0;transform:translateY(14px);
  transition:opacity .55s,transform .55s
}
.ba-pills.show{opacity:1;transform:translateY(0)}
.ba-pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 16px;
  background:rgba(14,165,233,.08);
  border:1px solid rgba(14,165,233,.18);
  border-radius:100px;font-size:.77rem;
  color:rgba(255,255,255,.58)
}
.ba-pill .icon{color:var(--sky-lite)}
.area-card-title{display:flex;align-items:center;gap:10px}
.area-card-title .icon{width:20px;height:20px;color:var(--sky-dark);flex-shrink:0}
.ba-hint{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:rgba(255,255,255,.28);font-size:.6rem;
  letter-spacing:.13em;text-transform:uppercase;
  transition:opacity .5s;pointer-events:none
}
.ba-hint-bar{
  width:1px;height:30px;
  background:linear-gradient(to bottom,transparent,rgba(56,189,248,.55));
  animation:hintDrop 1.7s ease-in-out infinite
}
@keyframes hintDrop{
  0%,100%{opacity:.25;transform:scaleY(.85)}
  50%{opacity:1;transform:scaleY(1)}
}

/* ─── ABOUT ──────────────────────────────────────────────── */
.about{background:white}
.about-wrap{
  padding:96px max(24px,calc((100% - 1200px)/2));
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center
}
.about-imgs{position:relative}
.about-main{
  width:100%;height:520px;object-fit:cover;
  border-radius:var(--r-lg);box-shadow:var(--sh-lg)
}
.about-float{
  position:absolute;bottom:-20px;right:-20px;
  width:200px;height:175px;object-fit:cover;
  border-radius:var(--r);box-shadow:var(--sh-lg);border:4px solid white
}
.about-badge{
  position:absolute;top:28px;right:-18px;
  background:var(--ink);border-radius:var(--r);padding:15px 18px;
  box-shadow:var(--sh-lg);text-align:center
}
.about-badge-n{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.5rem;font-weight:700;color:var(--sky-lite)}
.about-badge-l{font-size:.72rem;color:rgba(255,255,255,.45);margin-top:2px}
.about-checks{margin-top:28px;display:flex;flex-direction:column;gap:11px}
.about-chk{display:flex;align-items:flex-start;gap:11px;font-size:.88rem;color:var(--ink-3);line-height:1.55}
.about-chk-ico{
  width:22px;height:22px;min-width:22px;background:rgba(14,165,233,.1);
  border-radius:6px;display:flex;align-items:center;justify-content:center;margin-top:1px
}
.about-chk-ico svg{width:12px;height:12px}
.about-tel{
  display:inline-flex;align-items:center;gap:9px;margin-top:28px;
  padding:13px 26px;background:var(--ink);color:white;border-radius:11px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.9rem;
  transition:background var(--ease-fast),transform var(--ease-fast),box-shadow var(--ease-fast)
}
.about-tel:hover{background:var(--ink-2);transform:translateY(-2px);box-shadow:var(--sh)}

/* ─── STATS ──────────────────────────────────────────────── */
.stats{background:var(--sky);position:relative;overflow:hidden}
.stats::before{
  content:'';position:absolute;top:-60%;left:-15%;
  width:600px;height:600px;background:rgba(255,255,255,.06);border-radius:50%
}
.stats::after{
  content:'';position:absolute;bottom:-40%;right:-10%;
  width:420px;height:420px;background:rgba(0,0,0,.06);border-radius:50%
}
.stats-grid{
  position:relative;z-index:1;
  padding:72px max(24px,calc((100% - 1200px)/2));
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px
}
.stat{text-align:center;color:white}
.stat-n{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(2.4rem,4vw,3.4rem);font-weight:700;letter-spacing:-.03em;line-height:1
}
.stat-sup{font-size:.55em;vertical-align:super;font-weight:600}
.stat-l{font-size:.88rem;opacity:.8;margin-top:6px}

/* ─── WHY US ─────────────────────────────────────────────── */
.why{background:var(--ink)}
.why-head{text-align:center;margin-bottom:56px}
.why-head .s-sub{margin:0 auto}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.why-card{
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  border-radius:var(--r);padding:34px;
  transition:background .4s var(--ease),border-color .4s var(--ease),transform .4s var(--ease)
}
.why-card:hover{background:rgba(255,255,255,.055);border-color:rgba(14,165,233,.2);transform:translateY(-5px)}
.why-ico{
  width:54px;height:54px;background:rgba(14,165,233,.1);border-radius:14px;
  display:flex;align-items:center;justify-content:center;margin-bottom:22px
}
.why-ico .icon{width:24px;height:24px;color:var(--sky-dark)}
.why-t{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1rem;color:white;margin-bottom:10px}
.why-d{font-size:.875rem;color:rgba(255,255,255,.48);line-height:1.7}

/* ─── GOOGLE REVIEWS CAROUSEL ──────────────────────────────── */
.reviews{background:var(--surface)}
.reviews-inner{padding:96px max(24px,calc((100% - 1200px)/2))}
.reviews-top{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:28px;margin-bottom:44px;flex-wrap:wrap
}
.reviews-top .s-sub{max-width:480px}
.reviews-summary-wrap{flex-shrink:0}
.reviews-summary{
  display:flex;align-items:center;gap:14px;
  background:white;border:1px solid var(--border);border-radius:var(--r);
  padding:16px 20px;box-shadow:var(--sh);min-width:min(100%,280px)
}
.reviews-google-badge{
  width:44px;height:44px;flex-shrink:0;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:var(--surface)
}
.reviews-summary-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.reviews-rating-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.reviews-rating-num{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.65rem;font-weight:700;
  color:var(--ink);letter-spacing:-.03em;line-height:1.1
}
.reviews-stars{
  color:#f59e0b;font-size:.88rem;letter-spacing:1px;line-height:1;
  transform:translateY(-1px)
}
.reviews-count{font-size:.78rem;color:var(--muted);line-height:1.4;margin:0}
.reviews-view{
  display:inline-flex;align-items:center;gap:6px;margin-top:6px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.8rem;
  color:var(--sky);transition:gap .25s,color var(--ease-fast);align-self:flex-start
}
.reviews-view:hover{gap:9px;color:var(--sky-dark)}
.reviews-carousel{position:relative}
.reviews-viewport{overflow:hidden;padding:8px 4px 28px}
.reviews-track{display:flex;transition:transform .55s var(--ease)}
.review-slide{min-width:100%;padding:0 2px;box-sizing:border-box}
.review-card{
  background:white;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:clamp(28px,4vw,40px);
  box-shadow:0 2px 8px rgba(15,23,42,0.04),0 12px 40px rgba(15,23,42,0.08);
  position:relative;overflow:hidden
}
.review-card::before{
  content:'"';position:absolute;top:-8px;right:24px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:6rem;font-weight:700;
  color:var(--sky);opacity:.06;line-height:1;pointer-events:none
}
.review-stars{color:#f59e0b;font-size:1rem;letter-spacing:2px;margin-bottom:18px}
.review-text{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(1.05rem,2.4vw,1.35rem);font-weight:500;font-style:normal;
  color:var(--ink);line-height:1.6;margin:0 0 28px;max-width:820px
}
.review-author{display:flex;align-items:center;gap:14px}
.review-av{
  width:50px;height:50px;border-radius:50%;overflow:hidden;flex-shrink:0;
  background:rgba(14,165,233,.1);display:flex;align-items:center;justify-content:center
}
.review-av-letter{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:1rem;color:var(--sky-dark)
}
.review-av-img{width:100%;height:100%;object-fit:cover}
.review-name{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.9rem;
  color:var(--ink);font-style:normal
}
.review-time{font-size:.78rem;color:var(--muted);margin-top:2px}
.reviews-controls{
  display:flex;align-items:center;justify-content:center;gap:20px;margin-top:28px
}
.reviews-nav{
  width:46px;height:46px;border-radius:50%;border:1px solid var(--border);
  background:white;color:var(--ink);display:flex;align-items:center;justify-content:center;
  transition:background var(--ease-fast),border-color var(--ease-fast),transform var(--ease-fast),box-shadow var(--ease-fast)
}
.reviews-nav:hover:not(:disabled){
  background:var(--sky);color:white;border-color:var(--sky);
  transform:translateY(-2px);box-shadow:var(--sh-sky)
}
.reviews-nav:disabled{opacity:.35;cursor:not-allowed}
.reviews-nav svg{width:18px;height:18px}
.reviews-dots{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}
.review-dot{
  width:8px;height:8px;border-radius:50%;background:var(--border);
  padding:0;transition:background .25s,transform .25s,width .25s
}
.review-dot.active{background:var(--sky);width:22px;border-radius:100px}
.reviews-empty{text-align:center;color:var(--muted);padding:40px 20px;font-size:.92rem}
.reviews:not(.loaded) .reviews-carousel{opacity:.6}

/* ─── GALLERY ────────────────────────────────────────────── */
.gallery{background:white}
.gal-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:44px;gap:20px}
.gal-grid{columns:3;column-gap:14px}
.gal-item{
  break-inside:avoid;margin-bottom:14px;border-radius:var(--r);
  overflow:hidden;cursor:pointer;position:relative;display:block;
  width:100%;padding:0;border:none;background:none;font:inherit;text-align:left;
  opacity:1;transform:none;
  animation:galIn .55s var(--ease) both;
  animation-delay:calc(var(--gal-i, 0) * 0.05s)
}
.gal-grid:not(.is-expanded) .gal-item--more{display:none}
#gallery.is-expanded .gal-more{display:none}
.gal-more{text-align:center;margin-top:36px}
.gal-more[hidden]{display:none}
.gal-more-btn{
  color:var(--ink);
  background:var(--surface);
  border:1px solid var(--border);
  font-weight:600;
  cursor:pointer;
}
.gal-more-btn:hover{
  background:white;
  border-color:rgba(14,165,233,.35);
  color:var(--sky-dark);
  box-shadow:var(--sh);
}
@keyframes galIn{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}
.gal-item img{width:100%;display:block;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.gal-item::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(14,165,233,.35),rgba(2,132,199,.2));
  opacity:0;transition:opacity .3s
}
.gal-item:hover img{transform:scale(1.06)}
.gal-item:hover::after{opacity:1}
/* lightbox */
.lb{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.96);z-index:200;
  align-items:center;justify-content:center
}
.lb.open{display:flex}
.lb img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:var(--r)}
.lb-x{
  position:absolute;top:20px;right:24px;color:rgba(255,255,255,.55);
  font-size:1.8rem;line-height:1;transition:color var(--ease-fast);padding:4px
}
.lb-x:hover{color:white}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;background:rgba(255,255,255,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:white;font-size:1.3rem;cursor:pointer;
  transition:background var(--ease-fast);backdrop-filter:blur(4px)
}
.lb-nav:hover{background:rgba(255,255,255,.22)}
.lb-prev{left:18px}.lb-next{right:18px}
.lb-count{
  position:absolute;bottom:22px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.45);font-family:'Plus Jakarta Sans',sans-serif;font-size:.82rem
}

/* ─── INSTANT QUOTE WIDGET ───────────────────────────────── */
.contact--quote{border-top:1px solid var(--border)}
.contact--quote .quote-widget{max-width:none;margin:0}
.contact--quote .qw-card{margin:0}
.qw-card{
  background:white;border-radius:var(--r-lg);padding:32px;
  box-shadow:var(--sh-lg);border:1px solid var(--border)
}
.qw-progress{
  display:flex;gap:8px;margin-bottom:32px;padding-bottom:24px;
  border-bottom:1px solid var(--border)
}
.qw-step{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;
  opacity:.4;transition:opacity .25s var(--ease)
}
.qw-step.active,.qw-step.done{opacity:1}
.qw-step-n{
  width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.75rem;font-weight:700;
  background:var(--surface-2);color:var(--muted);transition:background .25s,color .25s
}
.qw-step.active .qw-step-n{background:var(--sky);color:white}
.qw-step.done .qw-step-n{background:rgba(14,165,233,.15);color:var(--sky-dark)}
.qw-step-l{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.68rem;font-weight:600;
  color:var(--muted);text-transform:uppercase;letter-spacing:.06em;text-align:center
}
.qw-step.active .qw-step-l{color:var(--ink)}
.qw-panel-t{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.35rem;font-weight:700;
  color:var(--ink);letter-spacing:-.02em;margin-bottom:8px
}
.qw-panel-s{font-size:.92rem;color:var(--muted);line-height:1.65;margin-bottom:24px}
.qw-presets{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.qw-chips{display:flex;flex-wrap:wrap;gap:8px}
.qw-chip{
  padding:8px 14px;border-radius:100px;border:1px solid var(--border);
  background:var(--surface);font-family:'Plus Jakarta Sans',sans-serif;
  font-size:.8rem;font-weight:500;color:var(--ink-3);transition:all var(--ease-fast)
}
.qw-chip:hover{border-color:var(--sky);color:var(--sky-dark)}
.qw-chip.is-on{background:rgba(14,165,233,.1);border-color:var(--sky);color:var(--sky-dark)}
.qw-excluded{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.qw-excluded-l{font-size:.82rem;color:var(--muted);margin-bottom:10px}
.qw-fields{display:flex;flex-direction:column;gap:14px}
.qw-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:24px}
.qw-type-card{
  padding:14px 12px;border-radius:12px;border:1px solid var(--border);
  background:var(--surface);text-align:left;transition:all var(--ease-fast)
}
.qw-type-card:hover{border-color:var(--sky)}
.qw-type-card.is-on{background:rgba(14,165,233,.08);border-color:var(--sky);box-shadow:0 0 0 3px rgba(14,165,233,.1)}
.qw-type-l{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.85rem;color:var(--ink)}
.qw-type-n{display:block;font-size:.75rem;color:var(--muted);margin-top:4px}
.qw-window-ctrl label{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.76rem;color:var(--ink-3);margin-bottom:8px}
.qw-window-row{display:flex;align-items:center;gap:12px}
.qw-window-btn{
  width:40px;height:40px;border-radius:10px;border:1px solid var(--border);
  background:white;font-size:1.2rem;color:var(--ink);transition:all var(--ease-fast)
}
.qw-window-btn:hover{border-color:var(--sky);color:var(--sky-dark)}
.qw-window-row input{
  width:72px;text-align:center;padding:10px;border:1px solid var(--border);
  border-radius:10px;font-family:'Plus Jakarta Sans',sans-serif;font-size:1.1rem;font-weight:700
}
.qw-field-l{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.8rem;color:var(--ink-3);margin-bottom:10px}
.qw-freq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:24px}
.qw-freq-card{
  padding:14px;border-radius:12px;border:1px solid var(--border);background:var(--surface);
  text-align:left;font-family:'Plus Jakarta Sans',sans-serif;font-size:.88rem;font-weight:500;
  color:var(--ink);transition:all var(--ease-fast)
}
.qw-freq-card em{display:block;font-size:.72rem;font-style:normal;color:var(--sky-dark);margin-top:4px;font-weight:600}
.qw-freq-card.is-on{background:rgba(14,165,233,.08);border-color:var(--sky)}
.qw-addon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:8px}
.qw-addon-card{
  padding:14px;border-radius:12px;border:1px solid var(--border);background:var(--surface);
  text-align:left;transition:all var(--ease-fast)
}
.qw-addon-card span{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:.85rem;font-weight:500;color:var(--ink)}
.qw-addon-card strong{display:block;font-size:.82rem;color:var(--sky-dark);margin-top:4px}
.qw-addon-card small{display:block;font-size:.72rem;color:var(--muted);margin-top:4px;line-height:1.4}
.qw-addon-card.is-on{background:rgba(14,165,233,.08);border-color:var(--sky)}
.qw-skylight-ctrl{margin-bottom:24px}
.qw-skylight-note{font-size:.78rem;color:var(--muted);margin-top:8px}
.qw-manual-note{font-size:.75rem;color:var(--muted);line-height:1.5;margin-top:16px}
.qw-access-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.qw-access-card{
  padding:14px;border-radius:12px;border:1px solid var(--border);background:var(--surface);
  text-align:left;font-family:'Plus Jakarta Sans',sans-serif;font-size:.88rem;font-weight:500;
  color:var(--ink);transition:all var(--ease-fast)
}
.qw-access-card span{display:block}
.qw-access-card em{display:block;font-size:.72rem;font-style:normal;color:var(--muted);margin-top:6px;font-weight:500;line-height:1.4}
.qw-access-card.is-on{background:rgba(14,165,233,.08);border-color:var(--sky)}
.qw-cta-card{
  background:white;border-radius:var(--r-lg);padding:32px;box-shadow:var(--sh-lg);
  border:1px solid var(--border);text-align:center
}
.qw-cta-ico{
  width:56px;height:56px;margin:0 auto 16px;border-radius:14px;
  background:rgba(14,165,233,.1);color:var(--sky-dark);
  display:flex;align-items:center;justify-content:center
}
.qw-cta-t{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.25rem;font-weight:700;
  color:var(--ink);margin-bottom:8px;letter-spacing:-.02em
}
.qw-cta-s{font-size:.9rem;color:var(--muted);line-height:1.65;margin-bottom:16px}
.qw-cta-list{
  list-style:none;text-align:left;font-size:.85rem;color:var(--ink-3);
  margin:0 auto 24px;max-width:280px;display:flex;flex-direction:column;gap:8px
}
.qw-cta-list li{padding-left:18px;position:relative}
.qw-cta-list li::before{
  content:'';position:absolute;left:0;top:.55em;width:6px;height:6px;
  border-radius:50%;background:var(--sky)
}
.qw-cta-btn{width:100%}
.quote-page{padding-top:88px}
.quote-page .contact-wrap{padding-top:48px}
.qw-actions{display:flex;gap:12px;margin-top:28px;justify-content:flex-end}
.qw-actions-stack{flex-direction:column}
.qw-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 24px;border-radius:11px;font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:600;font-size:.92rem;transition:all var(--ease-fast);border:none;cursor:pointer
}
.qw-btn-p{background:var(--sky);color:white}
.qw-btn-p:hover:not(:disabled){background:var(--sky-dark);transform:translateY(-1px);box-shadow:var(--sh-sky)}
.qw-btn-p:disabled{opacity:.6;cursor:not-allowed}
.qw-btn-s{background:var(--surface);color:var(--ink);border:1px solid var(--border)}
.qw-btn-s:hover{background:var(--surface-2)}
.qw-err{color:#dc2626;font-size:.85rem;margin-top:12px}
.qw-quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.qw-quote-addr{font-size:.88rem;color:var(--muted);margin-bottom:16px}
.qw-quote-total{margin-bottom:20px}
.qw-quote-lbl{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;margin-bottom:4px}
.qw-quote-price{font-family:'Plus Jakarta Sans',sans-serif;font-size:2.4rem;font-weight:700;color:var(--ink);letter-spacing:-.03em}
.qw-breakdown{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.qw-breakdown li{display:flex;justify-content:space-between;gap:12px;font-size:.85rem;color:var(--ink-3);padding-bottom:8px;border-bottom:1px solid var(--border)}
.qw-breakdown li.is-disc{color:var(--sky-dark)}
.qw-quote-note{font-size:.78rem;color:var(--muted);line-height:1.5}
.qw-quote-form h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:4px}
.qw-quote-form>p{font-size:.85rem;color:var(--muted);margin-bottom:16px}
.qw-notice{
  padding:14px 16px;border-radius:12px;background:rgba(14,165,233,.08);
  border:1px solid rgba(14,165,233,.2);font-size:.85rem;color:var(--ink-3);
  margin-bottom:20px;line-height:1.55
}
.qw-done{text-align:center;padding:20px 0}
.qw-done-ico{color:var(--sky);margin-bottom:16px;display:flex;justify-content:center}
.qw-done .qw-btn{margin-top:20px}
.qw-fail{text-align:center;color:var(--muted);padding:24px}
.qw-loading{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;min-height:200px;text-align:center
}
.qw-loading p{font-size:.88rem;color:var(--muted)}
.qw-loading-pulse{
  width:36px;height:36px;border-radius:50%;
  border:3px solid rgba(14,165,233,.15);border-top-color:var(--sky);
  animation:qw-spin .8s linear infinite
}
@keyframes qw-spin{to{transform:rotate(360deg)}}
.qw-card .f-g input{
  padding:12px 15px;background:var(--surface);border:1px solid var(--border);
  border-radius:10px;font-family:'Inter',sans-serif;font-size:.92rem;color:var(--ink);
  transition:border-color var(--ease-fast),box-shadow var(--ease-fast);outline:none;width:100%
}
.qw-card .f-g input:focus{
  border-color:var(--sky);box-shadow:0 0 0 3px rgba(14,165,233,.1)
}
.qw-window-ctrl{margin-bottom:20px}
.qw-window-ctrl:last-of-type{margin-bottom:0}
.qw-window-row input[type=number]::-webkit-inner-spin-button,
.qw-window-row input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.qw-window-row input[type=number]{-moz-appearance:textfield;appearance:textfield}
.qw-type-card,.qw-freq-card,.qw-addon-card,.qw-access-card{cursor:pointer}
.qw-type-card:focus-visible,.qw-freq-card:focus-visible,.qw-addon-card:focus-visible,
.qw-access-card:focus-visible,.qw-window-btn:focus-visible,.qw-btn:focus-visible{
  outline:2px solid var(--sky);outline-offset:2px
}
.qw-breakdown li span:first-child{flex:1;min-width:0;line-height:1.45}
.qw-breakdown li span:last-child{flex-shrink:0;font-weight:600;font-family:'Plus Jakarta Sans',sans-serif}
.qw-quote-form{
  padding:28px;background:var(--surface);border-radius:var(--r);
  border:1px solid var(--border)
}
.contact--quote{padding-bottom:48px}
@media(max-width:720px){
  .qw-card{padding:20px 18px}
  .qw-step-l{display:none}
  .qw-progress{gap:6px;margin-bottom:24px;padding-bottom:18px}
  .qw-step-n{width:32px;height:32px;font-size:.8rem}
  .qw-panel-t{font-size:1.15rem}
  .qw-panel-s{font-size:.88rem;margin-bottom:20px}
  .qw-type-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .qw-access-grid,.qw-freq-grid,.qw-addon-grid{grid-template-columns:1fr}
  .qw-quote-grid{grid-template-columns:1fr;gap:24px}
  .qw-quote-form{padding:20px;margin-top:4px}
  .qw-quote-price{font-size:2rem}
  .qw-actions{flex-direction:column-reverse;margin-top:24px}
  .qw-btn{width:100%}
  .qw-window-row input,.qw-card .f-g input{font-size:16px}
  .contact--quote{padding-bottom:108px}
  .contact--quote .contact-wrap{padding-top:48px;padding-bottom:24px}
  .quote-page{padding-top:72px}
  .quote-page .contact-wrap{padding-top:32px}
}

/* ─── CONTACT ────────────────────────────────────────────── */
.contact{background:var(--surface)}
.contact-wrap{
  padding:96px max(24px,calc((100% - 1200px)/2));
  display:grid;grid-template-columns:1fr 1.3fr;gap:72px;align-items:start
}
.contact-h{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.9rem;font-weight:700;
  color:var(--ink);letter-spacing:-.02em;margin-bottom:14px
}
.contact-sub{font-size:.95rem;color:var(--muted);line-height:1.7;margin-bottom:36px}
.contact-details{display:flex;flex-direction:column;gap:18px;margin-bottom:36px}
.c-det{display:flex;align-items:center;gap:13px}
.c-det-ico{
  width:42px;height:42px;background:rgba(14,165,233,.08);border-radius:11px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0
}
.c-det-ico .icon{width:18px;height:18px;color:var(--sky-dark)}
.c-det-lbl{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600}
.c-det-val{font-size:.92rem;color:var(--ink);font-weight:500;margin-top:1px}
.contact-tags{display:flex;flex-wrap:wrap;gap:7px}
.c-tag{
  padding:5px 13px;background:white;border:1px solid var(--border);
  border-radius:100px;font-size:.78rem;color:var(--muted);
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:500
}
.contact-form{
  background:white;border-radius:var(--r-lg);padding:36px;
  box-shadow:var(--sh);border:1px solid var(--border)
}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.f-g{display:flex;flex-direction:column;gap:6px}
.f-g label{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;
  font-size:.76rem;color:var(--ink-3);letter-spacing:.03em
}
.f-g input,.f-g select,.f-g textarea{
  padding:11px 15px;background:var(--surface);border:1px solid var(--border);
  border-radius:9px;font-family:'Inter',sans-serif;font-size:.92rem;color:var(--ink);
  transition:border-color var(--ease-fast),box-shadow var(--ease-fast);outline:none;width:100%
}
.f-g input::placeholder,.f-g textarea::placeholder{color:var(--muted)}
.f-g input:focus,.f-g select:focus,.f-g textarea:focus{
  border-color:var(--sky);box-shadow:0 0 0 3px rgba(14,165,233,.1)
}
.f-g textarea{resize:vertical;min-height:112px}
.f-g select{appearance:none;cursor:pointer}
.f-stack{display:flex;flex-direction:column;gap:14px;margin-top:14px}
.f-submit{
  display:flex;align-items:center;justify-content:center;gap:9px;width:100%;
  padding:13px;background:var(--sky);color:white;border-radius:11px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.95rem;
  transition:background var(--ease-fast),transform var(--ease-fast),box-shadow var(--ease-fast);
  margin-top:4px
}
.f-submit:hover{background:var(--sky-dark);transform:translateY(-2px);box-shadow:var(--sh-sky)}
.f-ok{display:none;text-align:center;padding:40px}
.f-ok.show{display:block}
.f-ok-ico{font-size:2.8rem;margin-bottom:14px}
.f-ok-t{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.2rem;font-weight:600;color:var(--ink);margin-bottom:6px}
.f-ok-s{color:var(--muted);font-size:.88rem}

/* ─── FOOTER ─────────────────────────────────────────────── */
.footer{background:var(--ink);border-top:1px solid rgba(255,255,255,.04)}
.footer-inner{padding:60px max(24px,calc((100% - 1200px)/2)) 28px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px}
.f-logo{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.f-logo-mark{
  width:31px;height:31px;background:var(--sky);border-radius:8px;
  display:flex;align-items:center;justify-content:center
}
.f-logo-mark .icon{width:18px;height:18px;color:white}
.f-ok-ico{display:flex;justify-content:center;margin-bottom:14px}
.f-ok-ico .icon{width:40px;height:40px}
.f-logo-t{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.95rem;color:white}
.f-tag{font-size:.82rem;color:rgba(255,255,255,.3);line-height:1.65;max-width:230px}
.f-col-h{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.75rem;
  color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.09em;margin-bottom:14px
}
.f-links{display:flex;flex-direction:column;gap:9px}
.f-links a{font-size:.82rem;color:rgba(255,255,255,.35);transition:color var(--ease-fast)}
.f-links a:hover{color:white}
.f-bot{
  padding-top:22px;border-top:1px solid rgba(255,255,255,.05);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap
}
.f-copy{font-size:.78rem;color:rgba(255,255,255,.22)}
.f-bot-links{display:flex;gap:22px}
.f-bot-links a{font-size:.78rem;color:rgba(255,255,255,.22);transition:color var(--ease-fast)}
.f-bot-links a:hover{color:rgba(255,255,255,.6)}

/* ─── MOBILE CTA ─────────────────────────────────────────── */
.mob-cta-btn{
  display:none;position:fixed;bottom:20px;left:50%;
  transform:translateX(-50%);z-index:50;
  padding:13px 36px;background:var(--sky);color:white;border-radius:100px;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.92rem;
  box-shadow:0 8px 32px rgba(14,165,233,.42);white-space:nowrap;
  transition:background var(--ease-fast),transform var(--ease-fast),opacity .3s
}
.mob-cta-btn:hover{background:var(--sky-dark);transform:translateX(-50%) translateY(-2px)}

/* ─── MODALS ─────────────────────────────────────────────── */
.modal-ov{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.8);
  z-index:300;align-items:center;justify-content:center;padding:20px
}
.modal-ov.open{display:flex}
.modal{
  background:white;border-radius:var(--r-lg);padding:36px;
  max-width:580px;width:100%;max-height:80vh;overflow-y:auto;position:relative
}
.modal-x{position:absolute;top:14px;right:16px;color:var(--muted);font-size:1.2rem;transition:color var(--ease-fast)}
.modal-x:hover{color:var(--ink)}
.modal h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.3rem;font-weight:700;color:var(--ink);margin-bottom:14px}
.modal p{font-size:.87rem;color:var(--muted);line-height:1.7;margin-bottom:10px}
.modal h3{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.95rem;color:var(--ink);margin:18px 0 7px}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:1024px){
  .hero-content{grid-template-columns:1fr;padding-top:120px;padding-bottom:72px}
  .hero-right{display:none}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .ba-scroll-outer{height:210vh}
  .ba-frame{aspect-ratio:4/3;max-height:min(420px,calc(100vh - 180px))}
  .ba-frame-img{aspect-ratio:unset;height:100%;position:absolute;inset:0}
  .about-wrap{grid-template-columns:1fr;gap:48px}
  .about-imgs{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1fr 1fr}
  .contact-wrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .mob-cta-btn{display:flex}
}
@media(max-width:640px){
  .s-inner,.about-wrap,.contact-wrap{padding-left:20px;padding-right:20px}
  .ba-scroll-outer{height:168vh}
  .ba-sticky{
    height:100dvh;
    justify-content:center;
    padding:14px 20px 18px;
    gap:10px
  }
  .ba-head-sub{margin-top:4px}
  .ba-frame{aspect-ratio:5/6;max-height:min(58dvh,calc(100dvh - 148px))}
  .ba-hint{display:none}
  .ba-pills{display:none}
  .hero-left{text-align:center}
  .hero-pill{margin-left:auto;margin-right:auto}
  .hero-sub{max-width:100%}
  .hero-btns{justify-content:center}
  .hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;text-align:center}
  .h-stat-n{font-size:1.3rem}
  .h-stat-l{font-size:.65rem}
  .stats-grid{padding-left:20px;padding-right:20px}
  .footer-inner{padding-left:20px;padding-right:20px}
  .why-grid,.why-head{padding:0}
  .s-inner{padding-top:72px;padding-bottom:72px}
  .why-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .f-row{grid-template-columns:1fr}
  .hero-stats{flex-wrap:wrap;gap:20px}
  .contact-form{padding:22px}
  .gal-grid{columns:2}
  .gal-head{flex-direction:column;align-items:flex-start}
  .reviews-top{flex-direction:column;align-items:flex-start}
  .review-card::before{font-size:4rem;right:12px}
}
@media(max-width:480px){
  /* swipeable services on small phones */
  .svc-grid{
    display:flex;overflow-x:auto;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;gap:14px;padding-bottom:12px;
    grid-template-columns:unset
  }
  .svc-grid::-webkit-scrollbar{display:none}
  .svc-card{width:calc(100vw - 60px);max-width:320px;min-width:unset;scroll-snap-align:start;flex-shrink:0}
}

/* ─── LOCAL AREA PAGES ─────────────────────────────────────── */
.hero .area-breadcrumb + .hero-content{padding-top:28px}
.area-breadcrumb{
  padding:88px max(24px,calc((100% - 1200px)/2)) 0;
  font-size:.82rem;color:rgba(255,255,255,.45);
  font-family:'Plus Jakarta Sans',sans-serif
}
.area-breadcrumb a{color:rgba(255,255,255,.65);transition:color var(--ease-fast)}
.area-breadcrumb a:hover{color:white}
.area-breadcrumb span{margin:0 8px;opacity:.4}
.area-local{background:white;border-bottom:1px solid var(--border)}
.area-local-wrap{
  padding:64px max(24px,calc((100% - 1200px)/2));
  display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start
}
.area-local-points{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.area-local-point{
  display:flex;align-items:flex-start;gap:11px;font-size:.9rem;color:var(--ink-3);line-height:1.55
}
.area-local-point::before{
  content:'';width:8px;height:8px;margin-top:7px;border-radius:50%;
  background:var(--sky);flex-shrink:0;box-shadow:0 0 0 3px rgba(14,165,233,.15)
}
.areas-index-hero{
  padding:120px max(24px,calc((100% - 1200px)/2)) 48px;
  background:var(--ink);color:white
}
.areas-index-hero h1{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(2rem,4vw,3rem);font-weight:700;letter-spacing:-.03em;margin:14px 0
}
.areas-index-hero p{color:rgba(255,255,255,.55);max-width:560px;line-height:1.75}
.areas-grid-section{padding:64px max(24px,calc((100% - 1200px)/2)) 96px;background:var(--surface)}
.areas-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:32px
}
.area-card.svc-card{padding:0}
.area-card.svc-card .svc-name{font-size:1.05rem;padding:16px 14px 18px}
.area-card{
  display:block;background:white;border:1px solid var(--border);border-radius:var(--r);
  padding:22px 24px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s
}
.area-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(14,165,233,.2)}
.area-card h3{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1.05rem;color:var(--ink);margin-bottom:6px
}
.area-card p{font-size:.84rem;color:var(--muted);line-height:1.55;margin-bottom:14px}
.area-card-link{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.82rem;color:var(--sky);
  display:inline-flex;align-items:center;gap:5px
}
.c-tag.is-link{cursor:pointer;transition:border-color var(--ease-fast),color var(--ease-fast)}
.c-tag.is-link:hover{border-color:rgba(14,165,233,.35);color:var(--sky-dark)}
@media(max-width:1024px){
  .area-local-wrap{grid-template-columns:1fr;gap:32px}
}

.faq-section{
  padding:88px max(24px,calc((100% - 1200px)/2));
  background:white;border-top:1px solid var(--border)
}
.faq-head{text-align:center;margin-bottom:44px}
.faq-head .s-sub{max-width:520px;margin:14px auto 0}
.faq-list{
  max-width:760px;margin:0 auto;
  display:flex;flex-direction:column;gap:12px
}
.faq-item{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease)
}
.faq-item:hover{border-color:rgba(14,165,233,.18)}
.faq-item[open]{
  background:white;border-color:rgba(14,165,233,.22);
  box-shadow:0 4px 24px rgba(15,23,42,.06)
}
.faq-item summary{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:20px 24px;cursor:pointer;list-style:none;
  -webkit-user-select:none;user-select:none
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-q{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1rem;
  color:var(--ink);line-height:1.45;letter-spacing:-.02em;text-align:left
}
.faq-icon{
  width:38px;height:38px;flex-shrink:0;border-radius:11px;
  background:rgba(14,165,233,.08);color:var(--sky-dark);
  display:flex;align-items:center;justify-content:center;
  transition:transform .35s var(--ease),background .35s var(--ease)
}
.faq-item[open] .faq-icon{
  transform:rotate(180deg);background:rgba(14,165,233,.14)
}
.faq-a{
  padding:0 24px 22px;border-top:1px solid var(--border)
}
.faq-a p{
  margin:18px 0 0;font-size:.92rem;color:var(--muted);line-height:1.75
}
.faq-cta{
  text-align:center;margin-top:36px;font-size:.9rem;color:var(--muted);line-height:1.6
}
.faq-cta a{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;color:var(--sky);
  transition:color var(--ease-fast)
}
.faq-cta a:hover{color:var(--sky-dark)}

.gallery--service{padding:64px max(24px,calc((100% - 1200px)/2))}
.gallery--service .gal-head{
  justify-content:flex-start;align-items:flex-start;margin-bottom:32px
}
.gallery--service .gal-head .s-title{margin-top:10px}
.gallery--service .gal-grid--service{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:14px;
  columns:unset
}
.gallery--service .gal-item{
  break-inside:unset;margin-bottom:0
}

/* ─── SERVICE PAGE: LOCAL AREAS ─────────────────────────── */
.local-areas{background:var(--surface)}
.local-areas .svc-head{margin-bottom:40px}
.local-areas-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:14px
}
.local-area-card{
  display:flex;flex-direction:column;gap:6px;position:relative;
  background:white;border:1px solid var(--border);border-radius:var(--r);
  padding:20px 48px 20px 22px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)
}
.local-area-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--sky-dark),var(--sky-lite));
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);
  border-radius:0 0 var(--r) var(--r)
}
.local-area-card:hover{
  transform:translateY(-4px);box-shadow:var(--sh-lg);
  border-color:rgba(14,165,233,.15)
}
.local-area-card:hover::after{transform:scaleX(1)}
.local-area-card-name{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1.05rem;
  color:var(--ink);letter-spacing:-.02em
}
.local-area-card-meta{font-size:.8rem;color:var(--muted);line-height:1.4}
.local-area-card-arrow{
  position:absolute;right:18px;top:50%;transform:translateY(-50%);
  color:var(--sky);opacity:.45;transition:opacity .25s var(--ease-fast),transform .25s var(--ease-fast)
}
.local-area-card:hover .local-area-card-arrow{opacity:1;transform:translate(2px,-50%)}
.local-areas-foot{
  text-align:center;margin-top:36px;font-size:.88rem;color:var(--muted)
}
.local-areas-foot a{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;color:var(--sky);
  transition:color var(--ease-fast)
}
.local-areas-foot a:hover{color:var(--sky-dark)}
.local-areas-foot span{margin:0 10px;opacity:.4}

.legal-page{padding:100px 24px 64px;min-height:60vh}
.legal-page-inner{max-width:680px;margin:0 auto}
.legal-page h1{font-family:'Plus Jakarta Sans',sans-serif;font-size:2rem;font-weight:700;margin-bottom:8px}
.legal-updated{font-size:.88rem;color:var(--muted);margin-bottom:32px}
.legal-page h2{font-size:1.1rem;font-weight:600;margin:28px 0 10px;color:var(--ink)}
.legal-page p{font-size:.92rem;color:var(--muted);line-height:1.7;margin-bottom:12px}

.reviews-summary--static[hidden]{display:none!important}
