/* ============================================================
   A.M.I.C.E. Building Company — styles.css
   Lighter blue · High readability · Modern / Futuristic
   ============================================================ */

:root {
  /* Backgrounds — light grey-blue / very light blue */
  --bg:          #eaecf5;
  --bg-1:        #e4e8f3;
  --bg-2:        #e6edff;
  --bg-3:        #dde4f5;
  --bg-slate:    #d4dcee;
  --bg-graphite: #c8d2e8;
  --bg-coal:     #bcc8e2;
  --bg-steel:    #b0bcdc;

  --surface:     #eaecf5;
  --card:        #ffffff;
  --border:      rgba(0,32,80,.10);
  --border-hi:   rgba(0,32,80,.22);

  /* Blues — brighter, sky-cornflower palette */
  --blue-deep:   #0f4a9e;
  --blue:        #1d7de0;
  --blue-mid:    #3a9ef8;
  --blue-lt:     #6abcff;
  --sky:         #8dd4ff;
  --cyan:        #40e8ff;
  --ice:         #d0eeff;

  /* Text — dark on light backgrounds */
  --text:        #1a2040;
  --text-2:      #4a5568;
  --text-3:      #8a9bb5;
  --text-inv:    #ffffff;

  --gold:        #d4870a;
  --green:       #0a9e65;
  --red:         #c93535;

  --g-blue:    linear-gradient(135deg,#1d7de0 0%,#3a9ef8 55%,#6abcff 100%);
  --g-card:    linear-gradient(145deg,rgba(255,255,255,.98),rgba(240,235,225,.90));

  --sh-sm:  0 2px 14px rgba(0,0,0,.07);
  --sh-md:  0 8px 32px rgba(0,0,0,.11);
  --sh-lg:  0 24px 64px rgba(0,0,0,.16);
  --sh-glow:0 0 48px rgba(58,158,248,.12);

  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --t-fast:.18s ease; --t:.3s cubic-bezier(.2,0,.2,1); --t-slow:.65s cubic-bezier(.2,0,.2,1);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:color var(--t-fast)}
button{font-family:inherit;cursor:pointer}
svg{display:block}

/* CURSOR SPOTLIGHT */
#globalSpotlight{position:fixed;width:24px;height:24px;border-radius:50%;background:rgba(64,232,255,.08);border:1.5px solid rgba(64,232,255,.9);box-shadow:0 0 10px rgba(64,232,255,.5),0 0 22px rgba(29,125,224,.3);pointer-events:none;transform:translate(-50%,-50%);z-index:9999;will-change:left,top;top:-999px;left:-999px;animation:cursorGlow 2.4s ease-in-out infinite}
@keyframes cursorGlow{0%,100%{box-shadow:0 0 8px rgba(64,232,255,.45),0 0 18px rgba(29,125,224,.25)}50%{box-shadow:0 0 16px rgba(64,232,255,.8),0 0 36px rgba(29,125,224,.5)}}
@media(max-width:768px){#globalSpotlight{display:none}}

/* LAYOUT */
.section-inner{max-width:1280px;margin:0 auto;padding:0 40px}
@media(max-width:768px){.section-inner{padding:0 20px}}
.section-kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(29,125,224,.08);border:1px solid rgba(29,125,224,.2);color:var(--blue);padding:6px 16px;border-radius:50px;font-size:.75rem;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:18px}
.section-kicker svg{width:13px;height:13px;fill:var(--blue)}
.section-title{font-family:'Barlow Condensed',sans-serif;font-size:clamp(2rem,4.5vw,3.25rem);font-weight:700;color:var(--text);line-height:1.05;letter-spacing:-.5px;margin-bottom:16px}
.section-title em,.hl{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:400;background:var(--g-blue);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-sub{font-size:1.0625rem;color:var(--text-2);line-height:1.72;max-width:560px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:.8125rem 1.625rem;border-radius:50px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:.9375rem;border:none;cursor:pointer;transition:all var(--t);white-space:nowrap;text-decoration:none}
.btn svg{width:17px;height:17px;flex-shrink:0}
.btn-primary{background:var(--g-blue);color:#fff;box-shadow:0 8px 28px rgba(29,125,224,.38)}
.btn-primary svg{fill:#fff}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(29,125,224,.52)}
.btn-glass{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(12px)}
.btn-glass svg{fill:#fff}
.btn-glass:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.34);transform:translateY(-2px)}
.btn-glass-dark{background:rgba(29,125,224,.12);color:var(--sky);border:1px solid rgba(130,200,255,.22)}
.btn-glass-dark:hover{background:rgba(58,158,248,.24);border-color:var(--sky)}
.btn-white{background:#fff;color:var(--blue)}
.btn-white svg{fill:var(--blue)}
.btn-white:hover{background:#ddeeff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.28)}
.btn-ghost svg{fill:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}
/* btn-glass on light hero background */
.hero .btn-glass{background:#fff;color:var(--text);border:1.5px solid var(--border);box-shadow:var(--sh-sm)}
.hero .btn-glass svg{fill:var(--text)}
.hero .btn-glass:hover{background:#f0f4ff;border-color:rgba(29,125,224,.3);transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn-lg{padding:.9375rem 2.125rem;font-size:1rem}

/* PROGRESS BAR */
.progress-bar{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--blue-mid),var(--cyan));z-index:2000;transition:width .1s linear;box-shadow:0 0 10px var(--cyan)}

/* NAV — always light (hero is now white) */
.main-nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .35s;background:rgba(255,255,255,.96);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);box-shadow:0 1px 0 rgba(0,32,80,.08),0 4px 20px rgba(0,0,0,.09)}
.main-nav.scrolled{background:rgba(255,255,255,.98);box-shadow:0 1px 0 rgba(0,32,80,.08),0 4px 20px rgba(0,0,0,.10)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 40px;height:72px;display:flex;align-items:center;justify-content:space-between;gap:24px}
@media(max-width:768px){.nav-inner{padding:0 20px}}
.logo{display:flex;align-items:center;gap:12px}
.logo-img{height:76px;width:auto;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(0,32,80,.4)) drop-shadow(0 2px 8px rgba(0,0,0,.15))}
.logo-mark{width:44px;height:44px;background:var(--g-blue);border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 16px rgba(29,125,224,.35)}
.logo-mark svg{width:28px;height:28px}
.logo-name{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:#fff;letter-spacing:.5px;line-height:1}
.logo-sub{font-size:9px;color:rgba(255,255,255,.42);font-weight:500;letter-spacing:2px;text-transform:uppercase;margin-top:2px}
.footer-brand .logo-img{height:72px;filter:drop-shadow(0 1px 3px rgba(0,32,80,.35)) brightness(0.82) contrast(1.1)}
.nav-links{display:flex;gap:4px}
.nav-link{color:rgba(20,30,70,.7);font-weight:600;font-size:.9375rem;padding:8px 16px;border-radius:8px;transition:all var(--t-fast);border:1px solid transparent}
.nav-link:hover{color:var(--blue);background:rgba(29,125,224,.08);border-color:rgba(29,125,224,.22);box-shadow:0 2px 12px rgba(29,125,224,.12);transform:translateY(-1px)}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-phone{display:flex;align-items:center;gap:8px;color:var(--blue);font-weight:600;font-size:.9375rem}
.nav-phone svg{width:15px;height:15px;fill:var(--blue)}
.nav-phone:hover{color:var(--blue-deep)}
.ham-btn{display:none;flex-direction:column;gap:5px;padding:7px;background:transparent;border:none}
.ham-btn span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .25s}

/* MOBILE MENU */
.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:min(360px,100vw);background:rgba(3,10,22,.99);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border-left:1px solid rgba(130,200,255,.1);z-index:1100;display:flex;flex-direction:column;padding:80px 32px 40px;gap:4px;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.mobile-menu.open{transform:translateX(0)}
.mm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.68);backdrop-filter:blur(4px);z-index:1099;opacity:0;pointer-events:none;transition:opacity .3s}
.mm-overlay.open{opacity:1;pointer-events:auto}
.mm-close{position:absolute;top:20px;right:20px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}
.mm-close:hover{background:rgba(255,255,255,.15)}
.mm-link{display:block;padding:15px 0;color:rgba(255,255,255,.78);font-size:1.25rem;font-weight:600;border-bottom:1px solid rgba(255,255,255,.05);transition:color var(--t-fast)}
.mm-link:hover{color:#fff}
.mm-cta{margin-top:auto;display:flex;flex-direction:column;gap:10px}
.mm-btn{justify-content:center;font-size:1rem;padding:14px}

/* MASTER PLUMBER BAR — dark background, keep white text */
.hpb-sub{color:rgba(255,255,255,.65)!important}
.hpb-feat{color:#fff!important}

/* HERO */
.hero{position:relative;min-height:88vh;min-height:88svh;display:flex;flex-direction:column;align-items:stretch;overflow:hidden;padding-top:72px}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-base-gradient{position:absolute;inset:0;background:var(--bg)}
.hero-grid-overlay{display:none}
.hero-orb{position:absolute;border-radius:50%;pointer-events:none;animation:orbFloat 18s ease-in-out infinite;will-change:transform}
.hero-orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(29,125,224,.07) 0%,transparent 68%);top:-160px;right:-80px}
.hero-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(29,125,224,.05) 0%,transparent 68%);bottom:-80px;left:-100px;animation-delay:-9s;animation-duration:22s}
@keyframes orbFloat{0%,100%{transform:translate(0,0)}33%{transform:translate(28px,-38px)}66%{transform:translate(-18px,22px)}}
.hero-pulse{display:none}
@keyframes heroBgPulse{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.12)}}
@media(prefers-reduced-motion:reduce){.hero-pulse{animation:none}}
.hero-spotlight{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(130,200,255,.09) 0%,transparent 65%);pointer-events:none;transform:translate(-50%,-50%);opacity:0;transition:opacity .6s;mix-blend-mode:screen}
.hero:hover .hero-spotlight{opacity:1}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.35;mix-blend-mode:multiply}
.hero-ripples{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.ripple-ring{position:absolute;border:1.5px solid rgba(29,125,224,.5);border-radius:50%;transform:translate(-50%,-50%) scale(.1);opacity:.7;animation:rippleExpand 1.5s ease-out forwards;pointer-events:none}
@keyframes rippleExpand{to{transform:translate(-50%,-50%) scale(1);opacity:0;width:300px;height:300px}}

.hero-inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:20px 40px 18px;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:stretch;flex:1}
@media(max-width:960px){.hero-inner{grid-template-columns:1fr;padding:60px 20px 32px;gap:40px}}

/* Hero left */
.hero-content{display:flex;flex-direction:column}
.hero-stats{margin-top:auto}
.hero-badge{display:inline-flex;align-items:center;align-self:flex-start;gap:10px;background:rgba(29,125,224,.07);border:1px solid rgba(29,125,224,.2);color:var(--blue);padding:7px 16px;border-radius:50px;font-size:.8125rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:12px}
.badge-dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 0 0 rgba(64,232,255,.5);animation:dotPulse 2s ease-out infinite}
@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(64,232,255,.5)}70%{box-shadow:0 0 0 8px rgba(64,232,255,0)}100%{box-shadow:0 0 0 0 rgba(64,232,255,0)}}
.hero-title{font-family:'Barlow Condensed',sans-serif;font-size:clamp(2rem,4.5vw,3.4rem);font-weight:900;line-height:1.14;letter-spacing:-.6px;color:var(--text);margin-bottom:6px}
.title-block{display:block;font-family:'Cinzel',Georgia,serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:900;letter-spacing:6px;color:var(--text);text-shadow:none;line-height:1.1}
@media(prefers-reduced-motion:reduce){.title-block{text-shadow:none}}
.hero-accent{display:block;font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:500;background:linear-gradient(135deg,var(--blue-lt),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-1px}
.hero-tagline{font-family:'Inter',sans-serif;font-style:italic;font-size:clamp(.9rem,1.7vw,1.2rem);font-weight:500;color:var(--text-2);letter-spacing:.3px;margin-bottom:14px}
.hero-desc{font-size:1.0625rem;color:var(--text-2);line-height:1.75;margin-bottom:14px;max-width:500px}
.hero-bullets{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.hero-bullets li{display:flex;align-items:center;gap:10px;font-size:.9375rem;color:var(--text-2);font-weight:500}
.hero-bullets li svg{width:17px;height:17px;fill:var(--green);flex-shrink:0}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.hero-stats{display:inline-flex;align-items:center;flex-wrap:wrap;width:fit-content;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 22px;box-shadow:var(--sh-sm)}
.hstat{padding:4px 18px;text-align:center}
.hstat:first-child{padding-left:0}
.hstat-num{font-family:'Barlow Condensed',sans-serif;font-size:1.35rem;font-weight:800;color:var(--text);line-height:1}
.hstat-lbl{font-size:.7rem;color:var(--text-3);font-weight:500;margin-top:2px;white-space:nowrap}
.hstat-div{width:1px;height:32px;background:var(--border)}

/* Hero right — gallery + mini widgets */
.hero-visual{display:flex;flex-direction:column;gap:12px}

/* HERO GALLERY */
.hero-gallery{position:relative;border-radius:var(--r-xl);overflow:hidden;aspect-ratio:16/10;background:#e8edf5;box-shadow:var(--sh-lg);border:1px solid var(--border)}
.hg-track{position:absolute;inset:0;overflow:hidden}
.hg-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .85s cubic-bezier(.4,0,.2,1),transform .85s cubic-bezier(.4,0,.2,1);transform:scale(1.04)}
.hg-slide.active{opacity:1;transform:scale(1)}
.hg-slide.exiting{opacity:0;transform:scale(1.06)}
.hg-controls{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:12px;z-index:4}
.hg-prev,.hg-next{width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.18);color:#fff;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast);backdrop-filter:blur(8px)}
.hg-prev:hover,.hg-next:hover{background:rgba(29,125,224,.6);border-color:var(--sky)}
.hg-prev svg,.hg-next svg{width:16px;height:16px;fill:#fff}
.hg-dots{display:flex;gap:6px;align-items:center}
.hg-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.35);border:none;cursor:pointer;transition:all var(--t-fast);padding:0}
.hg-dot.active{background:var(--sky);width:18px;border-radius:3px}
.hg-expand{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:var(--r-sm);background:rgba(0,0,0,.5);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;z-index:4;transition:all var(--t-fast)}
.hg-expand:hover{background:rgba(29,125,224,.6);border-color:var(--sky)}
.hg-expand svg{width:17px;height:17px;fill:#fff}
.hg-corners{position:absolute;inset:0;pointer-events:none;z-index:3}
.hg-corners i{position:absolute;width:20px;height:20px;border:2px solid rgba(130,200,255,.55);display:block}
.hg-corners i:nth-child(1){top:14px;left:14px;border-right:none;border-bottom:none;border-radius:4px 0 0 0}
.hg-corners i:nth-child(2){top:14px;right:14px;border-left:none;border-bottom:none;border-radius:0 4px 0 0}
.hg-corners i:nth-child(3){bottom:52px;left:14px;border-right:none;border-top:none;border-radius:0 0 0 4px}
.hg-corners i:nth-child(4){bottom:52px;right:14px;border-left:none;border-top:none;border-radius:0 0 4px 0}

/* PERSUASIVE CTA widget below gallery */
.hmw-hero-cta{flex:1;display:flex;flex-direction:column;justify-content:center;background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:20px 22px;box-shadow:var(--sh-sm)}
.hmw-cta-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.hmw-cta-badges span{font-size:.68rem;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.5px;background:rgba(29,125,224,.07);border:1px solid rgba(29,125,224,.2);border-radius:20px;padding:3px 10px}
.hmw-cta-headline{font-family:'Barlow Condensed',sans-serif;font-size:1.35rem;font-weight:800;color:var(--text);line-height:1.2;margin-bottom:8px}
.hmw-cta-sub{font-size:.8rem;color:var(--text-2);line-height:1.5}

/* MASTER PLUMBER BAR */
@keyframes bannerPulseTop{0%,78%,100%{filter:none}83%{filter:drop-shadow(0 -9px 34px rgba(58,158,248,.42))}92%{filter:none}}
@keyframes bannerPulseBoth{0%,78%,100%{filter:none}83%{filter:drop-shadow(0 -9px 34px rgba(58,158,248,.42)) drop-shadow(0 9px 34px rgba(58,158,248,.42))}92%{filter:none}}
@keyframes bannerPulseBottom{0%,78%,100%{filter:none}83%{filter:drop-shadow(0 9px 34px rgba(58,158,248,.42))}92%{filter:none}}
.hero-plumber-bar{position:relative;z-index:2;width:100%;background:linear-gradient(90deg,rgba(5,18,42,.95) 0%,rgba(10,30,68,.95) 50%,rgba(5,18,42,.95) 100%);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);animation:bannerPulseTop 8s ease-in-out infinite}
.hpb-inner{max-width:1280px;margin:0 auto;padding:0 40px}
@media(max-width:768px){.hpb-inner{padding:0 20px}}
.hpb-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;padding:18px 0}
@media(max-width:768px){.hpb-card{grid-template-columns:1fr;gap:12px;padding:18px 0}}
.hpb-left{display:flex;align-items:center;gap:16px}
.hpb-logo{height:48px;width:auto;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 1px 6px rgba(0,0,0,.4))}
.hpb-icon{width:52px;height:52px;border-radius:12px;background:var(--g-blue);flex-shrink:0;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(29,125,224,.4)}
.hpb-icon svg{width:26px;height:26px;fill:#fff}
.hpb-title{font-family:'Barlow Condensed',sans-serif;font-size:1.375rem;font-weight:800;color:#fff;line-height:1;margin-bottom:4px}
.hpb-sub{font-size:.8125rem;color:var(--text-2)}
.hpb-center{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.hpb-feat{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:600;color:var(--text)}
.hpb-feat svg{width:14px;height:14px;fill:var(--sky);flex-shrink:0}
.hpb-call{padding:10px 22px;font-size:.9375rem}
.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;animation:dotPulse 2s infinite}

/* TRUST BAR */
.trust-bar{background:linear-gradient(90deg,#0a1830 0%,#0d2050 50%,#0a1830 100%);border-top:1px solid rgba(130,200,255,.06);border-bottom:1px solid rgba(130,200,255,.07);overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%,black 6%,black 94%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0%,black 6%,black 94%,transparent 100%)}
.trust-track{display:flex;align-items:center;width:max-content;padding:13px 0;animation:trustScroll 20s linear infinite}
@keyframes trustScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.trust-item{display:flex;align-items:center;gap:8px;font-size:.8125rem;font-weight:600;color:rgba(255,255,255,.72);padding:6px 28px;white-space:nowrap}
.trust-item svg{width:13px;height:13px;fill:var(--sky);flex-shrink:0}
.trust-sep{width:1px;height:18px;background:rgba(255,255,255,.1);flex-shrink:0}

/* ── SERVICES — TABBED ──────────────────────────────────── */
.services-section{padding:60px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 50% 55% at 80% 20%,rgba(29,125,224,.04) 0%,transparent 62%),radial-gradient(ellipse 38% 45% at 5% 80%,rgba(29,125,224,.03) 0%,transparent 60%),linear-gradient(180deg,var(--bg-2) 0%,var(--bg-1) 100%)}
.services-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(29,125,224,.03) 1.5px,transparent 1.5px);background-size:28px 28px;mask-image:radial-gradient(ellipse at 50% 50%,black 20%,transparent 78%);-webkit-mask-image:radial-gradient(ellipse at 50% 50%,black 20%,transparent 78%)}
.services-section .section-inner{position:relative;z-index:1}

/* Tab nav */
@keyframes svcTabShimmer{0%{background-position:0% 0%}50%{background-position:100% 100%}100%{background-position:0% 0%}}
.svc-tab-nav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:8px;box-shadow:var(--sh-sm)}
.svc-tab-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:18px 20px;min-height:88px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-1);color:var(--text);font-family:'DM Sans',sans-serif;font-weight:600;font-size:.9375rem;cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);flex:1;position:relative;overflow:hidden}
.svc-tab-btn svg{width:22px;height:22px;fill:var(--blue);flex-shrink:0}
.svc-tab-label{font-size:.9375rem;font-weight:700;line-height:1}
.svc-tab-sub{font-size:.72rem;color:var(--text-2);font-weight:400;letter-spacing:.15px;line-height:1.3;text-align:center}
.svc-tab-btn:hover{color:var(--blue);border-color:rgba(29,125,224,.3);background:#fff}
.svc-tab-btn:hover .svc-tab-sub{color:var(--text-3)}
.svc-tab-btn.active{background:var(--g-blue);animation:none;color:#fff;border-color:transparent;box-shadow:0 4px 22px rgba(29,125,224,.38)}
.svc-tab-btn.active svg{fill:#fff}
.svc-tab-btn.active .svc-tab-sub{color:rgba(255,255,255,.75)}
@media(max-width:600px){.svc-tab-btn{font-size:.875rem;padding:14px 12px;min-height:72px}.svc-tab-sub{display:none}}

/* 24/7 Emergency bar — always visible, outside tab panels */
@keyframes emergGlow{0%,100%{box-shadow:0 0 0 0 rgba(232,69,69,.25),0 4px 24px rgba(0,0,0,.3)}55%{box-shadow:0 0 0 6px rgba(232,69,69,0),0 6px 32px rgba(232,69,69,.18)}}
.svc-emergency-bar{display:flex;align-items:center;gap:18px;background:linear-gradient(135deg,#fce8e8 0%,#f8dede 50%,#fce8e8 100%);border:2px solid rgba(200,50,50,.48);border-radius:var(--r-lg);padding:16px 24px;margin-bottom:24px;position:relative;overflow:hidden;animation:emergGlow 3.5s ease-in-out infinite;box-shadow:0 2px 12px rgba(200,50,50,.1)}
.svc-emergency-bar::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0,transparent 44px,rgba(232,69,69,.018) 44px,rgba(232,69,69,.018) 45px);pointer-events:none}
.svc-emerg-live{display:flex;align-items:center;gap:6px;font-size:.68rem;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.9px;flex-shrink:0}
.svc-emerg-icon{width:46px;height:46px;border-radius:12px;background:rgba(232,69,69,.15);border:1px solid rgba(232,69,69,.32);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc-emerg-icon svg{width:21px;height:21px;fill:var(--red)}
.svc-emerg-content{flex:1;min-width:0}
.svc-emerg-title{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:700;color:#b02020;line-height:1;margin-bottom:3px}
.svc-emerg-sub{font-size:.8rem;color:var(--text-3);line-height:1.4}
.svc-emerg-stat{text-align:center;flex-shrink:0;padding:0 8px}
.svc-emerg-num{font-family:'Barlow Condensed',sans-serif;font-size:1.7rem;font-weight:800;color:#c93535;line-height:1;text-shadow:none}
.svc-emerg-lbl{font-size:.62rem;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;font-weight:600;white-space:nowrap}
.svc-emerg-btn{background:linear-gradient(135deg,#e84545,#c02828);color:#fff;font-weight:700;padding:11px 22px;font-size:.9rem;display:inline-flex;align-items:center;gap:8px;border-radius:var(--r-md);border:none;cursor:pointer;transition:opacity var(--t-fast);flex-shrink:0}
.svc-emerg-btn svg{width:15px;height:15px;fill:#fff}
.svc-emerg-btn:hover{opacity:.88}
@media(max-width:640px){.svc-emergency-bar{flex-wrap:wrap;gap:12px}.svc-emerg-live,.svc-emerg-stat{display:none}}
@media(max-width:480px){.svc-emergency-bar{flex-direction:column;align-items:stretch;padding:14px 16px;gap:10px}.svc-emerg-icon{display:none}.svc-emerg-btn{width:100%;justify-content:center}}

/* Tab content */
.svc-tab-content{display:none}
.svc-tab-content.active{display:block}

/* Accordion grid */
.svc-accordion-grid{display:grid;grid-template-columns:1fr;gap:14px}

/* Service accordion item */
.sacc-item{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:border-color var(--t-fast),box-shadow var(--t-fast);box-shadow:var(--sh-sm)}
.sacc-item.open,.sacc-item:hover{border-color:rgba(29,125,224,.28)}
.sacc-item.open{box-shadow:var(--sh-md)}
.sacc-emerg{border-color:rgba(232,69,69,.12)}
.sacc-emerg.open,.sacc-emerg:hover{border-color:rgba(232,69,69,.38)}
.sacc-head{display:flex;align-items:center;gap:14px;padding:18px 20px;cursor:pointer;user-select:none}
.sacc-icon{width:42px;height:42px;flex-shrink:0;border-radius:10px;background:rgba(58,158,248,.12);border:1px solid rgba(130,200,255,.22);display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}
.sacc-icon svg{width:20px;height:20px;fill:var(--blue)}
.sacc-icon--red{background:rgba(232,69,69,.12);border-color:rgba(232,69,69,.26)}
.sacc-icon--red svg{fill:var(--red)}
.sacc-item.open .sacc-icon{background:rgba(58,158,248,.2);border-color:rgba(130,200,255,.5)}
.sacc-name{flex:1;font-family:'Barlow Condensed',sans-serif;font-size:1.1875rem;font-weight:800;color:var(--text);line-height:1.1}
.sacc-toggle{width:24px;height:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:transform var(--t-fast)}
.sacc-toggle svg{width:20px;height:20px;fill:currentColor}
.sacc-item.open .sacc-toggle{transform:rotate(180deg);color:var(--blue)}

/* Accordion body */
.sacc-body{max-height:0;overflow:hidden;opacity:0;transition:max-height .48s cubic-bezier(0,0,.2,1),opacity .3s ease .06s,padding .3s ease;display:flex;flex-direction:column;gap:12px}
.sacc-item.open .sacc-body{max-height:300px;opacity:1;padding:4px 22px 22px}
.sacc-body p{padding:0;font-size:.875rem;color:var(--text-2);line-height:1.6;margin-bottom:0}
.sacc-cta{margin-top:4px;display:inline-flex;align-self:start}
@media(max-width:580px){
  .sacc-item.open .sacc-body{padding:4px 16px 18px}
  .sacc-body p{font-size:.8125rem}
}
.sacc-cta--red{background:linear-gradient(135deg,var(--red),#c02828)}

/* FEATURES */
.features-section{padding:80px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 60% 70% at 50% 50%,rgba(12,52,120,.2) 0%,transparent 70%),linear-gradient(170deg,#060a16 0%,#05080f 100%)}
.features-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(130,200,255,.04) 1.5px,transparent 1.5px);background-size:32px 32px;mask-image:radial-gradient(ellipse at 50% 50%,black 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at 50% 50%,black 30%,transparent 75%)}
.features-section .section-inner{position:relative;z-index:1}
.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:768px){.features-grid{grid-template-columns:1fr}}
.feat-block{background:linear-gradient(145deg,rgba(10,30,70,.55),rgba(5,14,36,.72));border:1px solid rgba(130,200,255,.13);border-radius:var(--r-xl);padding:32px;transition:all var(--t)}
.feat-block:hover{border-color:rgba(130,200,255,.28);box-shadow:0 24px 56px rgba(0,0,0,.38),0 0 24px rgba(58,158,248,.07)}
.feat-block-hdr{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.feat-block-icon{width:52px;height:52px;border-radius:14px;background:var(--g-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 6px 20px rgba(29,125,224,.35)}
.feat-block-icon--green{background:linear-gradient(135deg,#0a8a5c,#12d98e)}
.feat-block-icon svg{width:26px;height:26px;fill:#fff}
.feat-block-title{font-family:'Barlow Condensed',sans-serif;font-size:1.5rem;font-weight:800;color:#fff}
.feat-items{display:flex;flex-direction:column;gap:18px}
.feat-item{display:flex;gap:14px;align-items:flex-start}
.fi-icon{width:38px;height:38px;flex-shrink:0;border-radius:9px;background:rgba(58,158,248,.12);border:1px solid rgba(130,200,255,.22);display:flex;align-items:center;justify-content:center;margin-top:2px}
.fi-icon--green{background:rgba(18,217,142,.1);border-color:rgba(18,217,142,.24)}
.fi-icon svg{width:18px;height:18px;fill:var(--sky)}
.fi-icon--green svg{fill:var(--green)}
.fi-title{font-weight:700;color:#fff;font-size:.9375rem;margin-bottom:3px}
.fi-text{font-size:.875rem;color:var(--text-2);line-height:1.55}

/* WHY US */
.why-section{padding:100px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 55% 75% at 0% 55%,rgba(8,40,100,.38) 0%,transparent 65%),linear-gradient(170deg,#0a0e16 0%,#060a12 55%,var(--bg-coal) 100%)}
.why-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(95deg,transparent 0,transparent 90px,rgba(130,200,255,.018) 90px,rgba(130,200,255,.018) 91px),repeating-linear-gradient(125deg,transparent 0,transparent 130px,rgba(130,200,255,.014) 130px,rgba(130,200,255,.014) 131px)}
.why-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
@media(max-width:860px){.why-layout{grid-template-columns:1fr;gap:48px}}
.why-photo-col{position:relative}
.why-frame{position:relative;border-radius:var(--r-xl);overflow:visible;aspect-ratio:4/5;max-width:480px}
.why-photo{width:100%;height:100%;object-fit:cover;border-radius:var(--r-xl);display:block;filter:saturate(1.08) contrast(1.06);position:relative;z-index:1}
.why-frame-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(3,12,26,.75) 100%);border-radius:var(--r-xl);z-index:2;pointer-events:none}
.no-photo .why-photo{display:none}
.no-photo{background:var(--g-card);border:1px solid var(--border);border-radius:var(--r-xl);aspect-ratio:4/5}
.why-frame-corners{position:absolute;inset:0;z-index:3;pointer-events:none;border-radius:var(--r-xl)}
.why-frame-corners i{position:absolute;width:22px;height:22px;border:2px solid rgba(130,200,255,.62);display:block}
.why-frame-corners i:nth-child(1){top:18px;left:18px;border-right:none;border-bottom:none;border-radius:5px 0 0 0}
.why-frame-corners i:nth-child(2){top:18px;right:18px;border-left:none;border-bottom:none;border-radius:0 5px 0 0}
.why-frame-corners i:nth-child(3){bottom:18px;left:18px;border-right:none;border-top:none;border-radius:0 0 0 5px}
.why-frame-corners i:nth-child(4){bottom:18px;right:18px;border-left:none;border-top:none;border-radius:0 0 5px 0}
.why-frame-bottom{position:absolute;bottom:24px;left:24px;right:24px;z-index:4}
.why-play-wrap{display:flex;align-items:center;gap:14px}
.why-play{width:58px;height:58px;border-radius:50%;background:var(--g-blue);border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(29,125,224,.5);flex-shrink:0;transition:transform var(--t),box-shadow var(--t);position:relative;cursor:pointer}
.why-play::before{content:'';position:absolute;inset:-10px;border:2px solid rgba(130,200,255,.32);border-radius:50%;animation:playRipple 2.2s ease-out infinite}
@keyframes playRipple{0%{transform:scale(.85);opacity:.8}100%{transform:scale(1.38);opacity:0}}
.why-play:hover{transform:scale(1.1);box-shadow:0 14px 36px rgba(29,125,224,.62)}
.why-play svg{width:22px;height:22px;fill:#fff;margin-left:4px}
.why-play-wrap span{color:#fff;font-weight:600;font-size:.9375rem;text-shadow:0 2px 10px rgba(0,0,0,.7)}
.why-badge{position:absolute;bottom:-20px;right:-14px;background:linear-gradient(145deg,#0c1e38,#142648);border:1px solid var(--border);border-radius:var(--r-md);padding:13px 17px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-lg);z-index:5;backdrop-filter:blur(18px)}
.why-badge svg{width:28px;height:28px;fill:var(--sky);flex-shrink:0}
.why-badge strong{display:block;font-size:.875rem;font-weight:700;color:#fff;line-height:1.2}
.why-badge span{display:block;font-size:.75rem;color:var(--text-3);margin-top:2px}
.why-feats{display:flex;flex-direction:column;gap:14px;margin-top:32px}
.wfeat{display:flex;gap:16px;padding:16px 18px;background:rgba(255,255,255,.022);border:1px solid rgba(130,200,255,.09);border-radius:var(--r-md);transition:all var(--t);cursor:default}
.wfeat:hover{background:rgba(58,158,248,.055);border-color:rgba(130,200,255,.26);transform:translateX(6px)}
.wfeat-icon{width:42px;height:42px;flex-shrink:0;background:rgba(58,158,248,.1);border:1px solid rgba(58,158,248,.22);border-radius:9px;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}
.wfeat:hover .wfeat-icon{background:rgba(58,158,248,.2)}
.wfeat-icon svg{width:19px;height:19px;fill:var(--sky)}
.wfeat>div:last-child strong{display:block;font-weight:700;color:#fff;font-size:.9375rem;margin-bottom:4px}
.wfeat>div:last-child p{font-size:.875rem;color:var(--text-2);line-height:1.55;margin:0}

/* BUSINESS MARQUEE */
.business-marquee{overflow:hidden;padding:10px 0;background:linear-gradient(90deg,#0b1830,#0f2248,#0b1830);border-top:1px solid rgba(130,200,255,.07);border-bottom:1px solid rgba(130,200,255,.07);animation:bannerPulseBoth 8s ease-in-out infinite;position:relative;z-index:2}
.hero + .business-marquee{animation:bannerPulseBottom 8s ease-in-out infinite;clip-path:inset(0 0 -80px 0)}
.bmarquee-track{display:flex;width:max-content;animation:marqueeScroll 28s linear infinite}
.bmarquee-group{display:flex;align-items:center;gap:32px;padding:0 16px;white-space:nowrap}
.bmarquee-group span{font-family:'Barlow Condensed',sans-serif;font-size:.875rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.65)}
.bmarquee-sep{color:var(--sky) !important;font-size:1.1rem !important;letter-spacing:0 !important}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.bmarquee-track{animation:none}}

/* GALLERY */
.gallery-section{padding:70px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 55% 65% at 50% 50%,rgba(29,125,224,.06) 0%,transparent 68%),linear-gradient(180deg,var(--bg-1) 0%,var(--bg-2) 100%)}
.gallery-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(102deg,transparent 0,transparent 65px,rgba(29,125,224,.018) 65px,rgba(29,125,224,.018) 66px)}
.gallery-section .section-inner{position:relative;z-index:1}
.ba-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:28px}
@media(max-width:860px){.ba-grid{grid-template-columns:1fr}}
.ba-item{display:flex;flex-direction:column;gap:10px}
.ba-slider{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;cursor:ew-resize;user-select:none;border:1px solid rgba(130,200,255,.14);box-shadow:0 8px 32px rgba(0,0,0,.45)}
.ba-slider:hover{border-color:rgba(130,200,255,.32)}
.ba-before,.ba-after{position:absolute;inset:0;background-size:cover;background-position:center}
.ba-before img,.ba-after img{width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba-after{clip-path:inset(0 50% 0 0);will-change:clip-path;transform:translateZ(0)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:3px;z-index:3;cursor:ew-resize}
.ba-line{position:absolute;inset:0;background:rgba(255,255,255,.85);box-shadow:0 0 8px rgba(130,200,255,.5)}
.ba-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--blue-mid),var(--sky));display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(29,125,224,.55)}
.ba-btn svg{width:18px;height:18px;fill:#fff}
.ba-labels{position:absolute;bottom:14px;left:14px;right:14px;z-index:4;display:flex;justify-content:space-between;pointer-events:none}
.ba-label{font-size:.75rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:50px;backdrop-filter:blur(8px)}
.ba-label-b{background:rgba(0,0,0,.55);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.14)}
.ba-label-a{background:rgba(29,125,224,.65);color:#fff;border:1px solid rgba(130,200,255,.35)}
.ba-caption{font-size:.875rem;font-weight:600;color:var(--text-2);text-align:center}
.project-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:12px}
@media(max-width:768px){.project-grid{grid-template-columns:repeat(2,1fr)}}
.pg-item{position:relative;aspect-ratio:4/3;border-radius:var(--r-md);overflow:hidden;cursor:pointer;border:1px solid rgba(130,200,255,.1);transition:all var(--t)}
.pg-item:hover{border-color:rgba(130,200,255,.42);transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.45)}
.pg-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,0,.2,1)}
.pg-item:hover img{transform:scale(1.08)}
.pg-overlay{position:absolute;inset:0;background:rgba(0,12,35,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t)}
.pg-item:hover .pg-overlay{opacity:1}
.pg-overlay svg{width:28px;height:28px;fill:rgba(255,255,255,.9)}

/* PROCESS */
.process-section{padding:64px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 55% 45% at 50% 50%,rgba(29,125,224,.06) 0%,transparent 70%),linear-gradient(135deg,var(--bg-2) 0%,var(--bg-1) 100%)}
.process-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(29,125,224,.04) 1.5px,transparent 1.5px);background-size:36px 36px;mask-image:radial-gradient(ellipse at 50% 50%,black 30%,transparent 78%);-webkit-mask-image:radial-gradient(ellipse at 50% 50%,black 30%,transparent 78%)}
.process-section .section-inner{position:relative;z-index:1}
.process-track{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:860px){.process-track{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.process-track{grid-template-columns:1fr}}
.process-line{position:absolute;top:40px;left:10%;right:10%;height:2px;background:rgba(29,125,224,.12);z-index:0}
@media(max-width:860px){.process-line{display:none}}
.process-line-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan));width:0;transition:width 1.4s cubic-bezier(.4,0,.2,1);box-shadow:0 0 12px var(--cyan)}
.pstep{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:22px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);transition:all var(--t);cursor:default;box-shadow:var(--sh-sm)}
.pstep:hover{background:#fff;border-color:rgba(29,125,224,.3);transform:translateY(-8px);box-shadow:var(--sh-md),0 0 24px rgba(29,125,224,.08)}
.pstep-num{width:62px;height:62px;background:var(--g-blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:1.5rem;font-weight:700;color:#fff;box-shadow:0 8px 28px rgba(29,125,224,.42);flex-shrink:0}
.pstep-title{font-family:'Barlow Condensed',sans-serif;font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:8px}
.pstep-text{font-size:.875rem;color:var(--text-2);line-height:1.6}

/* AREAS */
.areas-section{padding:70px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 65% 80% at 50% 55%,rgba(29,125,224,.06) 0%,transparent 68%),linear-gradient(180deg,var(--bg) 0%,var(--bg-1) 55%,var(--bg) 100%)}
.areas-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(ellipse 100% 60% at 50% 50%,transparent 30%,rgba(29,125,224,.018) 30.5%,transparent 31%),radial-gradient(ellipse 130% 80% at 50% 50%,transparent 42%,rgba(29,125,224,.012) 42.5%,transparent 43%)}
.areas-section .section-inner{position:relative;z-index:1}
.city-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:900px){.city-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.city-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:380px){.city-grid{grid-template-columns:1fr}}
.city-tile{position:relative;height:155px;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;border:1px solid rgba(130,200,255,.12);transition:all var(--t);outline:none}
.city-tile:hover,.city-tile.active{transform:translateY(-5px);border-color:rgba(130,200,255,.5);box-shadow:0 22px 52px rgba(0,0,0,.5),0 0 28px rgba(58,158,248,.14)}
.city-tile.active{border-color:var(--sky)}
.city-tile:focus-visible{outline:2px solid var(--sky);outline-offset:2px}
.city-tile-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .65s cubic-bezier(.2,0,.2,1)}
.city-tile:hover .city-tile-bg,.city-tile.active .city-tile-bg{transform:scale(1.12)}
.city-tile-veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(3,8,20,.94) 0%,rgba(5,12,32,.56) 50%,rgba(8,20,58,.2) 100%);transition:background var(--t)}
.city-tile:hover .city-tile-veil,.city-tile.active .city-tile-veil{background:linear-gradient(to top,rgba(3,8,20,.96) 0%,rgba(10,46,128,.68) 55%,rgba(16,72,158,.35) 100%)}
.city-tile-name{position:absolute;bottom:14px;left:14px;right:14px;z-index:2;font-family:'Barlow Condensed',sans-serif;font-size:1.125rem;font-weight:700;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.9);letter-spacing:.3px}
.city-tile-tag{position:absolute;top:10px;left:10px;z-index:2;background:rgba(58,158,248,.2);border:1px solid rgba(130,200,255,.28);color:var(--sky);padding:3px 9px;border-radius:50px;font-size:.6875rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;opacity:0;transition:opacity var(--t-fast)}
.city-tile:hover .city-tile-tag,.city-tile.active .city-tile-tag{opacity:1}
.city-panel{margin-top:18px;border-radius:var(--r-xl);overflow:hidden;display:none;position:relative;border:1px solid rgba(130,200,255,.26);box-shadow:0 40px 90px rgba(0,0,0,.6);animation:panelIn .4s cubic-bezier(.2,0,.2,1)}
.city-panel.open{display:grid;grid-template-columns:1.1fr 1fr}
@media(max-width:768px){.city-panel.open{grid-template-columns:1fr}}
@keyframes panelIn{from{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.city-panel-img{height:100%;min-height:280px;background-size:cover;background-position:center;position:relative}
.city-panel-img::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 45%,rgba(5,16,36,.98) 100%)}
@media(max-width:768px){.city-panel-img{min-height:200px}.city-panel-img::after{background:linear-gradient(180deg,transparent 30%,rgba(5,16,36,.98) 100%)}}
.city-panel-body{background:linear-gradient(145deg,#0a2244,#060f22);padding:40px 36px;display:flex;flex-direction:column;justify-content:center;gap:16px}
@media(max-width:768px){.city-panel-body{padding:26px 22px}}
.city-panel-kicker{font-size:.7rem;font-weight:700;color:var(--sky);letter-spacing:2px;text-transform:uppercase}
.city-panel-name{font-family:'Barlow Condensed',sans-serif;font-size:2.25rem;font-weight:800;color:#fff;margin:0;line-height:1}
.city-panel-desc{font-size:.9375rem;color:rgba(255,255,255,.72);line-height:1.65;margin:0}
.city-panel-meta{display:flex;gap:18px;flex-wrap:wrap;padding:14px 0;border-top:1px solid rgba(130,200,255,.1);border-bottom:1px solid rgba(130,200,255,.1)}
.cpm-item{display:flex;align-items:center;gap:8px;font-size:.8125rem;color:rgba(255,255,255,.72)}
.cpm-item svg{width:14px;height:14px;fill:var(--sky);flex-shrink:0}
.cpm-item strong{color:#fff}
.city-panel-actions{display:flex;gap:10px;flex-wrap:wrap}
.city-panel-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.13);color:#fff;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast);z-index:4}
.city-panel-close:hover{background:rgba(0,0,0,.82);transform:rotate(90deg)}

/* CTA STRIP */
.cta-strip{background:linear-gradient(135deg,var(--blue-deep) 0%,var(--blue) 50%,var(--blue-mid) 100%);padding:60px 0;position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(118deg,transparent 0,transparent 50px,rgba(255,255,255,.03) 50px,rgba(255,255,255,.03) 51px)}
.cta-inner{max-width:1280px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;position:relative;z-index:1}
@media(max-width:768px){.cta-inner{padding:0 20px;flex-direction:column;text-align:center}}
.cta-text h2{font-family:'Barlow Condensed',sans-serif;font-size:clamp(1.8rem,3.5vw,2.75rem);font-weight:800;color:#fff;line-height:1.1}
.cta-text p{color:rgba(255,255,255,.8);font-size:1rem;margin-top:8px}
.cta-actions{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}

/* SECTION DIVIDER */
.section-divider{height:1px;background:linear-gradient(90deg,transparent 0%,rgba(29,125,224,.15) 25%,rgba(29,125,224,.28) 50%,rgba(29,125,224,.15) 75%,transparent 100%);margin:0;animation:bannerPulseBoth 8s ease-in-out infinite;position:relative;z-index:2}

/* REVIEWS */
.reviews-section{padding:70px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 40% 50% at 88% 18%,rgba(29,125,224,.05) 0%,transparent 62%),linear-gradient(180deg,var(--bg-2) 0%,var(--bg-1) 100%)}
.reviews-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(29,125,224,.04) 1.5px,transparent 1.5px);background-size:28px 28px;mask-image:radial-gradient(ellipse at 50% 50%,black 20%,transparent 78%);-webkit-mask-image:radial-gradient(ellipse at 50% 50%,black 20%,transparent 78%)}
.reviews-section .section-inner{position:relative;z-index:1}
.reviews-top{display:flex;align-items:center;justify-content:center;text-align:center;gap:32px;margin-bottom:36px;flex-wrap:wrap}
.reviews-grid--3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.reviews-grid--3{grid-template-columns:1fr;gap:16px}}
.rcard{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;display:flex;flex-direction:column;gap:12px;transition:all var(--t);box-shadow:var(--sh-sm)}
.rcard:hover{border-color:rgba(29,125,224,.25);transform:translateY(-6px);box-shadow:var(--sh-lg)}
.rcard-top{display:flex;align-items:center;gap:12px}
.rc-avatar{width:46px;height:46px;border-radius:50%;background:var(--g-blue);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;color:#fff;flex-shrink:0}
.rc-avatar--gold{background:linear-gradient(135deg,#b8860b,#f5a623)}
.rc-name{font-weight:700;color:var(--text);font-size:.9375rem}
.rc-role{font-size:.75rem;color:var(--text-3);margin-top:2px}
.rc-stars{font-size:1rem;color:var(--gold);letter-spacing:2px}
.rc-quote{font-size:.9375rem;color:var(--text-2);line-height:1.65;flex:1}
.rc-tag{display:inline-flex;align-items:center;background:rgba(29,125,224,.08);border:1px solid rgba(29,125,224,.2);color:var(--blue);padding:4px 12px;border-radius:50px;font-size:.75rem;font-weight:600;width:fit-content;margin-top:4px}

/* ABOUT — scroll-autoplay video layout */
.about-section{padding:50px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 50% 60% at 100% 50%,rgba(29,125,224,.05) 0%,transparent 65%),linear-gradient(170deg,var(--bg-1) 0%,var(--bg) 100%)}
.about-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(108deg,transparent 0,transparent 70px,rgba(29,125,224,.014) 70px,rgba(29,125,224,.014) 71px)}
.about-section .section-inner{position:relative;z-index:1}
.about-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center}
.about-layout--no-video{grid-template-columns:1fr}
.about-body .section-title{font-size:clamp(1.5rem,2.8vw,2.2rem);white-space:nowrap}
@media(max-width:860px){.about-layout{grid-template-columns:1fr;gap:48px}.about-owner{text-align:center;margin-top:16px;justify-self:center}.about-img{max-height:300px}}
@media(min-width:861px){.about-img-col{grid-column:2;grid-row:1/3}.about-owner{grid-column:1;grid-row:2;align-self:end;justify-self:start}}

/* About video */
.about-video-col{position:relative}
.about-video-wrap{position:relative;border-radius:var(--r-xl);overflow:hidden;background:#000;box-shadow:var(--sh-lg),var(--sh-glow);border:1px solid rgba(130,200,255,.18)}
.about-video{width:100%;display:block;border-radius:var(--r-xl);aspect-ratio:16/10;object-fit:cover}
.about-video-overlay-corners{position:absolute;inset:0;pointer-events:none;z-index:2}
.about-video-overlay-corners i{position:absolute;width:22px;height:22px;border:2px solid rgba(130,200,255,.6);display:block}
.about-video-overlay-corners i:nth-child(1){top:16px;left:16px;border-right:none;border-bottom:none;border-radius:5px 0 0 0}
.about-video-overlay-corners i:nth-child(2){top:16px;right:16px;border-left:none;border-bottom:none;border-radius:0 5px 0 0}
.about-video-overlay-corners i:nth-child(3){bottom:16px;left:16px;border-right:none;border-top:none;border-radius:0 0 0 5px}
.about-video-overlay-corners i:nth-child(4){bottom:16px;right:16px;border-left:none;border-top:none;border-radius:0 0 5px 0}
.about-video-note{font-size:.7rem;color:var(--text-3);text-align:center;padding:8px;background:rgba(0,0,0,.4)}
.about-video-note code{color:var(--sky);background:rgba(130,200,255,.1);padding:1px 5px;border-radius:4px}
.about-bio{font-size:1rem;font-weight:700;color:var(--text);line-height:1.78;margin-bottom:16px}
.about-feats{display:flex;gap:28px;flex-wrap:wrap;margin:28px 0}
.about-feat{display:flex;flex-direction:column;gap:4px}
.af-num{font-family:'Barlow Condensed',sans-serif;font-size:2rem;font-weight:800;color:var(--blue);line-height:1}
.af-lbl{font-size:.75rem;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.about-img-col{position:relative}
.about-img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:50% 28%;border-radius:var(--r-xl);box-shadow:var(--sh-lg);display:block}

/* BOOKING */
.booking-section{padding:60px 0;position:relative;overflow:hidden;background:radial-gradient(ellipse 55% 65% at 100% 55%,rgba(29,125,224,.07) 0%,transparent 65%),radial-gradient(ellipse 38% 48% at 0% 45%,rgba(29,125,224,.04) 0%,transparent 60%),linear-gradient(180deg,var(--bg-2) 0%,var(--bg-1) 100%)}
.booking-section::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(102deg,transparent 0,transparent 65px,rgba(29,125,224,.016) 65px,rgba(29,125,224,.016) 66px)}
.booking-section .section-inner{position:relative;z-index:1}
.booking-layout{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.booking-info .section-sub{font-size:.8125rem;line-height:1.5;white-space:nowrap;max-width:none;margin-top:8px;margin-bottom:18px}
@media(max-width:900px){.booking-layout{grid-template-columns:1fr;gap:40px}}
.book-feats{display:flex;flex-direction:column;gap:7px;margin-bottom:20px}
.bfeat{display:flex;align-items:center;gap:12px;font-size:.9375rem;font-weight:600;color:var(--text)}
.bfeat-check{width:24px;height:24px;flex-shrink:0;background:rgba(18,217,142,.1);border:1px solid rgba(18,217,142,.26);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6875rem;color:var(--green);font-weight:700}
.contact-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--sh-sm)}
.cc-row{display:flex;align-items:flex-start;gap:10px;font-size:.875rem;color:var(--text-2)}
.cc-row svg{width:14px;height:14px;fill:var(--blue);flex-shrink:0;margin-top:2px}
.cc-phone{display:inline-flex;align-items:center;gap:8px;font-family:'Barlow Condensed',sans-serif;font-size:1.6rem;font-weight:700;color:var(--blue);margin-top:4px;transition:color var(--t-fast)}
.cc-phone:hover{color:var(--blue-deep)}
.cc-phone svg{width:20px;height:20px;fill:var(--blue)}
.cc-social-row{display:flex;align-items:center;gap:10px;margin-top:8px;padding-top:12px;border-top:1px solid var(--border);flex-wrap:wrap}
.cc-social-label{font-size:.75rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;line-height:1}
.cc-social-row .footer-socials{margin-top:0;flex-wrap:nowrap}
.contact-card .social-btn{background:rgba(29,125,224,.08);border:1px solid rgba(29,125,224,.2)}
.contact-card .social-btn svg{fill:var(--blue)}
.contact-card .social-btn:hover{background:rgba(29,125,224,.18);border-color:var(--blue);transform:translateY(-2px)}
@media(max-width:480px){.cc-social-row{justify-content:center}}
.booking-form-card{background:linear-gradient(145deg,rgba(29,125,224,.07),rgba(29,125,224,.13));border:1px solid rgba(29,125,224,.18);border-radius:var(--r-xl);padding:24px;box-shadow:var(--sh-md)}
.emerg-bar{display:flex;align-items:center;gap:13px;background:rgba(232,69,69,.07);border:1px solid rgba(232,69,69,.17);border-radius:var(--r-md);padding:10px 14px;margin-bottom:14px}
.eb-icon{width:36px;height:36px;flex-shrink:0;background:rgba(232,69,69,.11);border-radius:8px;display:flex;align-items:center;justify-content:center}
.eb-icon svg{width:17px;height:17px;fill:var(--red)}
.eb-title{font-weight:700;color:var(--text);font-size:.875rem}
.eb-sub{font-size:.8125rem;color:var(--text-2);margin-top:2px}
.eb-sub a{color:var(--red);font-weight:700}
.booking-form-card h3{font-family:'Barlow Condensed',sans-serif;font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:14px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:580px){.fgrid{grid-template-columns:1fr}}
@media(max-width:580px){.fgroup input,.fgroup select,.fgroup textarea{font-size:1rem}}
.fgroup{display:flex;flex-direction:column;gap:6px}
.frow{grid-column:1/-1}
.fgroup label{font-size:.8125rem;font-weight:700;color:var(--text)}
.fgroup input,.fgroup select,.fgroup textarea{background:var(--card);border:1.5px solid rgba(0,32,80,.15);border-radius:var(--r-sm);padding:11px 13px;font-size:.9375rem;color:var(--text);font-family:inherit;outline:none;transition:all var(--t-fast);-webkit-appearance:none}
.fgroup input::placeholder,.fgroup textarea::placeholder{color:rgba(30,40,80,.35)}
.fgroup select option{background:#fff;color:var(--text)}
.fgroup input:focus,.fgroup select:focus,.fgroup textarea:focus{border-color:var(--blue);background:#f5f9ff;box-shadow:0 0 0 3px rgba(29,125,224,.1)}
.fgroup textarea{resize:vertical;min-height:72px}
.form-submit{width:100%;margin-top:14px;display:flex;align-items:center;justify-content:center;gap:9px;padding:14px;background:var(--g-blue);color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:1.125rem;font-weight:700;letter-spacing:.5px;border:none;border-radius:var(--r-md);cursor:pointer;box-shadow:0 8px 28px rgba(29,125,224,.4);transition:all var(--t)}
.form-submit svg{width:17px;height:17px;fill:#fff}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 14px 38px rgba(29,125,224,.55)}
.form-note{font-size:.6875rem;color:var(--text-3);margin-top:12px;text-align:center;line-height:1.5}
.form-note a{color:var(--blue);opacity:.8}
.form-success{text-align:center;padding:44px 20px;display:none}
.form-success.is-visible{display:block}
.fs-icon{width:68px;height:68px;border-radius:50%;background:rgba(18,217,142,.1);border:2px solid rgba(18,217,142,.36);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--green);margin:0 auto 18px}
.form-success h3{color:var(--text);font-size:1.5rem;margin-bottom:8px}
.form-success p{color:var(--text-2);font-size:.9375rem;line-height:1.6}
.form-success a{color:var(--blue);font-weight:700}

@media(max-width:580px){.form-note{font-size:.75rem}}
@media(max-width:768px){.booking-info .section-sub{white-space:normal}}
@media(max-width:480px){.booking-form-card{padding:16px}.contact-card{padding:14px}.cc-phone{font-size:1.1rem}#chatInput{font-size:1rem}}

/* FOOTER */

.site-footer{background:linear-gradient(180deg,var(--bg-1) 0%,var(--bg-2) 100%);border-top:1px solid rgba(0,32,80,.09);padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1.6fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(0,32,80,.08)}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .logo{margin-bottom:16px}
.footer-brand p{font-size:.9rem;color:var(--text-2);line-height:1.65;max-width:310px;margin-bottom:12px}
.footer-note{font-size:.8125rem;color:var(--text-2);line-height:1.55;max-width:310px;padding:10px 14px;background:rgba(29,125,224,.07);border:1px solid rgba(29,125,224,.16);border-radius:var(--r-sm);margin-bottom:16px}
.footer-note strong{color:var(--blue)}
.footer-socials{display:flex;gap:10px;margin-top:4px}
.social-btn{width:38px;height:38px;border-radius:50%;background:rgba(0,32,80,.07);border:1px solid rgba(0,32,80,.12);display:flex;align-items:center;justify-content:center;color:var(--text);transition:all var(--t-fast)}
.social-btn:hover{background:rgba(29,125,224,.12);border-color:rgba(29,125,224,.3);transform:translateY(-2px)}
.social-btn svg{width:15px;height:15px;fill:var(--text)}
.footer-col h4{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:800;color:var(--text);letter-spacing:.5px;text-transform:uppercase;margin-bottom:15px}
.footer-cat-label{font-size:.7rem;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.8px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border);display:block}
.footer-col a,.footer-col span{display:block;font-size:.875rem;color:var(--text-2);padding:4px 0;line-height:1.5;transition:color var(--t-fast)}
.footer-col a:hover{color:var(--blue)}
.footer-bottom{padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-bottom p{font-size:.8125rem;color:var(--text-3)}
.footer-bottom a{color:var(--blue)}

/* FLOAT CALL — hidden, replaced by emerg-pill */
.float-call{display:none}

/* EMERGENCY PILL — same row as chatbot */
.emerg-pill{position:fixed;bottom:26px;right:96px;z-index:996;display:flex;align-items:center;gap:10px;height:58px;padding:0 22px;background:linear-gradient(135deg,#ff3c3c,#d41212);color:#fff;border-radius:50px;font-size:.9375rem;font-weight:700;box-shadow:0 10px 32px rgba(255,60,60,.5);backdrop-filter:blur(10px);border:1px solid rgba(255,80,80,.45);transition:all var(--t-fast);white-space:nowrap}
.emerg-pill::before{content:'';position:absolute;inset:-6px;border-radius:50px;border:2px solid rgba(255,60,60,.45);pointer-events:none;animation:emergPulse 2.4s ease-out infinite}
@keyframes emergPulse{0%{transform:scale(.88);opacity:.8}100%{transform:scale(1.18);opacity:0}}
.emerg-pill svg{width:19px;height:19px;fill:#fff;flex-shrink:0}
.emerg-pill .live-dot{display:none}
.emerg-pill:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 18px 44px rgba(255,60,60,.65)}
.emerg-pill:hover::before{display:none}
@media(max-width:480px){.emerg-pill{bottom:16px;right:86px;padding:0;width:50px;height:50px;border-radius:50%;justify-content:center}.emerg-pill-text{display:none}}

/* CHATBOT */
.chat-fab{position:fixed;bottom:26px;right:26px;z-index:998;width:58px;height:58px;border-radius:50%;background:var(--g-blue);border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 32px rgba(29,125,224,.5);transition:all .3s cubic-bezier(.2,0,.2,1)}
.chat-fab:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 18px 44px rgba(29,125,224,.6)}
.chat-fab svg{width:26px;height:26px;fill:#fff;position:absolute;transition:all .25s}
.chat-icon-open{opacity:1;transform:scale(1) rotate(0)}
.chat-icon-close{opacity:0;transform:scale(.6) rotate(-90deg)}
.chat-fab.open .chat-icon-open{opacity:0;transform:scale(.6) rotate(90deg)}
.chat-fab.open .chat-icon-close{opacity:1;transform:scale(1) rotate(0)}
.chat-fab-pulse{position:absolute;inset:-8px;border-radius:50%;border:2px solid rgba(130,200,255,.4);pointer-events:none;animation:chatPulse 2.4s ease-out infinite}
.chat-fab.open .chat-fab-pulse{display:none}
@keyframes chatPulse{0%{transform:scale(.8);opacity:.8}100%{transform:scale(1.35);opacity:0}}
.chat-fab-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;background:var(--red);border:2px solid var(--bg);border-radius:50px;font-size:.6875rem;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:center}
.chat-fab.open .chat-fab-badge{display:none}
@media(max-width:480px){.chat-fab{bottom:16px;right:16px}}
.chat-panel{position:fixed;bottom:96px;right:26px;width:360px;max-width:calc(100% - 52px);max-height:calc(100vh - 130px);max-height:calc(100svh - 130px);background:#ffffff;border:1px solid rgba(0,32,80,.14);border-radius:var(--r-xl);box-shadow:0 28px 72px rgba(0,0,0,.22);display:flex;flex-direction:column;overflow:hidden;z-index:997;opacity:0;pointer-events:none;transform:translateY(14px) scale(.96);transform-origin:bottom right;transition:all .3s cubic-bezier(.2,0,.2,1)}
.chat-panel.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
@media(max-width:480px){.chat-panel{right:8px;left:8px;width:auto;bottom:82px}}
.chat-hdr{background:linear-gradient(135deg,#1d7de0,#3a9ef8);padding:15px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(29,125,224,.2);flex-shrink:0}
.chat-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;background:var(--g-blue);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.chat-avatar svg{width:20px;height:20px;fill:#fff}
.chat-logo{width:40px;height:40px;border-radius:50%;object-fit:contain;background:#fff;padding:4px}
.chat-online-dot{position:absolute;bottom:0;right:0;width:11px;height:11px;border-radius:50%;background:var(--green);border:2px solid #3a9ef8}
.chat-hdr-info{flex:1;min-width:0}
.chat-hdr-name{font-weight:700;color:#fff;font-size:.9375rem}
.chat-hdr-status{font-size:.75rem;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:6px;margin-top:2px}
.chat-status-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0}
.chat-close-btn{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.32);color:#fff;font-size:13px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}
.chat-close-btn:hover{background:rgba(255,255,255,.36)}
.chat-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;background:#f5f8ff}
.chat-msgs::-webkit-scrollbar{width:4px}
.chat-msgs::-webkit-scrollbar-thumb{background:rgba(0,32,80,.18);border-radius:2px}
.chat-msg{display:flex;max-width:88%}
.chat-msg.bot{align-self:flex-start}
.chat-msg.user{align-self:flex-end}
.chat-bubble{padding:10px 14px;border-radius:14px;font-size:.875rem;line-height:1.55;animation:bubbleIn .22s ease both}
@keyframes bubbleIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.chat-msg.bot .chat-bubble{background:#ffffff;border:1px solid rgba(0,32,80,.12);color:var(--text);border-bottom-left-radius:4px;box-shadow:0 1px 4px rgba(0,0,0,.07)}
.chat-msg.user .chat-bubble{background:var(--g-blue);color:#fff;border-bottom-right-radius:4px;box-shadow:0 4px 16px rgba(29,125,224,.3)}
.chat-msg.bot .chat-bubble a{color:var(--blue);text-decoration:underline;font-weight:600}
.chat-msg.bot .chat-bubble strong{color:var(--text);font-weight:700}
.chat-typing-dots{display:flex;gap:4px;padding:4px 6px;align-items:center}
.chat-typing-dots span{width:7px;height:7px;border-radius:50%;background:var(--blue);opacity:.45;animation:typeBounce 1.1s ease-in-out infinite}
.chat-typing-dots span:nth-child(2){animation-delay:.18s}
.chat-typing-dots span:nth-child(3){animation-delay:.36s}
@keyframes typeBounce{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}
.chat-chips{padding:9px 13px;display:flex;flex-wrap:wrap;gap:6px;border-top:1px solid rgba(0,32,80,.09);background:#ffffff;flex-shrink:0}
.chat-chip{background:rgba(29,125,224,.07);border:1px solid rgba(29,125,224,.22);color:var(--text);padding:6px 11px;border-radius:50px;font-size:.75rem;font-weight:600;transition:all var(--t-fast);font-family:inherit}
.chat-chip:hover{background:rgba(29,125,224,.18);border-color:var(--blue);color:var(--blue)}
.chat-input-row{display:flex;gap:8px;padding:11px 13px;border-top:1px solid rgba(0,32,80,.09);background:#ffffff;flex-shrink:0}
#chatInput{flex:1;background:#f5f8ff;border:1.5px solid rgba(0,32,80,.16);border-radius:50px;padding:9px 15px;font-size:.875rem;color:var(--text);font-family:inherit;outline:none;transition:all var(--t-fast)}
#chatInput::placeholder{color:rgba(26,32,64,.35)}
#chatInput:focus{border-color:var(--blue);background:#eef4ff;box-shadow:0 0 0 3px rgba(29,125,224,.1)}
.chat-send{width:38px;height:38px;border-radius:50%;border:none;background:var(--g-blue);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:transform var(--t-fast)}
.chat-send:hover{transform:scale(1.1)}
.chat-send svg{width:16px;height:16px;fill:#fff}
/* Emergency call row inside chat */
.chat-emerg-call{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 13px;background:rgba(232,69,69,.06);border-top:1px solid rgba(232,69,69,.15);color:#b02020;font-size:.8125rem;font-weight:700;transition:background var(--t-fast);flex-shrink:0}
.chat-emerg-call svg{width:14px;height:14px;fill:#b02020;flex-shrink:0}
.chat-emerg-call:hover{background:rgba(232,69,69,.12);color:#8a1818}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:1500;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .3s}
.lightbox.open{opacity:1;pointer-events:auto}
.lb-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.92);backdrop-filter:blur(10px);cursor:pointer}
.lb-inner{position:relative;z-index:1;max-width:90vw;max-height:90vh}
.lb-close{position:absolute;top:-44px;right:0;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:all var(--t-fast)}
.lb-close:hover{background:rgba(255,255,255,.2);transform:rotate(90deg)}
.lb-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--r-lg);box-shadow:0 32px 80px rgba(0,0,0,.7)}

/* VIDEO MODAL */
.video-modal{position:fixed;inset:0;z-index:1500;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .3s cubic-bezier(.2,0,.2,1)}
.video-modal.open{opacity:1;pointer-events:auto}
.vm-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(10px);cursor:pointer}
.vm-inner{position:relative;z-index:1;width:100%;max-width:940px;transform:scale(.96) translateY(10px);transition:transform .35s cubic-bezier(.2,0,.2,1)}
.video-modal.open .vm-inner{transform:scale(1) translateY(0)}
.vm-close{position:absolute;top:-44px;right:0;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#fff;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast);cursor:pointer}
.vm-close svg{width:18px;height:18px;fill:#fff}
.vm-close:hover{background:rgba(255,255,255,.22);transform:rotate(90deg)}
.vm-embed{position:relative;padding-bottom:56.25%;height:0;background:#000;border-radius:var(--r-lg);overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.7);border:1px solid rgba(130,200,255,.18)}
.vm-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.vm-note{margin-top:12px;text-align:center;font-size:.75rem;color:rgba(255,255,255,.35)}
.vm-note code{color:var(--sky);background:rgba(130,200,255,.1);padding:1px 5px;border-radius:4px}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .72s cubic-bezier(.2,0,.2,1),transform .72s cubic-bezier(.2,0,.2,1);will-change:opacity,transform}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal.exiting{opacity:0;transform:translateY(-16px);transition:opacity .45s cubic-bezier(.2,0,.2,1),transform .45s cubic-bezier(.2,0,.2,1)}
.reveal-hero{animation:heroFadeUp .9s cubic-bezier(.2,0,.2,1) both}
.reveal-hero-d1{animation:heroFadeUp .9s .18s cubic-bezier(.2,0,.2,1) both}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.rd2{transition-delay:.13s!important}.rd3{transition-delay:.26s!important}
.sd1{transition-delay:.05s!important}.sd2{transition-delay:.15s!important}.sd3{transition-delay:.25s!important}

/* RESPONSIVE */
@media(max-width:768px){
  .nav-links,.nav-right{display:none}
  .ham-btn{display:flex}
  .hero-inner{padding:16px 16px 28px}
  .hero-visual{display:flex}
  .hmw-hero-cta{display:none}
  .hero-gallery{aspect-ratio:16/9}
  .why-badge{position:static;margin-top:16px;display:inline-flex}
  .svc-tab-nav{flex-direction:column}
  .svc-tab-btn{text-align:left;justify-content:flex-start}
  /* Master Plumber bar — stack and center all sections */
  .hpb-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:18px 0}
  .hpb-left{flex-direction:column;align-items:center;gap:8px}
  .hpb-title{text-align:center}
  .hpb-sub{text-align:center}
  .hpb-center{justify-content:center;gap:12px}
  .hpb-right{width:100%;display:flex;justify-content:center}
}
@media(max-width:480px){
  .hero-stats{width:100%;justify-content:space-between;flex-wrap:nowrap;align-self:stretch}
  .hstat{padding:0 4px;text-align:center}
}

/* REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1!important;transform:none!important}
  #globalSpotlight{display:none}
}

/* ── LAYOUT UTILITIES ─────────────────────────────────── */
.section-header--centered{text-align:center;margin-left:auto;margin-right:auto}
.section-header--mb-sm{margin-bottom:20px}
.section-header--mb-md{margin-bottom:40px}
.section-header--mb-lg{margin-bottom:56px}
.section-kicker--centered{justify-content:center}
.section-sub--centered{margin:0 auto}
.about-owner{font-family:'Cinzel',serif;font-size:1rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;margin-top:8px;display:inline-block;position:relative;padding:5px 18px;background:linear-gradient(105deg,#1558a0 0%,#2a85e8 20%,#5ab4ff 38%,#e8f6ff 50%,#5ab4ff 62%,#2a85e8 80%,#1558a0 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 1px 0 #1a5db0) drop-shadow(0 2px 2px rgba(15,60,140,.45)) drop-shadow(0 0 10px rgba(90,180,255,.35));animation:ownerShimmer 3s ease-in-out infinite alternate,ownerGlow 4s ease-in-out infinite;will-change:filter}
.about-owner::before{content:'';position:absolute;inset:0;background:rgba(15,50,120,.06);border-radius:50px;z-index:-1}
@keyframes ownerShimmer{0%{background-position:0% center}100%{background-position:100% center}}
@keyframes ownerGlow{0%,100%{filter:drop-shadow(0 1px 0 #1a5db0) drop-shadow(0 2px 2px rgba(15,60,140,.45)) drop-shadow(0 0 10px rgba(90,180,255,.35))}50%{filter:drop-shadow(0 1px 0 #1a5db0) drop-shadow(0 2px 2px rgba(15,60,140,.45)) drop-shadow(0 0 20px rgba(90,180,255,.65))}}
.form-hidden{display:none}
