/* ================================================================
   MABATI PRO v4.0 — Premium Stylesheet
   Apple/Amazon blog | Fixed carousel | Perfect CTA | All screens
   ================================================================ */
:root{--navy:#0F2A44;--blue:#1B3F8B;--red:#E8192C;--red-dark:#C01020;--red-light:#FFF0F1;--off:#F8F9FB;--off2:#EEF1F5;--border:#E2E6EC;--gray:#8A94A6;--gray-dk:#4A5568;--text:#1A202C;--font-h:'Barlow Condensed',sans-serif;--font-b:'DM Sans',sans-serif;--r:10px;--r-sm:6px;--r-lg:16px;--r-xl:24px;--sh-sm:0 1px 4px rgba(15,42,68,.06),0 4px 16px rgba(15,42,68,.07);--sh:0 4px 24px rgba(15,42,68,.11);--sh-lg:0 8px 40px rgba(15,42,68,.15);--sh-xl:0 20px 60px rgba(15,42,68,.2);--ease:cubic-bezier(.4,0,.2,1);--t:.22s;--max:1280px;--hh:68px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-b);color:var(--text);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-h);font-weight:700;line-height:1.12;letter-spacing:-.01em;}
p{margin-bottom:1em;}p:last-child{margin-bottom:0;}

/* UTILITY */
.container{max-width:var(--max);margin:0 auto;padding:0 32px;}

/* Wider container for blog and shop pages on large screens */
@media(min-width:1400px){
  .blog-page .container,
  .shop-page .container{
    max-width:1400px;
  }
}

.section{padding:88px 0;}
.section-header{margin-bottom:52px;}
.section-header--split{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:40px;}
.section-title{font-size:clamp(2rem,3.8vw,2.9rem);color:var(--navy);margin-bottom:12px;}
.section-sub{font-size:1.02rem;color:var(--gray-dk);max-width:560px;line-height:1.75;margin:0;}
.section-label{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-h);font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:10px;}
.section-label span{width:20px;height:2px;background:var(--red);flex-shrink:0;}
.section-cta{text-align:center;margin-top:48px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-h);font-size:.88rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:13px 26px;border-radius:var(--r-sm);border:2px solid transparent;cursor:pointer;transition:all var(--t) var(--ease);white-space:nowrap;line-height:1.2;text-decoration:none;}
.btn-lg{padding:15px 34px;font-size:.97rem;}.btn-sm{padding:9px 18px;font-size:.76rem;}.btn-xs{padding:7px 14px;font-size:.7rem;}.btn-block{width:100%;justify-content:center;}
.btn-primary{background:var(--red);color:#fff;border-color:var(--red);}
.btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,25,44,.28);color:#fff;}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy);}
.btn-navy:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-2px);color:#fff;}
.btn-outline-light{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.45);}
.btn-outline-light:hover{background:rgba(255,255,255,.2);border-color:#fff;color:#fff;}
.btn-outline-red{background:transparent;color:var(--red);border-color:var(--red);}
.btn-outline-red:hover{background:var(--red);color:#fff;}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.5);}
.btn-outline-white:hover{background:rgba(255,255,255,.14);border-color:#fff;color:#fff;}
.btn-white{background:#fff;color:var(--navy);border-color:#fff;}
.btn-white:hover{background:#f0f2f5;}
.btn-whatsapp{background:#25D366;color:#fff;border-color:#25D366;}
.btn-whatsapp:hover{background:#1aaa52;border-color:#1aaa52;color:#fff;transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--border);}
.btn-ghost:hover{background:var(--off);border-color:var(--navy);}

/* HEADER TOPBAR */
.header-topbar{background:#071A2B;border-bottom:1px solid rgba(255,255,255,.06);}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:32px;}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:16px;}
.topbar-left a,.topbar-right a,.topbar-right span{font-size:.71rem;color:rgba(255,255,255,.48);display:flex;align-items:center;gap:5px;transition:color var(--t);font-family:var(--font-h);letter-spacing:.05em;}
.topbar-left a:hover,.topbar-right a:hover{color:rgba(255,255,255,.9);}
.topbar-wa{color:#25D366!important;}.topbar-wa:hover{color:#2fe070!important;}

/* HEADER MAIN */
#site-header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 1px 0 var(--border);transition:box-shadow var(--t);}
#site-header.scrolled{box-shadow:0 2px 20px rgba(15,42,68,.1);}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--hh);gap:20px;}
.site-logo{flex-shrink:0;display:block;}
/* WP custom-logo + our bundled fallback img — desktop header */
.site-logo .custom-logo,
.site-logo .site-logo-img{
  display:block;
  max-height:54px;
  width:auto;
  object-fit:contain;
}
.logo-fallback{display:flex;align-items:center;gap:9px;}
.logo-fallback i{font-size:1.5rem;color:var(--red);}
.logo-fallback strong{font-family:var(--font-h);font-size:1.2rem;font-weight:800;color:var(--navy);display:block;line-height:1;}
.logo-fallback small{font-size:.58rem;color:var(--red);letter-spacing:.1em;text-transform:uppercase;display:block;}
.main-nav{flex:1;display:flex;justify-content:center;}
.nav-list{display:flex;align-items:center;gap:2px;}
.nav-list li a{display:block;padding:7px 13px;font-family:var(--font-h);font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--gray-dk);border-radius:var(--r-sm);transition:color var(--t);position:relative;}
.nav-list li a::after{content:'';position:absolute;bottom:2px;left:50%;right:50%;height:2px;background:var(--red);transition:left var(--t) var(--ease),right var(--t) var(--ease);border-radius:2px;}
.nav-list li a:hover,.nav-list .current-menu-item>a{color:var(--navy);}
.nav-list li a:hover::after,.nav-list .current-menu-item>a::after{left:13px;right:13px;}
.header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.cart-btn{position:relative;color:var(--navy);font-size:1.1rem;padding:6px;transition:color var(--t);}
.cart-btn:hover{color:var(--red);}
.cart-count{position:absolute;top:-1px;right:-5px;background:var(--red);color:#fff;font-size:.54rem;font-weight:800;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff;}
.cart-count.hidden{display:none;}
.btn-header{padding:9px 18px;font-size:.75rem;}
.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:38px;height:38px;background:var(--off);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;flex-shrink:0;}
.hamburger span{display:block;width:19px;height:2px;background:var(--navy);border-radius:2px;transition:all var(--t) var(--ease);}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* MOBILE NAV */
.mobile-nav{position:fixed;top:0;right:-320px;width:300px;height:100vh;background:#fff;z-index:1100;transition:right .32s var(--ease);overflow-y:auto;border-left:1px solid var(--border);box-shadow:-4px 0 32px rgba(0,0,0,.1);}
.mobile-nav.open{right:0;}
.mobile-nav-inner{display:flex;flex-direction:column;min-height:100%;}
.mobile-nav-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);}
/* Mobile drawer logo */
.mobile-logo .custom-logo,
.site-logo-img--mobile{max-height:40px;width:auto;object-fit:contain;display:block;}
.mobile-close{width:34px;height:34px;background:var(--off);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray-dk);font-size:.88rem;transition:all var(--t);}
.mobile-close:hover{background:var(--red);color:#fff;border-color:var(--red);}
.mobile-nav-list li a{display:flex;align-items:center;padding:13px 18px;font-family:var(--font-h);font-size:.98rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);border-bottom:1px solid var(--off2);transition:all var(--t);}
.mobile-nav-list li a:hover{color:var(--red);background:var(--off);padding-left:26px;}
.mobile-nav-footer{padding:16px 18px;display:flex;flex-direction:column;gap:9px;border-top:1px solid var(--border);margin-top:auto;}
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1090;opacity:0;pointer-events:none;transition:opacity .32s;}
.mobile-overlay.active{opacity:1;pointer-events:all;}

/* BREADCRUMB */
.mabati-breadcrumb ol{display:flex;flex-wrap:wrap;align-items:center;gap:4px;list-style:none;font-family:var(--font-h);font-size:.66rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;}
.mabati-breadcrumb li{display:flex;align-items:center;gap:5px;color:rgba(255,255,255,.35);}
.mabati-breadcrumb li::after{content:'/';opacity:.28;}
.mabati-breadcrumb li:last-child::after{display:none;}
.mabati-breadcrumb a{color:rgba(255,255,255,.52);transition:color var(--t);}
.mabati-breadcrumb a:hover{color:var(--red);}
.mabati-breadcrumb .current{color:rgba(255,255,255,.8);}

/* PAGE HERO */
.page-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 100%);padding:56px 0 48px;position:relative;overflow:hidden;}
.page-hero-pattern{position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,transparent 0,transparent 18px,rgba(255,255,255,.02) 18px,rgba(255,255,255,.02) 20px);pointer-events:none;}
.page-hero .container{position:relative;z-index:1;}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);color:#fff;margin:12px 0 7px;}
.page-hero p{color:rgba(255,255,255,.6);font-size:.97rem;max-width:520px;margin:0;}

/* HERO */
.hero{background:linear-gradient(140deg,var(--navy) 0%,#153569 55%,var(--blue) 100%);min-height:88vh;display:flex;align-items:center;position:relative;overflow:hidden;}
.hero-overlay{position:absolute;inset:0;pointer-events:none;}
.hero .container{position:relative;z-index:1;padding-top:48px;padding-bottom:48px;}
.hero-content{max-width:680px;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(232,25,44,.15);border:1px solid rgba(232,25,44,.38);color:#ff8a96;font-family:var(--font-h);font-size:.67rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:5px 13px;border-radius:100px;margin-bottom:20px;}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(1.5);}}
.hero-title{font-size:clamp(2.8rem,5.5vw,4.8rem);font-weight:800;color:#fff;line-height:1.0;letter-spacing:-.02em;margin-bottom:18px;}
.hero-subtitle{font-size:1.04rem;color:rgba(255,255,255,.7);line-height:1.78;max-width:520px;margin-bottom:34px;}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:44px;}
.hero-stats{display:flex;flex-wrap:wrap;align-items:center;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);}
.stat{flex:1;min-width:68px;display:flex;flex-direction:column;}
.stat-num{font-family:var(--font-h);font-size:1.85rem;font-weight:800;color:#fff;line-height:1;}
.stat-suf{font-family:var(--font-h);font-size:1.3rem;color:var(--red);font-weight:800;}
.stat-lbl{font-size:.64rem;color:rgba(255,255,255,.46);letter-spacing:.1em;text-transform:uppercase;margin-top:3px;}
.stat-div{width:1px;height:32px;background:rgba(255,255,255,.12);margin:0 14px;flex-shrink:0;}
.hero-wave{position:absolute;bottom:-2px;left:0;right:0;height:50px;background:#fff;clip-path:polygon(0 100%,100% 25%,100% 100%);}

/* TRUST BAR */
.trust-bar{background:var(--off);border-bottom:1px solid var(--border);padding:15px 0;}
.trust-items{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 36px;}
.trust-item{display:flex;align-items:center;gap:6px;font-family:var(--font-h);font-size:.71rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--gray-dk);white-space:nowrap;}
.trust-item i{color:var(--red);font-size:.84rem;}

/* ━━━ PRODUCT CAROUSEL ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.products-section{background:var(--off);overflow:hidden;}

/* The outer wrapper clips the scrolling track — no mask so edges are clean */
.products-carousel-outer{
  position:relative;
  width:100%;
  overflow:hidden;
  /* soft left/right fade so cards appear to scroll in from infinity */
  -webkit-mask-image:linear-gradient(to right,transparent 0,rgba(0,0,0,.2) 3%,#000 8%,#000 92%,rgba(0,0,0,.2) 97%,transparent 100%);
          mask-image:linear-gradient(to right,transparent 0,rgba(0,0,0,.2) 3%,#000 8%,#000 92%,rgba(0,0,0,.2) 97%,transparent 100%);
  margin-top:0;
}
.products-carousel-track{
  display:flex;
  gap:22px;
  width:max-content;
  animation:carouselScroll 52s linear infinite;
  will-change:transform;
  /* left padding ensures first card isn't flush against viewport edge */
  padding:8px 22px 24px;
}
.products-carousel-outer:hover .products-carousel-track,
.products-carousel-outer:focus-within .products-carousel-track{
  animation-play-state:paused;
}
@keyframes carouselScroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ── Individual product card ── */
.prod-card{
  flex:0 0 300px;          /* wider so content breathes */
  background:#fff;
  border-radius:var(--r-xl);
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 2px 8px rgba(15,42,68,.06),0 8px 24px rgba(15,42,68,.08);
  transition:box-shadow .35s var(--ease),transform .35s var(--ease),border-color .35s;
  display:flex;
  flex-direction:column;
  user-select:none;
}
.prod-card:hover{
  box-shadow:0 12px 40px rgba(15,42,68,.18),0 2px 8px rgba(15,42,68,.06);
  transform:translateY(-8px);
  border-color:transparent;
}
.prod-card-link{display:block;color:inherit;}

/* Image — square aspect ratio shows product well */
.prod-card-img{
  position:relative;
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--off2);
}
.prod-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);pointer-events:none;}
.prod-card:hover .prod-card-img img{transform:scale(1.08);}
.prod-img-fallback{
  width:100%;height:100%;min-height:220px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;font-size:3.2rem;color:var(--blue);opacity:.15;
}

/* Badge */
.prod-badge{
  position:absolute;top:12px;left:12px;
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;color:#fff;z-index:1;
}
.badge-sale{background:var(--red);}
.badge-hot{background:var(--blue);}

/* Body */
.prod-card-body{padding:18px 20px 12px;flex:1;display:flex;flex-direction:column;gap:5px;}
.prod-cat{
  font-family:var(--font-h);font-size:.64rem;font-weight:700;
  letter-spacing:.13em;text-transform:uppercase;color:var(--blue);
}
.prod-name{font-size:1.08rem;font-weight:700;color:var(--navy);line-height:1.28;margin:0;}
.prod-price{
  font-family:var(--font-h);font-size:1.18rem;font-weight:800;color:var(--navy);
  line-height:1;margin-top:auto;padding-top:8px;
}
.prod-price del{color:var(--gray);font-size:.82rem;font-weight:400;margin-right:4px;}
.prod-price ins{text-decoration:none;}

/* Footer action row */
.prod-card-footer{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  padding:0 16px 16px;
}
.prod-card-footer .btn{
  justify-content:center;
  font-size:.72rem;
  padding:9px 12px;
  border-radius:var(--r-sm);
  letter-spacing:.04em;
}

/* Pause indicator */
.products-carousel-outer::after{
  content:'⏸  Paused';
  position:absolute;bottom:24px;right:32px;
  font-family:var(--font-h);font-size:.64rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--red);background:rgba(255,255,255,.95);
  border:1px solid var(--border);border-radius:100px;
  padding:4px 12px;opacity:0;transition:opacity .25s;pointer-events:none;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
}
.products-carousel-outer:hover::after{opacity:1;}

/* CTA row below carousel */
.products-section-footer{
  display:flex;align-items:center;justify-content:center;
  gap:14px;padding:8px 32px 52px;flex-wrap:wrap;
}

/* Mobile: narrower cards */
@media(max-width:640px){
  .prod-card{flex:0 0 240px;}
  .products-carousel-track{padding:6px 16px 20px;gap:14px;}
}

/* FEATURES */
.features-section{background:#fff;}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.feature-card{padding:30px 26px;background:#fff;border-radius:var(--r-xl);border:1px solid var(--border);transition:all .28s var(--ease);position:relative;overflow:hidden;}
.feature-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--red);transition:height .4s ease;}
.feature-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:transparent;}
.feature-card:hover::before{height:100%;}
.feature-icon-wrap{width:50px;height:50px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:14px;}
.feature-icon-navy{background:rgba(15,42,68,.07);color:var(--navy);}
.feature-icon-blue{background:rgba(27,63,139,.07);color:var(--blue);}
.feature-icon-red{background:rgba(232,25,44,.07);color:var(--red);}
.feature-title{font-size:1.1rem;color:var(--navy);margin-bottom:7px;}
.feature-text{font-size:.87rem;color:var(--gray-dk);line-height:1.72;margin:0;}

/* TYPES (no WC) */
.types-section{background:var(--off);}
.types-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.type-card{background:#fff;border-radius:var(--r-xl);padding:26px 22px 20px;border:1px solid var(--border);box-shadow:var(--sh-sm);transition:all .28s var(--ease);position:relative;overflow:hidden;display:flex;flex-direction:column;}
.type-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;}
.type-card--navy::before{background:var(--navy);}
.type-card--red::before{background:var(--red);}
.type-card--blue::before{background:var(--blue);}
.type-card:hover{transform:translateY(-6px);box-shadow:var(--sh-xl);border-color:transparent;}
.type-icon-wrap{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:13px;}
.type-card--navy .type-icon-wrap{background:rgba(15,42,68,.07);color:var(--navy);}
.type-card--red  .type-icon-wrap{background:rgba(232,25,44,.07);color:var(--red);}
.type-card--blue .type-icon-wrap{background:rgba(27,63,139,.07);color:var(--blue);}
.type-name{font-size:1.15rem;color:var(--navy);margin-bottom:7px;}
.type-desc{font-size:.85rem;color:var(--gray-dk);line-height:1.65;margin-bottom:13px;flex:1;}
.type-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px;}
.type-tag{background:var(--off);border:1px solid var(--border);color:var(--gray-dk);font-family:var(--font-h);font-size:.63rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:3px 9px;border-radius:100px;}
.type-quote{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px;border:1.5px dashed var(--border);border-radius:var(--r-sm);font-family:var(--font-h);font-size:.71rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--gray-dk);transition:all var(--t);}
.type-quote:hover{border-color:var(--red);color:var(--red);background:var(--red-light);}

/* ABOUT */
.about-section{background:#fff;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;}
.about-img-col{position:relative;}
.about-img-wrap{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/5;background:var(--off2);}
.about-img-wrap img{width:100%;height:100%;object-fit:cover;}
.about-img-fallback{width:100%;height:100%;min-height:420px;background:linear-gradient(135deg,var(--navy),var(--blue));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:32px;}
.about-img-fallback i{font-size:4rem;color:rgba(255,255,255,.2);}
.about-img-fallback p{color:rgba(255,255,255,.3);font-size:.8rem;line-height:1.6;margin:0;}
.about-badge{position:absolute;bottom:24px;right:-16px;background:var(--red);color:#fff;padding:14px 20px;border-radius:var(--r);box-shadow:var(--sh);text-align:center;}
.about-badge-num{font-family:var(--font-h);font-size:2.2rem;font-weight:800;line-height:1;}
.about-badge-lbl{font-size:.7rem;opacity:.88;}
.about-cert{position:absolute;top:22px;left:-12px;background:#fff;color:var(--navy);padding:9px 14px;border-radius:var(--r);box-shadow:var(--sh);display:flex;align-items:center;gap:7px;font-family:var(--font-h);font-size:.74rem;font-weight:700;border:1px solid var(--border);}
.about-cert i{color:var(--red);}
.about-text-col p{color:var(--gray-dk);line-height:1.8;}
.about-checklist{margin:18px 0 26px;display:flex;flex-direction:column;gap:10px;}
.about-checklist li{display:flex;align-items:flex-start;gap:9px;font-size:.9rem;color:var(--gray-dk);line-height:1.52;}
.about-checklist li::before{content:'✓';flex-shrink:0;width:19px;height:19px;background:var(--red-light);color:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:900;margin-top:2px;}
.about-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px;}

/* PORTFOLIO */
.portfolio-section{background:var(--off);}
.portfolio-scroll-outer{position:relative;overflow:hidden;margin:0 -32px;}
.portfolio-track{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:4px 32px 18px;cursor:grab;user-select:none;}
.portfolio-track::-webkit-scrollbar{height:4px;}
.portfolio-track::-webkit-scrollbar-track{background:var(--border);}
.portfolio-track::-webkit-scrollbar-thumb{background:var(--red);border-radius:4px;}
.portfolio-track.grabbing{cursor:grabbing;}
.portfolio-card{flex:0 0 300px;scroll-snap-align:start;border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:var(--sh-sm);border:1px solid var(--border);transition:box-shadow var(--t),transform var(--t);}
.portfolio-card:hover{box-shadow:var(--sh-lg);transform:translateY(-4px);}
.portfolio-img{aspect-ratio:3/2;overflow:hidden;background:var(--off2);}
.portfolio-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s;pointer-events:none;}
.portfolio-card:hover .portfolio-img img{transform:scale(1.06);}
.portfolio-img--ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px;text-align:center;min-height:190px;}
.portfolio-img--ph i{font-size:2.6rem;color:var(--border);}
.portfolio-img--ph span{font-size:.74rem;color:var(--gray);line-height:1.5;}
.portfolio-caption{padding:12px 16px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;}
.portfolio-loc{font-family:var(--font-h);font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:4px;white-space:nowrap;}
.portfolio-type{font-family:var(--font-h);font-size:.76rem;font-weight:700;color:var(--navy);text-align:right;}
.portfolio-btn{position:absolute;top:50%;transform:translateY(-62%);z-index:10;width:42px;height:42px;border-radius:50%;background:#fff;border:1px solid var(--border);box-shadow:var(--sh);color:var(--navy);font-size:.9rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--t);}
.portfolio-btn:hover{background:var(--red);color:#fff;border-color:var(--red);}
.portfolio-prev{left:10px;}.portfolio-next{right:10px;}
.portfolio-hint{text-align:center;margin-top:14px;font-size:.7rem;color:var(--gray);font-family:var(--font-h);letter-spacing:.09em;text-transform:uppercase;}

/* TESTIMONIALS */
.testimonials-section{background:#fff;}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.testimonial-card{background:#fff;padding:28px;border-radius:var(--r-xl);box-shadow:var(--sh-sm);border:1px solid var(--border);transition:all var(--t);}
.testimonial-card:hover{box-shadow:var(--sh-lg);transform:translateY(-4px);border-color:transparent;}
.testimonial-stars{color:#F59E0B;font-size:.82rem;letter-spacing:2px;margin-bottom:12px;}
.testimonial-text{font-size:.9rem;color:var(--gray-dk);line-height:1.78;margin-bottom:20px;font-style:italic;}
.testimonial-author{display:flex;align-items:center;gap:10px;}
.author-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;font-family:var(--font-h);font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.author-name{font-family:var(--font-h);font-weight:700;color:var(--navy);font-size:.9rem;}
.author-role{font-size:.72rem;color:var(--gray);}

/* BLOG CARDS (homepage preview) */
.blog-section{background:var(--off);}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.blog-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);transition:all .28s var(--ease);}
.blog-card:hover{box-shadow:var(--sh-xl);transform:translateY(-5px);border-color:transparent;}
.blog-card-img{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--off2);}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);}
.blog-card:hover .blog-card-img img{transform:scale(1.06);}
.blog-card-body{padding:18px 20px 22px;}
.blog-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:5px 9px;margin-bottom:8px;}
.blog-cat{font-family:var(--font-h);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);}
.blog-date{font-size:.72rem;color:var(--gray);display:flex;align-items:center;gap:3px;}
.blog-read{font-size:.72rem;color:var(--gray);display:flex;align-items:center;gap:3px;}
.blog-card-title{font-size:1.04rem;color:var(--navy);line-height:1.32;margin-bottom:7px;}
.blog-card-title a:hover{color:var(--blue);}
.blog-card-excerpt{font-size:.85rem;color:var(--gray-dk);line-height:1.68;margin-bottom:14px;}
.read-more{font-family:var(--font-h);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:5px;transition:gap var(--t),color var(--t);}
.read-more:hover{gap:9px;color:var(--red);}

/* ━━━ HOMEPAGE CTA BAND — after blog, full-width editorial ━━━━━━━ */
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   HOME CTA BAND — editorial two-column, desktop + mobile perfect
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.home-cta-band{
  background:linear-gradient(112deg,#081c30 0%,var(--navy) 38%,#1c3e70 68%,var(--blue) 100%);
  position:relative;overflow:hidden;padding:100px 0;
}
.home-cta-band::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(ellipse 58% 82% at 82% 50%,rgba(232,25,44,.17) 0%,transparent 62%),
    radial-gradient(ellipse 28% 48% at 8% 78%,rgba(27,63,139,.28) 0%,transparent 58%),
    repeating-linear-gradient(90deg,transparent 0,transparent 80px,rgba(255,255,255,.012) 80px,rgba(255,255,255,.012) 81px);
}
.home-cta-band .container{position:relative;z-index:1;}

/* Layout: content left | action card right */
.home-cta-inner{
  display:grid;
  grid-template-columns:1fr 420px;  /* 420px — enough for comfortably sized buttons */
  align-items:center;
  gap:80px;
}

/* Left content */
.home-cta-kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-h);font-size:.67rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.36);margin-bottom:20px;
}
.home-cta-kicker span{width:20px;height:1px;background:rgba(255,255,255,.22);}
.home-cta-heading{
  font-size:clamp(2.6rem,4.2vw,4rem);
  font-weight:800;color:#fff;line-height:1.04;
  margin-bottom:20px;letter-spacing:-.025em;
}
.home-cta-heading em{font-style:normal;color:var(--red);}
.home-cta-sub{
  font-size:1.06rem;color:rgba(255,255,255,.56);
  line-height:1.8;max-width:520px;margin-bottom:32px;
}
.home-cta-trust{display:flex;flex-wrap:wrap;gap:12px 28px;}
.home-cta-trust-item{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-h);font-size:.72rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.45);
}
.home-cta-trust-item i{color:#4ade80;font-size:.82rem;}

/* Right action card */
.home-cta-col{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  padding:36px 32px 32px;
  display:flex;flex-direction:column;gap:14px;
}
.home-cta-col-title{
  font-family:var(--font-h);font-size:.68rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.34);
  padding-bottom:14px;margin-bottom:2px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
/* All buttons inside the card fill full width */
.home-cta-col .btn{
  width:100%;justify-content:center;
  font-size:.9rem;padding:16px 24px;
  border-radius:var(--r);letter-spacing:.05em;
}
.home-cta-col .btn-primary{
  background:var(--red);border-color:var(--red);
  box-shadow:0 4px 20px rgba(232,25,44,.4);
}
.home-cta-col .btn-primary:hover{
  background:var(--red-dark);border-color:var(--red-dark);
  box-shadow:0 8px 30px rgba(232,25,44,.5);transform:translateY(-2px);
}
.home-cta-col .btn-whatsapp{box-shadow:0 4px 16px rgba(37,211,102,.28);}
.home-cta-col .btn-whatsapp:hover{box-shadow:0 8px 24px rgba(37,211,102,.4);transform:translateY(-2px);}
.home-cta-divider{
  display:flex;align-items:center;gap:12px;
  font-family:var(--font-h);font-size:.64rem;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.2);
}
.home-cta-divider::before,.home-cta-divider::after{
  content:'';flex:1;height:1px;background:rgba(255,255,255,.1);
}
.home-cta-call{
  display:flex;flex-direction:column;align-items:center;gap:5px;
}
.home-cta-call small{
  font-family:var(--font-h);font-size:.63rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.26);
}
.home-cta-call a{
  font-family:var(--font-h);font-size:1.35rem;font-weight:800;
  color:#fff;display:flex;align-items:center;justify-content:center;
  gap:9px;transition:color var(--t);letter-spacing:.01em;line-height:1.2;
}
.home-cta-call a:hover{color:var(--red);}
.home-cta-call a i{font-size:.95rem;color:rgba(255,255,255,.4);}

/* FOOTER CTA */
.footer-cta-band{background:linear-gradient(135deg,var(--red-dark),var(--red));padding:64px 0;position:relative;overflow:hidden;}
.footer-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;position:relative;z-index:1;}
.footer-cta-text h2{font-size:clamp(1.65rem,3vw,2.3rem);color:#fff;margin-bottom:7px;}
.footer-cta-text p{color:rgba(255,255,255,.78);font-size:.95rem;margin:0;}
.footer-cta-actions{display:flex;gap:11px;flex-wrap:wrap;flex-shrink:0;}

/* FOOTER */
#site-footer{background:var(--navy);padding:64px 0 0;}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.5fr;gap:40px;padding-bottom:48px;}
/* Footer logo — white background pill so navy logo reads on dark footer */
.footer-logo .custom-logo-link{display:inline-block;}
.footer-logo .custom-logo,
.footer-logo .site-logo-img--footer{
  display:block;
  max-height:70px;
  width:auto;
  max-width:200px;
  object-fit:contain;
  margin-bottom:16px;
  background:#fff;
  border-radius:8px;
  padding:8px 14px;
}
.logo-text-fallback{display:flex;align-items:center;gap:9px;margin-bottom:12px;}
.logo-text-fallback i{color:var(--red);font-size:1.4rem;}
.logo-text-fallback strong{font-family:var(--font-h);font-size:1.3rem;font-weight:800;color:#fff;}
.footer-desc{font-size:.84rem;color:rgba(255,255,255,.48);line-height:1.78;margin-bottom:20px;max-width:300px;}
.footer-social{display:flex;flex-wrap:wrap;gap:8px;}
.social-icon{width:33px;height:33px;border-radius:var(--r-sm);background:rgba(255,255,255,.08);color:rgba(255,255,255,.65);display:flex;align-items:center;justify-content:center;font-size:.83rem;transition:all var(--t);}
.social-icon:hover{background:var(--red);color:#fff;transform:translateY(-2px);}
.footer-col-title{font-family:var(--font-h);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:16px;padding-bottom:9px;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-links{display:flex;flex-direction:column;gap:8px;}
.footer-links li a{font-size:.84rem;color:rgba(255,255,255,.48);display:flex;align-items:center;gap:6px;transition:all var(--t);}
.footer-links li a i{font-size:.68rem;color:rgba(255,255,255,.22);}
.footer-links li a:hover{color:rgba(255,255,255,.88);gap:9px;}
.footer-contact{display:flex;flex-direction:column;gap:11px;margin-bottom:18px;}
.footer-contact li{display:flex;align-items:flex-start;gap:8px;font-size:.82rem;color:rgba(255,255,255,.52);}
.footer-contact i{color:var(--red);font-size:.86rem;flex-shrink:0;margin-top:2px;}
.footer-contact a{color:rgba(255,255,255,.52);transition:color var(--t);}
.footer-contact a:hover{color:var(--red);}
.footer-quick-actions{display:flex;gap:8px;flex-wrap:wrap;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:16px 0;}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.footer-copy{font-size:.74rem;color:rgba(255,255,255,.28);margin:0;}
.footer-copy strong{color:rgba(255,255,255,.48);}
.footer-bottom-links{display:flex;gap:16px;}
.footer-bottom-links a{font-size:.74rem;color:rgba(255,255,255,.28);transition:color var(--t);}
.footer-bottom-links a:hover{color:var(--red);}
.footer-dev-credit{font-size:.72rem;color:rgba(255,255,255,.22);margin:0;}
.footer-dev-credit a{color:rgba(255,255,255,.42);text-decoration:underline;text-underline-offset:3px;transition:color var(--t);}
.footer-dev-credit a:hover{color:var(--red);}
.whatsapp-fab{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:8px;background:#25D366;color:#fff;padding:12px 16px;border-radius:100px;box-shadow:0 4px 20px rgba(37,211,102,.42);z-index:999;font-family:var(--font-h);font-size:.78rem;font-weight:700;transition:all .3s;max-width:48px;overflow:hidden;}
.whatsapp-fab i{font-size:1.3rem;flex-shrink:0;}
.fab-label{white-space:nowrap;opacity:0;max-width:0;transition:all .3s;}
.whatsapp-fab:hover{max-width:200px;box-shadow:0 6px 28px rgba(37,211,102,.58);transform:scale(1.04);}
.whatsapp-fab:hover .fab-label{opacity:1;max-width:120px;}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   BLOG PAGE — Apple / Amazon editorial quality
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.blog-page{background:#fff;}

/* ── Dark editorial hero ── */
.blog-hero{
  background:linear-gradient(135deg,#071A2B 0%,var(--navy) 55%,#1c3870 100%);
  padding:64px 0 52px;position:relative;overflow:hidden;
}
.blog-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(ellipse 50% 70% at 90% 40%,rgba(232,25,44,.12) 0%,transparent 65%),
    repeating-linear-gradient(0deg,transparent 0,transparent 44px,rgba(255,255,255,.018) 44px,rgba(255,255,255,.018) 45px),
    repeating-linear-gradient(90deg,transparent 0,transparent 60px,rgba(255,255,255,.014) 60px,rgba(255,255,255,.014) 61px);
}
.blog-hero .container{position:relative;z-index:1;}
.blog-hero-inner{
  display:grid;grid-template-columns:1fr 320px;
  align-items:end;gap:48px;
}
.blog-hero-kicker{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-h);font-size:.68rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--red);margin-bottom:14px;
}
.blog-hero-kicker span{width:18px;height:2px;background:var(--red);}
.blog-hero h1{
  font-size:clamp(2.6rem,5vw,4.2rem);font-weight:800;
  color:#fff;line-height:1.04;letter-spacing:-.025em;margin-bottom:14px;
}
.blog-hero p{
  font-size:1.04rem;color:rgba(255,255,255,.54);
  line-height:1.75;max-width:540px;margin:0;
}
.blog-hero-search{display:flex;gap:0;width:100%;}
.blog-hero-search input{
  flex:1;padding:14px 18px;
  border:1.5px solid rgba(255,255,255,.16);border-right:none;
  border-radius:var(--r) 0 0 var(--r);
  font-family:var(--font-b);font-size:.92rem;
  background:rgba(255,255,255,.1);color:#fff;
  outline:none;transition:all var(--t);
}
.blog-hero-search input::placeholder{color:rgba(255,255,255,.38);}
.blog-hero-search input:focus{
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.38);
}
.blog-hero-search button{
  padding:14px 20px;background:var(--red);color:#fff;
  border:1.5px solid var(--red);border-radius:0 var(--r) var(--r) 0;
  cursor:pointer;font-size:.94rem;transition:background var(--t);
}
.blog-hero-search button:hover{background:var(--red-dark);border-color:var(--red-dark);}

/* ── Category nav strip ── */
.blog-cat-nav{
  border-bottom:1px solid var(--border);background:#fff;
  position:sticky;top:var(--hh);z-index:100;
  box-shadow:0 1px 0 var(--border);
}
.blog-cat-nav-inner{
  display:flex;align-items:center;gap:0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
  min-height:50px; /* Ensure minimum height for visibility */
}
.blog-cat-nav-inner::-webkit-scrollbar{display:none;}
.blog-cat-link{
  display:inline-flex;align-items:center;gap:7px;
  padding:14px 18px;
  font-family:var(--font-h);font-size:.76rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--gray-dk);white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color var(--t),border-color var(--t);flex-shrink:0;
}
.blog-cat-link:hover{color:var(--navy);}
.blog-cat-link.active{color:var(--navy);border-bottom-color:var(--red);}
.blog-cat-link-count{
  font-size:.6rem;background:var(--off2);color:var(--gray);
  padding:1px 6px;border-radius:100px;font-weight:700;
  transition:all var(--t);
}
.blog-cat-link.active .blog-cat-link-count{background:var(--red);color:#fff;}
.blog-cat-link i{color:var(--red);font-size:.85rem;}

/* ── Body layout ── */
.blog-page-body{padding:52px 0 88px;background:var(--off);}
.blog-page-layout{
  display:grid;
  grid-template-columns:1fr 292px;
  gap:44px;align-items:start;
}

/* ── Featured post — large editorial hero card ── */
.blog-featured{
  position:relative;
  border-radius:20px;overflow:hidden;
  margin-bottom:40px;
  box-shadow:0 4px 24px rgba(15,42,68,.1);
  transition:box-shadow .35s var(--ease);
  background:#fff;
}
.blog-featured:hover{box-shadow:0 16px 56px rgba(15,42,68,.18);}

/* Image takes top 56% of the card, text sits below */
.blog-featured-visual{
  position:relative;overflow:hidden;
  aspect-ratio:16/8;  /* wide cinematic crop */
  background:var(--navy);
}
.blog-featured-visual a{display:block;height:100%;}
.blog-featured-visual img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s var(--ease);
  filter:brightness(.92);
}
.blog-featured:hover .blog-featured-visual img{transform:scale(1.04);filter:brightness(.86);}

/* Gradient overlay on image */
.blog-featured-visual::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 30%,rgba(7,18,30,.82) 100%);
  pointer-events:none;
}
.blog-featured-label{
  position:absolute;top:16px;left:16px;z-index:2;
  background:var(--red);color:#fff;
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;
}
/* Title overlaid on image bottom */
.blog-featured-overlay{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  padding:28px 32px;
}
.blog-featured-meta{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:8px 12px;margin-bottom:12px;
}
.blog-featured-cat{
  font-family:var(--font-h);font-size:.64rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--red);padding:4px 10px;
  background:rgba(232,25,44,.18);border:1px solid rgba(232,25,44,.35);
  border-radius:100px;
}
.blog-featured-date{font-size:.78rem;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:4px;}
.blog-featured-time{font-size:.78rem;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:4px;}
.blog-featured-title{
  font-size:clamp(1.5rem,2.8vw,2.2rem);
  color:#fff;line-height:1.16;
  margin-bottom:0;letter-spacing:-.015em;
  text-shadow:0 2px 8px rgba(0,0,0,.4);
}
.blog-featured-title a{color:#fff;transition:color var(--t);}
.blog-featured-title a:hover{color:rgba(255,255,255,.85);}

/* Content below the image */
.blog-featured-content{padding:24px 32px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.blog-featured-excerpt{
  font-size:.94rem;color:var(--gray-dk);line-height:1.75;
  margin:0;flex:1;min-width:200px;
}
.blog-featured-footer{display:flex;align-items:center;gap:14px;flex-shrink:0;flex-wrap:wrap;}
.blog-author-chip{display:flex;align-items:center;gap:8px;}
.blog-author-chip img{width:32px;height:32px;border-radius:50%;object-fit:cover;}
.author-initials{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff;font-family:var(--font-h);font-weight:700;font-size:.78rem;
  display:flex;align-items:center;justify-content:center;
}
.blog-author-chip span{font-size:.82rem;color:var(--gray-dk);font-weight:500;}

/* ── Section label ── */
.blog-section-label{
  font-family:var(--font-h);font-size:.7rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gray);
  margin-bottom:20px;padding-bottom:12px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.blog-post-count{
  font-size:.66rem;background:#fff;border:1px solid var(--border);
  color:var(--gray);padding:2px 9px;border-radius:100px;
}

/* ── Post listing grid — 2 columns (sidebar is present) ── */
.blog-listing-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:24px;margin-bottom:36px;
}

/* On wider screens with sidebar, use 3 columns if space allows */
@media(min-width:1400px){
  .blog-listing-grid{
    grid-template-columns:repeat(3,1fr);
    gap:20px;
  }
}

.blog-post-card{
  background:#fff;border-radius:var(--r-lg);
  overflow:hidden;border:1px solid var(--border);
  transition:all .28s var(--ease);
  display:flex;flex-direction:column;
}
.blog-post-card:hover{
  box-shadow:0 12px 40px rgba(15,42,68,.14);
  transform:translateY(-5px);border-color:transparent;
}
.blog-post-img{
  display:block;aspect-ratio:16/9;overflow:hidden;
  background:var(--off2);flex-shrink:0;
}
.blog-post-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .55s var(--ease);
}
.blog-post-card:hover .blog-post-img img{transform:scale(1.07);}
.blog-post-body{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column;}
.blog-post-meta{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:5px 9px;margin-bottom:8px;
}
.blog-post-cat{
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--red);
}
.blog-post-date{font-size:.72rem;color:var(--gray);display:flex;align-items:center;gap:3px;}
.blog-post-title{
  font-size:1.02rem;color:var(--navy);line-height:1.32;
  margin-bottom:8px;font-weight:700;
}
.blog-post-title a:hover{color:var(--blue);}
.blog-post-excerpt{
  font-size:.85rem;color:var(--gray-dk);
  line-height:1.68;margin-bottom:14px;flex:1;
}
.blog-post-foot{
  display:flex;align-items:center;
  justify-content:space-between;gap:8px;margin-top:auto;
}
.blog-post-read{
  font-size:.68rem;color:var(--gray);
  display:flex;align-items:center;gap:3px;
  font-family:var(--font-h);letter-spacing:.06em;
  text-transform:uppercase;font-weight:700;
}

/* ── Sidebar ── */
.blog-sidebar-wrap{
  display:flex;flex-direction:column;gap:20px;
  position:sticky;top:calc(var(--hh) + 44px);
}
.sidebar-card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--border);overflow:hidden;
}
.sidebar-card-head{
  padding:14px 18px;border-bottom:1px solid var(--border);
  font-family:var(--font-h);font-size:.72rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--navy);
  display:flex;align-items:center;gap:7px;
}
.sidebar-card-head i{color:var(--red);}
.sidebar-search{display:flex;}
.sidebar-search input{
  flex:1;padding:13px 15px;border:none;border-right:1px solid var(--border);
  font-family:var(--font-b);font-size:.88rem;outline:none;color:var(--text);
  background:#fff;
}
.sidebar-search button{
  padding:13px 15px;background:#fff;color:var(--navy);
  border:none;cursor:pointer;font-size:.9rem;transition:all var(--t);
}
.sidebar-search button:hover{background:var(--navy);color:#fff;}
.sidebar-posts{display:flex;flex-direction:column;}
.sidebar-post-item{
  display:flex;gap:11px;padding:13px 18px;
  border-bottom:1px solid var(--border);transition:background var(--t);
}
.sidebar-post-item:last-child{border-bottom:none;}
.sidebar-post-item:hover{background:var(--off);}
.sidebar-post-thumb{
  width:60px;height:52px;border-radius:var(--r-sm);
  overflow:hidden;flex-shrink:0;background:var(--off2);
}
.sidebar-post-thumb img{width:100%;height:100%;object-fit:cover;}
.sidebar-post-info{flex:1;min-width:0;}
.sidebar-post-title{
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;font-family:var(--font-h);font-weight:700;
  color:var(--navy);font-size:.84rem;line-height:1.3;
  margin-bottom:3px;transition:color var(--t);
}
.sidebar-post-title:hover{color:var(--red);}
.sidebar-post-date{font-size:.68rem;color:var(--gray);}
.sidebar-product-price{
  font-family:var(--font-h);font-size:.82rem;
  font-weight:700;color:var(--navy);margin-top:2px;
}
.sidebar-product-price del{
  font-size:.7rem;color:var(--gray);
  margin-right:4px;font-weight:500;
}
.sidebar-product-price ins{
  text-decoration:none;color:var(--red);
}
.sidebar-cat-list{display:flex;flex-direction:column;}
.sidebar-cat-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 18px;border-bottom:1px solid var(--border);
  font-size:.86rem;color:var(--gray-dk);transition:all var(--t);
}
.sidebar-cat-item:last-child{border-bottom:none;}
.sidebar-cat-item:hover{background:var(--off);color:var(--red);padding-left:24px;}
.sidebar-cat-item .cat-count{
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  background:var(--off2);padding:2px 8px;border-radius:100px;color:var(--gray);
}
.sidebar-cat-item.active{color:var(--red);font-weight:600;}
.sidebar-cat-item.active .cat-count{background:var(--red);color:#fff;}
.sidebar-tags{display:flex;flex-wrap:wrap;gap:6px;padding:14px 18px;}
.sidebar-tag{
  background:var(--off);border:1px solid var(--border);
  color:var(--gray-dk);font-size:.72rem;padding:4px 11px;
  border-radius:100px;transition:all var(--t);
}
a.sidebar-tag:hover{background:var(--navy);color:#fff;border-color:var(--navy);}
.sidebar-cta-card{
  background:linear-gradient(145deg,var(--navy),var(--blue));
  border-radius:var(--r-lg);overflow:hidden;
}
.sidebar-cta-inner{padding:24px 22px;text-align:center;}
.sidebar-cta-icon-wrap{
  width:52px;height:52px;background:rgba(255,255,255,.12);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 12px;font-size:1.4rem;color:#fff;
}
.sidebar-cta-card h4{color:#fff;font-size:1.05rem;margin-bottom:6px;}
.sidebar-cta-card p{font-size:.82rem;color:rgba(255,255,255,.58);line-height:1.65;margin-bottom:14px;}

/* ── Blog pagination ── */
.blog-pagination{
  display:flex;align-items:center;justify-content:center;
  gap:6px;flex-wrap:wrap;
}
.blog-pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:var(--r);
  font-family:var(--font-h);font-size:.84rem;font-weight:700;
  color:var(--navy);background:#fff;border:1px solid var(--border);
  transition:all var(--t);
}
.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers.current{
  background:var(--navy);color:#fff;border-color:var(--navy);
}
.blog-pagination .prev,.blog-pagination .next{
  width:auto;padding:0 15px;font-size:.76rem;gap:6px;
}
.empty-state{text-align:center;padding:72px 0;}
.empty-icon{font-size:3rem;color:var(--border);margin-bottom:14px;}
.empty-state h3{font-size:1.3rem;color:var(--navy);margin-bottom:8px;}
.empty-state p{color:var(--gray-dk);}

/* ── Responsive for blog ── */
@media(max-width:1100px){
  .blog-page-layout{grid-template-columns:1fr 260px;gap:32px;}
}
@media(max-width:880px){
  .blog-hero-inner{grid-template-columns:1fr;}
  .blog-hero-search{max-width:400px;}
  .blog-featured-visual{aspect-ratio:16/9;}
  .blog-featured-overlay{padding:20px 22px;}
  .blog-featured-content{padding:18px 22px 22px;flex-direction:column;align-items:flex-start;}
  .blog-page-layout{grid-template-columns:1fr;}
  .blog-sidebar-wrap{position:static;}
}
@media(max-width:640px){
  .blog-listing-grid{grid-template-columns:1fr;}
  .blog-hero h1{font-size:2.2rem;}
  .blog-hero{padding:44px 0 36px;}
}

/* ── SINGLE BLOG POST LAYOUT WITH SIDEBAR ── */
.blog-single-wrap{background:var(--off);}
.blog-layout{
  display:grid;
  grid-template-columns:1fr 292px;
  gap:44px;align-items:start;
}
.blog-main{
  background:#fff;border-radius:var(--r-xl);
  padding:32px 40px 40px;
  border:1px solid var(--border);
}
@media(max-width:1024px){
  .blog-layout{grid-template-columns:1fr;gap:32px;}
  .blog-sidebar-wrap{position:static;max-width:100%;}
}
@media(max-width:768px){
  .blog-main{padding:24px 20px 28px;border-radius:var(--r);}
}

/* ── QUOTE MODAL — Premium redesign ── */

/* Overlay */
.quote-modal-overlay{
  position:fixed;inset:0;background:rgba(8,14,28,.72);z-index:9000;
  display:flex;align-items:center;justify-content:center;padding:16px;
  opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease);backdrop-filter:blur(6px);
}
.quote-modal-overlay.open{opacity:1;pointer-events:all;}

/* Modal shell */
.quote-modal{
  position:relative;background:#fff;border-radius:var(--r-xl);overflow:hidden;
  width:100%;max-width:860px;max-height:92vh;overflow-y:auto;
  display:grid;grid-template-columns:280px 1fr;
  transform:translateY(20px) scale(.97);
  transition:transform .34s var(--ease);
  box-shadow:0 24px 80px rgba(8,14,28,.36);
}
.quote-modal-overlay.open .quote-modal{transform:translateY(0) scale(1);}

/* Close button */
.modal-close{
  position:absolute;top:14px;right:14px;z-index:20;
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:.82rem;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all var(--t);
}
.modal-close:hover{background:rgba(255,255,255,.3);transform:scale(1.1);}

/* ── LEFT PANEL ── */
.modal-left{
  background:linear-gradient(170deg,#0a1e36 0%,var(--navy) 45%,#1a3a6b 100%);
  padding:32px 24px;display:flex;flex-direction:column;gap:0;
  position:relative;overflow:hidden;
}
/* decorative pattern */
.modal-left::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 80% 20%,rgba(232,25,44,.12) 0%,transparent 60%),
    radial-gradient(circle at 20% 80%,rgba(27,63,139,.25) 0%,transparent 55%);
  pointer-events:none;
}

/* Logo */
.modal-left-logo{margin-bottom:22px;position:relative;}
.modal-left-logo .custom-logo-link,
.modal-left-logo img.modal-logo-img{
  display:block;max-width:140px;max-height:52px;
  width:auto;height:auto;object-fit:contain;
  background:#fff;border-radius:var(--r-sm);padding:7px 12px;
}
.modal-left-logo .custom-logo{display:block;max-width:140px;max-height:52px;width:auto;height:auto;object-fit:contain;}

/* Live badge */
.modal-left-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);
  border-radius:100px;padding:5px 12px;margin-bottom:18px;
  font-size:.67rem;font-family:var(--font-h);font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.7);position:relative;
}
.modal-badge-dot{
  width:7px;height:7px;border-radius:50%;background:#4ade80;flex-shrink:0;
  animation:badge-pulse 2s infinite;
}
@keyframes badge-pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(74,222,128,.4);}50%{opacity:.8;box-shadow:0 0 0 5px rgba(74,222,128,0);}}

/* Title */
.modal-left-title{
  font-size:1.55rem;font-weight:800;color:#fff;line-height:1.15;
  margin-bottom:10px;position:relative;
}
.modal-left-sub{
  font-size:.82rem;color:rgba(255,255,255,.55);line-height:1.7;
  margin-bottom:20px;position:relative;
}

/* Stats row */
.modal-stats{
  display:flex;align-items:center;gap:0;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r);padding:12px 10px;margin-bottom:20px;position:relative;
}
.modal-stat{flex:1;text-align:center;}
.modal-stat strong{display:block;font-family:var(--font-h);font-size:1.3rem;font-weight:800;color:#fff;line-height:1;}
.modal-stat span{display:block;font-size:.6rem;font-family:var(--font-h);letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:2px;}
.modal-stat-divider{width:1px;height:32px;background:rgba(255,255,255,.12);}

/* Features list */
.modal-feats{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;position:relative;}
.modal-feat{display:flex;align-items:center;gap:9px;font-size:.81rem;color:rgba(255,255,255,.75);line-height:1.4;}
.modal-feat i{color:#4ade80;font-size:.77rem;flex-shrink:0;}

/* Contact buttons */
.modal-contact{display:flex;flex-direction:column;gap:8px;margin-top:auto;position:relative;}
.modal-contact-btn{
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r);padding:11px 14px;color:#fff;transition:all var(--t);
}
.modal-contact-btn:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.22);}
.modal-contact-btn.wa:hover{background:#25D366;border-color:#25D366;}
.modal-contact-icon{
  width:34px;height:34px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
}
.modal-contact-btn small{display:block;font-size:.6rem;font-family:var(--font-h);letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:1px;}
.modal-contact-btn strong{display:block;font-size:.86rem;font-weight:600;}

/* ── RIGHT PANEL ── */
.modal-right{
  padding:30px 28px;display:flex;flex-direction:column;background:#fff;
  overflow-y:auto;
}
.modal-form-head{margin-bottom:20px;}
.modal-form-head h4{
  font-family:var(--font-h);font-size:1.3rem;font-weight:800;
  color:var(--navy);margin-bottom:4px;line-height:1.2;
}
.modal-form-head p{font-size:.82rem;color:var(--gray);margin:0;}

/* Form field groups */
.qf-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;}
.qf-group{display:flex;flex-direction:column;gap:5px;margin-bottom:10px;}

/* Labels */
.qf-group label{
  font-family:var(--font-h);font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--navy);
}
.qf-req{color:var(--red);}
.qf-opt{font-weight:400;color:var(--gray);text-transform:none;letter-spacing:0;font-family:var(--font-b);font-size:.75em;}

/* Input wrapper with icon */
.qf-input-wrap{position:relative;display:flex;align-items:center;}
.qf-icon{
  position:absolute;left:13px;top:50%;transform:translateY(-50%);
  color:var(--gray);font-size:.76rem;pointer-events:none;z-index:1;
}
/* Select: icon + custom arrow */
.qf-input-wrap select{-webkit-appearance:none;appearance:none;}
.qf-input-wrap::after{
  content:'\f107';font-family:'Font Awesome 6 Free';font-weight:900;
  position:absolute;right:13px;top:50%;transform:translateY(-50%);
  font-size:.72rem;color:var(--gray);pointer-events:none;
}
/* Hide pseudo for non-select wrappers */
.qf-input-wrap:not(:has(select))::after{display:none;}

/* All form inputs */
.qf-group input,
.qf-group select,
.qf-group textarea{
  width:100%;padding:10px 12px 10px 36px;
  border:1.5px solid var(--border);border-radius:var(--r);
  font-family:var(--font-b);font-size:.875rem;color:var(--text);background:#fff;
  outline:none;transition:border-color var(--t),box-shadow var(--t);
  -webkit-appearance:none;appearance:none;line-height:1.4;
}
.qf-group textarea{padding-left:12px;resize:none;min-height:68px;}
.qf-group input:focus,
.qf-group select:focus,
.qf-group textarea:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(27,63,139,.1);
  background:#fafbff;
}
.qf-group input:focus~.qf-icon,
.qf-group select:focus~.qf-icon{color:var(--blue);}
.qf-group input.err{border-color:var(--red)!important;box-shadow:0 0 0 3px rgba(232,25,44,.1)!important;}

/* Submit button */
.qf-submit-btn{
  width:100%;margin-top:4px;padding:13px 24px;
  background:linear-gradient(135deg,var(--red) 0%,#c4001d 100%);
  color:#fff;border:none;border-radius:var(--r);
  font-family:var(--font-h);font-size:.95rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all var(--t);box-shadow:0 4px 16px rgba(232,25,44,.28);
}
.qf-submit-btn:hover{
  background:linear-gradient(135deg,#c4001d 0%,#a3001a 100%);
  box-shadow:0 6px 24px rgba(232,25,44,.38);transform:translateY(-1px);
}
.qf-submit-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(232,25,44,.2);}

/* Disclaimer */
.modal-disclaimer{
  font-size:.68rem;color:var(--gray);text-align:center;margin-top:10px;
  display:flex;align-items:center;justify-content:center;gap:5px;
}
.modal-disclaimer i{color:var(--gray);font-size:.65rem;}

/* Success state */
.modal-success{text-align:center;padding:40px 16px;animation:fadeInUp .4s ease;}
.modal-success-icon{font-size:3rem;color:#16A34A;margin-bottom:14px;}
.modal-success h4{font-family:var(--font-h);font-size:1.25rem;color:var(--navy);margin-bottom:8px;}
.modal-success p{font-size:.86rem;color:var(--gray-dk);margin-bottom:20px;}

/* Error state */
.modal-error{
  background:#FEF2F2;border:1px solid #FECACA;color:#B91C1C;
  padding:10px 14px;border-radius:var(--r);font-size:.82rem;
  margin-bottom:12px;display:none;
}
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

/* CF7 wrapper styles */
.modal-cf7-wrap .wpcf7-form{display:flex;flex-direction:column;gap:10px;}
.modal-cf7-wrap .wpcf7-form p{margin:0;}
.modal-cf7-wrap input[type="text"],
.modal-cf7-wrap input[type="email"],
.modal-cf7-wrap input[type="tel"],
.modal-cf7-wrap select,
.modal-cf7-wrap textarea{
  width:100%;padding:10px 12px;border:1.5px solid var(--border);
  border-radius:var(--r);font-family:var(--font-b);font-size:.875rem;
  outline:none;transition:all var(--t);-webkit-appearance:none;
}
.modal-cf7-wrap input:focus,
.modal-cf7-wrap select:focus,
.modal-cf7-wrap textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(27,63,139,.1);}
.modal-cf7-wrap .wpcf7-submit{
  width:100%;padding:13px 24px;
  background:linear-gradient(135deg,var(--red) 0%,#c4001d 100%);
  color:#fff;border:none;border-radius:var(--r);
  font-family:var(--font-h);font-size:.95rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  cursor:pointer;box-shadow:0 4px 16px rgba(232,25,44,.28);
  transition:all var(--t);
}
.modal-cf7-wrap .wpcf7-submit:hover{background:linear-gradient(135deg,#c4001d 0%,#a3001a 100%);}
.modal-cf7-wrap .wpcf7-not-valid-tip{font-size:.74rem;color:var(--red);margin-top:3px;display:block;}
.modal-cf7-wrap .wpcf7-response-output{
  margin:10px 0 0;padding:10px 14px;border-radius:var(--r);font-size:.82rem;border-width:1px!important;
}
.modal-cf7-wrap .wpcf7-mail-sent-ok{background:#F0FDF4;border-color:#86EFAC!important;color:#15803D;}
.modal-cf7-wrap .wpcf7-mail-sent-ng,.modal-cf7-wrap .wpcf7-aborted{background:#FEF2F2;border-color:#FECACA!important;color:#B91C1C;}

/* ── MODAL RESPONSIVE ── */
@media(max-width:700px){
  .quote-modal{grid-template-columns:1fr;max-height:96vh;}
  .modal-left{display:none;}
  .modal-right{padding:24px 20px;}
  .modal-close{background:rgba(15,42,68,.15);border-color:rgba(15,42,68,.12);color:var(--navy);}
}
@media(max-width:480px){
  .qf-row{grid-template-columns:1fr;}
  .modal-right{padding:20px 16px;}
}

/* WooCommerce */
.mabati-shop-wrap{display:grid;grid-template-columns:1fr minmax(0,256px);gap:36px;padding:44px 32px 88px;max-width:var(--max);margin:0 auto;}
.woocommerce ul.products{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:20px!important;margin:0!important;padding:0!important;list-style:none!important;}
.woocommerce ul.products li.product{background:#fff!important;border-radius:var(--r-xl)!important;overflow:hidden!important;border:1px solid var(--border)!important;box-shadow:var(--sh-sm)!important;padding:0!important;margin:0!important;transition:all var(--t)!important;list-style:none!important;}
.woocommerce ul.products li.product:hover{transform:translateY(-6px)!important;box-shadow:var(--sh-xl)!important;border-color:transparent!important;}
.mabati-product-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--off2);}
.mabati-product-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.product-img-overlay{position:absolute;inset:0;background:rgba(15,42,68,.6);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t);}
.woocommerce ul.products li.product:hover .product-img-overlay{opacity:1;}
.quick-view-btn{background:#fff;color:var(--navy);font-family:var(--font-h);font-size:.73rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:8px 16px;border-radius:var(--r-sm);display:flex;align-items:center;gap:5px;}
.quick-view-btn:hover{background:var(--red);color:#fff;}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--font-h)!important;font-size:1rem!important;font-weight:700!important;color:var(--navy)!important;padding:14px 16px 4px!important;}
.woocommerce ul.products li.product .price{font-family:var(--font-h)!important;font-size:1.1rem!important;font-weight:800!important;color:var(--navy)!important;padding:0 16px 4px!important;display:block!important;}
.woocommerce ul.products li.product .price del{color:var(--gray)!important;font-size:.8rem!important;}
.woocommerce ul.products li.product .price ins{text-decoration:none!important;}
.woocommerce ul.products li.product .button{display:block!important;width:calc(100% - 32px)!important;margin:0 16px 14px!important;background:var(--navy)!important;color:#fff!important;font-family:var(--font-h)!important;font-size:.75rem!important;font-weight:700!important;letter-spacing:.06em!important;text-transform:uppercase!important;text-align:center!important;padding:9px 14px!important;border-radius:var(--r-sm)!important;border:2px solid var(--navy)!important;transition:all var(--t)!important;}
.woocommerce ul.products li.product .button:hover{background:var(--red)!important;border-color:var(--red)!important;}
.woocommerce span.onsale{background:var(--red)!important;border-radius:var(--r-sm)!important;font-family:var(--font-h)!important;font-size:.64rem!important;font-weight:700!important;min-height:auto!important;min-width:auto!important;line-height:1!important;padding:4px 9px!important;top:8px!important;left:8px!important;right:auto!important;}
.woocommerce div.product .product_title{font-family:var(--font-h)!important;font-size:2rem!important;font-weight:800!important;color:var(--navy)!important;}
.woocommerce div.product .price{font-family:var(--font-h)!important;font-size:1.8rem!important;font-weight:800!important;color:var(--navy)!important;}
.woocommerce div.product form.cart .single_add_to_cart_button{background:var(--red)!important;color:#fff!important;font-family:var(--font-h)!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.06em!important;padding:13px 30px!important;border-radius:var(--r-sm)!important;border:2px solid var(--red)!important;}
.woocommerce div.product form.cart .single_add_to_cart_button:hover{background:var(--red-dark)!important;}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce form .form-row select{border:1.5px solid var(--border)!important;border-radius:var(--r)!important;padding:10px 12px!important;font-family:var(--font-b)!important;}
.woocommerce a.button.alt,.woocommerce button.button.alt{background:var(--red)!important;color:#fff!important;}
.shop-sidebar{position:sticky;top:calc(var(--hh) + 16px);}
.sidebar-widget{background:#fff;border-radius:var(--r-lg);padding:22px 20px;border:1px solid var(--border);margin-bottom:20px;}
.widget-title{font-family:var(--font-h);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);padding-bottom:10px;margin-bottom:12px;border-bottom:2px solid var(--border);}
.sidebar-cats li a{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border);font-size:.84rem;color:var(--gray-dk);transition:all var(--t);}
.sidebar-cats li:last-child a{border-bottom:none;}
.sidebar-cats li a:hover,.sidebar-cats li.active a{color:var(--red);padding-left:4px;}
.sidebar-cta{background:linear-gradient(135deg,var(--navy),var(--blue));border:none;text-align:center;}
.sidebar-cta-icon{font-size:2rem;color:var(--red);margin-bottom:8px;}
.sidebar-cta h4{color:#fff;font-size:.96rem;margin-bottom:6px;}
.sidebar-cta p{font-size:.8rem;color:rgba(255,255,255,.6);line-height:1.6;margin-bottom:12px;}
.sidebar-features li{display:flex;align-items:center;gap:8px;font-size:.83rem;color:var(--gray-dk);padding:6px 0;border-bottom:1px solid var(--border);}
.sidebar-features li:last-child{border-bottom:none;}
.sidebar-features i{color:var(--red);font-size:.8rem;width:14px;flex-shrink:0;}

/* Contact page */
.contact-page-layout{display:grid;grid-template-columns:1fr 1.55fr;gap:48px;align-items:start;}
.contact-info-panel{background:linear-gradient(160deg,var(--navy),var(--blue));border-radius:var(--r-xl);padding:38px 32px;color:#fff;position:sticky;top:calc(var(--hh) + 16px);}
.contact-info-panel h3{font-size:1.6rem;margin-bottom:7px;}
.contact-info-panel>p{color:rgba(255,255,255,.58);font-size:.87rem;line-height:1.7;margin-bottom:28px;}
.contact-detail-item{display:flex;gap:13px;margin-bottom:20px;}
.cdi-icon{width:40px;height:40px;background:rgba(255,255,255,.1);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.94rem;}
.cdi-label{font-size:.65rem;font-family:var(--font-h);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.36);margin-bottom:2px;}
.cdi-value{font-size:.86rem;color:rgba(255,255,255,.76);}
.cdi-value a{color:rgba(255,255,255,.76);transition:color var(--t);}
.cdi-value a:hover{color:var(--red);}
.contact-hours{margin-top:22px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);}
.contact-hours-title{font-size:.65rem;font-family:var(--font-h);font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:rgba(255,255,255,.36);margin-bottom:10px;}
.hours-row{display:flex;justify-content:space-between;font-size:.8rem;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.66);}
.hours-row:last-child{border-bottom:none;}
.contact-form-panel{background:#fff;border-radius:var(--r-xl);padding:38px 32px;border:1px solid var(--border);box-shadow:var(--sh-sm);}
.contact-form-panel h3{font-size:1.6rem;color:var(--navy);margin-bottom:5px;}
.contact-form-panel>p{color:var(--gray-dk);font-size:.88rem;margin-bottom:24px;}
.form-tabs{display:flex;background:var(--off);border-radius:var(--r);padding:3px;margin-bottom:22px;border:1px solid var(--border);}
.form-tab-btn{flex:1;padding:9px 14px;border-radius:var(--r-sm);border:none;background:transparent;font-family:var(--font-h);font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-dk);cursor:pointer;transition:all var(--t);}
.form-tab-btn.active{background:#fff;color:var(--navy);box-shadow:var(--sh-sm);}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.cf-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;}
.cf-group label{font-family:var(--font-h);font-size:.69rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--gray-dk);display:flex;align-items:center;gap:4px;}
.cf-group input,.cf-group select,.cf-group textarea{padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--r);font-family:var(--font-b);font-size:.9rem;color:var(--text);background:#fff;outline:none;transition:all var(--t);-webkit-appearance:none;}
.cf-group input:focus,.cf-group select:focus,.cf-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(27,63,139,.1);}
.cf-group textarea{resize:vertical;min-height:100px;}
.cf-disclaimer{font-size:.69rem;color:var(--gray);margin-top:9px;display:flex;align-items:center;gap:4px;}
.cf-success{background:#F0FDF4;border:1px solid #86EFAC;color:#166534;padding:14px 18px;border-radius:var(--r);display:none;animation:fadeInUp .4s ease;}
.cf-error{background:#FEF2F2;border:1px solid #FECACA;color:#B91C1C;padding:10px 14px;border-radius:var(--r);display:none;}

/* Scroll reveal */
[data-aos]{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease;}
[data-aos].aos-animate{opacity:1;transform:translateY(0);}
.features-grid [data-aos]:nth-child(1){transition-delay:.04s;}
.features-grid [data-aos]:nth-child(2){transition-delay:.09s;}
.features-grid [data-aos]:nth-child(3){transition-delay:.14s;}
.features-grid [data-aos]:nth-child(4){transition-delay:.19s;}
.features-grid [data-aos]:nth-child(5){transition-delay:.24s;}
.features-grid [data-aos]:nth-child(6){transition-delay:.29s;}

/* Page content */
.page-content-wrap{padding:52px 0 80px;}
.entry-content h2{font-size:1.55rem;color:var(--navy);margin:26px 0 11px;}
.entry-content p{color:var(--gray-dk);line-height:1.8;margin-bottom:14px;}
.entry-content ul,.entry-content ol{margin:0 0 14px 24px;color:var(--gray-dk);line-height:1.75;}
.entry-content a{color:var(--blue);text-decoration:underline;}

/* ━━━ RESPONSIVE ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .mabati-shop-wrap{grid-template-columns:1fr minmax(0,220px);}
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr)!important;}
  .contact-page-layout{grid-template-columns:1fr;}
  .contact-info-panel{position:static;}
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .types-grid{grid-template-columns:repeat(2,1fr);}
  .testimonials-grid{grid-template-columns:repeat(2,1fr);}
  .blog-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:960px){
  /* CTA band: stack to single column */
  .home-cta-inner{grid-template-columns:1fr;gap:44px;}
  .home-cta-col{max-width:100%;}
  .home-cta-sub{max-width:100%;}
}
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr;gap:44px;}
  .about-badge{right:12px;}
  .mabati-shop-wrap{grid-template-columns:1fr;padding:32px 28px 60px;}
  .shop-sidebar{position:static;}
  .quote-modal{grid-template-columns:1fr;max-width:500px;}
  .modal-left{display:none;}
}
@media(max-width:1024px){
  /* Blog & Shop - make hero single column on tablets */
  .blog-hero-inner,
  .shop-hero-inner{grid-template-columns:1fr;gap:24px;}
  .blog-hero-search,
  .shop-hero-search{max-width:100%;}
  /* Blog & Shop - make main layout single column */
  .blog-page-layout,
  .shop-page-layout{grid-template-columns:1fr;gap:32px;}
  .blog-sidebar-wrap,
  .shop-sidebar-wrap{position:static;max-width:100%;}
  /* Blog - make listing grid single column on tablets */
  .blog-listing-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  :root{--hh:60px;}
  .main-nav,.btn-header{display:none;}
  .hamburger{display:flex;}
  .header-topbar{display:none;}
  .hero{min-height:80vh;}
  .hero-title{font-size:2.6rem;}
  .hero-actions{flex-direction:column;}
  .hero-actions .btn{width:100%;justify-content:center;}
  .section{padding:60px 0;}
  .features-grid{grid-template-columns:1fr;}
  .types-grid{grid-template-columns:1fr;}
  .testimonials-grid{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .footer-cta-inner{flex-direction:column;align-items:flex-start;}
  .footer-cta-actions{flex-direction:column;width:100%;}
  .footer-cta-actions .btn{width:100%;justify-content:center;}
  .cf-row,.qf-row{grid-template-columns:1fr;}
  .form-tabs{flex-direction:column;}
  /* CTA band mobile */
  .home-cta-band{padding:60px 0;}
  .home-cta-heading{font-size:2.6rem;}
  .home-cta-col{padding:24px 20px;}
  .home-cta-col .btn{padding:14px 16px;font-size:.86rem;}
  .home-cta-call a{font-size:1.1rem;}
  /* Blog & Shop - mobile improvements */
  .blog-hero,
  .shop-hero{padding:40px 0 32px;}
  .blog-hero h1,
  .shop-hero h1{font-size:2.4rem;margin-bottom:12px;}
  .blog-hero p,
  .shop-hero p{font-size:.95rem;}
  .blog-hero-search input,
  .shop-hero-search input{padding:12px 16px;font-size:.88rem;}
  .blog-hero-search button,
  .shop-hero-search button{padding:12px 16px;}
  /* Blog grid improvements */
  .blog-listing-grid{grid-template-columns:1fr;}
  .blog-page-body,
  .shop-page-body{padding:32px 0 60px;}
  .blog-cat-nav,
  .shop-cat-nav{position:static;}
  .sidebar-card{margin-bottom:16px;}
  /* Shop products mobile optimization */
  .shop-product-card{margin-bottom:16px;}
  .shop-product-img{aspect-ratio:4/3;} /* Better for mobile viewing */
  .shop-product-body{padding:16px;}
  .shop-product-title{font-size:1.05rem;line-height:1.4;margin-bottom:10px;}
  .shop-product-excerpt{font-size:.9rem;margin-bottom:12px;}
  .shop-product-foot{flex-direction:column;align-items:stretch;gap:12px;}
  .shop-product-price{font-size:1.3rem;text-align:left;}
  .shop-product-card .button{
    width:100%;padding:12px 20px;font-size:.8rem;
    justify-content:center;display:flex;
  }
  .shop-toolbar{flex-direction:column;align-items:stretch;}
  .shop-result-count{text-align:left;}
  .shop-ordering{width:100%;}
  .shop-ordering select{width:100%;padding:10px 32px 10px 14px;}
}
/* ================================================================
   SHOP PAGE — Premium WooCommerce Design (Blog Style)
   ================================================================ */

.shop-page{background:#fff;}

/* ── Shop Hero (mirrors blog-hero) ── */
.shop-hero{
  background:linear-gradient(135deg,#071A2B 0%,var(--navy) 55%,#1c3870 100%);
  padding:64px 0 52px;position:relative;overflow:hidden;
}
.shop-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(ellipse 50% 70% at 90% 40%,rgba(232,25,44,.12) 0%,transparent 65%),
    repeating-linear-gradient(0deg,transparent 0,transparent 44px,rgba(255,255,255,.018) 44px,rgba(255,255,255,.018) 45px),
    repeating-linear-gradient(90deg,transparent 0,transparent 60px,rgba(255,255,255,.014) 60px,rgba(255,255,255,.014) 61px);
}
.shop-hero .container{position:relative;z-index:1;}
.shop-hero-inner{
  display:grid;grid-template-columns:1fr 320px;
  align-items:end;gap:48px;
}
.shop-hero-kicker{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-h);font-size:.68rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--red);margin-bottom:14px;
}
.shop-hero-kicker span{width:18px;height:2px;background:var(--red);}
.shop-hero h1{
  font-size:clamp(2.6rem,5vw,4.2rem);font-weight:800;
  color:#fff;line-height:1.04;letter-spacing:-.025em;margin-bottom:14px;
}
.shop-hero p{
  font-size:1.04rem;color:rgba(255,255,255,.54);
  line-height:1.75;max-width:540px;margin:0;
}
.shop-hero-search{display:flex;gap:0;width:100%;}
.shop-hero-search input{
  flex:1;padding:14px 18px;
  border:1.5px solid rgba(255,255,255,.16);border-right:none;
  border-radius:var(--r) 0 0 var(--r);
  font-family:var(--font-b);font-size:.92rem;
  background:rgba(255,255,255,.1);color:#fff;
  outline:none;transition:all var(--t);
}
.shop-hero-search input::placeholder{color:rgba(255,255,255,.38);}
.shop-hero-search input:focus{
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.38);
}
.shop-hero-search button{
  padding:14px 20px;background:var(--red);color:#fff;
  border:1.5px solid var(--red);border-radius:0 var(--r) var(--r) 0;
  cursor:pointer;font-size:.94rem;transition:background var(--t);
}
.shop-hero-search button:hover{background:var(--red-dark);border-color:var(--red-dark);}

/* ── Category nav (mirrors blog-cat-nav) ── */
.shop-cat-nav{
  border-bottom:1px solid var(--border);background:#fff;
  position:sticky;top:var(--hh);z-index:100;
  box-shadow:0 1px 0 var(--border);
}
.shop-cat-nav-inner{
  display:flex;align-items:center;gap:0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
  min-height:50px; /* Ensure minimum height for visibility */
}
.shop-cat-nav-inner::-webkit-scrollbar{display:none;}
.shop-cat-link{
  display:inline-flex;align-items:center;gap:7px;
  padding:14px 18px;
  font-family:var(--font-h);font-size:.76rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--gray-dk);white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color var(--t),border-color var(--t);flex-shrink:0;
}
.shop-cat-link:hover{color:var(--navy);}
.shop-cat-link.active{color:var(--navy);border-bottom-color:var(--red);}
.shop-cat-link-count{
  font-size:.6rem;background:var(--off2);color:var(--gray);
  padding:1px 6px;border-radius:100px;font-weight:700;
  transition:all var(--t);
}
.shop-cat-link.active .shop-cat-link-count{background:var(--red);color:#fff;}
.shop-cat-link i{color:var(--red);font-size:.85rem;}

/* ── Body layout ── */
.shop-page-body{padding:52px 0 88px;background:var(--off);}
.shop-page-layout{
  display:grid;
  grid-template-columns:1fr 292px;
  gap:44px;align-items:start;
}

/* ── Toolbar ── */
.shop-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;margin-bottom:28px;flex-wrap:wrap;
  padding-bottom:16px;border-bottom:1px solid var(--border);
}
.shop-result-count{
  font-family:var(--font-h);font-size:.7rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gray);
}
.shop-ordering select{
  padding:8px 32px 8px 14px;
  border:1px solid var(--border);border-radius:var(--r-sm);
  background:#fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%238A94A6' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e") no-repeat right 8px center/16px;
  font-family:var(--font-b);font-size:.85rem;color:var(--text);
  outline:none;cursor:pointer;appearance:none;
  transition:border-color var(--t);
}
.shop-ordering select:hover{border-color:var(--navy);}

/* ── Product Card Styling ── */
.shop-product-card{
  background:#fff;border-radius:var(--r-lg);
  overflow:hidden;border:1px solid var(--border);
  transition:all .28s var(--ease);
  display:flex;flex-direction:column;
  position:relative;
}
.shop-product-card:hover{
  box-shadow:0 12px 40px rgba(15,42,68,.14);
  transform:translateY(-5px);border-color:transparent;
}
.shop-product-img{
  display:block;aspect-ratio:1/1;overflow:hidden;
  background:var(--off2);flex-shrink:0;position:relative;
  width:100%;
}
.shop-product-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .55s var(--ease);
  display:block;
}
.shop-product-card:hover .shop-product-img img{transform:scale(1.07);}
.shop-sale-badge{
  position:absolute;top:12px;right:12px;z-index:2;
  background:var(--red);color:#fff;
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;
}
.shop-product-body{
  padding:18px 20px 20px;flex:1;
  display:flex;flex-direction:column;
}
.shop-product-meta{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:5px 9px;margin-bottom:8px;
}
.shop-product-cat{
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--red);
}
.shop-product-title{
  font-size:1.02rem;color:var(--navy);line-height:1.32;
  margin-bottom:8px;font-weight:700;
}
.shop-product-title a:hover{color:var(--blue);}
.shop-product-excerpt{
  font-size:.85rem;color:var(--gray-dk);
  line-height:1.68;margin-bottom:14px;flex:1;
}
.shop-product-foot{
  display:flex;align-items:center;
  justify-content:space-between;gap:10px;margin-top:auto;
  flex-wrap:wrap;
}
.shop-product-price{
  font-family:var(--font-h);font-size:1.2rem;
  font-weight:800;color:var(--navy);
}
.shop-product-price del{
  font-size:.85rem;color:var(--gray);
  margin-right:6px;font-weight:500;
}
.shop-product-price ins{
  text-decoration:none;color:var(--red);
}

/* ── Add to Cart Button ── */
.shop-product-card .button{
  padding:8px 16px;font-size:.74rem;
  background:var(--navy);color:#fff;
  border:1px solid var(--navy);
  border-radius:var(--r-sm);
  font-family:var(--font-h);font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  transition:all var(--t) var(--ease);
  cursor:pointer;text-decoration:none;
}
.shop-product-card .button:hover{
  background:var(--blue);border-color:var(--blue);
  transform:translateY(-1px);
}

/* ── Sidebar (reuse blog sidebar styles) ── */
.shop-sidebar-wrap{
  display:flex;flex-direction:column;gap:20px;
  position:sticky;top:calc(var(--hh) + 44px);
}

/* ── Pagination ── */
.shop-pagination{
  margin-top:48px;text-align:center;
}
.shop-pagination .page-numbers{
  display:inline-flex;align-items:center;gap:6px;
}
.shop-pagination .page-numbers a,
.shop-pagination .page-numbers span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:38px;height:38px;padding:0 12px;
  font-family:var(--font-h);font-size:.8rem;font-weight:700;
  color:var(--gray-dk);
  border:1px solid var(--border);border-radius:var(--r-sm);
  transition:all var(--t);
}
.shop-pagination .page-numbers a:hover{
  background:var(--navy);color:#fff;
  border-color:var(--navy);
}
.shop-pagination .page-numbers .current{
  background:var(--red);color:#fff;
  border-color:var(--red);
}

/* ── Empty State ── */
.empty-state{
  text-align:center;padding:88px 20px;
  background:#fff;border-radius:var(--r-xl);
  border:1px solid var(--border);
}
.empty-icon{
  font-size:4rem;color:var(--gray);
  margin-bottom:20px;opacity:.4;
}
.empty-state h3{
  font-size:1.8rem;color:var(--navy);
  margin-bottom:10px;
}
.empty-state p{
  font-size:1rem;color:var(--gray-dk);
  max-width:400px;margin:0 auto 24px;
}

/* ================================================================
   SINGLE PRODUCT PAGE — Premium Hero Design
   ================================================================ */

.product-page{background:#fff;}

/* ── Product Hero (matches shop/blog hero) ── */
.product-hero{
  background:linear-gradient(135deg,#071A2B 0%,var(--navy) 55%,#1c3870 100%);
  padding:48px 0 40px;position:relative;overflow:hidden;
}
.product-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(ellipse 50% 70% at 90% 40%,rgba(232,25,44,.12) 0%,transparent 65%),
    repeating-linear-gradient(0deg,transparent 0,transparent 44px,rgba(255,255,255,.018) 44px,rgba(255,255,255,.018) 45px),
    repeating-linear-gradient(90deg,transparent 0,transparent 60px,rgba(255,255,255,.014) 60px,rgba(255,255,255,.014) 61px);
}
.product-hero .container{position:relative;z-index:1;}
.product-hero-inner{
  max-width:800px;
}
.product-hero-kicker{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-h);font-size:.68rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--red);margin-bottom:14px;
}
.product-hero-kicker span{width:18px;height:2px;background:var(--red);}
.product-hero h1{
  font-size:clamp(2rem,4vw,3.2rem);font-weight:800;
  color:#fff;line-height:1.12;letter-spacing:-.025em;margin-bottom:12px;
}
.product-hero p{
  font-size:.95rem;color:rgba(255,255,255,.62);
  line-height:1.65;margin:0;
}

/* ── Product Category nav (matches shop-cat-nav) ── */
.product-cat-nav{
  border-bottom:1px solid var(--border);background:#fff;
  position:sticky;top:var(--hh);z-index:100;
  box-shadow:0 1px 0 var(--border);
}
.product-cat-nav-inner{
  display:flex;align-items:center;gap:0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
  min-height:50px;
}
.product-cat-nav-inner::-webkit-scrollbar{display:none;}
.product-cat-link{
  display:inline-flex;align-items:center;gap:7px;
  padding:14px 18px;
  font-family:var(--font-h);font-size:.76rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--gray-dk);white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color var(--t),border-color var(--t);flex-shrink:0;
}
.product-cat-link:hover{color:var(--navy);}
.product-cat-link.active{color:var(--navy);border-bottom-color:var(--red);}
.product-cat-link i{color:var(--red);font-size:.85rem;}

/* ── Product Page Body ── */
.product-page-body{
  padding:52px 0 88px;background:var(--off);
}

/* ── Product Page Layout with Sidebar ── */
.product-page-layout{
  display:grid;
  grid-template-columns:1fr minmax(0,272px);
  gap:40px;align-items:start;
}

/* ── Responsive ── */
@media(max-width:1024px){
  .product-page-layout{grid-template-columns:1fr;gap:32px;}
  .product-hero{padding:40px 0 32px;}
  .product-hero h1{font-size:2rem;}
  .product-hero p{font-size:.88rem;}
  .product-cat-nav{position:static;}
  .product-page-body{padding:32px 0 60px;}
}
@media(max-width:768px){
  .product-hero{padding:40px 0 32px;}
  .product-hero h1{font-size:2rem;}
  .product-hero p{font-size:.88rem;}
  .product-cat-nav{position:static;}
  .product-page-body{padding:32px 0 60px;}
}

/* ================================================================
   SHOP GRID - Industry Standard Layout
   ================================================================ */

/* Industry Standard: 4 columns on desktop, 3 on laptop, 2 on tablet, 1 on mobile */
.shop-products-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr); /* Base: 2 columns */
  gap:24px;margin-bottom:36px;
}

/* Large Desktop: 4 columns (1600px+) */
@media(min-width:1600px){
  .shop-products-grid{
    grid-template-columns:repeat(4,1fr);
    gap:24px;
  }
}

/* Desktop: 3 columns (1200px - 1599px) */
@media(min-width:1200px) and (max-width:1599px){
  .shop-products-grid{
    grid-template-columns:repeat(3,1fr);
    gap:24px;
  }
}

/* Laptop: 3 columns (1024px - 1199px) */
@media(min-width:1024px) and (max-width:1199px){
  .shop-products-grid{
    grid-template-columns:repeat(3,1fr);
    gap:20px;
  }
}

/* Tablet: 2 columns (768px - 1023px) */
@media(min-width:768px) and (max-width:1023px){
  .shop-products-grid{
    grid-template-columns:repeat(2,1fr);
    gap:20px;
  }
}

/* Large Mobile: 2 columns (480px - 767px) */
@media(min-width:480px) and (max-width:767px){
  .shop-products-grid{
    grid-template-columns:repeat(2,1fr);
    gap:16px;
  }
}

/* Mobile: 1 column (< 480px) */
@media(max-width:479px){
  .shop-products-grid{
    grid-template-columns:1fr;
    gap:16px;
  }
}

@media(max-width:540px){
  .container{padding:0 18px;}
  .woocommerce ul.products{grid-template-columns:1fr!important;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start;gap:7px;}
  .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
  .stat-div{display:none;}
  .portfolio-card{flex:0 0 270px;}
  /* Shop products - extra small mobile */
  .shop-products-grid{gap:16px;}
  .shop-product-card{border-radius:var(--r);}
  .shop-product-body{padding:14px;}
  .shop-product-title{font-size:1rem;}
  .shop-product-excerpt{font-size:.88rem;line-height:1.6;}
  .shop-product-price{font-size:1.2rem;}
  .shop-product-card .button{padding:11px 18px;font-size:.76rem;}
  .shop-sale-badge{top:10px;right:10px;padding:4px 10px;font-size:.6rem;}
  /* Blog products - extra small mobile */
  .blog-listing-grid{gap:16px;}
  .blog-product-card{border-radius:var(--r);}
}

/* ================================================================
   MABATI PRO v4.1 — CSS ADDITIONS
   Append these rules to the END of assets/css/main.css
   Covers: archive.php, single.php, shop, single-product
   ================================================================ */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   BLOG ARCHIVE — Extra card styles
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Meta separator */
.meta-sep{color:var(--border);font-size:.7rem;}

/* Image placeholder */
.blog-post-img-ph{
  width:100%;height:100%;min-height:180px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 100%);
  font-size:2.8rem;color:rgba(255,255,255,.12);
}

/* Load More button */
.blog-loadmore-wrap{
  text-align:center;margin-top:8px;display:flex;
  flex-direction:column;align-items:center;gap:24px;
}
#blog-load-more{
  gap:10px;position:relative;overflow:hidden;
}
#blog-load-more .load-more-sub{
  display:block;font-size:.64rem;font-weight:400;
  letter-spacing:.06em;opacity:.65;margin-top:2px;
  font-family:var(--font-b);text-transform:none;
}
#blog-load-more.loading::after{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.15);
  animation:shimmer 1s infinite;
}
@keyframes shimmer{0%{transform:translateX(-100%);}100%{transform:translateX(100%)}}

/* Pagination hidden when AJAX active */
.blog-pagination.js-hidden{display:none;}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SINGLE BLOG POST — page wrapper & hero
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.blog-single-page{background:#fff;}

/* ── Post Hero ── */
.post-hero{
  position:relative;overflow:hidden;
  min-height:420px;display:flex;align-items:flex-end;
  padding:0;background:var(--navy);
}
.post-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 8s ease;
}
.post-hero:hover .post-hero-bg{transform:scale(1.03);}
.post-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(7,18,30,.35) 0%,rgba(7,18,30,.88) 100%);
  z-index:1;
}
.post-hero-inner{
  position:relative;z-index:2;
  padding-top:40px;padding-bottom:48px;width:100%;
}
.post-hero-content{max-width:800px;}
.post-hero-cat{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--red);color:#fff;
  font-family:var(--font-h);font-size:.64rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;margin-bottom:16px;
}
.post-hero-title{
  font-size:clamp(1.9rem,4vw,3rem);font-weight:800;
  color:#fff;line-height:1.14;letter-spacing:-.02em;
  margin-bottom:20px;text-shadow:0 2px 12px rgba(0,0,0,.4);
}
.post-hero-meta{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:6px 14px;font-size:.82rem;color:rgba(255,255,255,.65);
}
.post-hero-author{display:flex;align-items:center;gap:8px;}
.post-hero-author span{color:rgba(255,255,255,.82);font-weight:500;}
.post-hero-sep{color:rgba(255,255,255,.25);}
.post-hero-date,.post-hero-readtime,.post-hero-views{
  display:flex;align-items:center;gap:5px;
}
.post-hero-date i,.post-hero-readtime i,.post-hero-views i{color:rgba(255,255,255,.4);}

/* ── Sticky Share Rail (left) ── */
.post-share-rail{
  position:sticky;top:calc(var(--hh) + 48px);float:left;
  margin-left:-80px;margin-right:0;
  display:flex;flex-direction:column;align-items:center;
  gap:8px;width:44px;z-index:50;
}
.share-rail-label{
  font-family:var(--font-h);font-size:.6rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--gray);writing-mode:vertical-rl;
  transform:rotate(180deg);margin-bottom:4px;
}
.share-rail-btn{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;color:#fff;
  border:none;cursor:pointer;transition:transform var(--t),opacity var(--t);
  text-decoration:none;
}
.share-rail-btn:hover{transform:scale(1.15);color:#fff;}
.share-fb{background:#1877F2;}.share-tw{background:#000;}.share-wa{background:#25D366;}
.share-li{background:#0A66C2;}.share-copy{background:var(--gray-dk);}

/* ── Table of Contents ── */
.post-toc{
  background:var(--off);border:1px solid var(--border);
  border-radius:var(--r-lg);margin-bottom:32px;overflow:hidden;
}
.post-toc-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;background:transparent;border:none;cursor:pointer;
  font-family:var(--font-h);font-size:.82rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:var(--navy);
  transition:background var(--t);
}
.post-toc-toggle:hover{background:var(--off2);}
.post-toc-toggle span{display:flex;align-items:center;gap:8px;}
.toc-arrow{transition:transform var(--t);font-size:.72rem;}
.post-toc.collapsed .toc-arrow{transform:rotate(180deg);}
.toc-list{
  padding:4px 18px 14px;display:flex;flex-direction:column;gap:3px;
  counter-reset:toc;
}
.post-toc.collapsed .toc-list{display:none;}
.toc-list li{
  counter-increment:toc;
}
.toc-list a{
  display:flex;align-items:flex-start;gap:8px;
  font-size:.86rem;color:var(--gray-dk);padding:4px 0;
  border-bottom:1px solid transparent;
  transition:color var(--t),padding-left var(--t);
  line-height:1.4;
}
.toc-list a::before{
  content:counter(toc);
  font-family:var(--font-h);font-size:.7rem;font-weight:800;
  color:var(--red);flex-shrink:0;margin-top:2px;
  min-width:14px;
}
.toc-list a:hover{color:var(--navy);padding-left:4px;}
.toc-list a.active{color:var(--red);font-weight:600;}
.toc-list .toc-h3{padding-left:16px;}
.toc-list .toc-h4{padding-left:32px;}

/* ── Post Content Typography ── */
.post-content.entry-content{
  font-size:1rem;line-height:1.85;color:var(--gray-dk);
}
.post-content h2{
  font-size:1.55rem;color:var(--navy);
  margin:36px 0 14px;padding-top:8px;
  border-top:2px solid var(--off2);padding-top:24px;
}
.post-content h3{
  font-size:1.2rem;color:var(--navy);margin:28px 0 10px;
}
.post-content h4{font-size:1.05rem;color:var(--navy);margin:22px 0 8px;}
.post-content p{margin-bottom:1.4em;}
.post-content ul,.post-content ol{
  margin:0 0 1.4em 24px;
}
.post-content li{margin-bottom:.5em;}
.post-content img{
  border-radius:var(--r-lg);margin:24px 0;
  box-shadow:var(--sh);width:100%;height:auto;
}
.post-content blockquote{
  border-left:4px solid var(--red);
  margin:28px 0;padding:16px 24px;
  background:var(--red-light);border-radius:0 var(--r) var(--r) 0;
  font-size:1.06rem;font-style:italic;color:var(--navy);line-height:1.7;
}
.post-content blockquote p{margin:0;}
.post-content a{color:var(--blue);text-decoration:underline;text-underline-offset:3px;}
.post-content a:hover{color:var(--red);}
.post-content code{
  background:var(--off2);padding:2px 6px;border-radius:4px;
  font-size:.9em;color:var(--navy);
}
.post-content pre{
  background:var(--navy);color:#e2e8f0;
  padding:20px 24px;border-radius:var(--r);
  overflow-x:auto;margin:24px 0;font-size:.88rem;
}
.post-content table{
  width:100%;border-collapse:collapse;margin:24px 0;font-size:.9rem;
}
.post-content th,.post-content td{
  padding:10px 14px;text-align:left;
  border:1px solid var(--border);
}
.post-content th{
  background:var(--navy);color:#fff;
  font-family:var(--font-h);font-weight:700;letter-spacing:.05em;
}
.post-content tr:nth-child(even){background:var(--off);}

/* ── Post Tags ── */
.post-tags{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:8px;margin:32px 0 24px;padding:24px 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.tags-label{
  font-family:var(--font-h);font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gray-dk);
  display:flex;align-items:center;gap:6px;
}
.tag-pill{
  background:var(--off);border:1px solid var(--border);
  color:var(--gray-dk);font-size:.76rem;padding:5px 12px;
  border-radius:100px;transition:all var(--t);
}
.tag-pill:hover{background:var(--navy);color:#fff;border-color:var(--navy);}

/* ── Bottom Share Bar ── */
.post-share-bar{
  background:var(--off);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px 22px;
  margin:24px 0;display:flex;flex-wrap:wrap;
  align-items:center;gap:14px;
}
.share-bar-label{
  font-family:var(--font-h);font-size:.74rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--gray-dk);
  display:flex;align-items:center;gap:7px;flex-shrink:0;
}
.share-bar-btns{display:flex;flex-wrap:wrap;gap:8px;}
.btn-share{padding:8px 16px;font-size:.75rem;border-radius:100px;gap:6px;}
.btn-share-fb{background:#1877F2;color:#fff;border-color:#1877F2;}
.btn-share-fb:hover{background:#1460c4;border-color:#1460c4;color:#fff;}
.btn-share-wa{background:#25D366;color:#fff;border-color:#25D366;}
.btn-share-wa:hover{background:#1aaa52;border-color:#1aaa52;color:#fff;}
.btn-share-tw{background:#000;color:#fff;border-color:#000;}
.btn-share-tw:hover{background:#333;border-color:#333;color:#fff;}
.btn-share-copy{background:var(--off2);color:var(--navy);border-color:var(--border);}
.btn-share-copy:hover{background:var(--navy);color:#fff;border-color:var(--navy);}

/* ── Author Box ── */
.post-author-box{
  display:flex;gap:22px;
  background:linear-gradient(135deg,var(--off),var(--off2));
  border:1px solid var(--border);border-radius:var(--r-xl);
  padding:28px;margin:32px 0 28px;
}
.author-box-avatar{flex-shrink:0;}
.author-box-initials{
  width:80px;height:80px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff;font-family:var(--font-h);font-size:1.5rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}
.author-box-role{
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--red);
  margin-bottom:5px;
}
.author-box-name{font-size:1.15rem;color:var(--navy);margin-bottom:8px;}
.author-box-bio{font-size:.87rem;color:var(--gray-dk);line-height:1.72;margin-bottom:14px;}
.author-box-actions{display:flex;flex-wrap:wrap;gap:8px;}

/* ── Related Posts ── */
.related-posts-section{
  background:var(--off);padding:72px 0;
}
.related-posts-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.related-post-card{
  background:#fff;border-radius:var(--r-lg);
  overflow:hidden;border:1px solid var(--border);
  transition:all .28s var(--ease);display:flex;flex-direction:column;
}
.related-post-card:hover{
  box-shadow:var(--sh-lg);transform:translateY(-5px);border-color:transparent;
}
.related-post-img{
  display:block;aspect-ratio:16/9;overflow:hidden;
  background:var(--off2);position:relative;flex-shrink:0;
}
.related-post-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.related-post-card:hover .related-post-img img{transform:scale(1.06);}
.related-post-img-ph{
  width:100%;height:100%;min-height:150px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  font-size:2.5rem;color:rgba(255,255,255,.12);
}
.related-post-badge{
  position:absolute;top:10px;left:10px;
  background:var(--red);color:#fff;
  font-family:var(--font-h);font-size:.6rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;
}
.related-post-body{padding:16px 18px 20px;flex:1;display:flex;flex-direction:column;}
.related-post-title{
  font-size:.97rem;color:var(--navy);line-height:1.3;
  margin-bottom:8px;font-weight:700;flex:1;
}
.related-post-title a:hover{color:var(--blue);}
.related-post-meta{
  display:flex;gap:12px;font-size:.72rem;color:var(--gray);
  margin-bottom:10px;align-items:center;
}
.related-post-meta i{color:var(--gray);font-size:.7rem;}

/* ── Post CTA Band ── */
.post-cta-band{
  background:linear-gradient(112deg,#081c30 0%,var(--navy) 38%,var(--blue) 100%);
  padding:72px 0;position:relative;overflow:hidden;
}
.post-cta-band::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(ellipse 50% 60% at 80% 50%,rgba(232,25,44,.15) 0%,transparent 65%);
}
.post-cta-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr auto;
  gap:48px;align-items:center;
}
.post-cta-text .section-label{margin-bottom:12px;}
.post-cta-text h2{
  font-size:clamp(1.8rem,3.5vw,2.8rem);color:#fff;
  margin-bottom:12px;line-height:1.1;
}
.post-cta-text p{color:rgba(255,255,255,.58);font-size:.95rem;line-height:1.7;margin:0;}
.post-cta-actions{display:flex;flex-wrap:wrap;gap:10px;flex-shrink:0;}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SHOP PAGE — Extra styles
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Trust badges in hero */
.shop-hero-trust{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:8px 20px;margin-top:18px;
}
.shop-hero-trust span{
  display:flex;align-items:center;gap:6px;
  font-family:var(--font-h);font-size:.7rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.shop-hero-trust i{color:var(--red);}

/* Toolbar right */
.shop-toolbar-right{display:flex;align-items:center;gap:10px;}

/* View toggle */
.shop-view-toggle{
  display:flex;gap:3px;background:var(--off);
  border:1px solid var(--border);border-radius:var(--r-sm);padding:3px;
}
.view-btn{
  width:30px;height:30px;border-radius:var(--r-sm);border:none;
  background:transparent;color:var(--gray);font-size:.78rem;
  cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center;
}
.view-btn.active,.view-btn:hover{background:#fff;color:var(--navy);box-shadow:var(--sh-sm);}

/* Mobile toolbar */
.shop-mobile-toolbar{
  display:none;
  position:sticky;top:var(--hh);z-index:90;
  background:#fff;border-bottom:1px solid var(--border);
  padding:10px 0;margin-bottom:20px;
  gap:10px;align-items:center;
}
.shop-mobile-filter-btn{
  display:flex;align-items:center;gap:8px;
  padding:9px 16px;background:var(--navy);color:#fff;
  border:none;border-radius:var(--r-sm);cursor:pointer;
  font-family:var(--font-h);font-size:.78rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  transition:background var(--t);position:relative;
  flex-shrink:0;
}
.shop-mobile-filter-btn:hover{background:var(--blue);}
.filter-active-count{
  background:var(--red);color:#fff;
  font-size:.6rem;font-weight:800;
  width:16px;height:16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-left:4px;
}
.shop-mobile-sort{flex:1;}
.shop-mobile-sort select{
  width:100%;padding:9px 30px 9px 12px;
  border:1px solid var(--border);border-radius:var(--r-sm);
  font-family:var(--font-b);font-size:.85rem;
  background:#fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%238A94A6' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e") no-repeat right 8px center/16px;
  appearance:none;outline:none;color:var(--text);cursor:pointer;
}

/* Filter Drawer */
.shop-filter-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  z-index:1200;opacity:0;pointer-events:none;
  transition:opacity .3s;
}
.shop-filter-overlay.active{opacity:1;pointer-events:all;}
.shop-filter-drawer{
  position:fixed;bottom:-100%;left:0;right:0;
  max-height:88vh;background:#fff;
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  z-index:1201;overflow-y:auto;
  transition:bottom .35s var(--ease);
  box-shadow:0 -8px 40px rgba(0,0,0,.15);
}
.shop-filter-drawer.open{bottom:0;}
.shop-filter-drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px 12px;border-bottom:1px solid var(--border);
  font-family:var(--font-h);font-size:.82rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--navy);
  position:sticky;top:0;background:#fff;z-index:1;
}
.shop-filter-drawer-close{
  width:34px;height:34px;border-radius:50%;
  background:var(--off);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--navy);font-size:.88rem;
  transition:all var(--t);
}
.shop-filter-drawer-close:hover{background:var(--red);color:#fff;border-color:var(--red);}
.shop-filter-drawer-body{padding:16px 20px;}
.shop-filter-group{margin-bottom:22px;}
.shop-filter-title{
  font-family:var(--font-h);font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--navy);
  padding-bottom:10px;margin-bottom:12px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:7px;
}
.shop-filter-title i{color:var(--red);}
.shop-filter-list{display:flex;flex-direction:column;gap:4px;}
.shop-filter-check{
  display:flex;align-items:center;gap:9px;
  padding:7px 10px;border-radius:var(--r-sm);cursor:pointer;
  font-size:.88rem;color:var(--gray-dk);transition:background var(--t);
}
.shop-filter-check:hover{background:var(--off);}
.shop-filter-check input{accent-color:var(--red);width:15px;height:15px;cursor:pointer;}
.check-count{
  margin-left:auto;font-size:.64rem;
  background:var(--off2);color:var(--gray);
  padding:1px 7px;border-radius:100px;
}
.shop-price-range{display:flex;flex-direction:column;gap:10px;}
.price-range-display{
  display:flex;justify-content:space-between;
  font-family:var(--font-h);font-size:.78rem;font-weight:700;color:var(--navy);
}
.price-range-slider{
  width:100%;accent-color:var(--red);cursor:pointer;
}
.shop-filter-sort{
  width:100%;padding:10px 12px;
  border:1.5px solid var(--border);border-radius:var(--r);
  font-family:var(--font-b);font-size:.88rem;
  outline:none;appearance:none;cursor:pointer;
  background:#fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%238A94A6' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e") no-repeat right 10px center/16px;
  transition:border-color var(--t);
}
.shop-filter-sort:focus{border-color:var(--blue);}
.shop-filter-drawer-footer{
  display:flex;flex-direction:column;gap:8px;
  padding-top:16px;border-top:1px solid var(--border);
}

/* Attribute pills */
.shop-attr-pill{
  background:var(--off);border:1px solid var(--border);
  color:var(--gray-dk);font-size:.74rem;padding:5px 11px;
  border-radius:100px;transition:all var(--t);
}
a.shop-attr-pill:hover{background:var(--navy);color:#fff;border-color:var(--navy);}

/* Filter widget in sidebar */
.shop-filter-widget .sidebar-card-head{padding:14px 18px;}

/* Product card — extra elements */
.shop-product-img-ph{
  width:100%;height:100%;min-height:200px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  font-size:3rem;color:rgba(255,255,255,.1);
}
.shop-product-overlay{
  position:absolute;inset:0;background:rgba(15,42,68,.62);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity var(--t);
}
.shop-product-card:hover .shop-product-overlay{opacity:1;}
.shop-quick-view-btn{
  background:#fff;color:var(--navy);
  font-family:var(--font-h);font-size:.74rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  padding:9px 18px;border-radius:var(--r-sm);
  display:flex;align-items:center;gap:6px;transition:all var(--t);
}
.shop-quick-view-btn:hover{background:var(--red);color:#fff;}
.shop-wishlist-btn{
  position:absolute;top:10px;left:10px;
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.92);border:none;
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-dk);font-size:.82rem;cursor:pointer;
  transition:all var(--t);opacity:0;
  box-shadow:var(--sh-sm);
}
.shop-product-card:hover .shop-wishlist-btn{opacity:1;}
.shop-wishlist-btn:hover{background:var(--red);color:#fff;}

/* Stock badges */
.shop-stock-badge{
  font-family:var(--font-h);font-size:.6rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:2px 8px;border-radius:100px;
}
.shop-stock-badge.in{background:rgba(22,163,74,.1);color:#166534;}
.shop-stock-badge.out{background:rgba(232,25,44,.1);color:var(--red);}
.badge-out{background:var(--gray-dk);}

/* Product rating stars */
.shop-product-rating{
  display:flex;align-items:center;gap:7px;
  margin-bottom:6px;
}
.rating-stars{display:flex;gap:2px;}
.rating-stars i,.rating-stars-large i{color:#F59E0B;font-size:.72rem;}
.rating-stars-large i{font-size:.9rem;}
.rating-count{font-size:.72rem;color:var(--gray);}

/* Quote / WA row at bottom of card */
.shop-product-quote-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 14px 12px;border-top:1px solid var(--off2);
  background:var(--off);gap:10px;
}
.shop-product-quote-link,.shop-product-wa-link{
  font-family:var(--font-h);font-size:.66rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  display:flex;align-items:center;gap:4px;transition:color var(--t);
}
.shop-product-quote-link{color:var(--blue);}
.shop-product-quote-link:hover{color:var(--red);}
.shop-product-wa-link{color:#25D366;}
.shop-product-wa-link:hover{color:#1aaa52;}

/* List view mode */
.shop-products-grid.list-view{
  grid-template-columns:1fr!important;
}
.shop-products-grid.list-view .shop-product-card{
  flex-direction:row;
}
.shop-products-grid.list-view .shop-product-img{
  width:200px;flex-shrink:0;aspect-ratio:1/1;
}
.shop-products-grid.list-view .shop-product-body{
  flex:1;padding:20px 24px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SINGLE PRODUCT PAGE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Layout */
.single-product-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:52px;align-items:start;
  margin-bottom:64px;
}

/* ── Gallery ── */
.single-product-gallery{
  position:sticky;top:calc(var(--hh) + 24px);
}
.gallery-main{
  position:relative;border-radius:var(--r-xl);
  overflow:hidden;background:var(--off2);
  margin-bottom:12px;aspect-ratio:1/1;
  border:1px solid var(--border);
}
.gallery-main-link{display:block;height:100%;}
.gallery-main img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.gallery-main:hover img{transform:scale(1.04);}
.gallery-zoom-hint{
  position:absolute;bottom:12px;right:12px;
  background:rgba(255,255,255,.92);color:var(--navy);
  font-family:var(--font-h);font-size:.64rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;
  display:flex;align-items:center;gap:6px;
  opacity:0;transition:opacity var(--t);pointer-events:none;
  box-shadow:var(--sh-sm);
}
.gallery-main:hover .gallery-zoom-hint{opacity:1;}
.gallery-sale-badge{
  position:absolute;top:14px;left:14px;
  background:var(--red);color:#fff;
  font-family:var(--font-h);font-size:.66rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;z-index:2;
}
.gallery-stock-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.5);display:flex;
  align-items:center;justify-content:center;z-index:3;
}
.gallery-stock-overlay span{
  background:#fff;color:var(--gray-dk);
  font-family:var(--font-h);font-size:.8rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:8px 18px;border-radius:100px;
}
.gallery-placeholder{
  width:100%;height:100%;min-height:400px;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:16px;padding:40px;text-align:center;
  font-size:4rem;color:rgba(255,255,255,.12);
}
.gallery-placeholder span{
  font-family:var(--font-h);font-size:.88rem;font-weight:700;
  color:rgba(255,255,255,.3);letter-spacing:.06em;text-transform:uppercase;
}
.gallery-thumbs{
  display:flex;gap:8px;overflow-x:auto;
  scrollbar-width:none;padding-bottom:4px;
}
.gallery-thumbs::-webkit-scrollbar{display:none;}
.gallery-thumb{
  flex:0 0 72px;height:72px;border-radius:var(--r);
  overflow:hidden;border:2px solid var(--border);
  cursor:pointer;transition:border-color var(--t);
  background:var(--off2);
}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;}
.gallery-thumb.active,.gallery-thumb:hover{border-color:var(--red);}

/* Gallery share row */
.product-gallery-share{
  display:flex;align-items:center;gap:8px;
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--border);
}
.product-gallery-share span{
  font-family:var(--font-h);font-size:.66rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gray);
  margin-right:4px;
}
.pgs-btn{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;color:#fff;
  border:none;cursor:pointer;transition:transform var(--t),opacity var(--t);
  text-decoration:none;
}
.pgs-btn:hover{transform:scale(1.12);color:#fff;}
.pgs-fb{background:#1877F2;}.pgs-wa{background:#25D366;}
.pgs-tw{background:#000;}.pgs-copy{background:var(--gray-dk);}

/* ── Product Summary ── */
.single-product-summary{
  position:sticky;top:calc(var(--hh) + 24px);
}
.single-product-cat{
  margin-bottom:10px;
}
.single-product-cat a{
  font-family:var(--font-h);font-size:.68rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--blue);
  display:inline-flex;align-items:center;gap:5px;transition:color var(--t);
}
.single-product-cat a:hover{color:var(--red);}
.single-product-title{
  font-size:clamp(1.65rem,3vw,2.4rem);font-weight:800;
  color:var(--navy);line-height:1.14;margin-bottom:12px;
}
.single-product-rating{
  display:flex;align-items:center;gap:9px;margin-bottom:14px;
}
.rating-text{font-size:.82rem;color:var(--gray-dk);}
.single-product-short-desc{
  font-size:.94rem;color:var(--gray-dk);line-height:1.75;
  margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--border);
}
.single-product-price-wrap{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:8px;margin-bottom:14px;
}
.single-product-price{
  font-family:var(--font-h);font-size:2rem;font-weight:800;color:var(--navy);
}
.single-product-price del{color:var(--gray);font-size:1.1rem;font-weight:400;margin-right:4px;}
.single-product-price ins{text-decoration:none;color:var(--red);}
.single-product-save-badge{
  background:var(--red);color:#fff;
  font-family:var(--font-h);font-size:.64rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;
}
.single-product-tax-note{
  font-size:.72rem;color:var(--gray);
  width:100%;font-style:italic;
}
.single-product-stock{
  display:flex;align-items:center;gap:6px;
  font-family:var(--font-h);font-size:.74rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  padding:9px 14px;border-radius:var(--r-sm);margin-bottom:14px;
}
.single-product-stock.in-stock{
  background:rgba(22,163,74,.08);color:#166534;
  border:1px solid rgba(22,163,74,.2);
}
.single-product-stock.out-of-stock{
  background:rgba(232,25,44,.07);color:var(--red);
  border:1px solid rgba(232,25,44,.2);
}
.single-product-sku{
  font-size:.78rem;color:var(--gray);margin-bottom:14px;
}
.single-product-sku span{font-weight:600;color:var(--gray-dk);}

/* WC form override for single product */
.single-product-form-wrap{margin-bottom:16px;}
.single-product-form-wrap .quantity{display:flex;align-items:center;gap:0;margin-bottom:12px;}
.single-product-form-wrap .qty{
  width:70px;padding:10px 12px;text-align:center;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-family:var(--font-h);font-size:1rem;font-weight:700;
  outline:none;
}
.single-product-form-wrap .qty:focus{border-color:var(--blue);}
.single-product-form-wrap .single_add_to_cart_button{
  width:100%;margin-top:8px;
}

.single-product-ctas{
  display:flex;flex-direction:column;gap:9px;margin-bottom:22px;
}

/* Trust badges */
.single-product-trust{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  padding:18px;background:var(--off);
  border:1px solid var(--border);border-radius:var(--r-lg);
  margin-bottom:18px;
}
.trust-badge-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:8px;border-radius:var(--r-sm);transition:background var(--t);
}
.trust-badge-item:hover{background:var(--off2);}
.trust-badge-icon{
  width:34px;height:34px;border-radius:var(--r-sm);
  background:rgba(232,25,44,.07);color:var(--red);
  display:flex;align-items:center;justify-content:center;
  font-size:.88rem;flex-shrink:0;
}
.trust-badge-item strong{
  display:block;font-family:var(--font-h);font-size:.76rem;
  font-weight:700;color:var(--navy);letter-spacing:.02em;
}
.trust-badge-item span{font-size:.7rem;color:var(--gray);line-height:1.4;}

/* Attribute preview */
.single-product-attr-preview{
  display:flex;flex-direction:column;gap:6px;
}
.attr-preview-row{
  display:flex;align-items:center;gap:8px;
  font-size:.82rem;padding:5px 0;
  border-bottom:1px dotted var(--border);
}
.attr-preview-row:last-child{border-bottom:none;}
.attr-preview-label{
  font-family:var(--font-h);font-size:.69rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:var(--gray-dk);
  min-width:80px;
}
.attr-preview-value{color:var(--navy);font-weight:500;}

/* ── Product Tabs ── */
.single-product-tabs-section{
  background:#fff;border-radius:var(--r-xl);
  border:1px solid var(--border);overflow:hidden;
  margin-bottom:64px;
}
.product-tabs{
  display:flex;overflow-x:auto;scrollbar-width:none;
  border-bottom:2px solid var(--border);
  background:var(--off);
}
.product-tabs::-webkit-scrollbar{display:none;}
.product-tab-btn{
  flex-shrink:0;padding:16px 24px;
  font-family:var(--font-h);font-size:.78rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  color:var(--gray-dk);background:transparent;border:none;
  border-bottom:2px solid transparent;margin-bottom:-2px;
  cursor:pointer;transition:all var(--t);
  display:flex;align-items:center;gap:7px;white-space:nowrap;
}
.product-tab-btn:hover{color:var(--navy);}
.product-tab-btn.active{
  color:var(--navy);border-bottom-color:var(--red);
  background:#fff;
}
.tab-badge{
  background:var(--red);color:#fff;
  font-size:.6rem;padding:2px 6px;border-radius:100px;
}
.product-tab-panel{padding:32px;}
.product-tab-panel.hidden{display:none;}
.product-tab-content{
  font-size:.94rem;color:var(--gray-dk);line-height:1.8;
}
.product-tab-content h2{font-size:1.35rem;color:var(--navy);margin:24px 0 10px;}
.product-tab-content h3{font-size:1.1rem;color:var(--navy);margin:18px 0 8px;}
.product-tab-content p{margin-bottom:1em;}
.product-tab-content ul,.product-tab-content ol{margin:0 0 1em 20px;}

/* Specs table */
.product-specs-table{
  width:100%;border-collapse:collapse;font-size:.88rem;
}
.product-specs-table th,.product-specs-table td{
  padding:10px 16px;text-align:left;
  border:1px solid var(--border);
}
.product-specs-table th{
  background:var(--off);font-family:var(--font-h);font-size:.72rem;
  font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--navy);width:35%;
}
.product-specs-table tr:nth-child(even) td{background:var(--off);}

/* Delivery info grid */
.delivery-info-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:20px;margin-bottom:24px;
}
.delivery-info-item{
  background:var(--off);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:20px;
}
.delivery-icon{
  font-size:1.4rem;color:var(--red);margin-bottom:10px;
}
.delivery-info-item h4{
  font-size:.97rem;color:var(--navy);margin-bottom:6px;
}
.delivery-info-item p{
  font-size:.84rem;color:var(--gray-dk);line-height:1.65;margin:0;
}
.delivery-cta-row{margin-top:8px;}

/* Related products on single product page */
.related-products-shop{
  background:var(--off);padding:72px 0;
}
.related-products-grid-shop{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.related-prod-card{
  background:#fff;border-radius:var(--r-lg);
  overflow:hidden;border:1px solid var(--border);
  transition:all .28s var(--ease);
}
.related-prod-card:hover{
  box-shadow:var(--sh-lg);transform:translateY(-4px);border-color:transparent;
}
.related-prod-img{
  aspect-ratio:1/1;overflow:hidden;
  background:var(--off2);position:relative;display:block;
}
.related-prod-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.related-prod-card:hover .related-prod-img img{transform:scale(1.06);}
.related-prod-body{padding:14px 16px 18px;}
.related-prod-name{
  font-size:.94rem;color:var(--navy);
  line-height:1.3;font-weight:700;margin:5px 0 8px;
}
.related-prod-name a:hover{color:var(--blue);}
.related-prod-price{
  font-family:var(--font-h);font-size:1.05rem;
  font-weight:800;color:var(--navy);
}
.related-prod-price del{color:var(--gray);font-size:.8rem;margin-right:4px;}
.related-prod-price ins{text-decoration:none;color:var(--red);}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WooCommerce overrides — clean up default styles
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Remove WC ul.products margins */
.shop-products-grid ul.products,
.woocommerce ul.products.columns-3{
  display:contents!important;
}

/* WC add to cart on single product */
.woocommerce div.product form.cart .single_add_to_cart_button{
  width:100%!important;padding:14px 24px!important;
  font-size:.88rem!important;letter-spacing:.07em!important;
}
.woocommerce div.product form.cart .qty{
  border:1.5px solid var(--border)!important;
  border-radius:var(--r-sm)!important;
  padding:10px 12px!important;
  font-family:var(--font-h)!important;
  text-align:center!important;
}

/* WC tabs — hide them (we use custom) */
.woocommerce div.product .woocommerce-tabs{display:none!important;}

/* WC reviews inside our tab */
#tab-reviews .woocommerce-Reviews{display:block;}
#tab-reviews .comment-form{margin-top:28px;}
#tab-reviews .comment-form input,
#tab-reviews .comment-form textarea{
  border:1.5px solid var(--border)!important;
  border-radius:var(--r)!important;
  padding:10px 12px!important;
  font-family:var(--font-b)!important;
  width:100%!important;margin-bottom:12px!important;
}
#tab-reviews .comment-form input:focus,
#tab-reviews .comment-form textarea:focus{
  border-color:var(--blue)!important;
  outline:none!important;box-shadow:0 0 0 3px rgba(27,63,139,.1)!important;
}
#tab-reviews #submit{
  background:var(--red)!important;color:#fff!important;
  border:none!important;padding:11px 24px!important;
  font-family:var(--font-h)!important;font-weight:700!important;
  letter-spacing:.06em!important;text-transform:uppercase!important;
  border-radius:var(--r-sm)!important;cursor:pointer!important;
  transition:background var(--t)!important;
}
#tab-reviews #submit:hover{background:var(--red-dark)!important;}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE — New additions
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

@media(max-width:1200px){
  .single-product-layout{grid-template-columns:1fr;gap:36px;}
  .single-product-gallery{position:static;}
  .single-product-summary{position:static;}
  .related-products-grid-shop{grid-template-columns:repeat(3,1fr);}
  .post-share-rail{display:none;}
}

@media(max-width:1024px){
  .post-cta-inner{grid-template-columns:1fr;gap:32px;}
  .post-cta-actions{justify-content:flex-start;}
  .related-products-grid{grid-template-columns:repeat(2,1fr);}
  .related-products-grid-shop{grid-template-columns:repeat(2,1fr);}
  .single-product-trust{grid-template-columns:1fr;}
  .delivery-info-grid{grid-template-columns:1fr;}
  .product-tab-panel{padding:20px;}
}

@media(max-width:768px){
  /* Post hero */
  .post-hero{min-height:320px;align-items:center;}
  .post-hero-title{font-size:1.75rem;}
  .post-hero-meta{flex-wrap:wrap;gap:6px 10px;}
  /* Author box */
  .post-author-box{flex-direction:column;gap:16px;}
  /* Related */
  .related-posts-grid{grid-template-columns:1fr;}
  /* Mobile shop toolbar visible */
  .shop-mobile-toolbar{display:flex;}
  /* Hide desktop toolbar sort (keep view toggle + results count) */
  .shop-toolbar .shop-ordering{display:none;}
  /* Trust in single */
  .single-product-trust{grid-template-columns:1fr 1fr;}
  /* Product tabs */
  .product-tab-btn{padding:12px 16px;font-size:.72rem;}
  /* Related grid */
  .related-products-grid-shop{grid-template-columns:repeat(2,1fr);}
}

@media(max-width:540px){
  .post-hero-title{font-size:1.5rem;}
  .post-share-bar{flex-direction:column;align-items:flex-start;}
  .post-cta-actions{flex-direction:column;width:100%;}
  .post-cta-actions .btn{width:100%;justify-content:center;}
  .related-posts-grid{grid-template-columns:1fr;}
  .related-products-grid-shop{grid-template-columns:1fr;}
  .single-product-trust{grid-template-columns:1fr;}
  .shop-products-grid.list-view .shop-product-card{flex-direction:column;}
  .shop-products-grid.list-view .shop-product-img{width:100%;}
  .gallery-thumbs .gallery-thumb{flex:0 0 60px;height:60px;}
  .delivery-info-grid{grid-template-columns:1fr;}
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   COPY LINK TOAST
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mabati-toast{
  position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(12px);
  background:var(--navy);color:#fff;
  font-family:var(--font-h);font-size:.76rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  padding:10px 20px;border-radius:100px;
  box-shadow:var(--sh-lg);z-index:9999;
  opacity:0;pointer-events:none;
  transition:all .3s var(--ease);
  display:flex;align-items:center;gap:8px;
}
.mabati-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.mabati-toast i{color:#4ade80;}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SCROLL PROGRESS BAR (single post)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;
  background:linear-gradient(90deg,var(--red),var(--blue));
  z-index:9999;transition:width .1s linear;
  pointer-events:none;width:0%;
}

/* ================================================================
   MABATI PRO v4.2 — PATCH CSS
   Cart, Checkout, Single Post fixes, Shop layout, New components
   ================================================================ */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WOOCOMMERCE CART — Brand Colors
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Cart page wrapper */
.woocommerce-cart .woocommerce{padding:48px 0 80px;}

/* Cart table */
.woocommerce table.shop_table{
  border:1px solid var(--border)!important;
  border-collapse:collapse!important;
  border-radius:var(--r-lg)!important;
  overflow:hidden!important;
  font-family:var(--font-b)!important;
}
.woocommerce table.shop_table thead tr{
  background:var(--navy)!important;
}
.woocommerce table.shop_table thead th{
  font-family:var(--font-h)!important;
  font-size:.72rem!important;
  font-weight:700!important;
  letter-spacing:.1em!important;
  text-transform:uppercase!important;
  color:#fff!important;
  padding:14px 18px!important;
  border:none!important;
}
.woocommerce table.shop_table tbody td{
  padding:16px 18px!important;
  border-bottom:1px solid var(--border)!important;
  vertical-align:middle!important;
}
.woocommerce table.shop_table tbody tr:last-child td{border-bottom:none!important;}
.woocommerce table.shop_table tbody tr:hover{background:var(--off)!important;}
.woocommerce table.shop_table .product-name a{
  font-family:var(--font-h)!important;
  font-weight:700!important;
  font-size:1rem!important;
  color:var(--navy)!important;
}
.woocommerce table.shop_table .product-name a:hover{color:var(--red)!important;}
.woocommerce table.shop_table .product-price,
.woocommerce table.shop_table .product-subtotal{
  font-family:var(--font-h)!important;
  font-weight:800!important;
  font-size:1.05rem!important;
  color:var(--navy)!important;
}

/* Cart quantity input */
.woocommerce .quantity .qty{
  border:1.5px solid var(--border)!important;
  border-radius:var(--r-sm)!important;
  padding:8px 10px!important;
  font-family:var(--font-h)!important;
  font-size:.95rem!important;
  font-weight:700!important;
  text-align:center!important;
  width:70px!important;
  color:var(--navy)!important;
  outline:none!important;
  transition:border-color var(--t)!important;
}
.woocommerce .quantity .qty:focus{border-color:var(--blue)!important;}

/* Remove item button */
.woocommerce table.shop_table .product-remove a{
  color:var(--gray)!important;
  font-size:1.1rem!important;
  transition:color var(--t)!important;
  display:flex!important;align-items:center!important;justify-content:center!important;
  width:28px!important;height:28px!important;
}
.woocommerce table.shop_table .product-remove a:hover{color:var(--red)!important;}

/* Update Cart button */
.woocommerce .cart .button[name="update_cart"],
button[name="update_cart"]{
  background:var(--off)!important;
  color:var(--gray-dk)!important;
  border:1.5px solid var(--border)!important;
  font-family:var(--font-h)!important;
  font-size:.76rem!important;
  font-weight:700!important;
  letter-spacing:.07em!important;
  text-transform:uppercase!important;
  padding:10px 20px!important;
  border-radius:var(--r-sm)!important;
  cursor:pointer!important;
  transition:all var(--t)!important;
}
.woocommerce .cart .button[name="update_cart"]:hover,
button[name="update_cart"]:hover{
  background:var(--navy)!important;
  color:#fff!important;
  border-color:var(--navy)!important;
}

/* Continue Shopping link */
.woocommerce .return-to-shop .button{
  background:transparent!important;
  color:var(--blue)!important;
  border:1.5px solid var(--border)!important;
  font-family:var(--font-h)!important;
  font-weight:700!important;
  text-transform:uppercase!important;
  letter-spacing:.06em!important;
  padding:10px 20px!important;
  border-radius:var(--r-sm)!important;
  transition:all var(--t)!important;
}
.woocommerce .return-to-shop .button:hover{
  background:var(--navy)!important;
  color:#fff!important;
  border-color:var(--navy)!important;
}

/* Cart totals box */
.woocommerce .cart_totals{
  background:#fff!important;
  border:1px solid var(--border)!important;
  border-radius:var(--r-xl)!important;
  padding:28px!important;
  box-shadow:var(--sh-sm)!important;
}
.woocommerce .cart_totals h2{
  font-family:var(--font-h)!important;
  font-size:1.1rem!important;
  font-weight:700!important;
  letter-spacing:.1em!important;
  text-transform:uppercase!important;
  color:var(--navy)!important;
  margin-bottom:18px!important;
  padding-bottom:14px!important;
  border-bottom:2px solid var(--border)!important;
}
.woocommerce .cart_totals table.shop_table th{
  font-family:var(--font-h)!important;
  font-size:.72rem!important;
  font-weight:700!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
  color:var(--gray-dk)!important;
  padding:10px 0!important;
  background:transparent!important;
  border:none!important;
  border-bottom:1px solid var(--border)!important;
}
.woocommerce .cart_totals table.shop_table td{
  padding:10px 0!important;
  color:var(--navy)!important;
  border-bottom:1px solid var(--border)!important;
}
.woocommerce .cart_totals .order-total th,
.woocommerce .cart_totals .order-total td{
  font-size:1.1rem!important;
  font-weight:800!important;
  border-bottom:none!important;
  padding-top:16px!important;
}
.woocommerce .cart_totals .order-total .amount{
  color:var(--red)!important;
  font-family:var(--font-h)!important;
  font-size:1.4rem!important;
}

/* ══ PROCEED TO CHECKOUT — RED .btn-primary ══ */
.woocommerce .wc-proceed-to-checkout .checkout-button,
.woocommerce a.checkout-button,
.wc-proceed-to-checkout .button.alt,
.checkout-button.button.alt{
  display:block!important;
  width:100%!important;
  background:var(--red)!important;
  color:#fff!important;
  border:2px solid var(--red)!important;
  border-radius:var(--r-sm)!important;
  font-family:var(--font-h)!important;
  font-size:1rem!important;
  font-weight:700!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
  padding:16px 24px!important;
  text-align:center!important;
  cursor:pointer!important;
  transition:all var(--t) var(--ease)!important;
  box-shadow:0 4px 20px rgba(232,25,44,.3)!important;
  margin-top:16px!important;
  text-decoration:none!important;
}
.woocommerce .wc-proceed-to-checkout .checkout-button:hover,
.woocommerce a.checkout-button:hover,
.checkout-button.button.alt:hover{
  background:var(--red-dark)!important;
  border-color:var(--red-dark)!important;
  transform:translateY(-2px)!important;
  box-shadow:0 8px 28px rgba(232,25,44,.4)!important;
  color:#fff!important;
}

/* Coupon form */
.woocommerce .coupon input.input-text{
  border:1.5px solid var(--border)!important;
  border-radius:var(--r-sm) 0 0 var(--r-sm)!important;
  padding:10px 14px!important;
  font-family:var(--font-b)!important;
  font-size:.88rem!important;
  outline:none!important;
}
.woocommerce .coupon input.input-text:focus{border-color:var(--blue)!important;}
.woocommerce .coupon .button{
  border-radius:0 var(--r-sm) var(--r-sm) 0!important;
  background:var(--navy)!important;
  color:#fff!important;
  border:none!important;
  padding:10px 18px!important;
  font-family:var(--font-h)!important;
  font-size:.76rem!important;
  font-weight:700!important;
  letter-spacing:.06em!important;
  text-transform:uppercase!important;
  cursor:pointer!important;
  transition:background var(--t)!important;
}
.woocommerce .coupon .button:hover{background:var(--blue)!important;}

/* Validation messages — WooCommerce global */
.woocommerce-invalid-required-field label{color:var(--red)!important;}
.woocommerce-error,.woocommerce-message,.woocommerce-info{
  border-radius:var(--r)!important;padding:14px 18px!important;
  font-size:.9rem!important;margin-bottom:16px!important;
}
.woocommerce-error{background:#FEF2F2!important;border-left:4px solid var(--red)!important;color:#B91C1C!important;}
.woocommerce-message{background:#F0FDF4!important;border-left:4px solid #22C55E!important;color:#166534!important;}
.woocommerce-info::before{display:none !important;}

/* Checkbox labels — scoped to checkout form */
.co-form .woocommerce-form__label-for-checkbox{display:flex;align-items:center;gap:9px;font-size:.88rem;color:var(--gray-dk);cursor:pointer;}
.co-form input[type="checkbox"]{width:17px;height:17px;accent-color:var(--red);cursor:pointer;flex-shrink:0;}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SHOP PAGE LAYOUT FIX — correct grid, mobile products first
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Override: sidebar 260px LEFT, main content 1fr RIGHT
   HTML order: main first → on mobile products appear on top */
.shop-page-layout{
  grid-template-columns:260px 1fr!important;
}
/* Sidebar is 2nd in HTML, CSS order pushes it to column 1 */
.shop-main-col{order:2;}
.shop-sidebar-wrap{order:1;}

/* Mobile: single column, natural DOM order (main=products first) */
@media(max-width:1024px){
  .shop-page-layout{grid-template-columns:1fr!important;}
  .shop-main-col{order:1;}
  .shop-sidebar-wrap{order:2;}
}

/* Sidebar price filter padding */
.sidebar-price-filter{padding:16px 18px;}
.sidebar-price-display{
  display:flex;justify-content:space-between;
  font-family:var(--font-h);font-size:.78rem;font-weight:700;color:var(--navy);
  margin-bottom:10px;
}
.sidebar-attr-pills{
  display:flex;flex-wrap:wrap;gap:6px;padding:10px 14px;
}

/* Per-page pills */
.per-page-pill{
  background:var(--off);border:1.5px solid var(--border);
  color:var(--gray-dk);font-family:var(--font-h);font-size:.72rem;
  font-weight:700;letter-spacing:.04em;
  padding:5px 14px;border-radius:100px;
  cursor:pointer;transition:all var(--t);
}
.per-page-pill:hover,.per-page-pill.active{
  background:var(--navy);color:#fff;border-color:var(--navy);
}

/* Per-page select on toolbar */
.shop-perpage{display:flex;align-items:center;}
.shop-perpage-select,.shop-ordering-select{
  padding:8px 28px 8px 12px;
  border:1px solid var(--border);border-radius:var(--r-sm);
  background:#fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%238A94A6' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e") no-repeat right 8px center/14px;
  font-family:var(--font-b);font-size:.84rem;color:var(--text);
  outline:none;cursor:pointer;appearance:none;
  transition:border-color var(--t);
}
.shop-perpage-select:hover,.shop-ordering-select:hover{border-color:var(--navy);}
/* Mobile per-page quick select */
#mob-perpage-quick{min-width:80px;}

/* Related product actions row */
.related-prod-actions{display:flex;gap:8px;margin-top:10px;}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SINGLE BLOG POST v4.2 — New components
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Branded share pills (replaces old btn-share) */
.post-share-bar{
  background:var(--off);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px 22px;
  margin:24px 0;
}
.share-bar-label{
  display:block;
  font-family:var(--font-h);font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gray-dk);
  margin-bottom:12px;display:flex;align-items:center;gap:7px;
}
.share-bar-btns{display:flex;flex-wrap:wrap;gap:8px;}

.share-pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 18px;border-radius:100px;
  font-family:var(--font-h);font-size:.74rem;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;
  color:#fff;border:none;cursor:pointer;
  transition:transform var(--t),box-shadow var(--t),opacity var(--t);
  text-decoration:none;line-height:1;
}
.share-pill:hover{transform:translateY(-2px);opacity:.92;color:#fff;}
.share-pill i{font-size:.88rem;}
.share-pill span{white-space:nowrap;}

.share-pill-fb{background:#1877F2;}
.share-pill-wa{background:#25D366;}
.share-pill-tw{background:#000;}
.share-pill-copy{background:var(--gray-dk);}
.share-pill-copy:hover{background:var(--navy);}

/* Post CTA band — new two-col layout with card */
.post-cta-inner{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:52px;align-items:center;
}
.post-cta-text .section-label{margin-bottom:14px;}
.post-cta-text h2{
  font-size:clamp(1.8rem,3.2vw,2.7rem);
  color:#fff;margin-bottom:14px;line-height:1.1;
}
.post-cta-text p{
  color:rgba(255,255,255,.6);font-size:.95rem;line-height:1.75;margin-bottom:18px;
}
.post-cta-features{
  display:flex;flex-direction:column;gap:7px;margin:0;
  list-style:none!important;
}
.post-cta-features li{
  display:flex;align-items:center;gap:8px;
  font-size:.87rem;color:rgba(255,255,255,.65);
}
.post-cta-features i{color:#4ade80;font-size:.82rem;flex-shrink:0;}

/* CTA action card */
.post-cta-card{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-xl);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  padding:28px 26px;
  display:flex;flex-direction:column;gap:10px;
}
.post-cta-card-label{
  font-family:var(--font-h);font-size:.66rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.38);
  padding-bottom:12px;margin-bottom:2px;
  border-bottom:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;gap:7px;
}
.post-cta-card-label i{color:var(--red);}
.post-cta-card .btn{
  width:100%!important;justify-content:center!important;
  font-size:.92rem!important;padding:15px 20px!important;
}
.post-cta-card .btn-primary{
  box-shadow:0 4px 20px rgba(232,25,44,.4)!important;
}
.post-cta-card .btn-whatsapp{
  box-shadow:0 4px 16px rgba(37,211,102,.28)!important;
}
.post-cta-or{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-h);font-size:.62rem;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.22);
}
.post-cta-or::before,.post-cta-or::after{
  content:'';flex:1;height:1px;background:rgba(255,255,255,.1);
}
.post-cta-phone-link{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-h);font-size:1.1rem;font-weight:800;
  color:#fff;letter-spacing:.02em;transition:color var(--t);
}
.post-cta-phone-link i{color:rgba(255,255,255,.4);font-size:.9rem;}
.post-cta-phone-link:hover{color:var(--red);}

/* CTA band responsive */
@media(max-width:900px){
  .post-cta-inner{grid-template-columns:1fr;gap:36px;}
  .post-cta-card{max-width:480px;}
}
@media(max-width:540px){
  .post-cta-inner{gap:28px;}
  .post-cta-card{padding:20px 18px;}
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SINGLE PRODUCT v4.2 — new components
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* CTA hero — the two big buttons above Add to Cart */
.single-product-cta-hero{
  display:flex;flex-direction:column;gap:10px;
  margin-bottom:6px;
  padding:20px;
  background:linear-gradient(135deg,rgba(15,42,68,.04),rgba(27,63,139,.04));
  border:1px solid var(--border);
  border-radius:var(--r-lg);
}
.single-product-cta-hero .btn{
  width:100%!important;justify-content:center!important;
  font-size:.95rem!important;padding:15px!important;
}
.single-product-cta-hero .btn-primary{
  box-shadow:0 4px 18px rgba(232,25,44,.3)!important;
}
.single-product-cta-hero .btn-whatsapp{
  box-shadow:0 4px 14px rgba(37,211,102,.25)!important;
}

/* "or add to cart below" divider */
.single-product-or-cart{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-h);font-size:.64rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gray);
  margin:4px 0;
}
.single-product-or-cart::before,.single-product-or-cart::after{
  content:'';flex:1;height:1px;background:var(--border);
}

/* Phone CTA row */
.single-product-phone-cta{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  padding:10px 14px;background:var(--off);
  border:1px solid var(--border);border-radius:var(--r-sm);
  font-size:.8rem;color:var(--gray-dk);
}
.single-product-phone-cta i{color:var(--red);}
.single-product-phone-cta a{
  font-family:var(--font-h);font-weight:700;font-size:.9rem;
  color:var(--navy);transition:color var(--t);
}
.single-product-phone-cta a:hover{color:var(--red);}
.phone-hours{
  font-size:.7rem;color:var(--gray);
  font-family:var(--font-h);letter-spacing:.06em;
  text-transform:uppercase;
}

/* Mobile single product layout */
@media(max-width:768px){
  .single-product-cta-hero .btn{padding:14px!important;font-size:.88rem!important;}
  .single-product-layout{gap:28px;}
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ACCESSIBILITY
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;
  margin:-1px;overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* ================================================================
   MABATI PRO v4.2 — REFACTOR PATCH
   Covers: sidebar width, related products, cart/checkout,
           blog sidebar, shop hero mobile, responsive fixes
   ================================================================ */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   1. PRODUCT PAGE — Sidebar wider on large screens
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media(min-width:1400px){
  .product-page-layout{grid-template-columns:1fr minmax(0,296px);}
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   2. RELATED PRODUCTS — Equal card heights + clean grid
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.related-products-grid-shop{
  align-items:stretch!important;
}
.related-prod-card{
  display:flex!important;
  flex-direction:column!important;
}
.related-prod-body{
  flex:1!important;
  display:flex!important;
  flex-direction:column!important;
}
.related-prod-actions{
  margin-top:auto!important;
  padding-top:10px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   3. CART & CHECKOUT — Branded page header + layout fixes
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── Shared hero band (injected via WC hooks in functions.php) ── */
.mabati-page-hero{
  background:linear-gradient(135deg,#071A2B 0%,var(--navy) 55%,#1c3870 100%);
  padding:44px 0 36px;position:relative;overflow:hidden;
}
.mabati-page-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(ellipse 50% 70% at 90% 40%,rgba(232,25,44,.1) 0%,transparent 65%),
    repeating-linear-gradient(0deg,transparent 0,transparent 44px,rgba(255,255,255,.016) 44px,rgba(255,255,255,.016) 45px);
}
.mabati-page-hero .container{position:relative;z-index:1;}
.mabati-page-hero-inner{margin-top:16px;}
.mabati-page-hero h1{
  color:#fff;font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-family:var(--font-h);font-weight:800;
  letter-spacing:-.02em;margin:0;
  display:flex;align-items:center;gap:14px;
}
.mabati-page-hero h1 i{font-size:.85em;opacity:.7;}
.mabati-page-hero p{
  color:rgba(255,255,255,.55);font-size:.93rem;
  margin-top:8px;margin-bottom:0;
}

/* ── Cart & Checkout page wrapper background ── */
.woocommerce-cart,
.woocommerce-checkout{background:var(--off);}

/* ── Cart wrapper ── */
.woocommerce-cart .woocommerce{
  max-width:var(--max);margin:0 auto;
  padding:52px 32px 96px!important;
}
.woocommerce table.shop_table{
  width:100%!important;
  background:#fff!important;
  border-radius:var(--r-xl)!important;
  overflow:hidden!important;
}

/* Cart two-panel layout: table (2fr) + totals (1fr) */
.woocommerce-cart .woocommerce{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
}
.woocommerce-cart .cart-collaterals{
  margin-top:32px;
}
.woocommerce-cart .cart_totals{
  max-width:480px;
  margin-left:auto;
}


/* ── Cart: mobile table stacking ── */
@media(max-width:768px){
  .woocommerce-cart .woocommerce{padding:32px 18px 72px!important;}
  .woocommerce table.shop_table thead{display:none!important;}
  .woocommerce table.shop_table tbody td{
    display:block!important;text-align:right!important;
    padding:10px 14px!important;
  }
  .woocommerce table.shop_table tbody td::before{
    content:attr(data-title) ' ';float:left;
    font-family:var(--font-h);font-size:.7rem;font-weight:700;
    letter-spacing:.08em;text-transform:uppercase;color:var(--gray);
  }
}

/* ── Hero responsive ── */
@media(max-width:768px){
  .mabati-page-hero{padding:32px 0 28px;}
  .mabati-page-hero h1{font-size:1.7rem;}
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   4. BLOG SIDEBAR — ensure full theme-style inheritance
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Sidebar widget form inputs match theme */
.blog-sidebar-wrap input[type="text"],
.blog-sidebar-wrap input[type="search"],
.blog-sidebar-wrap input[type="email"],
.blog-sidebar-wrap select,
.blog-sidebar-wrap textarea{
  font-family:var(--font-b)!important;
  font-size:.88rem!important;
  color:var(--text)!important;
  border:1.5px solid var(--border)!important;
  border-radius:var(--r)!important;
  background:#fff!important;
  outline:none!important;
  transition:border-color var(--t)!important;
}
.blog-sidebar-wrap input:focus,
.blog-sidebar-wrap select:focus,
.blog-sidebar-wrap textarea:focus{
  border-color:var(--blue)!important;
  box-shadow:0 0 0 3px rgba(27,63,139,.08)!important;
}

/* Sidebar widget generic WP buttons */
.blog-sidebar-wrap .widget .button,
.blog-sidebar-wrap .widget button,
.blog-sidebar-wrap .widget input[type="submit"]{
  background:var(--navy)!important;color:#fff!important;
  border:none!important;border-radius:var(--r-sm)!important;
  font-family:var(--font-h)!important;font-size:.76rem!important;
  font-weight:700!important;letter-spacing:.07em!important;
  text-transform:uppercase!important;
  padding:10px 18px!important;cursor:pointer!important;
  transition:background var(--t)!important;
}
.blog-sidebar-wrap .widget .button:hover,
.blog-sidebar-wrap .widget button:hover,
.blog-sidebar-wrap .widget input[type="submit"]:hover{
  background:var(--red)!important;
}

/* WP default widget titles in blog sidebar */
.blog-sidebar-wrap .widget_title,
.blog-sidebar-wrap .widgettitle,
.blog-sidebar-wrap h2.widget-title{
  font-family:var(--font-h)!important;
  font-size:.72rem!important;font-weight:700!important;
  letter-spacing:.12em!important;text-transform:uppercase!important;
  color:var(--navy)!important;
  padding-bottom:10px!important;margin-bottom:14px!important;
  border-bottom:2px solid var(--border)!important;
}

/* WP default list-based widgets (categories, pages, etc.) */
.blog-sidebar-wrap .widget ul{list-style:none!important;margin:0!important;padding:0!important;}
.blog-sidebar-wrap .widget ul li a{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;border-bottom:1px solid var(--border);
  font-size:.86rem;color:var(--gray-dk);
  transition:all var(--t);font-family:var(--font-b);
}
.blog-sidebar-wrap .widget ul li:last-child a{border-bottom:none;}
.blog-sidebar-wrap .widget ul li a:hover{color:var(--red);padding-left:4px;}
.blog-sidebar-wrap .widget ul li .post-count{
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  background:var(--off2);padding:2px 8px;border-radius:100px;color:var(--gray);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   5. SHOP HERO — Mobile responsiveness
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media(max-width:640px){
  .shop-hero{padding:32px 0 28px;}
  .shop-hero h1{font-size:2rem!important;line-height:1.1;}
  .shop-hero p{font-size:.88rem;line-height:1.65;}
  .shop-hero-kicker{font-size:.62rem;margin-bottom:10px;}
  .shop-hero-search{flex-direction:column;gap:10px;}
  .shop-hero-search input{
    border-radius:var(--r)!important;border-right:1.5px solid rgba(255,255,255,.16)!important;
    padding:14px 16px!important;
  }
  .shop-hero-search button{
    border-radius:var(--r)!important;padding:14px!important;
    justify-content:center;display:flex;align-items:center;gap:8px;
  }
  .shop-hero-search button::after{content:'Search';}

  /* Trust badges below hero stack cleanly */
  .shop-hero-badges{
    flex-wrap:wrap;gap:10px;justify-content:flex-start;
  }
  .shop-hero-badge{flex:1 1 calc(50% - 5px);min-width:130px;}
}

@media(max-width:480px){
  .shop-hero{padding:28px 0 24px;}
  .shop-hero h1{font-size:1.75rem!important;}
  .shop-hero p{display:none;}/* hide long desc on tiny screens */
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   6. PRODUCT PAGE BODY — Spacing & alignment improvements
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Ensure shop sidebar items match overall card style */
.shop-sidebar-wrap .sidebar-card,
.shop-sidebar-wrap .sidebar-cta-card{
  border-radius:var(--r-lg)!important;
  border:1px solid var(--border)!important;
  background:#fff!important;
}

/* Remove extra bottom margin on last sidebar widget */
.shop-sidebar-wrap>*:last-child{margin-bottom:0!important;}
.blog-sidebar-wrap>*:last-child{margin-bottom:0!important;}

/* Product page sidebar card consistent head */
.shop-sidebar-wrap .sidebar-card-head,
.product-page-layout .sidebar-card-head{
  font-family:var(--font-h)!important;
  font-size:.72rem!important;font-weight:700!important;
  letter-spacing:.12em!important;text-transform:uppercase!important;
  color:var(--navy)!important;
}



/* ═══════════════════════════════════════════════════════════════════════
   MABATI PRO — SHOP PAGE (sp-*) — Best Practice Styles
   archive-product.php + content-product.php
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Page wrapper ── */
.sp-page{
  background:var(--off,#f8f9fb);
  min-height:60vh;
}

/* ── Hero ── */
.sp-hero{
  background:linear-gradient(135deg,var(--navy,#0f2043) 0%,#1b3f8b 100%);
  color:#fff;
  padding:52px 0 44px;
  position:relative;
  overflow:hidden;
}
.sp-hero::before{
  content:'';
  position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.sp-hero-inner{
  display:flex;
  align-items:center;
  gap:48px;
  position:relative;z-index:1;
}
.sp-hero-text{flex:1;min-width:0;}
.sp-hero-title{
  font-family:var(--font-h);
  font-size:clamp(1.6rem,4vw,2.6rem);
  font-weight:800;
  color:#fff;
  margin:0 0 10px;
  line-height:1.15;
  letter-spacing:-.02em;
}
.sp-hero-desc{
  font-size:1rem;
  color:rgba(255,255,255,.82);
  margin:0 0 18px;
  max-width:560px;
}
.sp-hero-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.sp-hero-badges span{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  border-radius:40px;
  padding:5px 13px;
  font-size:.78rem;
  font-weight:600;
  color:rgba(255,255,255,.92);
}
.sp-hero-badges span i{
  color:var(--gold,#f5a623);
  font-size:.7rem;
}

/* Hero search */
.sp-hero-search{
  display:flex;
  align-items:center;
  background:#fff;
  border-radius:var(--r-sm,8px);
  overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.18);
  width:100%;
  max-width:360px;
  flex-shrink:0;
}
.sp-hero-search-input{
  flex:1;
  border:none;
  outline:none;
  padding:14px 18px;
  font-family:var(--font-b);
  font-size:.95rem;
  color:var(--navy);
  background:transparent;
  min-width:0;
}
.sp-hero-search-input::placeholder{color:var(--gray,#8a9bb5);}
.sp-hero-search-btn{
  background:var(--red,#e8192c);
  border:none;
  color:#fff;
  padding:14px 18px;
  cursor:pointer;
  font-size:1rem;
  transition:background var(--t,.25s);
  flex-shrink:0;
}
.sp-hero-search-btn:hover{background:var(--red-dark,#c0121f);}

/* ── Category nav strip ── */
.sp-cat-nav{
  background:#fff;
  border-bottom:1px solid var(--border,#e2e8f0);
  position:sticky;
  top:var(--hh,68px); /* sits directly below the fixed site header */
  z-index:80;
  box-shadow:0 2px 8px rgba(15,32,67,.06);
}
.sp-cat-nav-inner{
  display:flex;
  align-items:center;
  gap:4px;
  overflow-x:auto;
  scrollbar-width:none;
  -ms-overflow-style:none;
  padding:0 0 0 0;
  white-space:nowrap;
}
.sp-cat-nav-inner::-webkit-scrollbar{display:none;}
.sp-cat-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:14px 16px;
  font-family:var(--font-h);
  font-size:.82rem;
  font-weight:600;
  color:var(--gray-dk,#4a5568);
  text-decoration:none;
  border-bottom:3px solid transparent;
  transition:all var(--t,.25s);
  white-space:nowrap;
}
.sp-cat-link:hover{
  color:var(--navy);
  border-bottom-color:var(--navy);
}
.sp-cat-link.is-active{
  color:var(--red,#e8192c);
  border-bottom-color:var(--red);
}
.sp-cat-count{
  display:inline-block;
  background:var(--off,#f0f4f8);
  color:var(--gray,#8a9bb5);
  border-radius:40px;
  padding:1px 7px;
  font-size:.68rem;
  font-weight:700;
  transition:all var(--t,.25s);
}
.sp-cat-link.is-active .sp-cat-count{
  background:var(--red,#e8192c);
  color:#fff;
}

/* ── Page body ── */
.sp-body{
  padding:36px 0 72px;
}

/* ── Unified toolbar bar (replaces sp-toolbar + sp-toolbar-mobile + sp-layout) ── */
.sp-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 16px;
  background:#fff;
  border:1px solid var(--border,#e2e8f0);
  border-radius:var(--r-sm,8px);
  margin-bottom:20px;
}
.sp-bar-left{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.sp-bar-right{
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}

.sp-result-count{
  font-family:var(--font-h);
  font-size:.82rem;
  color:var(--gray,#8a9bb5);
}
.sp-result-count p{margin:0;}

/* WooCommerce ordering select inside toolbar */
.sp-bar .woocommerce-ordering{margin:0;}
.sp-bar .woocommerce-ordering select,
.sp-ordering-select{
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  padding:7px 12px;
  font-family:var(--font-h);
  font-size:.8rem;
  font-weight:600;
  color:var(--navy);
  background:#fff;
  cursor:pointer;
  outline:none;
  transition:border-color var(--t);
}
.sp-bar .woocommerce-ordering select:focus,
.sp-ordering-select:focus{border-color:var(--navy);}

/* View toggle */
.sp-view-toggle{
  display:flex;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  overflow:hidden;
}
.sp-view-btn{
  background:transparent;
  border:none;
  padding:6px 11px;
  color:var(--gray);
  cursor:pointer;
  transition:all var(--t);
  font-size:.9rem;
}
.sp-view-btn.is-active,
.sp-view-btn:hover{
  background:var(--navy);
  color:#fff;
}
.sp-desktop-only{}

/* ── Product grid (ul.products) — 4 cols full-width ── */
ul.products{
  display:grid !important;
  grid-template-columns:repeat(4,1fr) !important;
  gap:20px !important;
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}

/* List view state */
.sp-main.is-list ul.products{
  grid-template-columns:1fr !important;
  gap:12px !important;
}
.sp-main.is-list ul.products li.shop-product-card{
  display:flex !important;
  gap:20px;
}
.sp-main.is-list ul.products .shop-product-img{
  width:160px;
  flex-shrink:0;
}
.sp-main.is-list ul.products .shop-product-body{
  flex:1;
}

/* ── Pagination ── */
.sp-pagination{margin-top:32px;}
.sp-pagination .nav-links{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  flex-wrap:wrap;
}
.sp-pagination .page-numbers{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;height:40px;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  font-family:var(--font-h);
  font-size:.88rem;
  font-weight:600;
  color:var(--navy);
  text-decoration:none;
  transition:all var(--t);
  background:#fff;
}
.sp-pagination .page-numbers:hover{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
}
.sp-pagination .page-numbers.current{
  background:var(--red);
  border-color:var(--red);
  color:#fff;
}
.sp-pagination .page-numbers.dots{
  border-color:transparent;
  background:transparent;
  width:auto;
}

/* ── Empty state ── */
.sp-empty{
  text-align:center;
  padding:60px 24px;
}
.sp-empty-icon{
  font-size:3.5rem;
  color:var(--border);
  margin-bottom:20px;
}
.sp-empty h3{
  font-family:var(--font-h);
  color:var(--navy);
  margin:0 0 8px;
}
.sp-empty p{
  color:var(--gray);
  margin:0 0 24px;
}
.sp-empty-actions{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
}

/* ── Sidebar widgets ── */
.sp-widget{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r,12px);
  padding:20px;
  margin-bottom:20px;
}
.sp-widget:last-child{margin-bottom:0;}
.sp-widget-title{
  font-family:var(--font-h);
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--navy);
  margin:0 0 14px;
  padding-bottom:12px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:7px;
}
.sp-widget-title i{
  color:var(--red);
  font-size:.75rem;
}

/* Category list */
.sp-cat-list{
  list-style:none;
  margin:0;padding:0;
}
.sp-cat-item{
  border-bottom:1px solid var(--off);
}
.sp-cat-item:last-child{border-bottom:none;}
.sp-cat-item a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 4px;
  font-size:.88rem;
  color:var(--gray-dk);
  text-decoration:none;
  transition:color var(--t);
}
.sp-cat-item a:hover,
.sp-cat-item.is-active a{
  color:var(--red);
}
.sp-cat-item.is-active a{font-weight:700;}
.sp-cat-item-count{
  background:var(--off);
  border-radius:40px;
  padding:2px 8px;
  font-size:.68rem;
  font-weight:700;
  color:var(--gray);
}
.sp-cat-item.is-active .sp-cat-item-count{
  background:var(--red);
  color:#fff;
}

/* Price filter */
.sp-price-filter{}
.sp-price-display{
  display:flex;
  justify-content:space-between;
  font-size:.82rem;
  color:var(--gray);
  margin-bottom:10px;
}
.sp-price-display strong{color:var(--navy);}
.sp-price-slider{
  -webkit-appearance:none;
  appearance:none;
  width:100%;
  height:4px;
  border-radius:2px;
  background:linear-gradient(to right,var(--red) 0%,var(--red) 100%);
  outline:none;
  cursor:pointer;
}
.sp-price-slider::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:18px;height:18px;
  border-radius:50%;
  background:var(--red);
  border:3px solid #fff;
  box-shadow:0 2px 6px rgba(0,0,0,.18);
  cursor:pointer;
}
.sp-price-slider::-moz-range-thumb{
  width:18px;height:18px;
  border-radius:50%;
  background:var(--red);
  border:3px solid #fff;
  box-shadow:0 2px 6px rgba(0,0,0,.18);
  cursor:pointer;
}

/* Attribute pills */
.sp-attr-pills{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
}
.sp-attr-pill{
  display:inline-block;
  padding:5px 12px;
  border:1.5px solid var(--border);
  border-radius:40px;
  font-size:.78rem;
  font-weight:600;
  color:var(--navy);
  text-decoration:none;
  transition:all var(--t);
}
.sp-attr-pill:hover{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
}

/* CTA widget */
.sp-cta-widget{
  text-align:center;
  background:linear-gradient(135deg,var(--navy) 0%,#1b3f8b 100%);
  border-color:transparent;
  color:#fff;
}
.sp-cta-widget h4,.sp-cta-widget p{color:#fff;}
.sp-cta-widget h4{font-family:var(--font-h);font-size:1rem;font-weight:700;margin:0 0 6px;}
.sp-cta-widget p{font-size:.84rem;opacity:.85;margin:0 0 16px;}
.sp-cta-icon{
  font-size:2rem;
  color:var(--gold,#f5a623);
  margin-bottom:12px;
}

/* Trust list */
.sp-trust-list{
  list-style:none;
  margin:0;padding:0;
}
.sp-trust-list li{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 0;
  border-bottom:1px solid var(--off);
  font-size:.86rem;
  color:var(--gray-dk);
}
.sp-trust-list li:last-child{border-bottom:none;}
.sp-trust-list li i{
  color:var(--red);
  font-size:.8rem;
  width:16px;
  flex-shrink:0;
}

/* ── Mobile toolbar ── */
.sp-filter-open-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  padding:9px 16px;
  font-family:var(--font-h);
  font-size:.84rem;
  font-weight:600;
  color:var(--navy);
  cursor:pointer;
  transition:all var(--t);
  position:relative;
}
.sp-filter-open-btn:hover{border-color:var(--navy);}
.sp-active-count{
  background:var(--red);
  color:#fff;
  border-radius:50%;
  width:18px;height:18px;
  font-size:.65rem;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.sp-active-count:empty{display:none;}

/* ── Filter drawer ── */
.sp-filter-backdrop{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  z-index:1000;
  opacity:0;
  transition:opacity var(--t);
}
.sp-filter-backdrop.is-open{
  display:block;
  opacity:1;
}
.sp-filter-drawer{
  position:fixed;
  top:0;left:0;bottom:0;
  width:min(320px,92vw);
  background:#fff;
  z-index:1001;
  transform:translateX(-100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  display:flex;
  flex-direction:column;
  box-shadow:8px 0 40px rgba(0,0,0,.15);
}
.sp-filter-drawer.is-open{
  transform:translateX(0);
}
.sp-filter-drawer-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 20px;
  border-bottom:1px solid var(--border);
  font-family:var(--font-h);
  font-size:.9rem;
  font-weight:700;
  color:var(--navy);
}
.sp-filter-close{
  background:var(--off);
  border:none;
  width:34px;height:34px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:var(--gray-dk);
  font-size:1rem;
  transition:all var(--t);
}
.sp-filter-close:hover{background:var(--navy);color:#fff;}
.sp-filter-drawer-body{
  flex:1;
  overflow-y:auto;
  padding:16px 20px;
}
.sp-filter-section{
  margin-bottom:24px;
  padding-bottom:24px;
  border-bottom:1px solid var(--off);
}
.sp-filter-section:last-child{
  border-bottom:none;margin-bottom:0;
}
.sp-filter-label{
  font-family:var(--font-h);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.07em;
  text-transform:uppercase;
  color:var(--navy);
  margin:0 0 12px;
  display:flex;align-items:center;gap:6px;
}
.sp-filter-label i{color:var(--red);font-size:.7rem;}
.sp-filter-radios{
  list-style:none;
  margin:0;padding:0;
}
.sp-filter-radios li{margin-bottom:2px;}
.sp-filter-radio{
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 4px;
  cursor:pointer;
  font-size:.88rem;
  color:var(--gray-dk);
  transition:color var(--t);
}
.sp-filter-radio:hover{color:var(--navy);}
.sp-filter-radio input{
  accent-color:var(--red);
  width:15px;height:15px;
  cursor:pointer;
  flex-shrink:0;
}
.sp-filter-radio span:first-of-type{flex:1;}
.sp-filter-count{
  background:var(--off);
  border-radius:40px;
  padding:1px 7px;
  font-size:.68rem;
  font-weight:700;
  color:var(--gray);
}
.sp-perpage-pills{
  display:flex;gap:8px;
}
.sp-pp-pill{
  flex:1;
  padding:8px;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  background:#fff;
  font-family:var(--font-h);
  font-size:.82rem;
  font-weight:600;
  color:var(--navy);
  cursor:pointer;
  text-align:center;
  transition:all var(--t);
}
.sp-pp-pill.is-active,.sp-pp-pill:hover{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
}
.sp-filter-drawer-footer{
  padding:16px 20px;
  border-top:1px solid var(--border);
  display:flex;
  gap:10px;
}

/* Prevent body scroll when drawer open */
body.sp-drawer-open{overflow:hidden;}

/* ── WooCommerce notices inside shop ── */
.sp-main .woocommerce-info,
.sp-main .woocommerce-error,
.sp-main .woocommerce-message{
  margin-bottom:16px;
}

/* ── Responsive: Shop Page ── */

/* Large desktop: 4 cols (default, set above) */

/* Medium desktop / tablet landscape */
@media(max-width:1100px){
  ul.products{
    grid-template-columns:repeat(3,1fr) !important;
  }
}

/* Tablet */
@media(max-width:900px){
  .sp-view-toggle,
  .sp-desktop-only{display:none !important;}
  /* Also hide the WooCommerce ordering select in the toolbar on mobile
     (it's available inside the filter drawer instead) */
  .sp-bar .woocommerce-ordering{display:none !important;}
  ul.products{
    grid-template-columns:repeat(2,1fr) !important;
    gap:14px !important;
  }
}

/* Large mobile */
@media(max-width:640px){
  .sp-hero{padding:36px 0 30px;}
  .sp-hero-inner{flex-direction:column;gap:24px;}
  .sp-hero-search{max-width:100%;}
  .sp-hero-title{font-size:1.55rem;}
  .sp-hero-badges{gap:6px;}
  .sp-hero-badges span{font-size:.72rem;padding:4px 10px;}
  .sp-body{padding:24px 0 48px;}
  ul.products{
    grid-template-columns:repeat(2,1fr) !important;
    gap:10px !important;
  }
}

/* Small mobile */
@media(max-width:420px){
  ul.products{
    grid-template-columns:1fr !important;
  }
}

/* ── btn-outline-red (used in sidebar price filter apply btn) ── */
.btn-outline-red{
  border:1.5px solid var(--red,#e8192c) !important;
  color:var(--red,#e8192c) !important;
  background:transparent !important;
}
.btn-outline-red:hover{
  background:var(--red,#e8192c) !important;
  color:#fff !important;
}

/* ── Product card: ensure equal heights in grid ── */
ul.products li.shop-product-card{
  display:flex !important;
  flex-direction:column !important;
}
ul.products li.shop-product-card .shop-product-body{
  flex:1 !important;
  display:flex !important;
  flex-direction:column !important;
}
ul.products li.shop-product-card .shop-product-foot{
  margin-top:auto !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   CART PAGE (cart-*)
   cart/cart.php v4.4
   ═══════════════════════════════════════════════════════════════════════ */

.cart-page{
  padding:48px 0 80px;
  background:var(--off,#f8f9fb);
  min-height:60vh;
}

/* Two-column layout */
.cart-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:32px;
  align-items:start;
  margin-top:32px;
}

/* ── Column headings ── */
.cart-col-title{
  font-family:var(--font-h);
  font-size:1.15rem;
  font-weight:700;
  color:var(--navy);
  margin:0 0 20px;
  display:flex;
  align-items:center;
  gap:10px;
}
.cart-col-title i{color:var(--red);}
.cart-item-count{
  background:var(--off);
  border:1px solid var(--border);
  border-radius:40px;
  padding:2px 10px;
  font-size:.78rem;
  font-weight:600;
  color:var(--gray);
  margin-left:4px;
}

/* ── Item card ── */
.cart-items-list{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r,12px);
  overflow:hidden;
}
.cart-item{
  display:grid;
  grid-template-columns:88px 1fr;
  align-items:start;
  gap:16px;
  padding:20px;
  border-bottom:1px solid var(--off);
  transition:background var(--t,.25s);
}
.cart-item:last-child{border-bottom:none;}
.cart-item:hover{background:var(--off);}

/* Thumbnail */
.cart-item-img{
  width:88px;
  height:88px;
  border-radius:var(--r-sm,8px);
  overflow:hidden;
  flex-shrink:0;
  background:var(--off);
}
.cart-item-img img,
.cart-item-img a{display:block;width:100%;height:100%;}
.cart-item-img img{object-fit:cover;width:100%;height:100%;}

/* Body */
.cart-item-body{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}

/* Header row: name left, subtotal right */
.cart-item-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.cart-item-name{
  font-family:var(--font-h);
  font-size:.93rem;
  font-weight:700;
  color:var(--navy);
  min-width:0;
}
.cart-item-name a{color:inherit;text-decoration:none;}
.cart-item-name a:hover{color:var(--red);}
.cart-item-subtotal{
  font-family:var(--font-h);
  font-size:1rem;
  font-weight:700;
  color:var(--navy);
  white-space:nowrap;
  flex-shrink:0;
}
.cart-item-subtotal ins{text-decoration:none;}

/* Meta row: "12 sheets × 2.70 m = 32.40 m" + variation attrs */
.cart-item-meta dl.variation,
.cart-item-meta{
  font-size:.8rem;
  color:var(--gray);
  line-height:1.5;
}
.cart-item-meta dl{margin:0;display:flex;flex-direction:column;gap:2px;}
.cart-item-meta dt{font-weight:600;color:var(--navy-soft,#4a5568);display:inline;}
.cart-item-meta dd{margin:0;display:inline;}
.cart-item-meta dt::after{content:': ';}
.cart-item-meta p{margin:0;}

.cart-item-backorder{
  font-size:.78rem;color:var(--gold,#f5a623);margin:0;
}

/* Footer row: unit price left, actions right */
.cart-item-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:2px;
}
.cart-item-unit-price{
  font-size:.82rem;
  color:var(--gray);
  display:flex;
  align-items:baseline;
  gap:2px;
  flex-wrap:wrap;
}
.cart-item-unit-label{
  font-size:.72rem;
  opacity:.75;
}

/* Actions: qty inputs + remove */
.cart-item-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.cart-item-qty .quantity{display:flex;align-items:center;gap:0;}
.cart-item-qty input.qty{
  width:52px;
  text-align:center;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  padding:7px 6px;
  font-family:var(--font-h);
  font-size:.88rem;
  font-weight:600;
  color:var(--navy);
  outline:none;
  transition:border-color var(--t);
}
.cart-item-qty input.qty:focus{border-color:var(--navy);}

/* MMP (Mabati Meter Pricing) custom cart inputs */
.mmp-cart-field{
  display:flex;
  align-items:center;
  gap:4px;
  flex-direction:column;
}
.mmp-cart-label{
  font-size:.68rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--gray);
  white-space:nowrap;
}
.mmp-cart-input{
  width:56px;
  text-align:center;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  padding:5px 4px;
  font-family:var(--font-h);
  font-size:.85rem;
  font-weight:600;
  color:var(--navy);
  outline:none;
  transition:border-color var(--t);
  -moz-appearance:textfield;
}
.mmp-cart-input::-webkit-inner-spin-button,
.mmp-cart-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}
.mmp-cart-input:focus{border-color:var(--navy);}

/* Remove button */
.cart-item-remove{flex-shrink:0;}
.cart-remove-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:32px;height:32px;
  border-radius:50%;
  background:var(--off);
  color:var(--gray);
  text-decoration:none;
  transition:all var(--t);
  font-size:.9rem;
}
.cart-remove-btn:hover{background:var(--red);color:#fff;}

/* ── Actions row ── */
.cart-actions-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 20px;
  background:#fff;
  border:1px solid var(--border);
  border-top:none;
  border-radius:0 0 var(--r) var(--r);
  margin-bottom:16px;
}
.cart-coupon-wrap{
  display:flex;
  gap:8px;
  align-items:center;
}
.cart-coupon-wrap .input-text{
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  padding:8px 14px;
  font-family:var(--font-b);
  font-size:.88rem;
  color:var(--navy);
  outline:none;
  transition:border-color var(--t);
  width:180px;
}
.cart-coupon-wrap .input-text:focus{border-color:var(--navy);}
.cart-update-btn{flex-shrink:0;}

/* Continue link */
.cart-continue-link{
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-family:var(--font-h);
  font-size:.84rem;
  font-weight:600;
  color:var(--gray);
  text-decoration:none;
  transition:color var(--t);
  padding:8px 0;
}
.cart-continue-link:hover{color:var(--navy);}

/* ── Summary column ── */
.cart-summary-col{
  position:sticky;
  top:24px;
}
.cart-summary-box{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:24px;
  margin-bottom:16px;
}
.cart-summary-title{
  font-family:var(--font-h);
  font-size:1rem;
  font-weight:700;
  color:var(--navy);
  margin:0 0 20px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:9px;
}
.cart-summary-title i{color:var(--red);}

/* WC cart totals overrides */
.cart-summary-box .cart_totals h2{display:none;}
.cart-summary-box .shop_table{width:100%;border-collapse:collapse;}
.cart-summary-box .shop_table th,
.cart-summary-box .shop_table td{
  padding:10px 0;
  border-bottom:1px solid var(--off);
  font-size:.9rem;
}
.cart-summary-box .shop_table th{
  font-family:var(--font-h);
  font-weight:600;
  color:var(--gray);
  text-align:left;
}
.cart-summary-box .shop_table .order-total th,
.cart-summary-box .shop_table .order-total td{
  border-bottom:none;
  padding-top:14px;
  font-size:1.05rem;
  color:var(--navy);
  font-weight:700;
}
.cart-summary-box .wc-proceed-to-checkout{margin-top:16px;}
.cart-summary-box .checkout-button{
  display:block;
  width:100%;
  background:var(--red) !important;
  color:#fff !important;
  border:2px solid var(--red) !important;
  border-radius:var(--r-sm) !important;
  font-family:var(--font-h) !important;
  font-size:1rem !important;
  font-weight:700 !important;
  letter-spacing:.06em !important;
  text-transform:uppercase !important;
  padding:14px 20px !important;
  text-align:center;
  text-decoration:none;
  transition:all var(--t) !important;
  box-shadow:0 4px 20px rgba(232,25,44,.25) !important;
}
.cart-summary-box .checkout-button:hover{
  background:var(--red-dark,#c0121f) !important;
  border-color:var(--red-dark) !important;
  transform:translateY(-2px) !important;
}

/* Trust strip */
.cart-trust-strip{
  display:flex;
  flex-direction:column;
  gap:0;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;
  margin-bottom:16px;
}
.cart-trust-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 16px;
  font-size:.84rem;
  color:var(--gray-dk);
  border-bottom:1px solid var(--off);
}
.cart-trust-item:last-child{border-bottom:none;}
.cart-trust-item i{
  color:var(--navy);
  font-size:.85rem;
  width:16px;
  flex-shrink:0;
}

/* WhatsApp CTA */
.cart-wa-cta{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:16px;
  text-align:center;
}
.cart-wa-cta p{
  font-size:.84rem;
  color:var(--gray);
  margin:0 0 10px;
}
.cart-wa-cta p i{color:#25D366;}

/* ── Empty state ── */
.cart-empty-state{
  text-align:center;
  padding:80px 24px;
}
.cart-empty-icon{
  font-size:4rem;
  color:var(--border);
  margin-bottom:20px;
}
.cart-empty-title{
  font-family:var(--font-h);
  color:var(--navy);
  margin:0 0 8px;
}
.cart-empty-desc{
  color:var(--gray);
  margin:0 0 28px;
}

/* ── Responsive: Cart ── */
@media(max-width:1024px){
  .cart-layout{
    grid-template-columns:1fr 300px;
    gap:24px;
  }
}
@media(max-width:768px){
  .cart-page{padding:32px 0 60px;}
  .cart-layout{
    grid-template-columns:1fr;
    gap:24px;
    margin-top:24px;
  }
  .cart-summary-col{position:static;}
  .cart-item{grid-template-columns:72px 1fr;padding:16px;}
  .cart-item-foot{flex-wrap:wrap;gap:8px;}
  .cart-actions-row{flex-direction:column;align-items:stretch;gap:10px;}
  .cart-coupon-wrap{flex:1;}
  .cart-coupon-wrap .input-text{flex:1;width:auto;}
}
@media(max-width:480px){
  .cart-item{grid-template-columns:64px 1fr;gap:12px;}
  .cart-item-img{width:64px;height:64px;}
  .cart-item-header{flex-direction:column;gap:4px;}
  .cart-item-subtotal{font-size:.95rem;}
}

/* ═══════════════════════════════════════════════════════════════════════
   CHECKOUT PAGE (co-*)
   checkout/form-checkout.php v4.4
   ═══════════════════════════════════════════════════════════════════════ */

.co-page{
  padding:48px 0 120px; /* extra bottom for sticky CTA on mobile */
  background:var(--off,#f8f9fb);
  min-height:60vh;
}

/* Two-column layout */
.co-layout{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:32px;
  align-items:start;
  margin-top:32px;
}

/* ── Form column ── */
.co-form-col{}

/* Checkout sections */
.co-section{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:28px;
  margin-bottom:20px;
}
.co-section-title{
  font-family:var(--font-h);
  font-size:1rem;
  font-weight:700;
  color:var(--navy);
  margin:0 0 22px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:10px;
}
.co-section-title i{color:var(--red);font-size:.9rem;}
.co-step-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px;height:24px;
  background:var(--navy);
  color:#fff;
  border-radius:50%;
  font-size:.72rem;
  font-weight:700;
  flex-shrink:0;
}

/* WooCommerce form field overrides */
.co-form .form-row{margin-bottom:16px;}
.co-form .form-row label{
  display:block;
  font-family:var(--font-h);
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--gray-dk);
  margin-bottom:6px;
}
.co-form .form-row .required{color:var(--red);}
.co-form .form-row input[type="text"],
.co-form .form-row input[type="email"],
.co-form .form-row input[type="tel"],
.co-form .form-row input[type="number"],
.co-form .form-row input[type="password"],
.co-form .form-row select,
.co-form .form-row textarea{
  width:100%;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  padding:12px 14px;
  font-family:var(--font-b);
  font-size:.92rem;
  color:var(--navy);
  background:#fff;
  outline:none;
  transition:border-color var(--t,.25s),box-shadow var(--t,.25s);
  -webkit-appearance:none;
  appearance:none;
}
.co-form .form-row input:focus,
.co-form .form-row select:focus,
.co-form .form-row textarea:focus{
  border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(15,32,67,.08);
}
.co-form .form-row input.woocommerce-invalid,
.co-form .form-row select.woocommerce-invalid{
  border-color:var(--red) !important;
  box-shadow:0 0 0 3px rgba(232,25,44,.08) !important;
}
.co-form .form-row input.woocommerce-validated,
.co-form .form-row select.woocommerce-validated{
  border-color:#22c55e !important;
}
.co-form .form-row .woocommerce-error,
.co-form .form-row .woocommerce-invalid-required-field{
  font-size:.75rem;
  color:var(--red);
  margin-top:4px;
  display:block;
}

/* Autofill highlight fix */
.co-form input:-webkit-autofill{
  -webkit-box-shadow:0 0 0 40px #fff inset !important;
  -webkit-text-fill-color:var(--navy) !important;
}

/* Shipping toggle label */
.co-form label[for="ship-to-different-address-checkbox"]{
  font-family:var(--font-h);
  font-size:.92rem;
  font-weight:700;
  color:var(--navy);
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:8px;
}

/* WC-injected billing/shipping — prevent double-card nesting */
.co-section .woocommerce-billing-fields,
.co-section .woocommerce-shipping-fields,
.co-section .woocommerce-additional-fields{
  background:transparent !important;
  border:none !important;
  padding:0 !important;
  box-shadow:none !important;
  border-radius:0 !important;
  margin:0 !important;
}
/* Hide WC's auto-injected headings (co-section-title already shows them) */
.co-section .woocommerce-billing-fields > h3,
.co-section .woocommerce-shipping-fields > h3{display:none !important;}

/* Form row grid — replace WC float layout */
.co-form .woocommerce-billing-fields__field-wrapper,
.co-form .woocommerce-shipping-fields__field-wrapper{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0 16px;
}
.co-form .form-row-wide{grid-column:1 / -1;}
.co-form .form-row-first,
.co-form .form-row-last{float:none !important;width:100% !important;margin:0 !important;}
@media(max-width:640px){
  .co-form .woocommerce-billing-fields__field-wrapper,
  .co-form .woocommerce-shipping-fields__field-wrapper{grid-template-columns:1fr;}
}

/* Payment section */
.co-payment-section #payment{
  background:transparent !important;
  border:none !important;
  padding:0 !important;
  margin:0 !important;
}
.co-payment-section #payment ul.payment_methods{
  border:none !important;
  padding:0 !important;
  margin-bottom:16px !important;
}
.co-payment-section #payment ul.payment_methods li{
  border:1.5px solid var(--border) !important;
  border-radius:var(--r-sm) !important;
  padding:14px 16px !important;
  margin-bottom:10px !important;
  transition:border-color var(--t) !important;
  background:#fff !important;
}
.co-payment-section #payment ul.payment_methods li:has(input:checked){
  border-color:var(--navy) !important;
  background:rgba(15,32,67,.03) !important;
}
.co-payment-section #payment ul.payment_methods li label{
  font-family:var(--font-h) !important;
  font-size:.88rem !important;
  font-weight:700 !important;
  color:var(--navy) !important;
  cursor:pointer !important;
}
.co-payment-section #payment .payment_box{
  background:var(--off) !important;
  border-radius:var(--r-sm) !important;
  padding:12px 14px !important;
  margin-top:8px !important;
  font-size:.86rem !important;
  color:var(--gray-dk) !important;
}
/* Single authoritative #place_order rule */
#place_order{
  display:block !important;
  width:100% !important;
  padding:18px 22px !important;
  font-size:17px !important;
  font-weight:600 !important;
  border-radius:14px !important;
  border:none !important;
  color:#fff !important;
  background:linear-gradient(135deg,#1E4A90,#163a73) !important;
  box-shadow:0 12px 30px rgba(0,0,0,.15) !important;
  transition:all .25s ease !important;
  cursor:pointer;
  margin-top:16px !important;
}
#place_order:hover{
  transform:translateY(-2px) !important;
  box-shadow:0 16px 35px rgba(0,0,0,.2) !important;
  background:linear-gradient(135deg,#163a73,#0f2c57) !important;
}
#place_order:active{
  transform:scale(.98) !important;
  box-shadow:0 6px 15px rgba(0,0,0,.15) !important;
}
#payment .place-order{padding:0 !important;background:transparent !important;}

/* ── Summary column ── */
.co-summary-col{
  position:sticky;
  top:calc(var(--hh) + 24px);
}
.co-summary-box{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:24px;
  margin-bottom:16px;
}
.co-summary-title{
  font-family:var(--font-h);
  font-size:1rem;
  font-weight:700;
  color:var(--navy);
  margin:0 0 20px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:9px;
}
.co-summary-title i{color:var(--red);}

/* WC order review overrides */
.co-summary-box .woocommerce-checkout-review-order-table{
  width:100%;
  border-collapse:collapse;
}
.co-summary-box .woocommerce-checkout-review-order-table th,
.co-summary-box .woocommerce-checkout-review-order-table td{
  padding:9px 0;
  border-bottom:1px solid var(--off);
  font-size:.88rem;
  vertical-align:middle;
}
.co-summary-box .woocommerce-checkout-review-order-table thead th{
  font-family:var(--font-h);
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--gray);
}
.co-summary-box .woocommerce-checkout-review-order-table .order-total th,
.co-summary-box .woocommerce-checkout-review-order-table .order-total td{
  border-bottom:none;
  padding-top:14px;
  font-family:var(--font-h);
  font-size:1.05rem;
  font-weight:700;
  color:var(--navy);
}

/* Trust strip */
.co-trust-strip{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;
  margin-bottom:16px;
}
.co-trust-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 16px;
  font-size:.84rem;
  color:var(--gray-dk);
  border-bottom:1px solid var(--off);
}
.co-trust-item:last-child{border-bottom:none;}
.co-trust-item i{
  color:var(--navy);
  font-size:.85rem;
  width:16px;
  flex-shrink:0;
}

/* WhatsApp CTA */
.co-wa-cta{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:16px;
  text-align:center;
}
.co-wa-cta p{
  font-size:.84rem;
  color:var(--gray);
  margin:0 0 10px;
}
.co-wa-cta p i{color:#25D366;}

/* ── Sticky mobile CTA ── */
.co-sticky-cta{
  display:none; /* shown only on mobile via media query */
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:900;
  background:#fff;
  border-top:1px solid var(--border);
  box-shadow:0 -4px 20px rgba(15,32,67,.1);
  padding:12px 16px;
  padding-bottom:max(12px, env(safe-area-inset-bottom));
}
.co-sticky-cta-inner{
  display:flex;
  align-items:center;
  gap:12px;
  max-width:540px;
  margin:0 auto;
}
.co-sticky-total{
  flex:1;
  min-width:0;
}
.co-sticky-total-label{
  display:block;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.07em;
  color:var(--gray);
  font-family:var(--font-h);
  font-weight:600;
}
.co-sticky-total-val{
  display:block;
  font-family:var(--font-h);
  font-size:1.1rem;
  font-weight:700;
  color:var(--navy);
}
.co-sticky-btn{
  flex-shrink:0;
  padding:12px 20px;
  font-size:.9rem;
}

/* ── Responsive: Checkout ── */
@media(max-width:1024px){
  .co-layout{
    grid-template-columns:1fr 320px;
    gap:24px;
  }
}
@media(max-width:768px){
  .co-page{padding:32px 0 100px;} /* extra space for sticky CTA */
  .co-layout{
    grid-template-columns:1fr;
    gap:20px;
    margin-top:20px;
  }
  .co-summary-col{
    position:static;
  }
  .co-sticky-cta{display:block;}
  .co-section{padding:20px;}
  .co-form .form-row{margin-bottom:12px;}
}
@media(max-width:480px){
  .co-section{padding:16px;}
  .co-section-title{font-size:.92rem;}
}

/* ==========================================================================
   404 PAGE
   ========================================================================== */
.error-404-page{
  min-height:70vh;
  display:flex;
  align-items:center;
  padding:80px 0;
}
.error-404-inner{
  text-align:center;
  max-width:560px;
  margin:0 auto;
}
.error-404-visual{
  font-size:clamp(6rem,18vw,10rem);
  font-weight:900;
  line-height:1;
  color:var(--navy,#0F2A44);
  letter-spacing:-.04em;
  margin-bottom:24px;
}
.error-404-visual span{
  color:var(--red,#C0392B);
}
.error-404-title{
  font-size:clamp(1.5rem,4vw,2rem);
  font-weight:700;
  color:var(--navy,#0F2A44);
  margin-bottom:12px;
}
.error-404-desc{
  color:var(--gray,#6b7280);
  font-size:1rem;
  line-height:1.6;
  margin-bottom:28px;
}
.error-404-search{
  margin-bottom:28px;
}
.error-404-search form{
  display:flex;
  gap:0;
  max-width:420px;
  margin:0 auto;
  border:2px solid var(--border,#e5e7eb);
  border-radius:8px;
  overflow:hidden;
}
.error-404-search input[type="search"]{
  flex:1;
  padding:12px 16px;
  border:none;
  font-size:.95rem;
  outline:none;
  background:#fff;
}
.error-404-search button{
  padding:12px 18px;
  background:var(--navy,#0F2A44);
  color:#fff;
  border:none;
  cursor:pointer;
  font-size:1rem;
  transition:background .2s;
}
.error-404-search button:hover{
  background:var(--blue,#1B3F8B);
}
.error-404-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
}
@media(max-width:480px){
  .error-404-page{padding:48px 0;}
  .error-404-actions{flex-direction:column;align-items:center;}
  .error-404-actions .btn{width:100%;max-width:280px;}
}

/* ==========================================================================
   SINGLE PRODUCT PAGE — pdp-* namespace (v4.5)
   ========================================================================== */

/* ── Topbar: breadcrumb + category nav ── */
.pdp-topbar{
  background:var(--off);
  border-bottom:1px solid var(--border);
  padding:10px 0 0;
}
.pdp-breadcrumb{margin-bottom:10px;}
.pdp-cat-nav{
  display:flex;gap:4px;overflow-x:auto;
  scrollbar-width:none;padding-bottom:0;
  flex-wrap:nowrap;
}
.pdp-cat-nav::-webkit-scrollbar{display:none;}
.pdp-cat-link{
  flex-shrink:0;padding:8px 16px;
  font-family:var(--font-h);font-size:.72rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  color:var(--gray-dk);border-bottom:2px solid transparent;
  white-space:nowrap;transition:all var(--t);text-decoration:none;
}
.pdp-cat-link:hover{color:var(--navy);}
.pdp-cat-link.active{color:var(--navy);border-bottom-color:var(--red);}

/* ── Page body ── */
.pdp-body{padding:48px 0 72px;}

/* ── Main 60/40 layout ── */
.pdp-layout{
  display:grid;
  grid-template-columns:1.5fr 1fr;
  gap:56px;
  align-items:start;
  margin-bottom:64px;
}

/* ── Gallery column (sticky) ── */
.pdp-gallery{
  position:sticky;
  top:calc(var(--hh,80px) + 24px);
}
.pdp-gallery-main{
  position:relative;
  border-radius:var(--r-xl);
  overflow:hidden;
  background:var(--off2);
  aspect-ratio:1/1;
  border:1px solid var(--border);
  margin-bottom:12px;
}
.pdp-gallery-open{
  display:block;width:100%;height:100%;
  border:none;background:none;padding:0;
  cursor:zoom-in;position:relative;
}
.pdp-gallery-open img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.pdp-gallery-main:hover .pdp-gallery-open img{transform:scale(1.04);}
.pdp-zoom-hint{
  position:absolute;bottom:12px;right:12px;
  background:rgba(255,255,255,.92);color:var(--navy);
  font-family:var(--font-h);font-size:.62rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;
  display:flex;align-items:center;gap:6px;
  opacity:0;transition:opacity var(--t);pointer-events:none;
  box-shadow:var(--sh-sm);
}
.pdp-gallery-main:hover .pdp-zoom-hint{opacity:1;}

/* Badges */
.pdp-badge{
  position:absolute;top:14px;left:14px;z-index:2;
  font-family:var(--font-h);font-size:.66rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;color:#fff;
}
.pdp-badge--sale{background:var(--red);}
.pdp-badge--hot{background:var(--blue);}

/* Out of stock overlay */
.pdp-oos-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;z-index:3;
}
.pdp-oos-overlay span{
  background:#fff;color:var(--gray-dk);
  font-family:var(--font-h);font-size:.8rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:8px 20px;border-radius:100px;
}

/* Gallery placeholder */
.pdp-gallery-ph{
  width:100%;height:100%;min-height:400px;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:16px;padding:40px;text-align:center;
  font-size:4rem;color:rgba(255,255,255,.12);
}
.pdp-gallery-ph span{
  font-family:var(--font-h);font-size:.88rem;font-weight:700;
  color:rgba(255,255,255,.3);letter-spacing:.06em;text-transform:uppercase;
}

/* Arrow navigation */
.pdp-arr{
  position:absolute;top:50%;transform:translateY(-50%);
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--navy);
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;cursor:pointer;z-index:4;
  transition:all var(--t);box-shadow:var(--sh-sm);
}
.pdp-arr:hover{background:#fff;box-shadow:var(--sh-md);}
.pdp-arr--prev{left:12px;}
.pdp-arr--next{right:12px;}

/* Image counter */
.pdp-gallery-counter{
  position:absolute;bottom:12px;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,.55);color:#fff;
  font-family:var(--font-h);font-size:.65rem;font-weight:700;
  letter-spacing:.08em;padding:4px 12px;border-radius:100px;z-index:4;
}

/* Thumbnails */
.pdp-thumbs{
  display:flex;gap:8px;overflow-x:auto;
  scrollbar-width:none;padding-bottom:4px;
}
.pdp-thumbs::-webkit-scrollbar{display:none;}
.pdp-thumb{
  flex:0 0 72px;height:72px;border-radius:var(--r);
  overflow:hidden;border:2px solid var(--border);
  background:var(--off2);cursor:pointer;
  transition:border-color var(--t);padding:0;
}
.pdp-thumb img{width:100%;height:100%;object-fit:cover;}
.pdp-thumb.active,.pdp-thumb:hover{border-color:var(--red);}

/* Share row */
.pdp-share{
  display:flex;align-items:center;gap:8px;
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--border);
}
.pdp-share span{
  font-family:var(--font-h);font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gray);
  margin-right:4px;
}
.pdp-share-btn{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;color:#fff;border:none;
  cursor:pointer;transition:transform var(--t);text-decoration:none;
}
.pdp-share-btn:hover{transform:scale(1.12);color:#fff;}
.pdp-fb{background:#1877F2;}.pdp-wa{background:#25D366;}
.pdp-tw{background:#000;}.pdp-copy{background:var(--gray-dk);}

/* ── Summary column (sticky) ── */
.pdp-summary{
  position:sticky;
  top:calc(var(--hh,80px) + 24px);
}

/* Category pill */
.pdp-cat-pill{margin-bottom:10px;}
.pdp-cat-pill a{
  font-family:var(--font-h);font-size:.68rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--blue);
  display:inline-flex;align-items:center;gap:5px;
  transition:color var(--t);text-decoration:none;
}
.pdp-cat-pill a:hover{color:var(--red);}

/* Title */
.pdp-title{
  font-size:clamp(1.55rem,2.8vw,2.2rem);font-weight:800;
  color:var(--navy);line-height:1.18;margin-bottom:10px;
}

/* Rating */
.pdp-rating{
  display:flex;align-items:center;gap:8px;margin-bottom:12px;
}
.pdp-stars{display:flex;gap:2px;color:#f59e0b;font-size:.85rem;}
.pdp-rating-link{
  font-size:.81rem;color:var(--gray-dk);text-decoration:none;
  border-bottom:1px dotted var(--gray);transition:color var(--t);
}
.pdp-rating-link:hover{color:var(--navy);}

/* Short description */
.pdp-short-desc{
  font-size:.93rem;color:var(--gray-dk);line-height:1.75;
  margin-bottom:16px;padding-bottom:16px;
  border-bottom:1px solid var(--border);
}

/* Price block */
.pdp-price-block{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:8px;margin-bottom:12px;
}
.pdp-price{
  font-family:var(--font-h);font-size:1.9rem;font-weight:800;color:var(--navy);
}
.pdp-price del{color:var(--gray);font-size:1.05rem;font-weight:400;margin-right:4px;}
.pdp-price ins{text-decoration:none;color:var(--red);}
.pdp-save-badge{
  background:var(--red);color:#fff;
  font-family:var(--font-h);font-size:.63rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;align-self:center;
}
.pdp-tax-note{font-size:.71rem;color:var(--gray);width:100%;font-style:italic;}

/* Stock */
.pdp-stock{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-h);font-size:.73rem;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  padding:8px 14px;border-radius:var(--r-sm);margin-bottom:16px;
}
.pdp-stock--in{
  background:rgba(22,163,74,.08);color:#166534;
  border:1px solid rgba(22,163,74,.2);
}
.pdp-stock--out{
  background:rgba(232,25,44,.07);color:var(--red);
  border:1px solid rgba(232,25,44,.2);
}

/* Primary CTAs */
.pdp-cta-primary{
  display:flex;flex-direction:column;gap:10px;margin-bottom:16px;
}
.pdp-cta-primary .btn{width:100%;justify-content:center;}

/* Or divider */
.pdp-or-divider{
  display:flex;align-items:center;gap:12px;
  margin-bottom:16px;
}
.pdp-or-divider::before,.pdp-or-divider::after{
  content:'';flex:1;height:1px;background:var(--border);
}
.pdp-or-divider span{
  font-family:var(--font-h);font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gray);
  white-space:nowrap;
}

/* ── WooCommerce variation attributes (Finish / Gauge selects) ── */
.variations{
  width:100%;
  border-collapse:collapse;
  margin-bottom:0;
}
.variations tr{
  border-top:1px solid var(--border,#e5e7eb);
}
.variations tr:first-child{border-top:none;}
.variations td{
  padding:10px 0;
  vertical-align:middle;
}
.variations td.label{
  width:75px;
  padding-right:16px;
  white-space:nowrap;
}
.variations td.label label{
  font-family:var(--font-h);
  font-weight:700;
  font-size:.9rem;
  color:var(--navy);
  margin:0;
  cursor:default;
}
/* Custom styled select — navy border, chevron arrow */
.variations td.value select{
  appearance:none;
  -webkit-appearance:none;
  background-color:#fff;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24'%3E%3Cpath fill='%230F2A44' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:18px;
  border:1.5px solid var(--border,#d1d5db);
  border-radius:8px;
  padding:10px 40px 10px 14px;
  font-family:var(--font-b);
  font-size:.9rem;
  font-weight:600;
  color:var(--navy);
  cursor:pointer;
  min-width:180px;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.variations td.value select:focus{
  border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(10,35,66,.08);
}
.variations td.value select:hover{
  border-color:var(--navy);
}
/* Hide WC's reset link — clutter */
.variations td.value .reset_variations{
  display:none!important;
}

/* ── WooCommerce add-to-cart form inside pdp-cart-wrap ── */
.pdp-cart-wrap{margin-bottom:16px;}

/* WC renders form.cart — make it a flex row */
.pdp-cart-wrap form.cart{
  display:flex;
  gap:12px;
  align-items:stretch;
  flex-wrap:wrap;
}

/* When metre pricing widget is inside the form, stack it above the button */
.pdp-cart-wrap form.cart:has(.mmp-wrap){
  flex-direction:column;
  align-items:stretch;
}
.pdp-cart-wrap form.cart:has(.mmp-wrap) .mmp-wrap{
  width:100%;
}
.pdp-cart-wrap form.cart:has(.mmp-wrap) .single_add_to_cart_button,
.pdp-cart-wrap form.cart:has(.mmp-wrap) button[type="submit"].button{
  flex:none;
  width:100%;
  min-height:52px;
}

/* The WC .quantity wrapper becomes our stepper when JS adds the class */
.pdp-cart-wrap .quantity,
.pdp-cart-wrap .quantity.pdp-qty-stepper{
  display:flex;align-items:stretch;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  overflow:hidden;flex-shrink:0;
  background:#fff;
}
.pdp-qty-btn{
  width:40px;background:var(--off);color:var(--navy);
  border:none;font-size:.9rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--t);flex-shrink:0;
}
.pdp-qty-btn:hover{background:var(--off2);}
.pdp-cart-wrap .quantity input.qty,
.pdp-qty-stepper .qty{
  width:52px;text-align:center;
  border:none;border-left:1.5px solid var(--border);
  border-right:1.5px solid var(--border);
  font-family:var(--font-h);font-size:1rem;font-weight:700;
  color:var(--navy);outline:none;padding:0;
  -moz-appearance:textfield;
  min-height:44px;
}
.pdp-cart-wrap .quantity input.qty::-webkit-outer-spin-button,
.pdp-cart-wrap .quantity input.qty::-webkit-inner-spin-button,
.pdp-qty-stepper .qty::-webkit-outer-spin-button,
.pdp-qty-stepper .qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}

/* Add to cart button — flex:1 so it fills remaining space */
.pdp-cart-wrap .single_add_to_cart_button,
.pdp-cart-wrap button[type="submit"].button{
  flex:1;min-width:0;
  /* inherit btn btn-navy styles — add padding override so height matches qty stepper */
  padding-top:0;padding-bottom:0;min-height:44px;
}

/* SKU */
.pdp-sku{font-size:.77rem;color:var(--gray);margin-bottom:14px;}
.pdp-sku span{font-weight:600;color:var(--gray-dk);}

/* Trust strip */
.pdp-trust{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
  padding:16px;background:var(--off);
  border:1px solid var(--border);border-radius:var(--r-lg);
  margin-bottom:16px;
}
.pdp-trust-item{
  display:flex;align-items:flex-start;gap:9px;padding:6px;
  border-radius:var(--r-sm);transition:background var(--t);
}
.pdp-trust-item:hover{background:var(--off2);}
.pdp-trust-item>i{
  width:32px;height:32px;border-radius:var(--r-sm);flex-shrink:0;
  background:rgba(232,25,44,.07);color:var(--red);
  display:flex;align-items:center;justify-content:center;font-size:.85rem;
}
.pdp-trust-item strong{
  display:block;font-family:var(--font-h);font-size:.72rem;
  font-weight:700;color:var(--navy);letter-spacing:.02em;
}
.pdp-trust-item span{font-size:.67rem;color:var(--gray);line-height:1.4;}

/* Attribute preview */
.pdp-attrs{
  display:flex;flex-direction:column;gap:0;
  border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;margin-bottom:16px;
}
.pdp-attr-row{
  display:flex;align-items:center;gap:0;
  font-size:.82rem;padding:9px 14px;
  border-bottom:1px solid var(--border);background:#fff;
}
.pdp-attr-row:last-child{border-bottom:none;}
.pdp-attr-row:nth-child(even){background:var(--off);}
.pdp-attr-label{
  font-family:var(--font-h);font-size:.68rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:var(--gray-dk);
  min-width:90px;flex-shrink:0;
}
.pdp-attr-value{color:var(--navy);font-weight:500;}

/* Phone CTA */
.pdp-phone-cta{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px;
  padding:12px 14px;background:var(--off);
  border:1px solid var(--border);border-radius:var(--r-lg);
  font-size:.82rem;color:var(--gray-dk);
}
.pdp-phone-cta>i{color:var(--blue);font-size:.85rem;}
.pdp-phone-cta a{
  font-family:var(--font-h);font-size:.95rem;font-weight:700;
  color:var(--navy);text-decoration:none;transition:color var(--t);
}
.pdp-phone-cta a:hover{color:var(--red);}
.pdp-phone-hours{
  font-size:.7rem;color:var(--gray);margin-left:auto;
}

/* ── Product Tabs ── */
.pdp-tabs-section{
  background:#fff;border-radius:var(--r-xl);
  border:1px solid var(--border);overflow:hidden;
  margin-bottom:64px;
}
.pdp-tabs{
  display:flex;overflow-x:auto;scrollbar-width:none;
  border-bottom:2px solid var(--border);background:var(--off);
}
.pdp-tabs::-webkit-scrollbar{display:none;}
.pdp-tab-btn{
  flex-shrink:0;padding:16px 24px;
  font-family:var(--font-h);font-size:.76rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  color:var(--gray-dk);background:transparent;border:none;
  border-bottom:2px solid transparent;margin-bottom:-2px;
  cursor:pointer;transition:all var(--t);
  display:flex;align-items:center;gap:7px;white-space:nowrap;
}
.pdp-tab-btn:hover{color:var(--navy);}
.pdp-tab-btn.active{
  color:var(--navy);border-bottom-color:var(--red);background:#fff;
}
.pdp-tab-badge{
  background:var(--red);color:#fff;
  font-size:.58rem;padding:2px 6px;border-radius:100px;
}
.pdp-tab-panel{padding:32px;}
.pdp-tab-panel--hidden{display:none;}
.pdp-tab-content{
  font-size:.93rem;color:var(--gray-dk);line-height:1.8;
}
.pdp-tab-content h2{font-size:1.3rem;color:var(--navy);margin:24px 0 10px;}
.pdp-tab-content h3{font-size:1.05rem;color:var(--navy);margin:18px 0 8px;}
.pdp-tab-content p{margin-bottom:1em;}
.pdp-tab-content ul,.pdp-tab-content ol{margin:0 0 1em 20px;}

/* Specs table */
.pdp-specs-table{
  width:100%;border-collapse:collapse;font-size:.87rem;
}
.pdp-specs-table th,.pdp-specs-table td{
  padding:10px 16px;text-align:left;
  border:1px solid var(--border);
}
.pdp-specs-table th{
  background:var(--off);font-family:var(--font-h);font-size:.71rem;
  font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--navy);width:35%;
}
.pdp-specs-table tr:nth-child(even) td{background:var(--off);}

/* Delivery grid */
.pdp-delivery-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:18px;margin-bottom:24px;
}
.pdp-delivery-item{
  background:var(--off);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px;
}
.pdp-delivery-icon{font-size:1.35rem;color:var(--red);margin-bottom:8px;}
.pdp-delivery-item h4{font-size:.95rem;color:var(--navy);margin-bottom:5px;}
.pdp-delivery-item p{font-size:.83rem;color:var(--gray-dk);line-height:1.65;margin:0;}
.pdp-delivery-actions{display:flex;gap:12px;flex-wrap:wrap;}

/* ── Related Products ── */
.pdp-related{background:var(--off);padding:64px 0;}
.pdp-related-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.pdp-related-card{
  background:#fff;border-radius:var(--r-lg);
  overflow:hidden;border:1px solid var(--border);
  transition:all .28s var(--ease);
}
.pdp-related-card:hover{
  box-shadow:var(--sh-lg);transform:translateY(-4px);border-color:transparent;
}
.pdp-related-img{
  aspect-ratio:1/1;overflow:hidden;
  background:var(--off2);position:relative;
}
.pdp-related-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.pdp-related-card:hover .pdp-related-img img{transform:scale(1.06);}
.pdp-related-body{padding:16px;}
.pdp-related-cat{
  font-family:var(--font-h);font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--blue);
  display:block;margin-bottom:5px;
}
.pdp-related-name{
  font-size:.95rem;font-weight:700;color:var(--navy);
  margin-bottom:6px;line-height:1.3;
}
.pdp-related-name a{color:inherit;text-decoration:none;}
.pdp-related-name a:hover{color:var(--red);}
.pdp-related-price{
  font-family:var(--font-h);font-size:1rem;font-weight:800;
  color:var(--navy);margin-bottom:12px;
}
.pdp-related-price del{color:var(--gray);font-size:.8rem;font-weight:400;}
.pdp-related-price ins{text-decoration:none;color:var(--red);}
.pdp-related-actions{display:flex;gap:8px;}
.pdp-related-actions .btn{flex:1;text-align:center;justify-content:center;}

/* ── Lightbox ── */
.pdp-lightbox{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.92);
  display:flex;align-items:center;justify-content:center;
}
.pdp-lightbox[hidden]{display:none;}
.pdp-lightbox-inner{
  max-width:92vw;max-height:92vh;
  display:flex;align-items:center;justify-content:center;
}
.pdp-lightbox-inner img{
  max-width:100%;max-height:92vh;
  object-fit:contain;border-radius:var(--r-lg);
}
.pdp-lightbox-close{
  position:absolute;top:20px;right:20px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.15);color:#fff;
  border:none;font-size:1.2rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--t);z-index:1;
}
.pdp-lightbox-close:hover{background:rgba(255,255,255,.25);}
.pdp-lightbox-arr{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.15);color:#fff;
  border:none;font-size:1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--t);z-index:1;
}
.pdp-lightbox-arr:hover{background:rgba(255,255,255,.25);}
.pdp-lightbox-arr--prev{left:20px;}
.pdp-lightbox-arr--next{right:20px;}
.pdp-lightbox-counter{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.7);font-size:.8rem;
  font-family:var(--font-h);letter-spacing:.06em;
}

/* ── Mobile Sticky CTA ── */
.pdp-sticky-cta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:800;
  background:#fff;border-top:1.5px solid var(--border);
  padding:10px 16px;
  align-items:center;justify-content:space-between;
  gap:12px;box-shadow:0 -4px 16px rgba(0,0,0,.1);
}
.pdp-sticky-cta.pdp-sticky-visible{display:flex;}
.pdp-sticky-info{
  min-width:0;flex:1;
  display:flex;flex-direction:column;gap:2px;overflow:hidden;
}
.pdp-sticky-name{
  font-size:.8rem;font-weight:600;color:var(--gray-dk);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pdp-sticky-price{
  font-family:var(--font-h);font-size:1rem;font-weight:800;color:var(--navy);
}
.pdp-sticky-price del{color:var(--gray);font-size:.75rem;font-weight:400;}
.pdp-sticky-price ins{text-decoration:none;color:var(--red);}
.pdp-sticky-actions{
  display:flex;gap:8px;flex-shrink:0;
}

/* ── Responsive ── */
@media(max-width:1024px){
  .pdp-layout{
    grid-template-columns:1.3fr 1fr;
    gap:36px;
  }
  .pdp-related-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:768px){
  .pdp-body{padding:28px 0 90px;}/* space for sticky bar */
  .pdp-layout{
    grid-template-columns:1fr;
    gap:28px;
  }
  .pdp-gallery{position:static;}
  .pdp-summary{position:static;}
  .pdp-gallery-main{aspect-ratio:4/3;}
  .pdp-related-grid{grid-template-columns:repeat(2,1fr);}
  .pdp-delivery-grid{grid-template-columns:1fr;}
  .pdp-tabs{gap:0;}
  .pdp-tab-btn{padding:13px 16px;font-size:.68rem;}
  .pdp-tab-panel{padding:20px;}
  /* Sticky CTA visible on mobile when not seeing the qty row */
  .pdp-sticky-cta.pdp-sticky-visible{display:flex;}
  .pdp-trust{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .pdp-layout{gap:20px;}
  .pdp-title{font-size:1.45rem;}
  .pdp-price{font-size:1.6rem;}
  .pdp-related-grid{grid-template-columns:repeat(2,1fr);gap:12px;}
  .pdp-related-body{padding:12px;}
  .pdp-cta-primary .btn{font-size:.88rem;padding:13px 16px;}
  .pdp-qty-row{flex-wrap:nowrap;}
  .pdp-lightbox-arr--prev{left:8px;}
  .pdp-lightbox-arr--next{right:8px;}
}

/* ============================================================
   CART PAGE  (.cart-*)
   woocommerce/cart/cart.php
   ============================================================ */

/* ── Page hero (injected via woocommerce_before_cart hook) ── */
.mabati-page-hero{
  background:var(--navy);
  color:#fff;
  padding:36px 0 28px;
}
.mabati-page-hero .container{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.mabati-page-hero-breadcrumb{
  font-size:.72rem;
  opacity:.65;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.mabati-page-hero-breadcrumb a{
  color:inherit;
  text-decoration:none;
}
.mabati-page-hero-breadcrumb a:hover{opacity:1;}
.mabati-page-hero-breadcrumb span{margin:0 6px;opacity:.5;}

/* hero used by cart/checkout hooks in functions.php */
.mabati-page-hero-inner{margin-top:10px;}
.mabati-page-hero-inner h1{
  font-family:var(--font-h);
  font-size:1.85rem;
  font-weight:700;
  margin:0 0 6px;
  line-height:1.15;
}
.mabati-page-hero-inner p{
  margin:0;
  opacity:.75;
  font-size:.9rem;
}
.mabati-page-hero h1{
  font-family:var(--font-h);
  font-size:1.85rem;
  font-weight:700;
  margin:0;
  line-height:1.15;
}

/* breadcrumb nav inside hero */
.mabati-breadcrumb ol{
  list-style:none;
  padding:0;margin:0;
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  font-size:.72rem;
  opacity:.65;
}
.mabati-breadcrumb li{display:flex;align-items:center;gap:6px;}
.mabati-breadcrumb li::after{content:'/';opacity:.5;}
.mabati-breadcrumb li:last-child::after{display:none;}
.mabati-breadcrumb a{color:#fff;text-decoration:none;}
.mabati-breadcrumb a:hover{opacity:1;}
.mabati-breadcrumb .current{font-weight:600;opacity:1;}
@media(max-width:600px){
  .mabati-page-hero h1{font-size:1.4rem;}
  .mabati-page-hero{padding:26px 0 20px;}
}

/* ── Outer wrapper ── */
.cart-page{
  padding:40px 0 80px;
  background:var(--bg-light,#f7f8fa);
  min-height:60vh;
}

/* ── Two-column layout ── */
.cart-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:32px;
  align-items:start;
}

/* ── Columns ── */
.cart-items-col{min-width:0;}

/* ── Column headings ── */
.cart-col-title{
  font-family:var(--font-h);
  font-size:1.1rem;
  font-weight:700;
  color:var(--navy);
  margin:0 0 20px;
  display:flex;
  align-items:center;
  gap:10px;
}
.cart-item-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--red);
  color:#fff;
  font-size:.72rem;
  font-weight:700;
  border-radius:99px;
  padding:2px 9px;
  line-height:1.4;
}

/* ── Items list ── */
.cart-items-list{
  display:flex;
  flex-direction:column;
  gap:1px;
  border:1px solid var(--border,#e2e5ea);
  border-radius:12px;
  overflow:hidden;
  background:#fff;
}

/* ── Single item (card layout) ── */
.cart-item{
  display:grid;
  grid-template-columns:88px 1fr;
  gap:16px;
  align-items:start;
  padding:20px;
  background:#fff;
  border-bottom:1px solid var(--border,#e2e5ea);
  transition:background .15s;
}
.cart-item:last-child{border-bottom:none;}
.cart-item:hover{background:#fafbfc;}

/* thumbnail */
.cart-item-img{
  width:88px;height:88px;
  flex-shrink:0;
  border-radius:8px;
  overflow:hidden;
  background:var(--off,#f8f9fb);
}
.cart-item-img img,
.cart-item-img a{display:block;width:100%;height:100%;}
.cart-item-img img{
  width:88px;height:88px;
  object-fit:cover;
  border-radius:8px;
  border:1px solid var(--border,#e2e5ea);
  display:block;
}

/* body */
.cart-item-body{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}

/* header: name left, subtotal right */
.cart-item-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.cart-item-name{
  font-weight:700;
  color:var(--navy);
  font-size:.93rem;
  min-width:0;
}
.cart-item-name a{color:inherit;text-decoration:none;}
.cart-item-name a:hover{color:var(--red);}
.cart-item-subtotal{
  font-weight:700;
  color:var(--navy);
  font-size:1rem;
  white-space:nowrap;
  flex-shrink:0;
}
.cart-item-subtotal ins{text-decoration:none;}

/* meta: "12 sheets × 2.70 m = 32.40 m" + variation attrs */
.cart-item-meta{font-size:.8rem;color:var(--gray,#6b7280);line-height:1.5;}
.cart-item-meta dl{margin:0;display:flex;flex-direction:column;gap:2px;}
.cart-item-meta dt{font-weight:600;color:var(--navy);display:inline;}
.cart-item-meta dd{margin:0;display:inline;}
.cart-item-meta dt::after{content:': ';}
.cart-item-meta p{margin:0;}

.cart-item-backorder{
  font-size:.75rem;color:var(--red);margin:0;
}

/* footer: unit price left, actions right */
.cart-item-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:2px;
}
.cart-item-unit-price{
  color:var(--gray,#6b7280);
  font-size:.8rem;
  display:flex;
  align-items:baseline;
  gap:2px;
  flex-wrap:wrap;
}
.cart-item-unit-label{font-size:.72rem;opacity:.7;}

/* actions: qty inputs + remove */
.cart-item-actions{display:flex;align-items:center;gap:10px;}
.cart-item-qty .quantity{display:flex;align-items:center;gap:0;}
.cart-item-qty .qty{
  width:56px;
  text-align:center;
  border:1px solid var(--border,#e2e5ea);
  border-radius:6px;
  padding:7px 8px;
  font-size:.88rem;
  font-weight:600;
  color:var(--navy);
  background:#fff;
  -moz-appearance:textfield;
}
.cart-item-qty .qty::-webkit-inner-spin-button,
.cart-item-qty .qty::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}

/* remove button */
.cart-item-remove{flex-shrink:0;}
.cart-remove-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:32px;height:32px;
  border-radius:50%;
  background:#f3f4f6;
  color:var(--gray,#6b7280);
  text-decoration:none;
  transition:background .15s,color .15s;
  font-size:.85rem;
}
.cart-remove-btn:hover{background:var(--red);color:#fff;}

/* ── Actions row (coupon + update) ── */
.cart-actions-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 0 0;
}
.cart-coupon{flex:1;min-width:220px;}
.cart-coupon-wrap{
  display:flex;
  gap:8px;
}
.cart-coupon-wrap .input-text{
  flex:1;
  border:1px solid var(--border,#e2e5ea);
  border-radius:6px;
  padding:9px 14px;
  font-size:.85rem;
  color:var(--navy);
  outline:none;
  transition:border-color .2s;
}
.cart-coupon-wrap .input-text:focus{border-color:var(--navy);}
.cart-update-btn{white-space:nowrap;}

/* ── Continue shopping ── */
.cart-continue-link{
  display:inline-flex;
  align-items:center;
  gap:7px;
  margin-top:18px;
  font-size:.82rem;
  color:var(--navy);
  text-decoration:none;
  opacity:.7;
  transition:opacity .15s;
}
.cart-continue-link:hover{opacity:1;}

/* ── Summary box (right column) ── */
.cart-summary-box{
  background:#fff;
  border:1px solid var(--border,#e2e5ea);
  border-radius:12px;
  overflow:hidden;
  padding:24px;
  margin-bottom:16px;
}
.cart-summary-title{
  font-family:var(--font-h);
  font-size:1rem;
  font-weight:700;
  color:var(--navy);
  margin:0 0 20px;
  display:flex;
  align-items:center;
  gap:9px;
}

/* WC cart totals inside summary box */
.cart-summary-box .cart_totals h2{display:none;}/* hide WC's own heading */
.cart-summary-box .shop_table{width:100%;border-collapse:collapse;}
.cart-summary-box .shop_table th,
.cart-summary-box .shop_table td{
  padding:10px 0;
  border-bottom:1px solid var(--border,#e2e5ea);
  font-size:.88rem;
  color:var(--navy);
}
.cart-summary-box .shop_table tr:last-child th,
.cart-summary-box .shop_table tr:last-child td{border-bottom:none;}
.cart-summary-box .shop_table .order-total th,
.cart-summary-box .shop_table .order-total td{
  font-size:1rem;
  font-weight:700;
}
.cart-summary-box .wc-proceed-to-checkout{margin-top:20px;}
.cart-summary-box .checkout-button{
  display:block;
  width:100%;
  text-align:center;
  background:var(--red);
  color:#fff;
  font-family:var(--font-h);
  font-weight:700;
  font-size:.95rem;
  padding:14px 20px;
  border-radius:8px;
  border:none;
  cursor:pointer;
  text-decoration:none;
  transition:background .2s,transform .1s;
}
.cart-summary-box .checkout-button:hover{
  background:var(--navy);
  transform:translateY(-1px);
}

/* ── Trust strip ── */
.cart-trust-strip{
  display:flex;
  flex-direction:column;
  gap:10px;
  background:#fff;
  border:1px solid var(--border,#e2e5ea);
  border-radius:12px;
  padding:16px 20px;
  margin-bottom:16px;
}
.cart-trust-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:.8rem;
  color:var(--navy);
}
.cart-trust-item i{color:var(--red);font-size:.9rem;width:16px;text-align:center;}

/* ── WhatsApp CTA ── */
.cart-wa-cta{
  background:#f0fdf4;
  border:1px solid #bbf7d0;
  border-radius:12px;
  padding:16px 20px;
  text-align:center;
}
.cart-wa-cta p{
  margin:0 0 10px;
  font-size:.82rem;
  color:var(--navy);
  opacity:.8;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.cart-wa-cta p i{color:#25d366;font-size:1rem;}

/* ── Empty cart ── */
.cart-empty-state{
  text-align:center;
  padding:80px 20px;
  max-width:440px;
  margin:0 auto;
}
.cart-empty-icon{
  width:80px;height:80px;
  border-radius:50%;
  background:var(--navy);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.8rem;
  margin:0 auto 24px;
}
.cart-empty-title{
  font-family:var(--font-h);
  font-size:1.5rem;
  color:var(--navy);
  margin:0 0 10px;
}
.cart-empty-desc{
  color:var(--gray,#6b7280);
  margin:0 0 28px;
  font-size:.9rem;
}

/* ── Responsive cart ── */
@media(max-width:1024px){
  .cart-layout{grid-template-columns:1fr 320px;}
}
@media(max-width:768px){
  .cart-page{padding:24px 0 60px;}
  .cart-layout{grid-template-columns:1fr;gap:24px;}
  .cart-item{grid-template-columns:72px 1fr;padding:16px;}
  .cart-item-img{width:72px;height:72px;}
  .cart-item-img img{width:72px;height:72px;}
  .cart-item-foot{flex-wrap:wrap;gap:8px;}
}
@media(max-width:480px){
  .cart-item{grid-template-columns:60px 1fr;gap:10px;}
  .cart-item-img{width:60px;height:60px;}
  .cart-item-img img{width:60px;height:60px;}
  .cart-item-header{flex-direction:column;gap:2px;}
}
@media(max-width:480px){
  .cart-item{
    grid-template-columns:56px 1fr auto;
  }
  .cart-item-img img{width:56px;height:56px;}
  .cart-actions-row{flex-direction:column;align-items:stretch;}
  .cart-coupon{min-width:0;}
}


/* ================================================================
   CHECKOUT REVIEW ORDER — Card-style product list
   Targets woocommerce/checkout/review-order.php override
   ================================================================ */

/* Wrapper */
.co-review-wrap{display:flex;flex-direction:column;gap:0;}

/* Product cards container */
.co-order-items{
  display:flex;flex-direction:column;gap:0;
  border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;margin-bottom:16px;background:#fff;
}

/* Individual product card */
.co-order-item{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  padding:14px 16px;border-bottom:1px solid var(--border);
}
.co-order-item:last-child{border-bottom:none;}

/* Left: product info */
.co-item-info{flex:1;min-width:0;}

.co-item-name{
  font-family:var(--font-h);font-size:.95rem;font-weight:700;
  color:var(--navy);line-height:1.3;margin-bottom:4px;
}

/* Calculation / item meta rows */
.co-item-calc,
.co-item-meta{
  font-size:.82rem;color:var(--gray-dk);margin-bottom:3px;line-height:1.4;
}
.co-item-calc strong{color:var(--navy);}
.co-item-meta dl{margin:0;display:flex;flex-direction:column;gap:1px;}
.co-item-meta dt{font-weight:600;color:var(--navy);display:inline;}
.co-item-meta dd{margin:0;display:inline;}
.co-item-meta dt::after{content:': ';}
.co-item-meta p{margin:0;}

/* Unit price: "KSh 550 / metre" */
.co-item-unit-price{
  font-size:.78rem;color:var(--gray);font-family:var(--font-h);
  letter-spacing:.03em;
}

/* Right: subtotal — bold, larger */
.co-item-subtotal{
  flex-shrink:0;text-align:right;
  font-family:var(--font-h);font-size:1.05rem;font-weight:800;
  color:var(--navy);white-space:nowrap;padding-top:2px;
}
.co-item-subtotal .woocommerce-Price-amount{
  font-size:1.05rem;font-weight:800;color:var(--navy);
}

/* Totals table */
.co-order-totals{
  width:100%;border-collapse:collapse;
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;
}
.co-order-totals th,
.co-order-totals td{
  padding:11px 16px;font-size:.86rem;color:var(--gray-dk);
  border-bottom:1px solid var(--border);vertical-align:middle;
}
.co-order-totals tr:last-child th,
.co-order-totals tr:last-child td{border-bottom:none;}
.co-order-totals th{font-family:var(--font-h);font-weight:700;color:var(--navy);text-align:left;}
.co-order-totals td{text-align:right;}

/* Highlight grand total row */
.co-order-totals .order-total th,
.co-order-totals .order-total td{
  font-size:1rem;font-weight:800;color:var(--navy);
  background:var(--off);padding:14px 16px;
}
.co-order-totals .order-total .woocommerce-Price-amount{
  font-size:1.05rem;font-weight:800;color:var(--red);
}

/* Coupon / discount row */
.co-order-totals .cart-discount td{color:var(--red);}

/* Mobile */
@media(max-width:480px){
  .co-order-item{flex-direction:column;gap:8px;}
  .co-item-subtotal{text-align:left;font-size:.95rem;padding-top:0;}
  .co-item-name{font-size:.88rem;}
}

/* ================================================================
   CART — Unit price label improvement
   ================================================================ */
.cart-item-unit-label{
  font-size:.76rem;color:var(--gray);margin-left:3px;
}

/* ================================================================
   QUOTE MODAL — CF7 responsive + premium polish
   ================================================================ */

/* Hide CF7 validation messages in raw state (belt-and-suspenders) */
.modal-cf7-wrap .wpcf7-not-valid-tip{font-size:.75rem;color:var(--red);margin-top:3px;display:block;}
.modal-cf7-wrap .wpcf7-response-output{
  margin:10px 0 0;padding:10px 14px;border-radius:var(--r);font-size:.83rem;border-width:1px!important;
}
.modal-cf7-wrap .wpcf7-mail-sent-ok{background:#F0FDF4;border-color:#86EFAC!important;color:#15803D;}
.modal-cf7-wrap .wpcf7-mail-sent-ng,
.modal-cf7-wrap .wpcf7-aborted{background:#FEF2F2;border-color:#FECACA!important;color:#B91C1C;}
.modal-cf7-wrap .wpcf7-spam-blocked{background:#FEF9C3;border-color:#FDE047!important;color:#854D0E;}

/* Two-column field layout inside CF7 modal */
.modal-cf7-wrap .wpcf7-form{display:flex;flex-direction:column;gap:12px;}
.modal-cf7-wrap .wpcf7-form p{margin:0;}
.modal-cf7-wrap .wpcf7-form .col-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* Ensure all inputs fill their container */
.modal-cf7-wrap input[type="text"],
.modal-cf7-wrap input[type="email"],
.modal-cf7-wrap input[type="tel"],
.modal-cf7-wrap select,
.modal-cf7-wrap textarea{
  width:100%;display:block;box-sizing:border-box;
}

/* Mobile modal: single column */
@media(max-width:640px){
  .quote-modal{grid-template-columns:1fr!important;}
  .modal-left{display:none!important;}
  .modal-right{padding:24px 20px;}
  .modal-cf7-wrap .wpcf7-form .col-2{grid-template-columns:1fr;}
  .qf-row{grid-template-columns:1fr;}
}

/* Product page — hide rating link cursor (no longer a tab link) */
.pdp-rating-link{cursor:default;color:var(--gray-dk);font-size:.84rem;}
