/*
Theme Name: Estilow Pro
Theme URI: https://estilowbd.com
Author: Estilow
Author URI: https://estilowbd.com
Description: Premium custom WooCommerce theme (no page builder). Mobile-first, SEO-ready.
Version: 1.2.9
Text Domain: estilow
*/

/* ========= Base ========= */
:root{
  --navy:#0A0F1F; --gold:#C9A86A; --beige:#F3ECE2;
  --black:#111111; --white:#FFFFFF; --muted:#f5f6fa;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Arial,sans-serif;background:#fff;color:#111;line-height:1.5}
a{color:var(--navy);text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 16px}
@media (min-width:768px){.container{padding:0 20px}}

/* ========= Header / Drawer ========= */
.site-header{background:var(--navy);color:#fff;position:sticky;top:0;z-index:99}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.site-logo a{color:var(--gold);font-weight:700;letter-spacing:.5px}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:18px}
.main-nav a{color:#fff;opacity:.9}
.main-nav a:hover{opacity:1}
.hamburger{display:none;background:transparent;border:0;color:#fff;font-size:24px}
@media (max-width:959px){.main-nav{display:none}.hamburger{display:block}}

.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.25s;z-index:98}
.drawer-backdrop.open{opacity:1;visibility:visible}
.drawer{position:fixed;inset:0 0 0 auto;width:82%;max-width:360px;background:#0b1226;color:#fff;transform:translateX(100%);transition:.25s;z-index:100;border-left:1px solid rgba(255,255,255,.08)}
.drawer.open{transform:translateX(0)}
.drawer header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid rgba(255,255,255,.1)}
.drawer nav ul{list-style:none;margin:0;padding:12px}
.drawer nav a{display:block;color:#fff;padding:12px;border-radius:8px}
.drawer nav a:hover{background:rgba(255,255,255,.08)}

/* ========= Footer ========= */
.site-footer{background:var(--navy);color:#fff;padding:28px 0 80px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:16px}
.footer-brand{font-weight:700;color:var(--gold)}
.footer-menu ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-contact div{display:flex;align-items:center;gap:8px}
.footer-social{display:flex;gap:12px;flex-wrap:wrap}
.social-pill{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;width:66px;height:66px;border-radius:14px;border:1px solid rgba(255,255,255,.18);transition:.25s;background:rgba(255,255,255,.02)}
.social-pill span{font-size:12px;margin-top:4px;opacity:.9}
.social-pill:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.25)}
.social-pill.facebook:hover{background:#1877f2}
.social-pill.youtube:hover{background:#ff0000}
.social-pill.whatsapp:hover{background:#25d366}
.footer-bottom{margin-top:14px;border-top:1px solid rgba(255,255,255,.15);padding-top:12px;text-align:center;font-size:14px;opacity:.9}

/* ========= Hero / Slider ========= */
.hero{position:relative;background:#000;color:#fff;border-radius:0;overflow:hidden;margin:0;min-height:56vh}
.hero .inner{position:relative;min-height:56vh;display:grid;place-items:center;text-align:center;padding:40px 20px}
.hero .overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.55),rgba(0,0,0,.25))}
.hero h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(28px,5vw,56px);margin:0 0 8px}
.hero p{opacity:.9;max-width:720px;margin:0 auto 18px}
.hero .cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.hero .cta a{background:var(--gold);color:#000;padding:10px 16px;border-radius:999px}
.hero.has-media .inner{display:none}
.hero-media{position:relative;height:56vh}
@media (min-width:992px){.hero,.hero.has-media,.hero-media{height:56vh}}

.slider{position:relative;overflow:hidden}
.slider-track{display:flex;transition:transform .5s ease}
.slide{min-width:100%;height:56vh;background-size:cover;background-position:center}
.slider-dots{position:absolute;left:0;right:0;bottom:12px;display:flex;gap:8px;justify-content:center}
.slider-dots button{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.5)}
.slider-dots button.active{background:#fff}

/* ========= Category strip / sheet ========= */
.cat-strip{padding:16px 0 6px;background:#fff}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (min-width:992px){.cat-grid{grid-template-columns:repeat(6,1fr)}}
.cat-card{background:var(--beige);border-radius:16px;padding:12px;text-align:center}
.cat-card .img-wrap{width:100%;aspect-ratio:1/1;border-radius:12px;background:#f3efe6;display:grid;place-items:center;overflow:hidden}
.cat-card img{max-height:90%;max-width:90%;object-fit:contain}
.cat-card .title{margin-top:8px;font-weight:600}

.sheet{position:fixed;left:0;right:0;bottom:-100%;background:#fff;border-radius:18px 18px 0 0;box-shadow:0 -20px 60px rgba(0,0,0,.25);transition:.3s;z-index:101;max-height:80vh;overflow:auto}
.sheet.open{bottom:0}
.sheet header{padding:12px 16px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}

/* ========= Bottom nav / WhatsApp / Loader ========= */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;background:#0b1226;color:#fff;display:flex;justify-content:space-around;padding:8px 4px;z-index:95;border-top:1px solid rgba(255,255,255,.15)}
.bottom-nav a{flex:1;text-align:center;color:#fff;font-size:12px;opacity:.9}
.bottom-nav a.active{opacity:1}
.bottom-nav svg{display:block;margin:0 auto 2px}
@media (min-width:960px){.bottom-nav{display:none}.hamburger{display:none}}
.whatsapp-fab{position:fixed;right:16px;bottom:80px;z-index:96;background:#25d366;color:#fff;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(0,0,0,.25)}
.page-loader{position:fixed;inset:0;background:rgba(255,255,255,.85);display:none;align-items:center;justify-content:center;z-index:200}
.page-loader.show{display:flex}
.spinner{width:44px;height:44px;border-radius:50%;border:4px solid #ddd;border-top-color:var(--navy);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* =================================================================
   WooCommerce: Product Grid (Left aligned, clean) + Card
   ================================================================= */
.woocommerce ul.products,
.woocommerce-page ul.products{
  list-style:none !important;
  padding:0 !important;
  margin:0 !important;

  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;                    /* mobile gap */
  justify-items:stretch;
  align-items:start;
}
@media (min-width:768px){
  .woocommerce ul.products,
  .woocommerce-page ul.products{ gap:14px; }
}
@media (min-width:992px){
  .woocommerce ul.products,
  .woocommerce-page ul.products{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:18px;
  }
}

/* kill legacy floats/margins so grid starts from LEFT */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{
  width:auto !important;
  margin:0 !important;
  float:none !important;
  clear:none !important;
  box-sizing:border-box;
}

/* kill old clearfix */
.woocommerce ul.products:before,
.woocommerce ul.products:after,
.woocommerce-page ul.products:before,
.woocommerce-page ul.products:after{content:none !important;display:none !important}

/* ---------- Card ---------- */
.woocommerce ul.products li.product.est-card{
  display:flex;flex-direction:column;text-align:left;
  border:1px solid #e9e9e9;border-radius:14px;background:#fff;padding:10px;
  transition:transform .18s, box-shadow .18s;min-height:420px;
}
.woocommerce ul.products li.product.est-card:hover{
  transform:translateY(-3px);box-shadow:0 10px 26px rgba(0,0,0,.06)
}

/* image box + hover second image */
.est-card .thumb{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:4/4;background:#f7f7f7}
.est-card .thumb .img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .25s}
.est-card .thumb .img.hover{position:absolute;inset:0;opacity:0}
.est-card:hover .thumb .img.hover{opacity:1}
.est-card .thumb-link{position:absolute;inset:0;display:block}

/* discount ribbon */
.est-card .ribbon{
  position:absolute;left:1px;top:11px;z-index:2;
  background:#e74c3c;color:#fff;font-weight:600;
  padding:1px 10px;border-radius:0;font-size:12px;transition:.2s;
}
.est-card:hover .ribbon{opacity:0;transform:translateY(-6px)}

/* quick view icon */
.est-card .qv{
  position:absolute;right:10px;top:10px;z-index:3;
  width:34px;height:34px;border-radius:50%;border:0;
  background:rgba(0,0,0,.55);color:#fff;opacity:0;transform:translateY(-6px);
  transition:.2s;cursor:pointer;
}
.est-card:hover .qv{opacity:1;transform:translateY(0)}

/* text + price */
.est-card .title{display:block;margin:10px 0 6px;font-weight:700;color:#111}
.est-card .sale-pill{display:inline-block;background:#cfeff3;color:#0e6572;padding:6px 12px;border-radius:999px;font-weight:600;font-size:13px;margin-bottom:6px;width:50px}
.est-card .price-row{margin:2px 0 10px}
.est-card .price-row .price del{color:#9aa0a6;margin-right:6px}
.est-card .price-row .price ins{text-decoration:none}

/* attribute chips */
.est-card .est-attrs{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0}
.est-card .chip{padding:6px 10px;border:1px solid #e0e0e0;border-radius:8px;background:#fff;font-size:12px;cursor:pointer}
.est-card .chip.selected{background:var(--navy);color:#fff;box-shadow:0 0 0 2px rgba(10,15,31,.08)}
.est-card .chip-color{text-transform:uppercase}

/* CTA: Add / View Cart (same look) */
.est-card .card-cta{margin-top:auto}
.est-card .button.est-add{width:100%;border-radius:28px;padding:12px 14px;text-align:center;background:var(--navy);color:#fff;border:none}
.est-card .button.est-add:hover{filter:brightness(1.05)}
.est-card .button.est-add.disabled{opacity:.6;cursor:not-allowed;background:none;box-shadow:0 0 0 2px rgba(10,15,31,.08)}
.est-card .button.est-add.viewcart{background:var(--navy);color:#fff;border:none}

/* Woo default inline “View cart” link hide (safety) */
.est-card a.added_to_cart,
.est-card a.wc-forward.added_to_cart{display:none !important}

/* ========= Header Cart Pill (simple premium, inside badge) ========= */
.header-cart{
  display:inline-flex;align-items:center;gap:10px;max-width:100%;
  padding:8px 14px;border-radius:999px;overflow:hidden;
  background:var(--navy);color:#fff;text-decoration:none;line-height:1;
  border:1px solid rgba(255,255,255,.08);box-shadow:0 6px 18px rgba(10,15,31,.18);
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.header-cart:hover{background:#111833;transform:translateY(-1px);box-shadow:0 10px 24px rgba(10,15,31,.22)}
.header-cart .cart-ico{
  width:28px;height:28px;display:grid;place-items:center;border-radius:999px;
  background:rgba(255,255,255,.12);font-size:16px;
}
.header-cart .count{
  display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 8px;
  border-radius:999px;background:#fff;color:var(--navy);font-weight:700;font-size:12px;
}
@keyframes bump{0%{transform:scale(1)}40%{transform:scale(1.08)}100%{transform:scale(1)}}
.header-cart.bump{animation:bump .35s ease}




/*================Cart Page===================*/
/* ====== Estilow — Minimal Cart (like screenshot) ====== */

/* Container + 2-column layout */
body.woocommerce-cart .wp-block-woocommerce-filled-cart-block{
  max-width:1120px; margin:24px auto 80px; padding:0 20px;
  display:grid; grid-template-columns: 2fr 1fr; gap:60px;
}

/* Page title */
body.woocommerce-cart h1, 
body.woocommerce-cart .wp-block-woocommerce-cart .wp-block-heading{
  font-size:42px; line-height:1.1; margin:0 0 18px; font-weight:800;
}

/* ----- LEFT: items table (flat, line separators) ----- */
body.woocommerce-cart .wc-block-cart__main{
  background:transparent; border:0; padding:0; box-shadow:none;
}
body.woocommerce-cart .wc-block-cart-items{ width:100%; border-collapse:collapse; }
body.woocommerce-cart .wc-block-cart-items__header{
  text-transform:uppercase; letter-spacing:.06em; color:#8b8f98;
  font-size:12px; border-bottom:1px solid #eee;
}
body.woocommerce-cart .wc-block-cart-items__row{
  border-bottom:1px solid #eee;
}
body.woocommerce-cart .wc-block-cart-item__image img{
  width:96px;height:96px; border-radius:10px; object-fit:cover;
}
body.woocommerce-cart .wc-block-components-product-name{
  font-weight:700; font-size:16px; color:#111; margin-bottom:6px;
}
body.woocommerce-cart .wc-block-cart-item__prices del{ color:#9aa0a6; margin-right:6px; }
body.woocommerce-cart .wc-block-components-sale-badge{
  display:inline-block; margin-top:6px;
  background: #aae5a9;
    color: #006921; font-weight:700;
  padding:4px 8px; border-radius:999px; font-size:12px;
}

/* Qty group like screenshot */
body.woocommerce-cart .wc-block-components-quantity-selector{
  display:inline-grid; grid-auto-flow:column; align-items:center; gap:0px;
  border:1px solid #e4e7ee; border-radius:8px; padding:6px 8px; background:#fff;
}
body.woocommerce-cart .wc-block-components-quantity-selector__input{
  width:36px; text-align:center; border:0; outline:0; background:transparent; font-weight:600;
}
body.woocommerce-cart .wc-block-components-quantity-selector__button{
  width:26px; height:26px; border:0; border-radius:6px; background:#f4f5f7; cursor:pointer;
}
body.woocommerce-cart .wc-block-components-quantity-selector__button:disabled{
  opacity:.5; cursor:not-allowed;
}

/* Remove link → small icon-like */
body.woocommerce-cart .wc-block-cart-item__remove-link{
  display:inline-grid;          /* nice click target */
  place-items:center;
  width:32px; height:32px;      /* touch friendly */
  padding:0;
  border-radius:8px;
  background:transparent;
  text-decoration:none !important;

  /* hide the text */
  font-size:0 !important;                  /* hides "Remove item" text */
  color:#0A0F1F;        
}
body.woocommerce-cart .wc-block-cart-item__remove-link::before{
  content: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' fill='%23111' viewBox='0 0 448 512' width='16' height='16'><path d='M135.2 17.7L141.5 0h165l6.3 17.7L344 32H104l31.2-14.3zM32 96h384l-35.8 372.3c-2.6 27.5-25.7 43.7-53.2 43.7H121c-27.5 0-50.6-16.2-53.2-43.7L32 96zm96 64v256h32V160h-32zm96 0v256h32V160h-32zm96 0v256h32V160h-32z'/></svg>");
   display: inline-block;
}
/* hover/focus state */
body.woocommerce-cart .wc-block-cart-item__remove-link:hover{
  background:red !important;
  color:white !important;
}
body.woocommerce-cart .wc-block-cart-item__remove-link:focus{
  outline:2px solid rgba(10,15,31,.35) !important;
  outline-offset:2px !important;
}
/* Right column: Totals box */
body.woocommerce-cart .wc-block-cart__sidebar{
  background:#fff;
  padding:20px 18px; height:fit-content; position:sticky; top:5px;
  
}
body.woocommerce-cart .wc-block-cart__totals-title{
  display:none;
}
body.woocommerce-cart .wc-block-components-totals-wrapper{ margin:0px 0 !important; border:none !important; padding:0px !important;}
body.woocommerce-cart .wc-block-components-totals-item{
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 0; 
}
.wc-block-cart .wp-block-woocommerce-cart-order-summary-block{
    border:none !important;
}
body.woocommerce-cart .wc-block-components-totals-item:first-child{ border-top:0; }

body.woocommerce-cart .wc-block-cart__submit .wc-block-components-button{
  width:100%; border-radius:5px; padding:14px 16px;float:center;
  background:#111; color:#fff; border:0; font-weight:800;
}
body.woocommerce-cart .wc-block-cart__submit .wc-block-components-button:hover{
  filter:brightness(1.08);
}

/* Coupon “accordion” look */
body.woocommerce-cart .wc-block-components-panel__button{
  border:1px solid #eceff4; border-radius:10px; padding:10px 12px; background:#fafbfc;
}

/* Recently viewed (spacing tidy) */
body.woocommerce-cart .rv-container, 
body.woocommerce-cart .woocommerce .related{
  max-width:1120px; margin:20px auto 80px; padding:0 20px;
}

/* ----- Responsive ----- */
@media (max-width: 900px){
  body.woocommerce-cart .wp-block-woocommerce-filled-cart-block{
    grid-template-columns:1fr; gap:0px; margin:16px auto 60px;
  }
  body.woocommerce-cart .wc-block-cart__sidebar{ position:relative; top:auto; }
  body.woocommerce-cart .wc-block-cart-item__image img{ width:72px;height:72px; }
}

/* ===== Desktop: Items full width; totals below, right side half ===== */

/* এক কলাম লেআউট—সব ব্রেকপয়েন্টে */
body.woocommerce-cart .wp-block-woocommerce-filled-cart-block{
  grid-template-columns: 1fr !important; /* override previous 2-col */
  gap: 0px !important;
}

/* আইটেম টেবিল পুরো প্রস্থে */
body.woocommerce-cart .wc-block-cart__main{
  width: 100% !important;
}

/* Totals ব্লক: নিচে, ডান দিকে, কনটেইনারের অর্ধেক */
body.woocommerce-cart .wc-block-cart__sidebar{
  width: min(50%, 520px);
  margin-left: auto;          /* ডান পাশে ঠেলে দেবে */
  margin-right: 0;
  /* একটু আলাদা স্পেসিং */
  padding: 0px 18px !important;
  position: relative; top: auto; /* sticky নয় */
}

/* টাইটেল ও লাইনস্পেস মসৃণ */
body.woocommerce-cart .wc-block-cart__totals-title{
  margin: 0 0 12px;
}

/* মোবাইল/ট্যাবলেটে 100% (রুলটি রেখে দিন) */
@media (max-width: 900px){
  body.woocommerce-cart .wc-block-cart__sidebar{
    width: 100%;
    margin: 0;
  }
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-weight: 400 !important;
    font-size: 17px !important;
    
}


/* ------------------------
   Checkout Page Responsive
   ------------------------ */
body.est-checkout .woocommerce {
  padding: 16px;
  max-width: 1200px;
  margin: 0 auto;
}

/* Headings */
body.est-checkout h3 {
  font-size: 18px;
  margin: 0 0 12px;
  font-weight: 600;
}

/* Two-column → Mobile 1col, Desktop 2col */
body.est-checkout .col2-set {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 768px) {
  body.est-checkout .col2-set {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
  }
}

/* Form fields */
body.est-checkout .woocommerce form .form-row {
  margin-bottom: 12px;
}
body.est-checkout .woocommerce input.input-text,
body.est-checkout .woocommerce textarea,
body.est-checkout .woocommerce select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #ddd;
  border-radius: 8px;
  background: #fff;
  font-size: 14px;
}
body.est-checkout .woocommerce input:focus,
body.est-checkout .woocommerce textarea:focus,
body.est-checkout .woocommerce select:focus {
  border-color: var(--navy, #0A0F1F);
  outline: none;
}

/* Order Review Card */
body.est-checkout #order_review {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  overflow: hidden;
}
body.est-checkout #order_review_heading {
  margin: 16px 0 8px;
  font-size: 18px;
}

/* Order Table */
body.est-checkout .shop_table {
  width: 100%;
  border-collapse: collapse;
}
body.est-checkout .shop_table th,
body.est-checkout .shop_table td {
  padding: 10px 12px;
  border-bottom: 1px solid #f0f0f0;
  font-size: 14px;
}
body.est-checkout .shop_table thead {
  background: #f9fafb;
  font-weight: 600;
}
body.est-checkout .shop_table tfoot th {
  text-align: left;
}
body.est-checkout .shop_table tfoot td {
  font-weight: 600;
}

/* Product thumbnail + name */
body.est-checkout .co-item {
  display: flex;
  align-items: center;
  gap: 10px;
}
body.est-checkout .co-thumb-wrap {
  width: 48px;
  height: 48px;
  border-radius: 6px;
  overflow: hidden;
  flex-shrink: 0;
}
body.est-checkout img.co-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
body.est-checkout .co-title {
  font-size: 14px;
  font-weight: 500;
}

/* Payment box */
body.est-checkout #payment {
  padding: 12px;
}
body.est-checkout .payment_methods {
  list-style: none;
  margin: 0;
  padding: 0;
}
body.est-checkout .payment_methods > li {
  margin-bottom: 10px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 10px;
}
body.est-checkout .payment_box {
  margin-top: 8px;
  background: #f9fafb;
  border-radius: 8px;
  padding: 10px;
  font-size: 13px;
}

/* Place Order Button */
body.est-checkout #place_order {
  width: 100%;
  padding: 14px;
  border: none;
  border-radius: 999px;
  background: var(--navy, #0A0F1F);
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
}
body.est-checkout #place_order:hover {
  opacity: 0.9;
}

/* Mobile Banking custom (bkash/nagad/rocket/upay) */
body.est-checkout .mobile-banking-container .payment-method-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 8px 0;
  padding: 0;
  list-style: none;
}
body.est-checkout .mobile-banking-container .payment-method-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border: 1px solid #ddd;
  border-radius: 8px;
  background: #fff;
  font-size: 13px;
}
body.est-checkout .mobile-banking-container .payment-icon {
  width: 22px;
  height: 22px;
}


/* ===== Le Reve style header (light) ===== */
.site-header.header--light{
  --bg:#fff; --fg:#111; --muted:#52565e; --sep:#eaeaea;
  position:sticky; top:0; z-index:99;
  background:var(--bg); color:var(--fg);
  border-bottom:1px solid var(--sep);
}
.site-header .inner{
  display:grid; grid-template-columns:40px 1fr auto; align-items:center;
  padding:8px 0;
}
.site-header .container{max-width:1200px;margin:0 auto;padding:0 16px}
@media (min-width:768px){.site-header .container{padding:0 20px}}

.site-logo a{
  display:inline-block; text-decoration:none; color:var(--fg);
  font-family:"Playfair Display", Georgia, serif;
  font-weight:900; font-size:22px; letter-spacing:.02em;
}
.hamburger{background:transparent;border:0;color:var(--fg);display:flex;align-items:center;justify-content:center}
@media (min-width:960px){.hamburger{display:none}}

.header-icons{display:flex;align-items:center;gap:14px}
.icon-link{position:relative;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--fg);opacity:.85}
.icon-link:hover{opacity:1}
.cart-link .badge{
  position:absolute; top:-6px; right:-6px; min-width:17px; height:17px;
  padding:0 6px; border-radius:999px; background:#111; color:#fff;
  font-size:11px; font-weight:800; display:grid; place-items:center;
}
.country-pill{
  display:inline-flex; align-items:center; gap:4px; font-size:12px;
  padding:4px 8px; border-radius:999px; border:1px solid var(--sep); color:var(--fg);
}

/* primary nav (optional; যদি header-এর ভেতরে দেখাতে চান) */
.main-nav{display:none}
@media (min-width:1200px){
  .main-nav{display:block}
  .main-nav .menu{display:flex;gap:20px;list-style:none;margin:0;padding:0}
  .main-nav a{color:var(--fg);font-weight:600}
}

/* ===== Category bar: thin, uppercase ===== */
.category-bar{
  background:#fff; border-top:1px solid var(--sep);
  overflow:auto; white-space:nowrap;
}
.cat-menu{display:flex;gap:26px;list-style:none;margin:0;padding:10px 16px}
.cat-menu a{
  color:#333; font-weight:600; letter-spacing:.04em; font-size:14px;
  text-transform:uppercase; opacity:.85; padding:2px 0;
}
.cat-menu a:hover{opacity:1}
.cat-menu li{flex:0 0 auto}

/* Mobile tweaks: logo center */
@media (max-width:959px){
  .site-header .inner{grid-template-columns:40px 1fr 100px}
  .header-icons{justify-content:flex-end}
}

/* Drawer (already exists)—just make it light */
.drawer{background:#fff;color:#111;border-left:1px solid #eee}
.drawer header{border-bottom:1px solid #eee}
.drawer nav a{color:#111}
.drawer nav a:hover{background:#f7f7f7}
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);opacity:0;visibility:hidden;transition:.25s;z-index:98}
.drawer-backdrop.open{opacity:1;visibility:visible}
.drawer{position:fixed;right:0;top:0;bottom:0;width:82%;max-width:360px;transform:translateX(100%);transition:.25s;z-index:100;padding-bottom:24px;overflow:auto}
.drawer.open{transform:translateX(0)}


/* ===== FORCE DARK HEADER (Le Reve layout, dark colors) ===== */
.site-header{ 
  --bg:#0A0F1F;           /* deep black/navy */
  --fg:#ffffff;
  --muted:rgba(255,255,255,.85);
  --sep:rgba(255,255,255,.12);
  background:var(--bg) !important;
  color:var(--fg) !important;
  border-bottom:1px solid var(--sep) !important;
}

/* grid + spacing same as before */
.site-header .inner{
  display:grid; grid-template-columns:40px 1fr auto; align-items:center;
  padding:8px 0;
}
@media (max-width:959px){
  .site-header .inner{ grid-template-columns:40px 1fr 110px; }
}

/* logo + icons white */
.site-logo a{ color:var(--fg) !important; font-weight:900; letter-spacing:.02em; }
.hamburger{ color:var(--fg) !important; }

/* right-side icons */
.header-icons{ display:flex; align-items:center; gap:14px; }
.icon-link{ color:var(--fg) !important; opacity:.9; }
.icon-link:hover{ opacity:1; }

/* cart badge: white pill on dark */
.cart-link .badge{
  position:absolute; top:-6px; right:-6px;
  min-width:18px; height:18px; padding:0 6px;
  border-radius:999px; display:grid; place-items:center;
  font-size:11px; font-weight:800;
  background:#fff; color:#0A0F1F; box-shadow:0 0 0 3px #0A0F1F;
}

/* country pill inverted (outline on dark) */
.country-pill{
  color:#fff; border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.04); border-radius:999px;
}

/* ===== DARK CATEGORY BAR ===== */
.category-bar{
  background:var(--bg) !important;
  border-top:1px solid var(--sep) !important;
  overflow:auto; white-space:nowrap;
}
.cat-menu{ display:flex; gap:26px; list-style:none; margin:0; padding:10px 16px; }
.cat-menu a{
  color:#fff !important; opacity:.85; text-transform:uppercase;
  font-weight:600; letter-spacing:.04em; padding:2px 0; font-size:12px;
}
.cat-menu a:hover{ opacity:1; }

/* optional underline for active */
.cat-menu .current a{ opacity:1; box-shadow:0 2px 0 0 #fff; }

/* ----- HEADER ALIGNMENT FIX ----- */
.site-header .inner {
  display: flex !important;
  align-items: center;      /* vertical center */
  justify-content: space-between; /* logo center হবে না, তাই grid hack */
  gap: 20px;
}

/* logo center করতে grid ব্যবহার */
.site-header .container {
  display: grid !important;
  grid-template-columns: 40px 1fr auto;  /* left - center - right */
  align-items: center;
}
.site-logo {
  text-align: center;
}
.site-logo a {
  display: inline-block;
  font-size: 22px;
  font-weight: 900;
  color: #fff; /* dark theme */
}

/* icons right-align */
.header-icons {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
}

/* category bar center */
.category-bar .cat-menu {
  display: flex;
  justify-content: center;   /* center horizontally */
  gap: 30px;
}

/* ================== LE REVE-LIKE DARK HEADER ================== */
.site-header{
  --bg:#0A0F1F; --fg:#fff; --sep:rgba(255,255,255,.12);
  position:sticky; top:0; z-index:99;
  background:var(--bg); color:var(--fg);
  border-bottom:1px solid var(--sep);
}

/* Top row: hamburger | LOGO (center) | icons (right) */
.site-header .top{
  display:grid; grid-template-columns:40px 1fr auto;
  align-items:center; gap:12px; padding:8px 0;
}
.hamburger{background:none;border:0;color:var(--fg);display:flex;align-items:center;justify-content:center}
@media (min-width:960px){ .hamburger{display:none} }

.site-logo{ text-align:center; }
.site-logo a{ color:#fff; font-family:"Playfair Display", Georgia, serif; font-weight:900; font-size:24px; letter-spacing:.02em; text-decoration:none; }
.header-icons{ display:flex; align-items:center; gap:12px; justify-content:flex-end; }
.icon-link{ position:relative; width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; color:#fff; opacity:.9 }
.icon-link:hover{ opacity:1 }
.cart-link .badge{
  position:absolute; top:-6px; right:-6px; min-width:18px; height:18px;
  padding:0 6px; border-radius:999px; background:#fff; color:#0A0F1F; font-size:11px; font-weight:800;
  display:grid; place-items:center; box-shadow:0 0 0 3px #0A0F1F;
}
.country-pill{ display:inline-flex; align-items:center; gap:4px; padding:4px 8px; font-size:12px;
  border:1px solid rgba(255,255,255,.18); color:#fff; border-radius:999px; background:rgba(255,255,255,.04) }

/* Second row: SEARCH | CATEGORIES(center) | CART bubble (right) */
.site-header .nav-row{
  display:grid; grid-template-columns: 280px 1fr 60px;
  align-items:center; border-top:1px solid var(--sep);
  padding:10px 0; gap:12px;
}
/* left: search (desktop only) */
.site-header .nav-left form.search-form,
.site-header .nav-left form.woocommerce-product-search{
  display:flex; align-items:center; gap:8px; background:#111833;
  border:1px solid rgba(255,255,255,.18); border-radius:999px; padding:8px 12px;
}
.site-header .nav-left input[type="search"]{
  background:transparent; border:0; outline:0; color:#fff; width:100%;
}
.site-header .nav-left button{ background:transparent; border:0; color:#fff; }

/* center: categories */
.site-header .nav-center{ overflow:auto; }
.cat-menu{ list-style:none; display:flex; justify-content:left; gap:26px; margin:0; padding:4px 0px; }
.cat-menu a{ color:#fff; text-transform:uppercase; opacity:.85; font-weight:600; letter-spacing:.04em; }
.cat-menu a:hover, .cat-menu .current a{ opacity:1 }

/* right: cart bubble (like Le Reve) */
.site-header .nav-right{ display:flex; justify-content:flex-end; }
.cart-bubble{
  position:relative; width:44px; height:44px; border-radius:22px;
  background:#0d1530; border:1px solid rgba(255,255,255,.1);
  display:inline-grid; place-items:center; color:#fff; text-decoration:none;
}
.cart-bubble span{
  position:absolute; top:-6px; right:-6px; width:20px; height:20px;
  border-radius:999px; background:#fff; color:#0A0F1F; font-size:12px; font-weight:800;
  display:grid; place-items:center; box-shadow:0 0 0 3px #0A0F1F;
}

/* MOBILE: search hide, cat-menu scrollable */
@media (max-width: 959px){
  .site-header .nav-row{ grid-template-columns: 1fr; gap:8px; padding:8px 0 10px; }
  .site-header .nav-left{ display:none; }
  .site-header .nav-right{ display:none; }  /* উপরের রো-য়ের কার্টই থাকবে */
  .cat-menu{ justify-content:flex-start; gap:20px; padding:5px 2px; overflow:auto; }
}

/* Container */
.site-header .container{ max-width:1200px; margin:0 auto; padding:0 16px }
@media (min-width:768px){ .site-header .container{ padding:0 20px } }

/* Logo size override */
.site-logo img {
  max-height: 40px !important;  /* height বাড়ানো */

  max-width: 150px;
}
@media (max-width: 768px) {
  .site-logo img {
    max-width: 120px;
  }
}


/* ---- KILL old inner hack (so our .top grid works) ---- */
.site-header .inner{
  display: contents !important;   /* inner কে layout-neutral করি */
}
.site-header > .container{
  display: block !important;      /* grid জোর করে নেই, block করি */
}

/* ---- TOP ROW: Hamburger | LOGO (center) | Icons (right) ---- */
.site-header .top{
  display: grid !important;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
}
/* logo always perfectly centered */
.site-header .top .site-logo{
  text-align: center;
  justify-self: center;           /* grid-level center */
}
.site-header .top .header-icons{
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
}

/* ---- NAV ROW: center categories on mobile too ---- */
.site-header .nav-row{
  display: grid;
  grid-template-columns: 280px 1fr 60px;
  align-items: center;
  border-top: 1px solid var(--sep);
  padding: 10px 0;
  gap: 12px;
}

/* ক্যাটাগরি সবসময়ই center থাকুক */
.site-header .nav-center .cat-menu{
  display: flex;
  justify-content: center !important;  /* override flex-start */
  gap: 26px;
  margin: 0;
  padding: 4px 0px;
}

/* ---- Mobile tweaks ---- */
@media (max-width: 959px){
  /* second row এক কলাম; তবু center */
  .site-header .nav-row{
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 8px 0 10px;
  }
  .site-header .nav-left{ display: none; }     /* search hide on mobile (Le Reve style) */
  .site-header .nav-right{ display: none; }    /* উপরের রো-য়ের cart-ই থাকবে */
  .site-header .nav-center .cat-menu{
    justify-content: center !important;        /* বাম নয়, কেন্দ্র */
  }

  /* লোগো সামান্য ছোট, তবু সেন্টার */
  .site-logo img{
    max-height: 32px !important;
    width: auto;
  }
}

/* ডেস্কটপে লোগো একটু বড় করে সুন্দর ব্যালান্স */
@media (min-width: 960px){
  .site-logo img{
    max-height: 40px !important;
    width: auto;
  }
}

/* --- SEARCH: collapsed by default --- */
.site-header .nav-row{
  /* যখন সার্চ বন্ধ থাকবে:  categories + cart শুধু */
  grid-template-columns: 1fr 60px;
}

/* সার্চ কন্টেইনার হাইডেড */
.site-header .nav-left{
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: max-height .25s ease, opacity .2s ease, transform .2s ease;
}

/* --- OPEN STATE --- */
.site-header.search-open .nav-row{
  grid-template-columns: 280px 1fr 60px; /* সার্চ কলাম দেখাও */
}
.site-header.search-open .nav-left{
  max-height: 56px;      /* তোমার ইনপুটের উচ্চতা অনুযায়ী */
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

/* সার্চ বক্স স্টাইল (আগেরটাই, শুধু ছোট height) */
.site-header .nav-left form.search-form,
.site-header .nav-left form.woocommerce-product-search{
  display: flex; align-items: center; gap: 8px;
  background: #111833;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px; padding: 8px 12px;
}
.site-header .nav-left input[type="search"]{
  background: transparent; border: 0; outline: 0; color:#fff; width:100%;
}
.site-header .nav-left button{ background: transparent; border: 0; color:#fff; }

/* --- MOBILE tweaks --- */
@media (max-width: 959px){
  /* মোবাইলে সার্চ খুললে এক কলাম */
  .site-header.search-open .nav-row{ grid-template-columns: 1fr; }
  .site-header .nav-row{ grid-template-columns: 1fr; }
  .site-header .nav-right{ display:none; } /* top row-এর cart ই থাকবে */

  /* ক্যাটেগরি মেনুর ফন্ট ও গ্যাপ ছোট */
  .category-bar .cat-menu a,
  .site-header .nav-center .cat-menu a{
    font-size: 10px;        /* আগে থেকে ছোট */
    letter-spacing: .03em;
  }
  .category-bar .cat-menu,
  .site-header .nav-center .cat-menu{
    gap: 16px;
  }
}

/* ডেস্কটপে ক্যাটেগরি সবসময় সেন্টার থাকবে */
.site-header .nav-center .cat-menu{ justify-content: center; }

/* শুধুমাত্র search icon এর জন্য আলাদা কালার */
.icon-link.search-icon svg path {
  fill: #ccc !important;   /* হালকা গ্রে */
}

/* hover করলে সাদা */
.icon-link.search-icon:hover svg path {
  fill: #fff !important;
}
.icon-link,
.icon-link:focus,
.icon-link:hover {
  background: transparent !important;  /* কোনো grey bg থাকবে না */
  border: none;                        /* default border clear */
  outline: none;                       /* default outline clear */
  box-shadow: none;                    /* কোনো shadow না */
}
.search-icon {
  background: rgba(255,255,255,.08);
  border-radius: 50%;
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.search-icon:hover {
  background: rgba(255,255,255,.18);
}
.search-icon i {
  font-size: 15px;
  color: #fff;
}
.search-icon i {
  font-size: 16px;     /* সাইজ বাড়াও */
  color: #fff;         /* সাদা দেখাবে */
  line-height: 1;
}
.search-icon {
  background: transparent; 
  border: none;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}


.cart-link {
  position: relative;
}

.cart-link .badge {
  position: absolute;
  top: -6px;
  right: -8px;
  background: #e74c3c;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  border-radius: 50%;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  box-shadow: 0 0 0 2px #0A0F1F; /* header background match */
}

.cart-link { position: relative; }
.cart-link .badge{
  position:absolute; top:-6px; right:-8px;
  background:#e74c3c; color:#fff;
  font-size:12px; font-weight:700;
  border-radius:50%;
  min-width:18px; height:18px; padding:0 5px;
  display:flex; align-items:center; justify-content:center; line-height:1;
  box-shadow:0 0 0 2px #0A0F1F; /* header bg color */
}


/* Keep cart icon + count inside the container */
.header-icons { display:flex; align-items:center; gap:12px; }

/* little breathing room on the right so badge doesn’t overflow */
.cart-link { position:relative; padding-right:6px; }

/* Tighter badge position for mobile */
.cart-link .badge{
  position:absolute;
  top:-4px;          /* a bit up */
  right:-2px;        /* not too far right */
  background:#e74c3c;
  color:#fff;
  font-size:10px;
  font-weight:700;
  border-radius:50%;
  min-width:16px;
  height:16px;
  padding:0 4px;
  display:flex; align-items:center; justify-content:center;
  line-height:1;
  box-shadow:0 0 0 2px var(--bg, #0A0F1F); /* header bg */
}

/* Desktop: slightly larger badge, still inside */
@media (min-width: 960px){
  .cart-link{ padding-right:8px; }
  .cart-link .badge{
    top:-6px;
    right:-4px;
    min-width:18px; height:18px; font-size:11px; padding:0 5px;
  }
}

/* Make sure the top row itself never clips content */
.site-header .top { overflow:visible; }

/* Optional: if কোনো থিম/প্লাগিন .container এ overflow:hidden সেট করে থাকে */
.site-header .container{ overflow:visible; }


/* Cart link wrapper always relative */
.cart-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
}

/* Cart SVG নিজেই সেন্টারে থাকবে */
.cart-link svg {
  width: 22px;
  height: 22px;
  display: block;
}

/* Badge fully inside the icon */
.cart-link .badge {
  position: absolute;
    top: 4px;
    right: 16px;
    transform: translate(30%, -30%);
    background: #e74c3c00;
    color: #ff0000;
    font-size: 11px;
    font-weight: 700;
    /* border-radius: 50%; */
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: none;
}

/* Desktop slightly bigger */
@media (min-width: 960px) {
  .cart-link {
    width: 40px;
    height: 40px;
  }
  .cart-link .badge {
    min-width: 20px;
    height: 20px;
    font-size: 12px;
    transform: translate(35%, -35%);
    top: 8px;
    right: 19px;
  }
}
/* === Mobile search toggle fix === */
@media (max-width: 959px){
  /* ডিফল্ট: এক কলাম */
  .site-header .nav-row{ grid-template-columns: 1fr !important; }

  /* ডিফল্টে হাইড */
  .site-header .nav-left{
    display: none !important;
    max-height: 0 !important;
    opacity: 0 !important;
    transform: translateY(-6px) !important;
    pointer-events: none !important;
  }

  /* search-open হলে শো */
  .site-header.search-open .nav-left{
    display: block !important;
    max-height: 80px !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
  }

  /* ফর্মটা ফুল-উইডথ */
  .site-header .nav-left form{
    width: 100%;
  }
}
/* ===== Search: keep inside container + unique glass style ===== */

/* nav-row সবসময় container-ভিতরে */
.site-header .nav-row.container{
  padding-left: 16px;
  padding-right: 16px;
}

/* সার্চ কন্টেইনার সীমাবদ্ধ: কন্টেইনারের ভেতরে সেন্টার */
.site-header .nav-left{
  justify-self: center;                  /* grid cell-এ center */
  width: min(720px, 100%);               /* ডেস্কটপে ম্যাক্স 720px */
}

/* মোবাইলে সার্চ ওপেন হলে এক কলাম – কন্টেইনারের ভেতরে ফুল-উইডথ */
@media (max-width: 959px){
  .site-header .nav-row.container{
    grid-template-columns: 1fr !important;
  }
  .site-header.search-open .nav-left{
    width: 100% !important;
  }
}

/* ফর্ম—একই স্টাইল দুই ধরনের ফরমের জন্যই */
.site-header .nav-left form.search-form,
.site-header .nav-left form.woocommerce-product-search{
  position: relative;
  display: flex; align-items: center; gap: 10px;
  width: 100%;
  height: 44px;
  padding: 8px 12px 8px 44px;            /* বাম পাশে আইকনের জন্য জায়গা */
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 6px 20px rgba(0,0,0,.25) inset, 0 4px 16px rgba(0,0,0,.18);
}

/* ইনপুট */
.site-header .nav-left input[type="search"]{
  flex: 1 1 auto;
  min-width: 0;
  background: transparent;
  border: 0; outline: 0;
  color: #fff;
  font-size: 14px;
}

/* সাবমিট বাটন—পিল ডানদিকে */
.site-header .nav-left button[type="submit"]{
  flex: 0 0 auto;
  height: 30px; padding: 0 12px;
  border: 0; border-radius: 999px;
  background: linear-gradient(180deg, #ffffff, #ffffff);
  color: #001018; font-weight: 800; font-size: 12px;
  cursor: pointer;
}
.site-header .nav-left button[type="submit"]:hover{
  filter: brightness(1.08);
}

/* কাস্টম আইকন (SVG) – ইনপুটের আগে বামে বসবে */
.site-header .nav-left .est-search-ico{
  position: absolute; left: 12px; top: 50%;
  transform: translateY(-50%);
  width: 22px; height: 22px; opacity: .95;
}

/* placeholder রঙ একটু নরম */
.site-header .nav-left input::placeholder{ color: rgba(255,255,255,.7); }

/* সার্চ বার কন্টেইনারের বাইরে না যেতে overflow visible রাখুন */
.site-header .top,
.site-header .nav-row{ overflow: visible; }

/* ডার্ক হেডার ব্যাকগ্রাউন্ডের সাথে হালকা বর্ডার */
.site-header{ --sep: rgba(255,255,255,.12); }

/* মোবাইলে ক্যাটেগরি ছোট */
@media (max-width:959px){
  .site-header .nav-center .cat-menu a{ font-size: 12px; }
}
/* === Keep header logo INSIDE the container === */

/* 1) কোনো generic container-কে grid বানাব না */
.site-header .container{
  display: block !important;    /* reset */
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

/* 2) Grid শুধু .top container-এ প্রয়োগ করব */
.site-header .top.container{
  display: grid !important;
  grid-template-columns: 40px 1fr auto; /* hamburger | logo | icons */
  align-items: center;
  gap: 12px;
}

/* 3) Logo bounds + safe sizing */
.site-logo{
  justify-self: center;          /* grid cell-এ কেন্দ্রে */
  max-width: 180px;              /* কন্টেইনারের বাইরে না যাক */
  margin: 0 auto;                /* fallback centering */
}
.site-logo a,
.site-logo .custom-logo-link{
  display: block;
  max-width: 100%;
}
.site-logo img{
  display: block;
                     /* wrapper-এর মধ্যে ফিট */
  height: auto;
  max-height: 40px !important;   /* আপনার থিমের হেডার হাইটে ফিট */
}

/* 4) মোবাইলে প্যাডিং একটু ছোট */
@media (max-width: 768px){
  .site-header .container{ padding: 0 12px; }
  .site-logo{ max-width: 150px; }
  .site-logo img{ max-height: 32px !important; }
}

/* ===== Phone cat-menu: first item আর কাটা যাবে না ===== */
@media (max-width: 959px){

  /* স্ক্রল-কন্টেইনারে ভিতরের প্যাডিং দাও যাতে কনটেন্ট কন্টেইনারের ভেতর থেকেই শুরু হয় */
  .site-header .nav-center{
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-left: 16px;   /* <-- এটাই মূল fix */
    padding-right: 16px;
    scroll-padding-left: 16px; /* snap/scroll positioning friendly */
  }

  /* UL-এ অতিরিক্ত left padding/margin যেন না থাকে */
  .site-header .nav-center .cat-menu{
    margin: 0;
    padding: 6px 0;       /* আগে ছিল 5px 2px; বাম/ডান 0 রাখি */
    gap: 18px;            /* চাইলে একটু কম/বেশি করো */
  }

  /* প্রথম আইটেমের আগে একটু ইনসেট (extra guard) */
  .site-header .nav-center .cat-menu::before{
    content:"";
    flex: 0 0 0;          /* default: 0 */
  }
}

/* চাইলে সুন্দর edge-fade (purely cosmetic) */
@media (max-width: 959px){
  .site-header .nav-center{
    mask-image: linear-gradient(to right, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
    -webkit-mask-image: linear-gradient(to right, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
  }
}
/* === Phone cat-menu fine-tune: না বাইরে, না বেশি ভিতরে === */
@media (max-width: 959px){

  /* insetটা কমাও; mask থাকলে কেটে যেতে পারে—off করো */
  .site-header .nav-center{
    padding-left: 0 !important;
    padding-right: 0 !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
  }

  /* ul-এ কোনো extra padding নয় */
  .site-header .nav-center .cat-menu{
    margin: 0 !important;
    padding: 6px 0 !important;
    gap: 16px !important;
  }

  /* প্রথম/শেষ আইটেমের সামনে-শেষে ছোট spacer—just enough */
  .site-header .nav-center .cat-menu li:first-child{
    margin-left: 10px !important;   /* যদি এক চুল কাটা লাগে, 12px করুন */
  }
  .site-header .nav-center .cat-menu li:last-child{
    margin-right: 10px !important;
  }
}
/* === Mobile cat-menu: left/right spacer + no clipping === */
@media (max-width: 959px){
  /* কোনো mask/clip যেন না থাকে */
  .site-header .nav-center{
    -webkit-mask-image: none !important;
    mask-image: none !important;
    overflow-x: auto !important;   /* স্ক্রল চালু */
    overflow-y: visible !important;
  }

  /* UL: সামান্য প্যাডিং + before/after spacer */
  .site-header .nav-center .cat-menu{
    display: flex !important;
    align-items: center;
    gap: 16px !important;
    margin: 0 !important;
    padding: 6px 0 !important;     /* ভিতরের padding ছোট */
    list-style: none !important;
    scroll-snap-type: x proximity; /* nice scrolling (optional) */
  }

  /* বাম/ডান প্রান্তে 12px “virtual” স্পেসার যোগ করো */
  .site-header .nav-center .cat-menu::before,
  .site-header .nav-center .cat-menu::after{
    content: "";
    flex: 0 0 12px;                /* <-- এটা প্রান্তে জায়গা রাখে */
  }

  /* প্রতিটি আইটেম প্রান্তে ঠিকঠাক বসুক (optional) */
  .site-header .nav-center .cat-menu li{
    scroll-snap-align: start;
  }
}
/* =============== MOBILE CAT-MENU EDGE FIX =============== */
@media (max-width: 959px){
  /* nav-center নিজেই একটু ইনসেট হবে + স্ক্রল চালু */
  .site-header .nav-center{
    overflow-x: auto !important;
    padding-inline: 14px !important;   /* ← দুই পাশেই জায়গা */
  }

  /* UL: gap/spacing tidy—আগের padding 0 রিসেট করে দিচ্ছি */
  .site-header .nav-center .cat-menu,
  .category-bar .cat-menu{
    margin: 0 !important;
    padding: 0 !important;              /* base */
    gap: 18px !important;
    display: flex !important;
    align-items: center;
    white-space: nowrap;
  }

  /* শুরুর/শেষের virtual spacer, যাতে প্রথম/শেষ আইটেম কাটে না */
  .site-header .nav-center .cat-menu::before,
  .site-header .nav-center .cat-menu::after,
  .category-bar .cat-menu::before,
  .category-bar .cat-menu::after{
    content: "" !important;
    flex: 0 0 10px !important;          /* ← চাইলে 12/16px করুন */
  }

  /* প্রতিটি li স্ক্রল-লাইনে বসবে */
  .site-header .nav-center .cat-menu > li,
  .category-bar .cat-menu > li{
    flex: 0 0 auto;
  }

  /* যদি কারও CSS separator থাকে, প্রথম আইটেমে সেটা বন্ধ করুন */
  .site-header .nav-center .cat-menu > li:first-child::before,
  .category-bar .cat-menu > li:first-child::before{
    content: none !important;
  }
}


/* ==== Mobile: hide category nav completely ==== */
@media (max-width: 959px){
  /* header row-এর ক্যাটাগরি অংশ অফ */
  .site-header .nav-center{ 
    display: none !important; 
  }

  /* আলাদা category-bar থাকলে সেটাও অফ */
  .category-bar{ 
    display: none !important; 
  }

  /* grid auto-fix: ক্যাটাগরি বাদ গেলে শুধু ১ কলাম রাখো */
  .site-header .nav-row{
    grid-template-columns: 1fr !important;
  }
}


/* drawer/backdrop z-index baseline */
.drawer-backdrop{ z-index: 98; }
.drawer{ z-index: 100; }

/* header default ঠিকই আছে (99), কিন্তু শুধু বাটনটাকে drawer-এর উপর আনবো */
#open-drawer{
  position: relative;   /* নতুন stacking context */
  z-index: 120;         /* drawer (100) থেকে বেশি */
}

/* চাইলে ছোট ডিভাইসে একটু ডানদিকে gap */
@media (max-width: 959px){
  #open-drawer{ margin-left: -2px; } /* অপশনাল */
}

/* body scroll lock helper (আগে না থাকলে) */
body.no-scroll{ overflow:hidden; }

/* === Product card: keep price row on one line (mobile) === */
@media (max-width: 480px){
  .est-card .price-row{
    display:flex;
    align-items:baseline;
    gap:6px;
    white-space:nowrap;      /* no wrap */
    overflow:hidden;         /* prevent 2nd line */
    text-overflow:ellipsis;  /* if too long, show … */
    line-height:1.1;
  }
  .est-card .price-row .price{
    display:flex;
    align-items:baseline;
    gap:6px;
    font-size:10px !important;          /* 12px fix */
  }
  .est-card .price-row .price del,
  .est-card .price-row .price ins{
    display:inline-flex;
    align-items:baseline;
    white-space:nowrap;
  }
  /* Woo price spans sometimes wrap; force no-wrap */
  .est-card .price-row .woocommerce-Price-amount,
  .est-card .price-row .woocommerce-Price-currencySymbol{
    white-space:nowrap;
    line-height:1;
  }
  
}
@media (max-width: 480px){
  .est-card .price-row { font-size: 14px; }
    
}
ins{
    text-decoration: none !important;
    font-weight:bold;
  }
  

 /* ===== Ultra-unique Store Scene ================================== */
.store-scene{ padding: 36px 0 52px; background: linear-gradient(180deg,#fff, #fbfbff); }
.store-scene .container{ max-width:1200px; margin:0 auto; padding:0 16px; }

.scene{
  position:relative; display:grid; gap:22px;
  grid-template-columns: 1fr; align-items:end;
}
@media (min-width: 960px){
  .scene{ grid-template-columns: 1.2fr .8fr; }
}

/* --- collage art ------------------------------------------------- */
.art{
  position:relative; min-height: 360px; isolation:isolate;
}
.photo{ margin:0; border-radius:18px; overflow:hidden; background:#0a0f1f; }
.photo img{ width:100%; height:100%; object-fit:cover; display:block; }

/* big photo with diagonal mask & soft border glow */
.photo.big{
  aspect-ratio: 21/10;
  border:1px solid rgba(10,15,31,.08);
  box-shadow: 0 24px 60px rgba(10,15,31,.14);
  -webkit-mask-image: linear-gradient(150deg,#000 70%, transparent 100%);
  mask-image: linear-gradient(150deg,#000 70%, transparent 100%);
}

/* two stacked small photos */
.photo.small{ position:absolute; width:40%; right:4%; border:1px solid rgba(10,15,31,.08); }
.photo.small.s1{ top:8%;  aspect-ratio: 4/5; transform: rotate(-2deg); }
.photo.small.s2{ bottom:0; aspect-ratio: 5/4; transform: rotate(1.5deg); }

/* gold orbits */
.orbit{
  position:absolute; border-radius:50%;
  background: radial-gradient(closest-side, rgba(201,168,106,.38), transparent 70%);
  filter: blur(6px); z-index:0; pointer-events:none;
}
.o1{ width:260px; height:260px; left:-120px; bottom:-100px; }
.o2{ width:200px; height:200px; right:-120px; top:-80px; opacity:.7; }

/* subtle grain (data URI) */
.grain{
  position:absolute; inset:0; z-index:0; pointer-events:none; mix-blend-mode:soft-light; opacity:.3;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.15'/></svg>");
  background-size: 220px 220px;
}

/* Base section */
.outlet-section{ padding:40px 0; background:#fff; }
.outlet-section .container{ max-width:1200px; margin:0 auto; padding:0 16px; }

/* Grid layout wrapper */
.outlet-layout{
  display:grid;
  grid-template-columns:1fr;   /* default: stacked */
  gap:20px;
}

/* Photo styling */
.outlet-photo{ 
  position:relative; border-radius:16px; overflow:hidden; 
  box-shadow:0 12px 28px rgba(0,0,0,.12);
}
.outlet-photo img{ width:100%; display:block; object-fit:cover; }

/* Overlay */
.outlet-overlay{
  position:absolute; right:20px; bottom:20px;
  background:rgba(10,15,31,.75);
  color:#fff; padding:12px 18px; border-radius:12px;
  box-shadow:0 6px 20px rgba(0,0,0,.25);
  text-align:right;
}
.outlet-overlay h2{ margin:0 0 4px; font-size:20px; font-weight:800; }
.outlet-overlay p{ margin:0; font-size:14px; line-height:1.4; }

/* Map */
.outlet-map{
  border-radius:16px; overflow:hidden;
  box-shadow:0 12px 28px rgba(0,0,0,.12);
}
.outlet-map iframe{ width:100%; height:360px; border:0; display:block; }

/* ----- Responsive breakpoints ----- */
@media(min-width: 992px){
  .outlet-layout{
    grid-template-columns: 1fr 1fr;  /* photo + map side by side */
    align-items: stretch;
  }
  .outlet-photo img, 
  .outlet-map iframe{ height:100%; object-fit:cover; }
}
@media(max-width: 640px){
  .outlet-overlay{
    left:0; right:0; bottom:0;
    border-radius:0; text-align:left;
    background:linear-gradient(to top, rgba(10,15,31,.9), rgba(10,15,31,.4), transparent);
    padding:12px;
  }
  .outlet-overlay h2{ font-size:16px; }
  .outlet-overlay p{ font-size:13px; }
}

/* ===== Best Clothing Brand Footer (minimal, luxe) ===== */
.brand-footer{
  --bg:#0B0F1C; --fg:#fff; --muted:rgba(255,255,255,.78); --line:rgba(255,255,255,.12);
  --chip:#121831; --chipText:#cbd5ff; --accent:#E5E7FF;
  background:var(--bg); color:var(--fg); margin-top:48px; border-top:1px solid var(--line);
}
.brand-footer .container{max-width:1200px;margin:0 auto;padding: 35px 16px;}
.brand-footer .bf-wrap{
  display:grid; grid-template-columns:1fr; gap:26px; padding:22px 0 28px;
}
@media(min-width:900px){
  .brand-footer .bf-wrap{ grid-template-columns:1.2fr .9fr .9fr 1.2fr; gap:32px; padding:28px 0 34px; }
}

/* Brand */
.bf-logo{display:inline-grid;grid-auto-flow:column;gap:10px;align-items:center;color:#fff;text-decoration:none}
.bf-mark{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-weight:900;
  background:linear-gradient(135deg,#3238f2 0%,#7a5cff 60%,#b44dff 100%);
  box-shadow:0 12px 28px rgba(122,92,255,.25);
}
.bf-name{font-weight:900;letter-spacing:.06em;font-size:22px}
.bf-tag{margin:6px 0 14px;color:var(--muted)}
/* Social (tiny, pro) */
.bf-social{display:flex;gap:10px}
.bf-social .s{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid var(--line);transition:.2s}
.bf-social .s svg{width:18px;height:18px;fill:#fff;opacity:.95}
.bf-social .s:hover{transform:translateY(-3px)}
.bf-social .fb:hover{background:#1877f2}
.bf-social .ig:hover{background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af,#515bd4)}
.bf-social .tiktok:hover {
  background: linear-gradient(135deg, #25F4EE, #000000, #FE2C55);
  color: #fff;
}

.bf-social .yt:hover{background:#ff0033}
.bf-social .wa:hover{background:#25d366}

/* Columns */
.brand-footer .bf-col h3{
  margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:#e9ecff;opacity:.9
}
.bf-menu{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.bf-menu a{color:var(--muted);text-decoration:none}
.bf-menu a:hover{color:#fff}

/* Contact + Newsletter */
.bf-address{font-style:normal;color:var(--muted);line-height:1.5;margin:0 0 10px}
.bf-address a{color:#fff;text-decoration:none}
.bf-address a:hover{text-decoration:underline}

.bf-news{display:grid;grid-template-columns:1fr auto;gap:8px;margin:10px 0 12px}
.bf-news input{
  background:var(--chip);color:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 12px;outline:0
}
.bf-news input::placeholder{color:rgba(255,255,255,.55)}
.bf-news button{
  border:0;border-radius:10px;padding:10px 14px;font-weight:800;cursor:pointer;
  background:#fff;color:#0A0F1F; font-size:20px;
}
.bf-news button:hover{filter:brightness(1.06)}

.bf-pay{display:flex;gap:8px;flex-wrap:wrap}
.bf-pay .pill{
  background:var(--chip);color:var(--chipText);border:1px solid var(--line);
  padding:6px 10px;border-radius:999px;font-size:12px
}

/* Bottom line */
.bf-bottom{border-top:1px solid var(--line)}
.bf-bottom-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;color:var(--muted);font-size:13px;gap:12px}
@media(max-width:640px){.bf-bottom-row{flex-direction:column;gap:6px}}

/* Accessibility helper (label hide but screen-reader visible) */
.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}
.brand-footer{
  --bg:#0B0F1C; --fg:#fff; --muted:rgba(255,255,255,.7); --line:rgba(255,255,255,.12);
  background:var(--bg); color:var(--fg); border-top:1px solid var(--line); margin-top:60px;
}
.brand-footer .container{max-width:1200px;margin:0 auto;padding:35px 16px}
.bf-wrap{display:grid;grid-template-columns:1fr;gap:28px;padding:40px 0}
@media(min-width:900px){.bf-wrap{grid-template-columns:1.2fr .8fr .8fr 1.2fr;gap:40px}}

/* Logo */
.bf-logo-img{max-height:46px;width:auto}
.bf-tag{margin:12px 0 18px;color:var(--muted);font-size:14px}

/* Social */
.bf-social{display:flex;gap:10px}
.bf-social a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.08);color:#fff;font-size:16px;transition:.2s}
.bf-social a:hover{transform:translateY(-3px)}
.fb:hover{background:#1877f2}.ig:hover{background:#e1306c}.yt:hover{background:#ff0033}.wa:hover{background:#25d366}

/* Links */
.bf-col h3{font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px}
.bf-menu{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.bf-menu a{color:var(--muted);text-decoration:none}
.bf-menu a:hover{color:#fff}

/* Address */
.bf-address{font-style:normal;color:var(--muted);line-height:1.7;margin-bottom:16px}
.bf-address a{color:#fff;text-decoration:none}
.bf-address a:hover{text-decoration:underline}

/* Newsletter */
.bf-news{position:relative;display:flex;margin-top:6px}
.bf-news input{
  flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);
  border-radius:999px;padding:12px 18px;color:#fff;font-size:14px;outline:none;
}
.bf-news input::placeholder{color:rgba(255,255,255,.6)}
.bf-news button{
  position:absolute;right:4px;top:50%;transform:translateY(-50%);
  background:#fff;color:#111;border:0;width:34px;height:34px;border-radius:50%;
  display:grid;place-items:center;cursor:pointer;transition:.2s
}
.bf-news button:hover{background:#eee}

/* Bottom */
.bf-bottom{border-top:1px solid var(--line)}
.bf-bottom-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;color:var(--muted);font-size:13px}
@media(max-width:640px){.bf-bottom-row{flex-direction:column;gap:8px;text-align:center}}

.bf-address div {
  display: flex;
  align-items: center;     /* আইকন আর টেক্সট এক লাইনে */
  gap: 10px;               /* আইকন আর টেক্সটের মাঝে space */
  margin-bottom: 8px;      /* লাইনগুলোর মাঝে gap */
}

.bf-address .icon {
  font-size: 16px;         /* আইকনের সাইজ */
  line-height: 1;
  flex-shrink: 0;          /* text চাপা পড়বে না */
}

/* লিংক সুন্দর করার জন্য */
.bf-address a {
  color: #fff;             /* footer এর color এর সাথে match করুন */
  text-decoration: none;
}

.bf-address a:hover {
  text-decoration: underline;
}

.bf-news {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 50px;
  padding: 6px 10px;
  max-width: 320px;
}

.bf-news input {
  flex: 1;
  border: none;
  background: transparent;
  color: #fff;
  padding: 8px 10px;
  font-size: 14px;
  outline: none;
}

.bf-news input::placeholder {
  color: rgba(255,255,255,0.6);
}

.bf-news button {
  border: none;
  background: #e74c3c;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .25s, transform .25s;
}

.bf-news button:hover {
  background: #c0392b;
  transform: scale(1.05);
}

.bf-news button svg {
  width: 20px;
  height: 20px;
}

/* === FORCE 3-COLUMN FOOTER GRID === */
.brand-footer .bf-wrap{
  display: grid;
  grid-template-columns: 1fr;      /* mobile: 1 col */
  gap: 28px;
}

/* ≥900px: 3 equal columns */
@media (min-width: 900px){
  .brand-footer .bf-wrap{
    grid-template-columns: repeat(3, 1fr) !important; /* override old 4-col */
    gap: 36px;
  }
}

/* safety: content overflow na hoy */
.brand-footer .bf-wrap > .bf-col{ min-width: 0; }
/* === Newsletter: full-width on mobile === */
@media (max-width: 640px){
  .brand-footer .bf-news{
    width: 100% !important;
    max-width: 100% !important;   /* 320px cap remove */
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .brand-footer .bf-news input{
    min-width: 0;                 /* flex overflow safe */
  }
}

/* --- Right summary sticky বন্ধ --- */
.single-product .summary { position: static !important; top:auto !important; }

/* Description নিশ্চিত visible (ATC-এর পরে) */
.single-product .summary .woocommerce-product-details__short-description{
  display:block !important; margin:12px 0 10px; color:#333; line-height:1.7;
}

/* Specs */
.est-specs-under-atc{ margin:8px 0 0; }
.est-specs-under-atc .est-sec-head{
  font-size:14px; text-transform:uppercase; letter-spacing:.06em; margin:0 0 6px; font-weight:800;
}
.est-specs-under-atc table.shop_attributes{ width:100%; border:0; }
.est-specs-under-atc table.shop_attributes th,
.est-specs-under-atc table.shop_attributes td{ border:0; padding:6px 0; font-size:14px; color:#222; }
.est-specs-under-atc table.shop_attributes tr{ border-bottom:1px dashed #eee; }
.est-specs-under-atc table.shop_attributes tr:last-child{ border-bottom:0; }

/* Minimal review strip (stars only) */
.est-rev-strip{ margin:22px 0 6px; padding:14px 0 8px; border-top:1px solid #f1f1f1; text-align:center; }
.est-rev-strip h3{ margin:0 0 8px; font-size:18px; font-weight:800; }
.est-rev-strip .star-rating{ float:none; display:inline-block; }
.est-rev-strip .est-rev-count{ margin-top:6px; color:#555; font-size:13px; }

/* Related block spacing আলাদা */
.woocommerce .related{ margin-top:18px; padding-top:12px; border-top:1px solid #f6f6f6; }

/* Gallery hover zoom */
.woocommerce-product-gallery__image img{ transition: transform .25s ease; }
.woocommerce-product-gallery__image:hover img{ transform: scale(1.08); }

/* Thumbs clickable cursor */
.flex-control-thumbs img{ cursor:pointer; }

/* Variation pills */
.est-pills{ display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }
.est-pills .pill{
  padding:8px 12px; border:1px solid #e0e0e0; border-radius:999px; background:#fff; font-size:13px; cursor:pointer;
}
.est-pills .pill.active{ background:#0A0F1F; color:#fff; box-shadow:0 0 0 2px rgba(10,15,31,.08); }

/* Mobile tweaks */
@media(max-width:640px){
  .est-specs-under-atc table.shop_attributes th,
  .est-specs-under-atc table.shop_attributes td{ font-size:13px; }
}



