/* =========================================================
   BNS Airmax — Elegant Plumbing Site
   ========================================================= */
:root{
  --red:#e30613;
  --red-dark:#b40510;
  --blue:#0a2540;
  --blue-2:#143b6b;
  --gold:#f5b301;
  --bg:#f7f8fb;
  --surface:#ffffff;
  --ink:#0d1b2a;
  --muted:#5a6779;
  --line:#e7eaf0;
  --shadow-sm:0 4px 14px rgba(10,37,64,.06);
  --shadow-md:0 16px 40px rgba(10,37,64,.10);
  --shadow-lg:0 30px 80px rgba(10,37,64,.18);
  --radius:18px;
  --radius-sm:10px;
  --container:1240px;
  --grad-red:linear-gradient(135deg,#ff2a3c,#b40510);
  --grad-blue:linear-gradient(135deg,#143b6b,#0a2540);
  --grad-gold:linear-gradient(135deg,#ffd34f,#f5b301);
  --font-display:"Playfair Display", Georgia, serif;
  --font-body:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}


/* overflow css */
/* =========================================
   COMPLETE MOBILE OVERFLOW FIX
========================================= */

html,
body{
    width:100%;
    max-width:100%;
    overflow-x:hidden !important;
}

*{
    box-sizing:border-box;
}

img{
    max-width:100%;
    height:auto;
    display:block;
}

section,
header,
footer,
div{
    max-width:100%;
}

/* CONTAINER FIX */
.container{
    width:100%;
    max-width:1240px;
    margin:auto;
    padding-left:16px;
    padding-right:16px;
}

/* HERO FIX */
.hero,
.hero .container,
.hero-visual,
.hero-visual .frame{
    overflow:hidden;
}

/* PRODUCT SLIDER FIX */
.product-slider,
.products-swiper,
.swiper{
    width:100%;
    overflow:hidden !important;
}

.swiper-wrapper{
    box-sizing:border-box;
}

/* SLIDER BUTTON FIX */
.slider-prev{
    left:5px !important;
}

.slider-next{
    right:5px !important;
}

/* MARQUEE FIX */
.badges-strip{
    overflow:hidden;
    width:100%;
}

.badges-track{
    display:flex;
    gap:28px;
    width:max-content;
}

/* MOBILE MENU FIX */
.menu{
    max-width:100vw;
    overflow-x:hidden;
    overflow-y:auto;
}

body.menu-open{
    overflow:hidden !important;
}

/* REMOVE DOUBLE ICON */
body.menu-open .hamburger{
    opacity:0;
    visibility:hidden;
}

/* RESPONSIVE FIX */
@media (max-width:768px){

    .features,
    .products-grid,
    .projects-grid,
    .footer .grid,
    .split{
        grid-template-columns:1fr !important;
    }

    .hero h1{
        font-size:2rem;
        line-height:1.2;
    }

    .hero-visual .frame img{
        height:300px;
        object-fit:cover;
    }

    .slider-btn{
        width:40px;
        height:40px;
    }

    .badge-item img{
        width:45px;
        height:45px;
    }

    .menu{
        width:85vw;
    }

}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);
  background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;color:var(--blue);line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em;color:var(--muted)}

.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--red);display:inline-block}

.btn{
  display:inline-flex;align-items:center;gap:10px;padding:14px 26px;
  border-radius:999px;font-weight:600;font-size:.92rem;
  transition:transform .25s ease, box-shadow .25s ease, background .25s;
}
.btn-primary{background:var(--grad-red);color:#fff;box-shadow:0 14px 30px rgba(227,6,19,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 38px rgba(227,6,19,.45)}
.btn-ghost{border:1.5px solid var(--blue);color:var(--blue)}
.btn-ghost:hover{background:var(--blue);color:#fff}

/* ============ HEADER ============ */
.topbar{background:var(--blue);color:#cbd6e8;font-size:.82rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding:8px 24px;flex-wrap:wrap;gap:8px}
.topbar a{color:#fff;opacity:.9;transition:opacity .2s}
.topbar a:hover{opacity:1;color:var(--gold)}
.topbar .top-info{display:flex;gap:20px;flex-wrap:wrap}
.topbar .top-info span i{color:var(--gold);margin-right:6px}
.topbar .top-social{display:flex;gap:14px;font-size:.95rem}

.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
}
@media (min-width:1025px){
  .menu-close{
     display:none !important;
  }
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;justify-content:space-between;align-items:center;padding:14px 0;gap:20px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand img{height:52px;width:auto;max-width:min(280px, calc(100vw - 112px));object-fit:contain}
.menu{display:flex;gap:6px;align-items:center}
.menu a{
  padding:10px 16px;border-radius:10px;font-size:.98rem;font-weight:450;color:var(--ink);
  position:relative;transition:color .2s
}
.menu a::after{
  content:"";position:absolute;left:50%;bottom:4px;width:0;height:2px;background:var(--red);transition:width .25s,left .25s;
}
.menu a:hover,.menu a.active{color:var(--red)}
.menu a:hover::after,.menu a.active::after{width:60%;left:20%}
.menu .btn{margin-left:14px;padding:10px 20px}
.hamburger{display:none;font-size:1.6rem;color:var(--blue);padding:8px;position:relative;z-index:1004;flex:0 0 auto}

/* ============ HERO (home) ============ */
/* .hero{
  position:relative;overflow:hidden;
  background:radial-gradient(circle at 80% 20%, #1a4a8a 0%, var(--blue) 40%, #06182d 100%);
  color:#fff;padding:90px 0 100px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at 10% 90%, rgba(227,6,19,.25), transparent 60%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40'><path d='M0 39.5h40M39.5 0v40' stroke='rgba(255,255,255,.04)' stroke-width='1'/></svg>");
}  */


/* video */

/* VIDEO HERO SECTION */

.video-hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  color:#fff;
}

/* VIDEO */

.hero-video{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:-2;
}

/* DARK OVERLAY */

.hero-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.55);
  z-index:-1;
}

/* CONTENT */

.video-hero .container{
  position:relative;
  z-index:2;
}

/* TEXT */

.video-hero h1{
  color:#fff;
}

.video-hero p{
  color:#e5e5e5;
}

.video-hero em{
  color:var(--gold);
}

/* MOBILE */

@media(max-width:768px){

  .video-hero{
    min-height:85vh;
    text-align:center;
  }

  .hero-cta{
    justify-content:center;
  }

  .hero-stats{
    justify-content:center;
  }

}


    /* product desgin */
    /* =========================
   CPVC PRODUCT CARD DESIGN
========================= */

.products{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:28px;
}

.product{
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  border:1px solid #e5e5e5;
  box-shadow:0 10px 30px rgba(0,0,0,0.08);
  transition:.35s ease;
  display:flex;
  flex-direction:column;
}

.product:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 40px rgba(0,0,0,0.12);
}

.product .pic{
  height:240px;
  background:#f7f7f7;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.product .pic img{
  max-width:80%;
  max-height:85%;
  object-fit:contain;
  transition:.4s ease;
}

.product:hover .pic img{
  transform:scale(1.08);
}

.product .body{
  padding:22px;
  display:flex;
  flex-direction:column;
  flex:1;
}

.product .cat{
  color:#ff1d25;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  margin-bottom:8px;
}

.product h3{
  font-size:1.35rem;
  margin-bottom:10px;
  color:#111;
}

.product p{
  font-size:.95rem;
  color:#555;
  line-height:1.7;
  flex:1;
}

.product .pack{
  margin-top:18px;
  padding:10px 12px;
  border:1px dashed #2BA84A;
  border-radius:10px;
  color:#1F7A36;
  background:#f5fff7;
  font-size:.85rem;
  font-weight:600;
}

.product .quick{
  display:flex;
  gap:10px;
  margin-top:18px;
}

.product .quick a{
  flex:1;
  text-align:center;
  padding:12px;
  border-radius:10px;
  text-decoration:none;
  font-weight:700;
  transition:.3s ease;
}

.product .quick a:first-child{
  background:#2BA84A;
  color:#fff;
}

.product .quick a:first-child:hover{
  background:#1F7A36;
}

.product .quick a.alt{
  border:2px solid #2BA84A;
  color:#1F7A36;
  background:#fff;
}

.product .quick a.alt:hover{
  background:#25D366;
  border-color:#25D366;
  color:#fff;
}

/* MOBILE */
@media(max-width:768px){

  .products{
    grid-template-columns:1fr;
    gap:18px;
  }

  .product .pic{
    height:200px;
  }

  .product .body{
    padding:18px;
  }

  .product h3{
    font-size:1.1rem;
  }

  .product p{
    font-size:.85rem;
  }

  .product .quick a{
    font-size:.82rem;
    padding:10px 8px;
  }

}








/* remove */
/* Remove top hamburger icon when mobile menu opens */
body.menu-open .hamburger{
  display:none !important;
}


.hero .container{position:relative;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.hero h1{color:#fff;font-size:clamp(2.4rem,5.4vw,4.4rem)}
.hero h1 em{color:var(--gold);font-style:italic;font-weight:400}
.hero p.lead{color:#cfd9ea;font-size:1.1rem;max-width:560px;margin-bottom:30px}
.hero .eyebrow{color:var(--gold)}
.hero .eyebrow::before{background:var(--gold)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:34px;margin-top:48px;flex-wrap:wrap}
.hero-stats .stat strong{font-family:var(--font-display);font-size:2rem;color:var(--gold);display:block}
.hero-stats .stat span{font-size:.78rem;color:#9fb0c8;letter-spacing:.12em;text-transform:uppercase}

.hero-visual{position:relative}
.hero-visual .frame{
  position:relative;border-radius:28px;overflow:hidden;
  box-shadow:var(--shadow-lg);transform:perspective(1200px) rotateY(-6deg) rotateX(2deg);
  background:#fff;
}
.hero-visual .frame img{width:100%;height:540px;object-fit:cover}
.hero-badge{
  position:absolute;left:-30px;bottom:30px;background:#fff;color:var(--blue);
  padding:18px 22px;border-radius:16px;display:flex;align-items:center;gap:14px;
  box-shadow:var(--shadow-md);animation:float 5s ease-in-out infinite;
}
.hero-badge .ico{width:46px;height:46px;border-radius:12px;background:var(--grad-red);display:grid;place-items:center;color:#fff;font-size:1.2rem}
.hero-badge strong{display:block;font-family:var(--font-display);font-size:1.1rem}
.hero-badge span{font-size:.75rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ============ SECTION GENERIC ============ */
section.block{padding:90px 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-head h2 em{color:var(--red);font-style:italic;font-weight:500}

/* ============ FEATURES ============ */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.feature{
  background:var(--surface);padding:30px 24px;border-radius:var(--radius);
  border:1px solid var(--line);transition:all .3s;text-align:left;
}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.feature .ico{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;color:#fff;
  font-size:1.3rem;margin-bottom:18px;background:var(--grad-red);
}
.feature:nth-child(2) .ico{background:var(--grad-blue)}
.feature:nth-child(3) .ico{background:var(--grad-gold);color:var(--blue)}
.feature:nth-child(4) .ico{background:linear-gradient(135deg,#16a34a,#0d6b32)}
.feature h3{font-size:1.1rem;margin-bottom:8px}
.feature p{font-size:.92rem;margin:0}

/* ============ PRODUCTS GRID ============ */
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.product-card{
  position:relative;background:var(--surface);border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);transition:all .35s ease;
  display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.product-card .img{
  aspect-ratio:4/3;overflow:hidden;background:linear-gradient(180deg,#eef2f8,#dde4ef);
  position:relative;
}
.product-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.product-card:hover .img img{transform:scale(1.08)}
.product-card .tag{
  position:absolute;top:14px;left:14px;background:#fff;color:var(--red);
  padding:6px 12px;border-radius:999px;font-size:.7rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;box-shadow:var(--shadow-sm);
}
.product-card .body{padding:24px}
.product-card h3{margin-bottom:10px;font-size:1.25rem}
.product-card p{font-size:.9rem;margin-bottom:16px}
.product-card .more{display:inline-flex;align-items:center;gap:6px;color:var(--red);font-weight:600;font-size:.88rem}
.product-card .more i{transition:transform .25s}
.product-card:hover .more i{transform:translateX(4px)}

/* ============ ABOUT SPLIT ============ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split .img-stack{position:relative}
.split .img-stack .main{border-radius:24px;overflow:hidden;box-shadow:var(--shadow-md);height:520px}
.split .img-stack .main img{width:100%;height:100%;object-fit:cover}
.split .img-stack .accent{
  position:absolute;right:-30px;bottom:-30px;width:55%;height:240px;border-radius:20px;
  overflow:hidden;border:6px solid #fff;box-shadow:var(--shadow-lg);
}
.split .img-stack .accent img{width:100%;height:100%;object-fit:cover}
.split ul.checks{list-style:none;padding:0;margin:24px 0}
.split ul.checks li{display:flex;gap:12px;margin-bottom:14px;font-size:.95rem;color:var(--ink)}
.split ul.checks i{color:#16a34a;font-size:1.1rem;margin-top:3px}

/* ============ CTA STRIP ============ */
.cta-strip{
  background:var(--grad-blue);color:#fff;border-radius:24px;padding:50px 56px;
  display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;
  position:relative;overflow:hidden;margin:0 24px;
}
.cta-strip::before{
  content:"";position:absolute;right:-100px;top:-100px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,179,1,.3),transparent 70%);
}
.cta-strip h2{color:#fff;margin:0}
.cta-strip p{color:#cfd9ea;margin:6px 0 0}

/* ============ TESTIMONIALS / SWIPER ============ */
.testimonials{background:linear-gradient(180deg,#fff,#eef3fa)}
.testi-swiper{padding-bottom:56px !important}
.testi-card{
  background:#fff;border-radius:20px;padding:34px;border:1px solid var(--line);
  height:100%;display:flex;flex-direction:column;gap:18px;
}
.testi-card .stars{color:var(--gold)}
.testi-card p{font-style:italic;font-size:1rem;color:var(--ink);margin:0;flex:1}
.testi-card .who{display:flex;align-items:center;gap:14px;border-top:1px solid var(--line);padding-top:18px}
.testi-card .who .av{width:48px;height:48px;border-radius:50%;background:var(--grad-blue);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--font-display)}
.testi-card .who strong{display:block;color:var(--blue)}
.testi-card .who small{color:var(--muted)}
.swiper-pagination-bullet-active{background:var(--red) !important}

/* ============ PAGE HERO ============ */
.page-hero{
  background:var(--grad-blue);color:#fff;padding:80px 0 100px;text-align:center;position:relative;overflow:hidden;
}
.page-hero::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px 300px at 50% 100%, rgba(227,6,19,.25), transparent 70%);
  pointer-events:none;
}
.page-hero h1{color:#fff;margin-bottom:14px}
.page-hero p{color:#cfd9ea;max-width:640px;margin:0 auto}
.crumbs{display:flex;justify-content:center;gap:8px;margin-top:18px;font-size:.85rem;color:#a8b8d2}
.crumbs a{color:var(--gold)}

/* ============ STATS BAND ============ */
.stats-band{background:var(--blue);color:#fff;padding:60px 0}
.stats-band .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stats-band .stat strong{font-family:var(--font-display);font-size:2.6rem;color:var(--gold);display:block}
.stats-band .stat span{letter-spacing:.14em;font-size:.78rem;text-transform:uppercase;color:#a8b8d2}

/* ============ TIMELINE (company profile) ============ */
.timeline{position:relative;padding-left:30px}
.timeline::before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--line)}
.tl-item{position:relative;margin-bottom:38px}
.tl-item::before{content:"";position:absolute;left:-29px;top:6px;width:18px;height:18px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px #fff,0 0 0 6px var(--red)}
.tl-item .y{font-family:var(--font-display);font-size:1.1rem;color:var(--red);font-weight:700}
.tl-item h4{margin:4px 0 6px;color:var(--blue);font-size:1.15rem;font-family:var(--font-display)}

/* ============ PROJECTS GRID ============ */
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.project{
  position:relative;border-radius:20px;overflow:hidden;height:320px;
  box-shadow:var(--shadow-sm);
}
.project img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.project:hover img{transform:scale(1.08)}
.project .overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;color:#fff;
  background:linear-gradient(180deg,rgba(0,0,0,0) 35%,rgba(0,0,0,.85));
}
.project .overlay span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.project .overlay h3{color:#fff;margin:6px 0 0;font-size:1.2rem}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:40px}
.contact-info{background:var(--grad-blue);color:#fff;border-radius:24px;padding:40px;position:relative;overflow:hidden}
.contact-info::after{content:"";position:absolute;right:-80px;bottom:-80px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(227,6,19,.4),transparent 70%)}
.contact-info h2{color:#fff}
.contact-info p{color:#cbd6e8}
.info-item{display:flex;gap:14px;margin-top:22px;position:relative;z-index:1}
.info-item .ico{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.1);display:grid;place-items:center;color:var(--gold);flex-shrink:0}
.info-item strong{display:block;font-family:var(--font-display);font-size:1rem}
.info-item small{color:#a8b8d2;font-size:.88rem}
.contact-social{display:flex;gap:12px;margin-top:30px;position:relative;z-index:1}
.contact-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:grid;place-items:center;transition:all .25s}
.contact-social a:hover{background:var(--red);transform:translateY(-3px)}

.contact-form{background:#fff;border-radius:24px;padding:40px;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.field input,.field textarea,.field select{
  width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:.95rem;background:#fafbfd;
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(227,6,19,.08);background:#fff}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ============ FOOTER ============ */
.footer{background:#06152b;color:#a8b8d2;padding:70px 0 0;margin-top:0}
.footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.footer h4{color:#fff;font-size:1rem;margin-bottom:18px;font-family:var(--font-body);font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.footer ul{list-style:none;padding:0;margin:0}
.footer ul li{margin-bottom:10px}
.footer a{transition:color .2s}
.footer a:hover{color:var(--gold)}
.footer .brand-foot img{height:50px;background:#fff;padding:6px 10px;border-radius:8px;margin-bottom:14px}
.footer .social{display:flex;gap:10px;margin-top:16px}
.footer .social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);display:grid;place-items:center;color:#fff;transition:all .25s}
.footer .social a:hover{background:var(--red);transform:translateY(-3px)}
.footer .copy{border-top:1px solid rgba(255,255,255,.08);margin-top:50px;padding:22px 0;text-align:center;font-size:.85rem}

/* ============ ANIMATIONS ============ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============ FLOATING SOCIAL SIDEBAR ============ */
.floating-social{
  position:fixed; right:14px; top:50%; transform:translateY(-50%);
  display:flex; flex-direction:column; gap:12px; z-index:1000;
}
.floating-social a{
  width:46px; height:46px; border-radius:50%;
  display:grid; place-items:center; color:#fff; font-size:1.15rem;
  box-shadow:0 8px 22px rgba(0,0,0,.18);
  transition:transform .25s ease, box-shadow .25s ease;
}
.floating-social a:hover{ transform:translateY(-3px) scale(1.06); box-shadow:0 12px 28px rgba(0,0,0,.28); }
.floating-social .fs-wa{ background:#25D366; }
.floating-social .fs-fb{ background:#1877F2; }
.floating-social .fs-ig{ background:radial-gradient(circle at 30% 110%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%); }
.floating-social .fs-in{ background:#0A66C2; }
.floating-social .fs-yt{ background:#FF0000; }
@media (max-width:520px){
  .floating-social{ right:10px; gap:10px; }
  .floating-social a{ width:40px; height:40px; font-size:1rem; }
}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .hero{padding:70px 0}
  .hero .container{grid-template-columns:1fr;gap:50px}
  .hero-visual .frame{transform:none}
  .hero-visual .frame img{height:420px}
  .features{grid-template-columns:repeat(2,1fr)}
  .products-grid,.projects-grid{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:80px}
  .split .img-stack .main{height:400px}
  .stats-band .grid{grid-template-columns:repeat(2,1fr);gap:36px}
  .footer .grid{grid-template-columns:1fr 1fr;gap:36px}
  .contact-grid{grid-template-columns:1fr}

   /* ============ MOBILE DRAWER MENU (BNS-style) ============ */
   .hamburger{display:grid;place-items:center;width:46px;height:46px;background:transparent;border:0;cursor:pointer;color:var(--blue);font-size:1.5rem;border-radius:10px;transition:background .2s}
   .hamburger:hover{background:rgba(10,37,64,.06)}
   body.menu-open{ overflow:hidden; }
   /* body.menu-open .floating-social{ display:none; } */
   .site-header{ z-index:1002; }

/* extraicons mobile view */
/* MOBILE FLOATING SOCIAL ICONS FIX */
/* =====================================
   FINAL FLOATING SOCIAL ICONS FIX
===================================== */

.floating-social{
  position:fixed !important;
  right:12px;
  bottom:20px;
  display:flex !important;
  flex-direction:column;
  gap:12px;
  z-index:999999 !important;
}

.floating-social a{
  width:48px;
  height:48px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:20px;
  text-decoration:none;
  box-shadow:0 10px 25px rgba(0,0,0,0.25);
}

/* COLORS */

.fs-wa{
  background:#25D366;
}

.fs-fb{
  background:#1877F2;
}

.fs-ig{
  background:linear-gradient(
      45deg,
      #feda75,
      #fa7e1e,
      #d62976,
      #962fbf,
      #4f5bd5
  );
}

.fs-in{
  background:#0A66C2;
}

/* MOBILE FIX */

@media (max-width:768px){

  .floating-social{
      top:auto !important;
      right:10px !important;
      bottom:20px !important;
      transform:none !important;
      display:flex !important;
      visibility:visible !important;
      opacity:1 !important;
  }

}





/* MOBILE SOCIAL ICONS SHOW FIX */

@media (max-width:768px){

  .floating-social{
      position:fixed !important;
      right:10px !important;
      top:50% !important;
      bottom:auto !important;
      transform:translateY(-50%) !important;

      display:flex !important;
      flex-direction:column !important;

      opacity:1 !important;
      visibility:visible !important;

      /* z-index:999999 !important; */
  }

}


/* REMOVE WHITE BACKGROUND */

.floating-social{
  background:transparent !important;
  padding:0 !important;
  box-shadow:none !important;
  border:none !important;
}

.floating-social a{
  box-shadow:0 10px 25px rgba(0,0,0,0.25);
}

/* extraicons mobile view */




   .menu-backdrop{
     position:fixed; inset:0; background:rgba(10,20,40,.55); backdrop-filter:blur(4px);
     opacity:0; visibility:hidden; transition:opacity .3s ease, visibility .3s ease;
     z-index:1002;
   }
   /* .menu-backdrop.open{ opacity:1; visibility:visible; } */

   /* Right-side slide-in drawer */
   .menu{
     position:fixed; top:0; right:0; height:100vh; height:100dvh;
     width:min(86vw, 380px);
     background:#ffffff;
     display:flex; flex-direction:column; align-items:stretch; gap:0;
     padding:80px 22px 30px;
     box-shadow:-20px 0 60px rgba(0,0,0,.25);
     transform:translateX(100%);
     transition:transform .42s cubic-bezier(.4,0,.2,1);
     z-index:1003; overflow-y:auto;
     visibility:hidden;
   }
   .menu.open{ transform:translateX(0); visibility:visible; }

   .menu .menu-close{
     position:absolute; top:18px; right:18px; width:42px; height:42px;
     display:grid; place-items:center; background:transparent; border:0;
     color:var(--blue); font-size:1.3rem; cursor:pointer; border-radius:10px;
     transition:background .2s, transform .2s;
   }
   .menu .menu-close:hover{ background:rgba(10,37,64,.06); transform:rotate(90deg); }

   .menu a{
     display:block; padding:16px 18px; border-radius:12px;
     color:var(--blue); font-size:1.02rem; font-weight:500;
     text-align:left; position:relative; margin-bottom:4px;
     opacity:0; transform:translateX(20px);
     transition:background .25s, color .25s, opacity .4s ease, transform .4s ease;
   }
   .menu a::after{ display:none; }
   .menu.open a{ opacity:1; transform:translateX(0); }
   .menu.open a:nth-child(2){ transition-delay:.08s }
   .menu.open a:nth-child(3){ transition-delay:.14s }
   .menu.open a:nth-child(4){ transition-delay:.2s }
   .menu.open a:nth-child(5){ transition-delay:.26s }
   .menu.open a:nth-child(6){ transition-delay:.32s }
   .menu.open a:nth-child(7){ transition-delay:.38s }
   .menu.open a:nth-child(8){ transition-delay:.44s }

   .menu a:hover{ background:#f7f1e3; color:var(--blue); }
   .menu a.active{
     background:#fdf6e6; color:var(--blue); font-weight:600;
   }
   .menu a.active::before{
     content:""; position:absolute; left:18px; bottom:8px;
     width:32px; height:3px; border-radius:3px; background:var(--gold);
   }
   .menu .btn{
     margin:18px 0 0; justify-content:center;
     color:#fff; background:var(--grad-red); padding:14px 22px;
     box-shadow:0 12px 26px rgba(227,6,19,.25);
   }
 }
@media (max-width:820px){
  .topbar .top-info{ gap:12px; font-size:.78rem; }
  .topbar .top-info span:nth-child(3){ display:none; }
  .cta-strip{ padding:40px 28px; text-align:center; justify-content:center; margin:0 16px; }
  .stats-band .grid{ grid-template-columns:repeat(2,1fr); }
  .projects-grid{ grid-template-columns:1fr; }
}
@media (max-width:720px){
  section.block{padding:56px 0}
  .container{ padding:0 18px; }
  .hero{ padding:56px 0 70px; }
  .hero h1{font-size:2rem}
  .hero p.lead{ font-size:1rem; }
  .hero-visual .frame img{ height:300px; }
  .hero-stats{ gap:20px; margin-top:30px; }
  .hero-stats .stat strong{ font-size:1.5rem; }
  .features{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .footer .grid{grid-template-columns:1fr;gap:30px}
  .split .img-stack .accent{width:65%;height:160px;right:-10px;bottom:-20px}
  .split .img-stack .main{height:280px}
  .split{ gap:60px; }
  .topbar .top-social{ display:none; }
  .topbar .top-info{ justify-content:center; width:100%; }
  .hero-badge{left:10px;bottom:10px;padding:10px 12px}
  .hero-badge .ico{width:36px;height:36px;font-size:1rem}
  .hero-badge strong{ font-size:.95rem; }
  .page-hero{ padding:60px 0 70px; }
  .contact-info, .contact-form{ padding:28px 22px; }
  .cta-strip h2{ font-size:1.4rem; }

  /* Mobile product slider — horizontal scroll-snap */
  .products-grid{
    grid-template-columns:none;
    display:flex;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    gap:16px;
    padding:4px 18px 24px;
    margin:0 -18px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .products-grid::-webkit-scrollbar{ display:none; }
  .products-grid > .product-card{
    flex:0 0 80%;
    max-width:300px;
    scroll-snap-align:center;
  }
  .products-grid > .product-card .img{ aspect-ratio:4/3; }

  /* Floating social — keep clear of CTA strip */
  .floating-social{ top:auto; bottom:18px; transform:none; flex-direction:row; right:50%; transform:translateX(50%); background:rgba(255,255,255,.95); padding:8px 10px; border-radius:999px; box-shadow:0 10px 30px rgba(0,0,0,.18); }
}
@media (max-width:420px){
  .brand img{ height:auto; max-height:38px; max-width:calc(100vw - 110px); }
  .nav{ padding:10px 0; gap:8px; }
  .menu{ width:min(92vw, 340px); padding:74px 18px 24px; }
}

/* ============ PRODUCT SLIDER (homepage) ============ */
.product-slider{ position:relative; padding:0 8px; }
.products-swiper{ overflow:hidden; padding:8px 4px 56px; }
.products-swiper .swiper-slide{ height:auto; display:flex; }
.products-swiper .swiper-slide .product-card{ width:100%; }
.products-swiper .swiper-pagination-bullet{ background:var(--blue); opacity:.25; }
.products-swiper .swiper-pagination-bullet-active{ background:var(--red); opacity:1; width:24px; border-radius:6px; transition:all .3s; }
.slider-btn{
  position:absolute; top:42%; transform:translateY(-50%); z-index:5;
  width:52px; height:52px; border-radius:50%; background:#fff; color:var(--red);
  display:grid; place-items:center; font-size:1.1rem;
  box-shadow:0 12px 30px rgba(10,37,64,.18); border:1px solid var(--line);
  transition:all .25s ease;
}
.slider-btn:hover{ background:var(--red); color:#fff; transform:translateY(-50%) scale(1.08); box-shadow:0 18px 40px rgba(227,6,19,.35); }
.slider-prev{ left:-10px; }
.slider-next{ right:-10px; }
.slider-btn.swiper-button-disabled{ opacity:.35; cursor:not-allowed; }
@media (max-width:720px){
  .slider-btn{ width:42px; height:42px; font-size:.95rem; }
  .slider-prev{ left:4px; }
  .slider-next{ right:4px; }
}

/* ============ BRAND BADGES MARQUEE ============ */
.badges-strip{
  background:linear-gradient(135deg,#ffffff,#f4f7fc);
  border:1px solid var(--line); border-radius:24px;
  padding:30px 0; overflow:hidden; position:relative;
  box-shadow:var(--shadow-sm);
}
.badges-strip::before, .badges-strip::after{
  content:""; position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none;
}
.badges-strip::before{ left:0; background:linear-gradient(90deg,#ffffff,transparent); }
.badges-strip::after{ right:0; background:linear-gradient(-90deg,#ffffff,transparent); }
.badges-track{
  display:flex; gap:56px; align-items:center;
  width:max-content; animation:badgesScroll 32s linear infinite;
}
.badge-item{
  display:flex; flex-direction:column; align-items:center; gap:10px;
  min-width:120px;
}
.badge-item img{
  height:64px; width:64px; object-fit:contain;
  filter:drop-shadow(0 6px 14px rgba(10,37,64,.15));
  transition:transform .35s ease;
}
.badge-item span{
  font-size:.72rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--blue); white-space:nowrap;
}
.badge-item:hover img{ transform:translateY(-4px) scale(1.06); }
.badges-strip:hover .badges-track{ animation-play-state:paused; }
@keyframes badgesScroll{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}
@media (max-width:720px){
  .badges-strip{ padding:22px 0; border-radius:18px; }
  .badges-strip::before, .badges-strip::after{ width:60px; }
  .badge-item{ min-width:90px; gap:6px; }
  .badge-item img{ height:48px; width:48px; }
  .badge-item span{ font-size:.62rem; letter-spacing:.1em; }
  .badges-track{ gap:32px; animation-duration:24s; }
}

/* Hamburger only visible at <=1024px */
.hamburger{ display:none; }
@media (max-width:1024px){
  .hamburger{ display:grid !important; place-items:center; width:46px; height:46px; }
}




/* Video layout — see css/video-layout.css */
/* clickable promoter */
.site-footer {
  text-align: center;
  padding: 20px;
  background: #0b1f2a;
  color: #ffffff;
  font-family: Arial, sans-serif;
  font-size: 15px;
}

.site-footer a {
  color: #f4b400;
  text-decoration: none;
  font-weight: 600;
}

.site-footer a:hover {
  text-decoration: underline;
}
