/* =================================================================
   CODE BLUE ELECTRICAL — Shared Design System (v3)
   Poppins · Electric Blue (#0628E9) + Charcoal
   Slim top bar · white sticky header · hero carousel · cards · FAQ
   ================================================================= */
:root{
  --blue:#0B2BEE; --blue-600:#0628E9; --blue-700:#0A1FB0; --blue-bright:#3358FF;
  --blue-soft:#EAEEFF; --glow:rgba(51,88,255,.45);
  --ink:#05112E; --ink-1:#081640; --ink-2:#0C1E52; --ink-3:#15296B;
  --steel:#8A94A6; --mist:#AEB8C8;
  --paper:#F4F6FB; --paper-2:#FFFFFF; --paper-3:#EEF1F8;
  --text:#0A1733; --text-muted:#586377;
  --line:rgba(12,18,30,.10); --line-2:rgba(12,18,30,.07); --line-dark:rgba(255,255,255,.12);
  --wa:#25D366; --wa-700:#128C7E; --star:#FFB400;
  --container:1240px; --gutter:clamp(20px,5vw,44px);
  --r-sm:8px; --r:16px; --r-lg:24px; --r-pill:999px;
  --ease:cubic-bezier(.22,1,.36,1);
  --shadow-1:0 12px 32px -14px rgba(8,14,30,.18);
  --shadow-2:0 36px 70px -26px rgba(8,14,30,.34);
  --shadow-blue:0 18px 44px -16px rgba(11,43,238,.5);
  --topbar-h:40px; --header-h:74px;
  --font:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:90px}
body{font-family:var(--font);color:var(--text);background:var(--paper-2);line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:3px solid var(--blue-bright);outline-offset:3px;border-radius:4px}
::selection{background:var(--blue);color:#fff}

h1,h2,h3,h4{line-height:1.1;letter-spacing:-.025em;font-weight:700;color:var(--text)}
.h-display{font-size:clamp(2.6rem,6vw,5rem);font-weight:800;letter-spacing:-.04em;line-height:1.02}
.h1{font-size:clamp(2.1rem,4.6vw,3.5rem);font-weight:800;letter-spacing:-.035em}
.h2{font-size:clamp(1.8rem,3.4vw,2.7rem);font-weight:700}
.h3{font-size:clamp(1.15rem,1.7vw,1.4rem);font-weight:600;letter-spacing:-.01em}
.lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--text-muted);font-weight:400;line-height:1.7}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--blue)}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--blue);border-radius:2px}
.eyebrow.light{color:#9fb0ff}.eyebrow.light::before{background:#9fb0ff}
.muted{color:var(--text-muted)} .center{text-align:center}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4rem,8vw,7rem);position:relative}
.section--tight{padding-block:clamp(3rem,5vw,4.5rem)}
.section--paper{background:var(--paper)}
.section--dark{background:var(--ink);color:#E8ECF4}
.section--dark .h2,.section--dark h2,.section--dark h3{color:#fff}
.section--dark .lead,.section--dark .muted{color:var(--mist)}
.section-head{max-width:680px;margin-bottom:clamp(2.2rem,4vw,3.4rem)}
.section-head.center{margin-inline:auto}
.section-head .h2{margin-top:.9rem}.section-head .lead{margin-top:1rem}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease),transform .55s var(--ease);will-change:opacity,transform}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.05s}.reveal[data-d="2"]{transition-delay:.1s}
.reveal[data-d="3"]{transition-delay:.15s}.reveal[data-d="4"]{transition-delay:.2s}
.reveal[data-d="5"]{transition-delay:.25s}.reveal[data-d="6"]{transition-delay:.3s}

/* buttons */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:.95rem 1.7rem;border-radius:var(--r-sm);font-weight:600;font-size:.97rem;
  background:var(--blue);color:#fff;box-shadow:0 10px 26px -12px rgba(11,43,238,.6);
  transition:transform .3s var(--ease),box-shadow .35s var(--ease),background .25s ease;
  white-space:nowrap;overflow:hidden;isolation:isolate}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,transparent 20%,rgba(255,255,255,.28) 50%,transparent 80%);transform:translateX(-120%);transition:transform .7s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-blue)}
.btn:hover::after{transform:translateX(120%)}
.btn:active{transform:translateY(-1px)}
.btn--lg{padding:1.1rem 2rem;font-size:1.01rem}
.btn--ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.5)}
.btn--ghost::after{display:none}
.btn--ghost:hover{background:#fff;color:var(--ink);box-shadow:none;transform:translateY(-3px)}
.btn--ghost-dark{background:transparent;color:var(--text);box-shadow:inset 0 0 0 1.5px var(--line)}
.btn--ghost-dark:hover{background:var(--ink);color:#fff;box-shadow:none}
.btn--white{background:#fff;color:var(--ink);box-shadow:0 12px 32px -14px rgba(0,0,0,.4)}
.btn--white:hover{box-shadow:0 24px 46px -18px rgba(0,0,0,.5)}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem}
.link-arrow{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--blue);transition:gap .25s var(--ease)}
.link-arrow svg{width:1.05em;height:1.05em;transition:transform .25s var(--ease)}
.link-arrow:hover{gap:.7rem}.link-arrow:hover svg{transform:translateX(3px)}

/* =================================================================
   TOP SLIM BAR  (phone left · email right)
   ================================================================= */
.topbar{background:var(--ink);color:var(--mist);font-size:.84rem}
.topbar .container{display:flex;align-items:center;justify-content:space-between;min-height:var(--topbar-h);gap:1rem}
.topbar a{display:inline-flex;align-items:center;gap:.5rem;color:var(--mist);transition:color .2s}
.topbar a:hover{color:#fff}
.topbar svg{width:15px;height:15px;color:var(--blue-bright);flex:none}
.topbar .tb-left{display:flex;gap:1.4rem;align-items:center}
.topbar .tb-right{display:flex;gap:1.4rem;align-items:center}
@media(max-width:600px){.topbar .tb-sep{display:none}.topbar .container{justify-content:center}.topbar .tb-right{display:none}}

/* =================================================================
   HEADER (solid white, sticky) + official logo
   ================================================================= */
.header{position:sticky;top:0;z-index:60;background:#fff;border-bottom:1px solid var(--line-2);transition:box-shadow .35s var(--ease)}
.header.scrolled{box-shadow:0 8px 30px -16px rgba(8,14,30,.35)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:var(--header-h);gap:1.5rem}
.brand{display:inline-flex;align-items:center}
.brand img{height:46px;width:auto;display:block}
@media(max-width:420px){.brand img{height:38px}}
.nav{display:flex;align-items:center;gap:.15rem}
.nav a{padding:.6rem .9rem;font-size:.95rem;font-weight:500;color:var(--text);border-radius:8px;position:relative;transition:color .2s}
.nav a::after{content:"";position:absolute;left:.9rem;right:.9rem;bottom:.35rem;height:2px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);border-radius:2px}
.nav a:hover{color:var(--blue)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}
.nav a.active{color:var(--blue);font-weight:600}
.header-cta{display:flex;align-items:center;gap:.7rem}
.burger{display:none;width:46px;height:46px;border-radius:10px;background:var(--paper);border:1px solid var(--line);position:relative}
.burger span{position:absolute;left:12px;right:12px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.burger span:nth-child(1){top:16px}.burger span:nth-child(2){top:22px}.burger span:nth-child(3){top:28px}
body.menu-open .burger span:nth-child(1){top:22px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:22px;transform:rotate(-45deg)}
@media(max-width:940px){.nav,.header-cta .btn{display:none}.burger{display:block}}

.mobile-menu{position:fixed;inset:0;z-index:55;background:rgba(5,17,46,.96);backdrop-filter:blur(12px);
  padding:calc(var(--header-h) + 1rem) var(--gutter) 2rem;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;text-align:center;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s var(--ease),visibility .35s var(--ease)}
body.menu-open .mobile-menu{opacity:1;visibility:visible;pointer-events:auto}
.mobile-menu a{font-size:clamp(1.7rem,6.5vw,2.2rem);font-weight:700;color:#fff;padding:.65rem 1rem;letter-spacing:-.015em;
  display:block;width:100%;max-width:440px;transition:color .2s,transform .25s var(--ease)}
.mobile-menu a:hover{color:#9fb0ff;transform:scale(1.05)}
.mobile-menu a svg{display:none}
.mobile-menu .mm-cta{display:none}
body.menu-open .floats{display:none}

/* =================================================================
   HERO CAROUSEL
   ================================================================= */
.hero{position:relative;height:clamp(540px,86vh,800px);overflow:hidden;background:var(--ink);isolation:isolate}
.slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity 1.1s var(--ease),visibility 1.1s}
.slide.active{opacity:1;visibility:visible}
.slide-bg{position:absolute;inset:0;z-index:-2;overflow:hidden}
.slide-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:transform 7s ease}
.slide.active .slide-bg img{transform:scale(1.16)}
.slide::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,rgba(5,17,46,.92) 0%,rgba(5,17,46,.66) 45%,rgba(5,17,46,.35) 100%)}
.hero-glow{position:absolute;top:-10%;right:-6%;width:50vw;height:50vw;z-index:0;background:radial-gradient(circle,rgba(51,88,255,.28),transparent 62%);pointer-events:none}
.hero-content{position:relative;z-index:2;height:100%;display:flex;align-items:center}
.hero-text{max-width:680px;color:#fff;opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease) .25s,transform .9s var(--ease) .25s}
.slide.active .hero-text{opacity:1;transform:none}
.hero-text .eyebrow{margin-bottom:1.2rem}
.hero-text h1{font-size:clamp(2.4rem,5.6vw,4.4rem);font-weight:800;letter-spacing:-.04em;line-height:1.02;color:#fff}
.hero-text h1 .grad{background:linear-gradient(100deg,#5b78ff,#9fb0ff 55%,#fff);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-text p{margin-top:1.3rem;font-size:clamp(1.02rem,1.5vw,1.25rem);color:#c6cfe0;max-width:520px;line-height:1.6}
.hero-text .btn-row{margin-top:2.2rem}
.hero-arrows{position:absolute;z-index:5;bottom:2rem;right:clamp(20px,5vw,44px);display:flex;gap:.6rem}
.hero-arrow{width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(6px);display:grid;place-items:center;color:#fff;transition:.25s var(--ease)}
.hero-arrow:hover{background:var(--blue);transform:translateY(-2px)}
.hero-arrow svg{width:22px;height:22px}
.hero-dots{position:absolute;z-index:5;bottom:2.6rem;left:clamp(20px,5vw,44px);display:flex;gap:.5rem}
.hero-dot{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.35);border:none;cursor:pointer;transition:.3s var(--ease)}
.hero-dot.active{background:#fff;width:32px;border-radius:6px}
@media(max-width:600px){.hero{height:78svh}.hero-arrows{display:none}}

/* =================================================================
   ABOUT PREVIEW
   ================================================================= */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.about-split.reverse .about-media{order:2}
.about-media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-2)}
.about-media img{width:100%;aspect-ratio:4/3.3;object-fit:cover}
.about-media.tall img{aspect-ratio:4/4.6}
.about-media .badge{position:absolute;right:-4%;bottom:-6%;background:var(--blue);color:#fff;border-radius:18px;padding:1.1rem 1.3rem;box-shadow:var(--shadow-blue);max-width:210px}
.about-media .badge b{font-size:1.3rem;font-weight:700;letter-spacing:-.01em;display:block}
.about-media .badge span{font-size:.82rem;color:rgba(255,255,255,.85)}
.trust-row{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.8rem}
.trust-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:var(--r-pill);background:var(--paper);border:1px solid var(--line);font-size:.88rem;font-weight:500}
.trust-chip svg{width:17px;height:17px;color:var(--blue)}
.section--dark .trust-chip{background:rgba(255,255,255,.04);border-color:var(--line-dark);color:#fff}
@media(max-width:840px){.about-split{grid-template-columns:1fr;gap:3rem}.about-split.reverse .about-media{order:0}.about-media .badge{position:static;max-width:none;margin-top:1rem;display:inline-block}}

/* =================================================================
   SERVICE CARDS — image on top, title, short description below
   ================================================================= */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.cards.cols-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .3s}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-2);border-color:rgba(11,43,238,.3)}
.card-media{position:relative;aspect-ratio:16/11;overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.card:hover .card-media img{transform:scale(1.08)}
.card-body{padding:1.5rem 1.4rem 1.6rem;display:flex;flex-direction:column;flex:1}
.card-body h3{font-size:1.18rem;font-weight:600;letter-spacing:-.01em}
.card-body p{margin-top:.5rem;font-size:.92rem;color:var(--text-muted);flex:1;line-height:1.6}
.card-body .link-arrow{margin-top:1.1rem;font-size:.9rem}
@media(max-width:1000px){.cards,.cards.cols-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cards,.cards.cols-3{grid-template-columns:1fr}}

/* =================================================================
   REVIEWS (Google)
   ================================================================= */
.reviews-top{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.2rem;margin-bottom:2.6rem;text-align:center}
.g-badge{display:inline-flex;align-items:center;gap:.7rem;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-pill);padding:.6rem 1.1rem;box-shadow:var(--shadow-1)}
.g-badge .g-logo{font-weight:700;font-size:1.05rem;letter-spacing:-.02em}
.g-badge .g-logo b:nth-child(1){color:#4285F4}.g-badge .g-logo b:nth-child(2){color:#EA4335}.g-badge .g-logo b:nth-child(3){color:#FBBC05}.g-badge .g-logo b:nth-child(4){color:#4285F4}.g-badge .g-logo b:nth-child(5){color:#34A853}.g-badge .g-logo b:nth-child(6){color:#EA4335}
.g-badge .g-score{font-weight:700;color:var(--text)}
.stars{display:inline-flex;gap:2px;color:var(--star)}
.stars svg{width:18px;height:18px}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.review{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:1.7rem 1.6rem;box-shadow:var(--shadow-1);transition:transform .35s var(--ease),box-shadow .35s var(--ease);display:flex;flex-direction:column}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow-2)}
.review .stars{margin-bottom:1rem}
.review p{font-size:.95rem;color:var(--text);line-height:1.65;flex:1}
.review .who{display:flex;align-items:center;gap:.8rem;margin-top:1.3rem}
.review .mono{width:44px;height:44px;border-radius:50%;background:linear-gradient(145deg,var(--blue),var(--blue-700));color:#fff;display:grid;place-items:center;font-weight:700}
.review .who .nm{font-weight:600;font-size:.95rem}
.review .who .loc{font-size:.8rem;color:var(--text-muted)}
.review .who .g-ic{margin-left:auto;width:22px;height:22px}
@media(max-width:900px){.reviews{grid-template-columns:1fr}}

/* =================================================================
   FAQ ACCORDION
   ================================================================= */
.faq{max-width:820px;margin-inline:auto}
.faq-item{border:1px solid var(--line);border-radius:var(--r);background:var(--paper-2);margin-bottom:.9rem;overflow:hidden;transition:border-color .3s,box-shadow .3s}
.faq-item.open{border-color:rgba(11,43,238,.35);box-shadow:var(--shadow-1)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.3rem 1.5rem;text-align:left;font-weight:600;font-size:1.04rem;color:var(--text)}
.faq-q .ic{width:34px;height:34px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;flex:none;transition:.35s var(--ease)}
.faq-q .ic svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.faq-item.open .faq-q .ic{background:var(--blue);color:#fff}
.faq-item.open .faq-q .ic svg{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 1.5rem 1.4rem;color:var(--text-muted);line-height:1.7;font-size:.96rem}
@media(max-width:560px){.faq-q{padding:1.1rem 1.2rem;font-size:.98rem}}

/* =================================================================
   FINAL CTA
   ================================================================= */
.cta{position:relative;overflow:hidden;isolation:isolate;color:#fff;text-align:center}
.cta-bg{position:absolute;inset:0;z-index:-3}.cta-bg img{width:100%;height:100%;object-fit:cover}
.cta::before{content:"";position:absolute;inset:0;z-index:-2;background:linear-gradient(120deg,rgba(10,31,176,.94),rgba(11,43,238,.84) 55%,rgba(51,88,255,.8))}
.cta::after{content:"";position:absolute;inset:0;z-index:-2;background:radial-gradient(circle at 18% 20%,rgba(255,255,255,.16),transparent 50%)}
.cta .container{padding-block:clamp(4rem,8vw,7rem)}
.cta h2{color:#fff} .cta p{max-width:540px;margin:1.1rem auto 0;color:rgba(255,255,255,.92)}
.cta .btn-row{justify-content:center;margin-top:2rem}

/* =================================================================
   PAGE BANNER (sub-pages)
   ================================================================= */
.page-banner{position:relative;color:#fff;overflow:hidden;isolation:isolate;min-height:clamp(300px,44vh,420px);display:flex;align-items:flex-end}
.page-banner .pb-bg{position:absolute;inset:0;z-index:-3}
.page-banner .pb-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.05)}
.page-banner::before{content:"";position:absolute;inset:0;z-index:-2;background:linear-gradient(180deg,rgba(5,17,46,.78),rgba(5,17,46,.5) 45%,rgba(5,17,46,.9))}
.page-banner .container{padding-bottom:clamp(2.2rem,5vw,3.4rem);padding-top:clamp(2rem,5vw,3rem);text-align:center}
.page-banner h1{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:800;letter-spacing:-.035em;color:#fff}
.page-banner p{margin:.7rem auto 0;color:#c6cfe0;max-width:560px;font-size:clamp(1rem,1.4vw,1.18rem)}
.crumbs{display:flex;gap:.5rem;align-items:center;justify-content:center;flex-wrap:wrap;font-size:.82rem;color:var(--mist);margin-bottom:1rem}
.crumbs a:hover{color:#fff}.crumbs span{color:#5b78ff}

/* =================================================================
   MISSION / VISION (about page)
   ================================================================= */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.mv-card{background:var(--ink-2);border:1px solid var(--line-dark);border-radius:var(--r-lg);padding:clamp(1.8rem,3.5vw,2.6rem);position:relative;overflow:hidden}
.mv-card .mv-ic{width:56px;height:56px;border-radius:15px;background:linear-gradient(145deg,var(--blue),var(--blue-700));display:grid;place-items:center;box-shadow:var(--shadow-blue);margin-bottom:1.3rem}
.mv-card .mv-ic svg{width:28px;height:28px;color:#fff}
.mv-card h3{color:#fff;font-size:1.5rem;font-weight:700;margin-bottom:.7rem}
.mv-card p{color:var(--mist);line-height:1.7}
@media(max-width:760px){.mv-grid{grid-template-columns:1fr}}

/* =================================================================
   CONTACT PAGE
   ================================================================= */
.contact-top{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-bottom:2.4rem}
.contact-box{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.9rem;padding:2.2rem 1.6rem;border-radius:var(--r-lg);background:var(--ink);color:#fff;box-shadow:var(--shadow-1);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.contact-box:hover{transform:translateY(-5px);box-shadow:var(--shadow-2)}
.contact-box .cb-ic{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;flex:none}
.contact-box.phone .cb-ic{background:rgba(51,88,255,.18);color:#7d93ff}
.contact-box.email .cb-ic{background:rgba(37,211,102,.16);color:#39e07d}
.contact-box .cb-ic svg{width:28px;height:28px}
.contact-box .cb-t{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mist);font-weight:600}
.contact-box .cb-nums{display:flex;flex-direction:column;gap:.15rem;margin-top:-.2rem}
.contact-box .cb-v{font-size:1.22rem;font-weight:700;color:#fff;line-height:1.45}
.contact-box .cb-v.sm{font-size:1.02rem;color:#c6cfe0;font-weight:600}
@media(max-width:600px){.contact-top{grid-template-columns:1fr}}

.contact-form{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.8rem,4vw,3rem);box-shadow:var(--shadow-1);max-width:820px;margin-inline:auto}
.form-intro{text-align:center;margin-bottom:1.8rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.45rem}
.field input,.field select,.field textarea{width:100%;padding:.9rem 1rem;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--paper);font-family:inherit;font-size:.95rem;color:var(--text);transition:.2s}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px rgba(11,43,238,.1)}
.form-success{display:none;text-align:center;padding:2rem 1rem}
.form-success.show{display:block}
.form-success .fs-ico{width:64px;height:64px;margin:0 auto 1rem;border-radius:50%;background:rgba(37,211,102,.14);color:var(--wa-700);display:grid;place-items:center}
.form-success .fs-ico svg{width:34px;height:34px}
.map-full{width:100%;line-height:0;margin:0;padding:0}
.map-full iframe{width:100%;height:clamp(320px,42vh,460px);border:0;display:block;filter:grayscale(.15) contrast(1.04)}

/* footer-style nav strip (contact page bottom) */
.nav-strip{background:var(--ink-1);border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}
.nav-strip .container{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem 2rem;padding-block:1.4rem}
.nav-strip a{color:var(--mist);font-weight:500;font-size:.96rem;transition:color .2s}
.nav-strip a:hover{color:#fff}

/* =================================================================
   GALLERY GRID + filters
   ================================================================= */
.filters{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2.4rem}
.filter{padding:.6rem 1.2rem;border-radius:var(--r-pill);font-size:.88rem;font-weight:500;color:var(--text-muted);background:var(--paper-2);border:1px solid var(--line);transition:.25s var(--ease)}
.filter:hover{color:var(--text);border-color:rgba(11,43,238,.3)}
.filter.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:1rem}
.gal-item{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;background:var(--ink-2);grid-row:span 1;transition:opacity .5s var(--ease)}
.gal-item.tall{grid-row:span 2}.gal-item.wide{grid-column:span 2}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(5,17,46,.7));opacity:.4;transition:opacity .4s}
.gal-item:hover img{transform:scale(1.09)}.gal-item:hover::after{opacity:.85}
.gal-item .zoom{position:absolute;inset:0;display:grid;place-items:center;z-index:2;opacity:0;transition:.35s var(--ease)}
.gal-item:hover .zoom{opacity:1}
.gal-item .zoom span{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);display:grid;place-items:center;transform:scale(.8);transition:.35s var(--ease)}
.gal-item:hover .zoom span{transform:none}.gal-item .zoom svg{width:22px;height:22px;color:#fff}
.gal-item .gal-tag{position:absolute;left:1rem;bottom:1rem;z-index:2;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#fff;opacity:0;transform:translateY(6px);transition:.4s var(--ease)}
.gal-item:hover .gal-tag{opacity:1;transform:none}.gal-item.hide{display:none}
@media(max-width:1000px){.gal{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gal{grid-template-columns:1fr;grid-auto-rows:240px}.gal-item.tall,.gal-item.wide{grid-row:span 1;grid-column:span 1}}

/* =================================================================
   FOOTER
   ================================================================= */
.footer{background:var(--ink);color:var(--mist);padding-top:clamp(3.5rem,6vw,5rem)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.3fr;gap:2.5rem;align-items:start}
.footer-logo{display:inline-block;background:#fff;padding:.55rem .8rem;border-radius:12px}
.footer-logo img{height:42px;width:auto;display:block}
.footer-about p{margin-top:1.2rem;font-size:.92rem;line-height:1.7;max-width:320px}
.footer-social{display:flex;gap:.6rem;margin-top:1.4rem}
.footer-social a{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.06);display:grid;place-items:center;transition:.25s var(--ease)}
.footer-social a:hover{background:var(--blue);transform:translateY(-3px)}
.footer-social a svg{width:18px;height:18px;color:#fff}
.footer h4{color:#fff;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;margin-bottom:1.2rem}
.footer-col ul li{margin-bottom:.65rem}
.footer-col a{font-size:.94rem;transition:.2s}.footer-col a:hover{color:#fff;padding-left:3px}
.footer-contact li{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:.9rem;font-size:.94rem}
.footer-contact li svg{width:18px;height:18px;color:#5b78ff;flex:none;margin-top:3px}
.footer-bottom{margin-top:clamp(2.5rem,5vw,3.5rem);border-top:1px solid var(--line-dark);padding:1.6rem 0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;font-size:.83rem}
.footer-bottom a:hover{color:#fff}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}.footer-about{grid-column:1/-1}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* =================================================================
   FLOATING BUTTONS — Call + WhatsApp
   ================================================================= */
.floats{position:fixed;left:0;right:0;bottom:clamp(16px,3vw,24px);z-index:80;display:flex;flex-direction:row-reverse;justify-content:space-between;align-items:center;padding-inline:clamp(16px,4vw,28px);pointer-events:none}
.floats>*{pointer-events:auto}
.float-btn{position:relative;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:0 14px 30px -10px rgba(0,0,0,.45);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.float-btn svg{width:26px;height:26px;position:relative;z-index:2}
.float-btn.call{background:var(--blue)}.float-btn.wa{background:var(--wa)}
.float-btn:hover{transform:translateY(-4px) scale(1.05)}
.float-btn.call:hover{box-shadow:0 20px 40px -12px rgba(11,43,238,.7)}
.float-btn.wa:hover{box-shadow:0 20px 40px -12px rgba(37,211,102,.6)}
.float-btn .ring{position:absolute;inset:0;border-radius:50%;z-index:1}
.float-btn.call .ring{animation:fpulse 2.4s infinite}
.float-btn.wa .ring{animation:fpulseg 2.4s infinite .6s}
@keyframes fpulse{0%{box-shadow:0 0 0 0 rgba(51,88,255,.5)}70%{box-shadow:0 0 0 16px rgba(51,88,255,0)}100%{box-shadow:0 0 0 0 rgba(51,88,255,0)}}
@keyframes fpulseg{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.float-btn .tip{position:absolute;left:50%;bottom:calc(100% + 12px);transform:translate(-50%,6px);background:var(--ink);color:#fff;font-size:.82rem;font-weight:600;padding:.5rem .8rem;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:.3s var(--ease)}
.float-btn:hover .tip{opacity:1;transform:translate(-50%,0)}
@media(max-width:560px){.float-btn{width:54px;height:54px}.float-btn .tip{display:none}}

/* ===== LIGHTBOX ===== */
.lightbox{position:fixed;inset:0;z-index:95;background:rgba(4,11,34,.93);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;padding:5vw}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:84vh;border-radius:12px;box-shadow:var(--shadow-2);animation:lbin .45s var(--ease)}
@keyframes lbin{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:none}}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.12);border-radius:50%;width:54px;height:54px;display:grid;place-items:center;color:#fff;transition:.25s}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--blue)}
.lb-close{top:4vh;right:4vw}.lb-prev{left:3vw;top:50%;transform:translateY(-50%)}.lb-next{right:3vw;top:50%;transform:translateY(-50%)}
.lb-close svg,.lb-prev svg,.lb-next svg{width:24px;height:24px}
@media(max-width:560px){.lb-prev,.lb-next{width:46px;height:46px;top:auto;bottom:5vh;transform:none}.lb-prev{left:24vw}.lb-next{right:24vw}}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .slide{transition:opacity .2s linear}.slide-bg img{transform:none!important}
}

/* =================================================================
   HOMEPAGE 6-IMAGE GALLERY (3 x 2)
   ================================================================= */
.gallery-6{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.gallery-6 .gal-item{aspect-ratio:4/3;grid-row:auto}
@media(max-width:900px){.gallery-6{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gallery-6{grid-template-columns:1fr}}

/* =================================================================
   SERVICE DETAIL PAGES
   ================================================================= */
.feature-list{display:grid;gap:.65rem;margin-top:1.5rem}
.feature-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:.97rem;color:var(--text);line-height:1.55}
.feature-list li svg{width:20px;height:20px;color:var(--blue);flex:none;margin-top:2px}
.section--dark .feature-list li{color:#e8ecf4}
.svc-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.6rem}
.svc-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r);box-shadow:var(--shadow-1)}
@media(max-width:700px){.svc-gallery{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.svc-gallery{grid-template-columns:1fr}}
.svc-related{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:.5rem}
.svc-related a{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.2rem 1.4rem;border-radius:var(--r);background:var(--paper-2);border:1px solid var(--line);font-weight:600;transition:.25s var(--ease)}
.svc-related a:hover{border-color:rgba(11,43,238,.35);transform:translateY(-3px);box-shadow:var(--shadow-1)}
.svc-related a svg{width:18px;height:18px;color:var(--blue);flex:none;transition:transform .25s var(--ease)}
.svc-related a:hover svg{transform:translateX(3px)}
@media(max-width:760px){.svc-related{grid-template-columns:1fr}}
