/* ============================================================
   BagsFactori main stylesheet
   Extracted from the approved preview + theme additions.
   Brand colors/tokens are in :root below — edit there.
   ============================================================ */

:root{
  --green:#10A66A; --green-dark:#0C8253; --green-light:#E7F6EF;
  --black:#111111; --grey:#333333; --grey-mid:#6B7280;
  --bg:#F5F7F8; --white:#FFFFFF; --navy:#0B1F33; --line:#E3E7EA;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--grey);background:var(--white);font-size:16px;line-height:1.65}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;color:var(--black);line-height:1.2}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;cursor:pointer}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;font-family:'Poppins';font-weight:600;font-size:15px;border-radius:6px;border:none;cursor:pointer;transition:all .18s;white-space:nowrap}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-dark);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--black);border:2px solid var(--black)}
.btn-outline:hover{background:var(--black);color:#fff}
.btn-white{background:#fff;color:var(--green-dark)}
.btn-white:hover{transform:translateY(-1px)}
.btn-lg{padding:16px 32px;font-size:16px}
.eyebrow{display:inline-block;font-family:'Poppins';font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:10px}
.section{padding:84px 0}
.section.tint{background:var(--bg)}
.section-head{max-width:660px;margin:0 auto 48px;text-align:center}
.section-head h2{font-size:clamp(26px,3.4vw,38px);font-weight:700;margin-bottom:12px}
.section-head p{color:var(--grey-mid);font-size:16.5px}

/* IMAGE PLACEHOLDER — realistic labeled, not AI art */
.imgph{background:linear-gradient(135deg,#EEF2F4 0%,#E4EAED 100%);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--grey-mid);padding:20px;position:relative;overflow:hidden}
.imgph::before{content:"";position:absolute;inset:0;background-image:linear-gradient(45deg,rgba(255,255,255,.5) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.5) 50%,rgba(255,255,255,.5) 75%,transparent 75%);background-size:18px 18px;opacity:.35}
.imgph .ico{font-size:26px;margin-bottom:8px;position:relative;z-index:1;opacity:.6}
.imgph .cap{font-size:12px;font-weight:500;position:relative;z-index:1;max-width:90%;line-height:1.4}
.imgph .tagimg{position:absolute;top:8px;left:8px;background:rgba(17,17,17,.62);color:#fff;font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;padding:3px 7px;border-radius:4px;z-index:2;font-weight:600}

/* TOP BAR */
.topbar{background:var(--navy);color:#C7D2DC;font-size:13px}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar a:hover{color:#fff}
.topbar .left{display:flex;gap:22px;flex-wrap:wrap}

/* NAV */
.nav{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:90}
.nav .container{display:flex;align-items:center;justify-content:space-between;height:80px;gap:16px}
.nav img.logo{height:50px;width:auto}
.nav-links{display:flex;gap:24px;font-size:15px;font-weight:500;color:var(--grey)}
.nav-links a{padding:8px 0;border-bottom:2px solid transparent;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--green);border-color:var(--green)}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-cta .wa{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:14px;color:var(--green-dark);white-space:nowrap}
.nav-cta .btn{padding:11px 20px;font-size:14px}
.burger{display:none;font-size:26px;background:none;border:none;cursor:pointer;color:var(--black)}

/* PAGE SWITCHING */


@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* HERO */
.hero{background:linear-gradient(180deg,#FFFFFF 0%,#F2F7F4 100%);border-bottom:1px solid var(--line);overflow:hidden}
.hero .container{display:grid;grid-template-columns:1.04fr .96fr;gap:50px;padding-top:66px;padding-bottom:66px;align-items:center}
.hero .pills{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.hero .pill{background:var(--green-light);color:var(--green-dark);font-size:12.5px;font-weight:600;padding:6px 14px;border-radius:99px}
.hero h1{font-size:clamp(32px,4.4vw,50px);font-weight:800;letter-spacing:-.01em}
.hero h1 span{color:var(--green)}
.hero .sub{margin:18px 0 28px;font-size:17px;color:var(--grey-mid);max-width:500px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-trust{display:flex;gap:22px;margin-top:30px;padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-trust div{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--grey)}
.hero-trust .tick{color:var(--green);font-weight:700}
.hero-visual{position:relative}
.hero-visual .imgph{aspect-ratio:1/1.04;border-radius:12px}
.badge-float{position:absolute;background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 15px;font-size:13px;font-weight:600;color:var(--black);box-shadow:0 10px 30px rgba(11,31,51,.10);display:flex;gap:10px;align-items:center;z-index:3}
.badge-float small{display:block;font-weight:400;color:var(--grey-mid);font-size:11.5px}
.badge-float.a{top:16px;right:-12px}
.badge-float.b{bottom:24px;left:-12px}
.badge-float .ic{width:34px;height:34px;border-radius:8px;background:var(--green-light);color:var(--green-dark);display:flex;align-items:center;justify-content:center;font-size:16px}

/* TRUST STRIP */
.trust{background:var(--navy);color:#fff;padding:20px 0}
.trust .container{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.trust .t{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:500}
.trust .t b{color:#3ED598}

/* PRODUCT GRID */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:20px}
.cat{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:all .18s;display:flex;flex-direction:column}
.cat:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(11,31,51,.10);border-color:var(--green)}
.cat .imgph{aspect-ratio:16/11}
.cat .body{padding:18px 20px;flex:1;display:flex;flex-direction:column}
.cat h3{font-size:16.5px;font-weight:600;margin-bottom:5px}
.cat p{font-size:13.5px;color:var(--grey-mid);flex:1}
.cat .meta{display:flex;justify-content:space-between;align-items:center;margin-top:14px;font-size:12.5px}
.cat .moq{background:var(--green-light);color:var(--green-dark);font-weight:600;padding:3px 11px;border-radius:99px}
.cat .lnk{color:var(--green);font-weight:600}

/* OEM */
.oem{background:var(--navy);color:#fff}
.oem .section-head h2{color:#fff}.oem .section-head p{color:#9FB0BE}
.oem-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.oem-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:26px}
.oem-card .n{font-family:'Poppins';font-weight:700;font-size:13px;color:#3ED598;margin-bottom:12px;letter-spacing:.05em}
.oem-card h3{color:#fff;font-size:17px;font-weight:600;margin-bottom:8px}
.oem-card p{font-size:13.5px;color:#9FB0BE}
.oem-cta{text-align:center;margin-top:40px}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.why-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:28px}
.why-card .ic{width:46px;height:46px;border-radius:10px;background:var(--green-light);color:var(--green-dark);display:flex;align-items:center;justify-content:center;font-size:21px;margin-bottom:16px}
.why-card h3{font-size:17px;font-weight:600;margin-bottom:8px}
.why-card p{font-size:14px;color:var(--grey-mid)}

/* INDUSTRIES */
.ind-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(232px,1fr));gap:14px}
.ind{background:#fff;border:1px solid var(--line);border-radius:10px;padding:20px;display:flex;gap:14px;align-items:center;transition:all .15s}
.ind:hover{border-color:var(--green);box-shadow:0 8px 22px rgba(11,31,51,.07)}
.ind .ic{width:42px;height:42px;border-radius:9px;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.ind b{font-family:'Poppins';font-size:14px;font-weight:600;color:var(--black);display:block}
.ind span{font-size:12px;color:var(--grey-mid)}

/* PROCESS */
.proc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;counter-reset:p}
.proc{background:#fff;border:1px solid var(--line);border-radius:10px;padding:22px 18px;position:relative}
.proc::before{counter-increment:p;content:counter(p,decimal-leading-zero);font-family:'Poppins';font-weight:800;font-size:30px;color:#E2EFE9;position:absolute;top:10px;right:14px}
.proc h3{font-size:14.5px;font-weight:600;margin-bottom:6px;padding-top:6px}
.proc p{font-size:12.5px;color:var(--grey-mid)}
.proc .tm{display:inline-block;margin-top:10px;font-size:11.5px;font-weight:600;color:var(--green-dark);background:var(--green-light);padding:2px 9px;border-radius:99px}

/* SAMPLE BANNER */
.sample{background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);color:#fff;border-radius:14px;padding:46px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.sample h2{color:#fff;font-size:clamp(22px,2.8vw,30px);font-weight:700;margin-bottom:8px}
.sample p{opacity:.95;max-width:560px}

/* FAQ */
.faq{max-width:760px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:10px;overflow:hidden}
.faq summary{padding:18px 22px;font-family:'Poppins';font-weight:600;font-size:15px;color:var(--black);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:20px;color:var(--green)}
.faq details[open] summary::after{content:"–"}
.faq .ans{padding:0 22px 18px;font-size:14.5px;color:var(--grey-mid)}

/* QUOTE FORM */
.quote{background:var(--navy)}
.quote .section-head h2{color:#fff}.quote .section-head p{color:#9FB0BE}
.qwrap{max-width:980px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:24px;align-items:start}
.qside{color:#fff;padding:10px}
.qside h3{color:#fff;font-size:20px;margin-bottom:14px}
.qside .qrow{display:flex;gap:12px;align-items:flex-start;margin-bottom:18px}
.qside .qrow .ic{width:38px;height:38px;border-radius:9px;background:rgba(62,213,152,.16);color:#3ED598;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:17px}
.qside .qrow b{color:#fff;display:block;font-family:'Poppins';font-size:14.5px}
.qside .qrow span{font-size:13px;color:#9FB0BE}
.qform{background:#fff;border-radius:14px;padding:32px;display:grid;grid-template-columns:1fr 1fr;gap:15px}
.qform label{font-size:13px;font-weight:600;color:var(--black);display:block;margin-bottom:6px;font-family:'Poppins'}
.qform input,.qform select,.qform textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:7px;font-family:'Inter';font-size:14px;background:var(--bg);color:var(--grey)}
.qform input:focus,.qform select:focus,.qform textarea:focus{outline:2px solid var(--green);background:#fff}
.qform .full{grid-column:1/-1}
.qform .btn{grid-column:1/-1;justify-self:start}
.qnote{grid-column:1/-1;font-size:12.5px;color:var(--grey-mid);text-align:center;margin-top:-4px}

/* PRODUCT DETAIL PAGE */
.pd-hero{display:grid;grid-template-columns:1fr 1fr;gap:36px;padding-top:48px;padding-bottom:48px;align-items:start}
.pd-gallery{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pd-gallery .imgph:first-child{grid-column:1/-1;aspect-ratio:16/11;border-radius:10px}
.pd-gallery .imgph{aspect-ratio:1/1;border-radius:8px}
.pd-info h1{font-size:clamp(26px,3vw,36px);font-weight:800;margin-bottom:14px}
.pd-info .lead{font-size:16px;color:var(--grey-mid);margin-bottom:22px}
.pd-specbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.pd-specbar .chip{background:var(--green-light);color:var(--green-dark);font-size:13px;font-weight:600;padding:7px 14px;border-radius:99px}
.pd-feat{list-style:none;margin:0 0 24px}
.pd-feat li{padding:8px 0 8px 28px;position:relative;font-size:14.5px;border-bottom:1px solid var(--line)}
.pd-feat li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:700}
.pd-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.spec-table{width:100%;border-collapse:collapse;margin-top:10px;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.spec-table td{padding:13px 18px;border-bottom:1px solid var(--line);font-size:14px}
.spec-table tr:last-child td{border-bottom:none}
.spec-table td:first-child{font-weight:600;color:var(--black);font-family:'Poppins';width:38%;background:var(--bg)}

/* BREADCRUMB */
.crumb{background:var(--bg);border-bottom:1px solid var(--line);font-size:13px;color:var(--grey-mid)}
.crumb .container{padding-top:12px;padding-bottom:12px}
.crumb a:hover{color:var(--green)}
.crumb b{color:var(--grey)}

/* FOOTER */
.footer{background:#0A1826;color:#9FB0BE;padding:62px 0 0;font-size:14px}
.footer h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:16px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:38px;padding-bottom:42px}
.footer a{display:block;padding:4px 0}
.footer a:hover{color:#fff}
.footer img.logo{height:44px;width:auto;background:#fff;border-radius:8px;padding:6px 12px}
.footer .desc{margin-top:14px;font-size:13.5px;line-height:1.7}
.footer-bottom{border-top:1px solid #1B2C3D;padding:18px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12.5px}

/* WHATSAPP FLOAT */
.wa-float{position:fixed;bottom:22px;right:22px;background:#25D366;color:#fff;border-radius:99px;padding:13px 20px;display:flex;align-items:center;gap:9px;font-family:'Poppins';font-weight:600;font-size:14px;box-shadow:0 10px 28px rgba(0,0,0,.25);z-index:100;transition:transform .15s}
.wa-float:hover{transform:scale(1.05)}

/* MOBILE MENU */
.mobile-menu{display:none;position:fixed;inset:0;background:var(--navy);z-index:200;padding:30px 24px;flex-direction:column}
.mobile-menu.open{display:flex}
.mobile-menu .close{align-self:flex-end;font-size:30px;background:none;border:none;color:#fff;cursor:pointer}
.mobile-menu a{color:#fff;font-family:'Poppins';font-weight:600;font-size:20px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.mobile-menu .btn{margin-top:20px}

@media(max-width:920px){
  .hero .container,.pd-hero{grid-template-columns:1fr}
  .nav-links,.nav-cta .wa,.nav-cta .btn-outline{display:none}
  .burger{display:block}
  .qwrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .qform{grid-template-columns:1fr;padding:22px}
  .footer-grid{grid-template-columns:1fr}
  .hero-trust{gap:12px}
  .section{padding:60px 0}
  .pd-gallery{grid-template-columns:1fr 1fr}
}

/* PREVIEW HELPER BAR */
.preview-bar{background:#111;color:#fff;font-size:12.5px;text-align:center;padding:7px 14px;font-family:'Poppins';letter-spacing:.02em}
.preview-bar span{color:#3ED598;font-weight:600}

/* ===== THEME ADDITIONS (page hero, blog, WP bits) ===== */
.page-hero{background:linear-gradient(180deg,#FFFFFF 0%,#F2F7F4 100%);border-bottom:1px solid var(--line);padding:50px 0 44px}
.page-hero h1{font-size:clamp(28px,3.6vw,42px);font-weight:800;letter-spacing:-.01em}
.page-hero .post-meta,.archive-desc{color:var(--grey-mid);font-size:14px;margin-top:10px}
.page-content{max-width:820px;margin:0 auto;font-size:16.5px}
.page-content h2{font-size:26px;margin:34px 0 12px}
.page-content h3{font-size:20px;margin:26px 0 10px}
.page-content p{margin-bottom:16px}
.page-content ul,.page-content ol{margin:0 0 16px 22px}
.page-content li{margin-bottom:7px}
.page-content img{border-radius:10px;margin:18px 0}
.page-content table{width:100%;border-collapse:collapse;margin:18px 0;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.page-content td,.page-content th{padding:12px 16px;border-bottom:1px solid var(--line);font-size:14.5px;text-align:left}
.page-content th{background:var(--bg);font-family:'Poppins';font-weight:600;color:var(--black)}
.page-cta{max-width:980px;margin:48px auto 0}
.post-thumb{max-width:900px;margin:0 auto 28px}
.post-thumb img{border-radius:12px;width:100%}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:all .18s}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(11,31,51,.10)}
.blog-thumb img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.blog-thumb .imgph-fallback{aspect-ratio:16/10;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--grey-mid);font-family:'Poppins';font-weight:600}
.blog-body{padding:20px}
.blog-body h3{font-size:18px;margin-bottom:6px}
.blog-body h3 a:hover{color:var(--green)}
.blog-body .lnk{color:var(--green);font-weight:600;font-size:14px;display:inline-block;margin-top:8px}
.pagination{margin-top:36px;display:flex;justify-content:center}
.pagination .page-numbers{padding:9px 15px;border:1px solid var(--line);border-radius:6px;margin:0 4px;font-weight:600;color:var(--grey)}
.pagination .current{background:var(--green);color:#fff;border-color:var(--green)}
.aligncenter{margin-left:auto;margin-right:auto;display:block}
.alignleft{float:left;margin:0 20px 14px 0}
.alignright{float:right;margin:0 0 14px 20px}
.wp-caption-text{font-size:13px;color:var(--grey-mid);text-align:center}
.footer-inline{list-style:none;display:inline-flex;gap:14px;margin:0;padding:0}
.error-404 h1{font-size:clamp(32px,5vw,52px)}
/* WP makes nav menu a <ul>; ensure our nav styles apply to li>a */
.nav-links li{list-style:none}
.mobile-links{list-style:none;display:flex;flex-direction:column;width:100%}
.mobile-links li a,.mobile-menu .mobile-links a{color:#fff;font-family:'Poppins';font-weight:600;font-size:20px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1);display:block}

/* ===== PRODUCTS DROPDOWN MENU (WordPress sub-menu) ===== */
.nav-links{position:relative}
.nav-links .menu-item-has-children{position:relative}
.nav-links .sub-menu{
  position:absolute;top:100%;left:0;min-width:280px;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:0 16px 40px rgba(11,31,51,.12);
  padding:8px;margin:0;list-style:none;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:all .18s;z-index:100
}
.nav-links .menu-item-has-children:hover > .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-links .sub-menu li{list-style:none;border:none}
.nav-links .sub-menu li a{
  display:block;padding:10px 14px;border-radius:7px;font-size:14.5px;
  color:var(--grey);border-bottom:none;white-space:nowrap
}
.nav-links .sub-menu li a:hover{background:var(--green-light);color:var(--green-dark)}
.nav-links .menu-item-has-children > a::after{content:" \25BE";font-size:11px;color:var(--grey-mid)}

/* mobile: show submenu inline */
@media(max-width:920px){
  .nav-links .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding-left:16px;min-width:auto}
  .mobile-links .sub-menu{padding-left:16px}
}

/* ===== QC FIXES: button alignment + equal-height cards ===== */
/* All buttons same height regardless of label length */
.btn{min-height:50px;line-height:1.2}
.btn-lg{min-height:56px}
/* Hero CTA buttons align to same baseline */
.hero-ctas{align-items:stretch}
.hero-ctas .btn{display:inline-flex;align-items:center}
/* Product cards equal height in a row */
.cat-grid{align-items:stretch}
.cat{height:100%}
/* Elementor: make columns in a row equal height so cards align */
.elementor-row{align-items:stretch}
.elementor-column .elementor-column-wrap{height:100%}
/* consistent icon-box spacing */
.elementor-widget-icon-box .elementor-icon-box-icon{margin-bottom:14px}

/* ============================================================
   ELEMENTOR NATIVE-WIDGET STYLES (bf-* classes)
   These style the native Heading/Text/Button/Image/Icon-Box
   widgets in the imported homepage template, so the design
   matches the approved preview while widgets stay editable.
   ============================================================ */

/* Section width + padding (balanced, not narrow, not stretched) */
.elementor-section.elementor-section-boxed > .elementor-container{max-width:1320px}
.bf-hero, .bf-trust, .bf-cats, .bf-feat, .bf-oem-row, .bf-inds, .bf-mats, .bf-procs, .bf-whys, .bf-faq-sec, .bf-quote-sec, .bf-sec-head-only{padding-left:24px;padding-right:24px}

/* Section heads */
.bf-sec-head-only{padding-top:70px;padding-bottom:0}
.bf-sec-h2 .elementor-heading-title{font-family:'Poppins';font-weight:700;font-size:clamp(26px,3.4vw,38px);color:var(--black)}
.bf-sec-sub .elementor-text-editor{color:var(--grey-mid);font-size:16.5px;max-width:640px;margin:8px auto 0}
.bf-white .elementor-heading-title{color:#fff !important}
.bf-muted .elementor-text-editor{color:#9FB0BE !important}
.bf-center{text-align:center}
.bf-center .elementor-widget-container{display:flex;justify-content:center}

/* Backgrounds */
.bf-navy{background:var(--navy)}
.bf-tint, .bf-tint-sec{background:var(--bg)}
.bf-navy .bf-sec-h2 .elementor-heading-title{color:#fff}

/* HERO */
.bf-hero{background:linear-gradient(180deg,#FFFFFF 0%,#F2F7F4 100%);border-bottom:1px solid var(--line);padding-top:64px;padding-bottom:64px}
.bf-pills-wrap .pills{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.bf-pills-wrap .pill{background:var(--green-light);color:var(--green-dark);font-size:12.5px;font-weight:600;padding:6px 14px;border-radius:99px}
.bf-hero-h1 .elementor-heading-title{font-family:'Poppins';font-weight:800;font-size:clamp(32px,4.4vw,50px);line-height:1.07;letter-spacing:-.01em;color:var(--black)}
.bf-hero-sub .elementor-text-editor{font-size:17px;color:var(--grey-mid);max-width:500px;margin:18px 0 0}
.bf-hero-btns{margin-top:26px}
.bf-hero-btns .elementor-column{width:auto !important}
.bf-hero-img img{border-radius:12px;width:100%;border:2px dashed #D5DBDF}

/* Buttons — force equal height/padding/alignment (fixes your complaint) */
.btn .elementor-button, a.btn, .elementor-button.btn{
  display:inline-flex !important;align-items:center;justify-content:center;
  font-family:'Poppins';font-weight:600;font-size:15px;border-radius:6px;
  padding:14px 28px !important;line-height:1.2;border:none;transition:all .18s;height:auto
}
.btn-lg .elementor-button{padding:16px 32px !important;font-size:16px}
.btn-green .elementor-button{background:var(--green);color:#fff}
.btn-green .elementor-button:hover{background:var(--green-dark)}
.btn-outline .elementor-button{background:transparent;color:var(--black);border:2px solid var(--black)}
.btn-outline .elementor-button:hover{background:var(--black);color:#fff}
.btn-white .elementor-button{background:#fff;color:var(--green-dark)}
/* make every button row align buttons to a consistent baseline */
.bf-card .elementor-widget-button{margin-top:auto}

/* TRUST STRIP */
.bf-trust{background:var(--navy);padding-top:20px;padding-bottom:20px}
.bf-trust .trust-inner{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.bf-trust .t{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:500;color:#fff}
.bf-trust .t b{color:#3ED598}

/* CARDS — equal height + consistent spacing (category & featured) */
.bf-cats, .bf-feat{padding-top:30px;padding-bottom:88px;display:flex}
.bf-cats > .elementor-container, .bf-feat > .elementor-container{gap:20px;align-items:stretch}
.bf-card{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:all .18s;display:flex !important;flex-direction:column;padding:0 !important}
.bf-card:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(11,31,51,.10);border-color:var(--green)}
.bf-card > .elementor-widget-wrap{height:100%;display:flex;flex-direction:column;padding:0}
.bf-card-img img{width:100%;aspect-ratio:16/11;object-fit:cover;border:none;border-bottom:1px solid var(--line);border-radius:0}
.bf-card-title{padding:16px 18px 0}
.bf-card-title .elementor-heading-title{font-size:16.5px;font-weight:600;color:var(--black)}
.bf-card-desc{padding:4px 18px 0}
.bf-card-desc .elementor-text-editor{font-size:13.5px;color:var(--grey-mid)}
.bf-card .elementor-widget-button{padding:14px 18px 18px;margin-top:auto}
.bf-card .btn-outline .elementor-button{width:100%;border-width:1.5px;padding:10px !important;font-size:13.5px}

/* OEM */
.bf-navy.bf-sec-head-only{padding-top:84px}
.bf-oem-row{padding-top:30px;padding-bottom:20px}
.bf-oem-row > .elementor-container{gap:18px;align-items:stretch}
.bf-oem-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:10px}
.bf-oem-iconbox .elementor-icon-box-icon{margin-bottom:12px}
.bf-oem-iconbox .elementor-icon{color:#3ED598;font-size:26px}
.bf-oem-iconbox .elementor-icon-box-title{color:#fff;font-size:17px;font-weight:600}
.bf-oem-iconbox .elementor-icon-box-description{color:#9FB0BE;font-size:13.5px}
.bf-oem-cta-sec{padding-bottom:84px;padding-top:20px}

/* INDUSTRIES + WHY + general icon boxes — brand colors */
.bf-inds, .bf-whys{padding-top:30px;padding-bottom:88px}
.bf-inds > .elementor-container, .bf-whys > .elementor-container{gap:14px;align-items:stretch}
.bf-ind-card, .bf-why-card{background:#fff;border:1px solid var(--line);border-radius:10px;transition:all .15s}
.bf-ind-card:hover, .bf-why-card:hover{border-color:var(--green);box-shadow:0 8px 22px rgba(11,31,51,.07)}
.bf-ind-iconbox .elementor-icon, .bf-why-iconbox .elementor-icon{
  background:var(--green-light);color:var(--green-dark);width:46px;height:46px;
  border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:20px
}
.bf-ind-iconbox .elementor-icon-box-title, .bf-why-iconbox .elementor-icon-box-title{font-size:15px;font-weight:600;color:var(--black)}
.bf-why-iconbox .elementor-icon-box-description{font-size:13.5px;color:var(--grey-mid)}

/* MATERIALS */
.bf-mats{padding-top:30px;padding-bottom:88px}
.bf-mats > .elementor-container{gap:16px;align-items:stretch}
.bf-mat-card{background:#fff;border-radius:10px;padding:22px}
.bf-mat-t .elementor-heading-title{font-family:'Poppins';font-size:14.5px;font-weight:600;color:var(--black)}
.bf-mat-d .elementor-text-editor{font-size:13px;color:var(--grey-mid);margin-top:6px}

/* PROCESS */
.bf-procs{padding-top:30px;padding-bottom:88px}
.bf-procs > .elementor-container{gap:14px;align-items:stretch}
.bf-proc-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:22px 18px}
.bf-proc-t .elementor-heading-title{font-size:14.5px;font-weight:600;color:var(--black)}
.bf-proc-d .elementor-text-editor{font-size:12.5px;color:var(--grey-mid);margin-top:6px}

/* SAMPLE BANNER */
.bf-sample-sec{background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);border-radius:14px;max-width:1320px;margin:0 auto 88px;padding:48px !important;align-items:center}
.bf-sample-h .elementor-heading-title{color:#fff;font-size:clamp(22px,2.8vw,32px);font-weight:700}
.bf-sample-p .elementor-text-editor{color:#fff;opacity:.95;margin-top:8px}
.bf-sample-btn{display:flex;align-items:center;justify-content:flex-end}

/* FAQ accordion → brand styling */
.bf-faq-sec{padding-bottom:88px}
.bf-faq{max-width:760px;margin:0 auto}
.bf-faq .elementor-accordion-item{background:#fff;border:1px solid var(--line) !important;border-radius:10px;margin-bottom:10px;overflow:hidden}
.bf-faq .elementor-tab-title{font-family:'Poppins';font-weight:600;font-size:15px;color:var(--black);padding:18px 22px}
.bf-faq .elementor-tab-content{font-size:14.5px;color:var(--grey-mid);padding:0 22px 18px}
.bf-faq .elementor-accordion-icon{color:var(--green)}

/* QUOTE SECTION */
.bf-quote-sec{padding-top:70px;padding-bottom:84px}
.bf-form-note{max-width:600px;margin:0 auto 20px;background:rgba(255,255,255,.07);border:1px dashed rgba(255,255,255,.25);border-radius:10px;padding:16px 20px;color:#C7D2DC;font-size:14px;text-align:center}

/* RESPONSIVE */
@media(max-width:1024px){
  .bf-cats > .elementor-container > .bf-card, .bf-feat > .elementor-container > .bf-card,
  .bf-inds > .elementor-container > .bf-ind-card, .bf-whys > .elementor-container > .bf-why-card,
  .bf-mats > .elementor-container > .bf-mat-card{width:calc(50% - 10px) !important}
  .bf-oem-row > .elementor-container > .bf-oem-card{width:calc(50% - 9px) !important}
}
@media(max-width:767px){
  .bf-hero > .elementor-container{flex-direction:column}
  .bf-hero .elementor-column{width:100% !important}
  .bf-cats > .elementor-container > .bf-card, .bf-feat > .elementor-container > .bf-card,
  .bf-inds > .elementor-container > .bf-ind-card, .bf-whys > .elementor-container > .bf-why-card,
  .bf-mats > .elementor-container > .bf-mat-card, .bf-procs .bf-proc-card,
  .bf-oem-row > .elementor-container > .bf-oem-card{width:100% !important}
  .bf-trust .trust-inner{justify-content:flex-start;gap:10px 18px}
  .bf-sample-sec{padding:30px !important}
  .bf-sample-btn{justify-content:flex-start;margin-top:18px}
  .bf-sec-head-only{padding-top:50px}
}

/* ============================================================
   MOBILE HEADER FIXES (logo, overlap, scrollable menu)
   ============================================================ */
@media(max-width:920px){
  .topbar .topbar-note{display:none}                 /* hide tagline on mobile */
  .topbar .left{gap:14px;font-size:12px}
  .nav .container{height:64px;gap:10px}
  .nav img.logo{height:38px !important;width:auto !important;max-width:140px}  /* logo never squeezed */
  .nav-cta .wa{display:none}                          /* free up space */
  .nav-cta .btn{padding:9px 14px;font-size:13px}
  .burger{display:block;font-size:26px;background:none;border:none;cursor:pointer;color:var(--black);line-height:1}
}
@media(max-width:920px){
  .mobile-menu{
    display:none;position:fixed;inset:0;background:var(--navy);z-index:9999;
    padding:24px;flex-direction:column;
    max-height:100vh;overflow-y:auto;-webkit-overflow-scrolling:touch;  /* scrollable */
  }
  .mobile-menu.open{display:flex}
  .mobile-menu .close{align-self:flex-end;font-size:34px;background:none;border:none;color:#fff;cursor:pointer;line-height:1;margin-bottom:8px}
  .mobile-menu a{color:#fff;font-family:'Poppins';font-weight:600;font-size:18px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.1);display:block}
  .mobile-menu .sub-menu{list-style:none;padding-left:14px}
  .mobile-menu .sub-menu a{font-size:15.5px;font-weight:500;color:#C7D2DC}
}
/* prevent horizontal scroll anywhere */
html,body{overflow-x:hidden;max-width:100%}
