/*
Theme Name: Abeerah Boutique
Theme URI: https://abeerahboutique.com
Author: Abeerah Boutique
Version: 6.0.0
Requires at least: 6.0
Requires PHP: 8.0
License: Private
Text Domain: abeerah
*/

@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@300;400;500;600&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Nunito:wght@300;400;500&display=swap');

/* ── TOKENS ──────────────────────────────────────────────────────── */
:root {
  --ivory:     #FDFAF6;
  --blush:     #F0D5C8;
  --rose:      #C9847A;
  --rose-d:    #A85F55;
  --mauve:     #7D4E57;
  --warm-grey: #9B8F8A;
  --border:    #E8E0DA;
  --dark:      #1C1C1C;
  --sale-red:  #C0392B;
  --f-head:    'Cormorant Garamond', Georgia, serif;
  --f-body:    'Instrument Sans', sans-serif;
  --f-desc:    'Nunito', sans-serif;
  --ease:      cubic-bezier(.4,0,.2,1);
  --ann-h:     32px;
  --hdr-h:     60px;
  --total-top: 92px; /* ann + header */
}

/* ── RESET ───────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--f-body);background:var(--ivory);color:var(--dark);font-size:14px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
h1,h2,h3,h4{font-family:var(--f-head);font-weight:400;line-height:1.15;letter-spacing:.02em}
p{font-family:var(--f-desc);color:var(--warm-grey);line-height:1.8;font-size:13px}
.container{max-width:1320px;margin:0 auto;padding:0 2rem}

/* ── ANNOUNCEMENT BAR — permanently fixed ───────────────────────── */
.ann-bar{
  position:fixed;top:0;left:0;right:0;z-index:1002;
  height:var(--ann-h);
  background:var(--mauve);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
}
.ann-bar p{margin:0;color:#fff}

/* ── HEADER ──────────────────────────────────────────────────────── */
.site-header{
  position:fixed;top:var(--ann-h);left:0;right:0;z-index:1000;
  height:var(--hdr-h);
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background .3s var(--ease),border-color .3s,box-shadow .3s;
}
.site-header.scrolled,
body:not(.home) .site-header{
  background:rgba(255,255,255,.98)!important;
  border-bottom-color:var(--border)!important;
  box-shadow:0 1px 12px rgba(0,0,0,.06)!important;
}
.header__inner{
  max-width:1400px;margin:0 auto;padding:0 2rem;
  height:var(--hdr-h);
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:1rem;
}

/* Left slot: desktop nav OR mobile hamburger */
.menu-toggle{
  display:none; /* hidden desktop */
  flex-direction:column;gap:5px;padding:6px;
}
.menu-toggle span{display:block;width:22px;height:1.5px;background:var(--dark);transition:all .3s}
.site-header:not(.scrolled).home-header .menu-toggle span,
body.home .site-header:not(.scrolled) .menu-toggle span{background:#fff}

/* Desktop nav */
.header__nav{
  display:flex;align-items:center;gap:2rem;
}
.nav-item{
  font-family:var(--f-body);font-size:12px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--dark);padding:.5rem 0;
  border-bottom:2px solid transparent;
  transition:border-color .2s,color .2s;cursor:pointer;
}
.site-header:not(.scrolled) body.home .nav-item,
body.home .site-header:not(.scrolled) .nav-item{color:#fff}
body:not(.home) .site-header .nav-item{color:var(--dark)!important}
.site-header.scrolled .nav-item{color:var(--dark)!important}
.nav-item:hover,.nav-item.active{border-bottom-color:var(--dark);color:var(--dark)!important}

/* Center: logo */
.header__logo{
  justify-self:center;
  font-family:var(--f-head);font-size:1.15rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--dark);display:flex;align-items:center;
  transition:color .3s;
}
.header__logo img,.header__logo .custom-logo{
  height:46px!important;width:auto!important;
  max-width:180px!important;max-height:46px!important;
  object-fit:contain!important;display:block!important;
  transition:filter .3s;
}
/* White logo on transparent header over hero */
body.home .site-header:not(.scrolled) .header__logo{color:#fff}
body.home .site-header:not(.scrolled) .header__logo img,
body.home .site-header:not(.scrolled) .custom-logo{filter:brightness(10)!important}
/* Dark logo always on inner pages + scrolled */
body:not(.home) .site-header .header__logo{color:var(--dark)!important}
body:not(.home) .site-header .header__logo img,
body:not(.home) .custom-logo,
.site-header.scrolled .header__logo img,
.site-header.scrolled .custom-logo{filter:none!important}

/* Right: icons */
.header__right{display:flex;align-items:center;justify-content:flex-end;gap:.9rem}
.header__icon{
  display:flex;align-items:center;justify-content:center;
  color:var(--dark);position:relative;cursor:pointer;
  transition:opacity .2s;
}
body.home .site-header:not(.scrolled) .header__icon{color:#fff}
body:not(.home) .site-header .header__icon,
.site-header.scrolled .header__icon{color:var(--dark)!important}
.header__icon:hover{opacity:.55}
.cart-count{
  position:absolute;top:-5px;right:-6px;
  background:var(--rose);color:#fff;
  font-size:9px;font-weight:700;
  width:15px;height:15px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}

/* ── MEGA MENU ───────────────────────────────────────────────────── */
.mega-wrap{
  position:fixed;top:calc(var(--ann-h) + var(--hdr-h));
  left:0;right:0;z-index:999;
}
.mega-panel{
  background:#fff;
  border-top:1px solid var(--border);
  box-shadow:0 20px 60px rgba(0,0,0,.1);
  opacity:0;pointer-events:none;
  transform:translateY(-6px);
  transition:opacity .22s var(--ease),transform .22s var(--ease);
  position:absolute;top:0;left:0;right:0;
}
.mega-panel.open{opacity:1;pointer-events:all;transform:translateY(0)}
.mega-panel__inner{
  max-width:1200px;margin:0 auto;padding:2rem 2rem 2.5rem;
  display:flex;gap:3rem;align-items:flex-start;
}
.mega-col{min-width:120px}
.mega-col__title{
  display:block;font-family:var(--f-body);font-size:10px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--dark);
  margin-bottom:.9rem;
}
.mega-col__links{display:flex;flex-direction:column;gap:.4rem}
.mega-col__links a{
  font-family:var(--f-desc);font-size:12px;color:var(--warm-grey);
  transition:color .18s;
}
.mega-col__links a:hover{color:var(--dark)}
.mega-imgs{display:flex;gap:1rem;margin-left:auto}
.mega-img-card{width:140px;flex-shrink:0}
.mega-img-card img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top}
.mega-img-card span{
  display:block;font-family:var(--f-body);font-size:10px;
  font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--dark);margin-top:.4rem;
}
.mega-overlay{
  position:fixed;inset:0;z-index:998;
  display:none;cursor:default;
}

/* ── MOBILE DRAWER ───────────────────────────────────────────────── */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1998;opacity:0;pointer-events:none;transition:opacity .3s}
.drawer-overlay.open{opacity:1;pointer-events:all}
.drawer{
  position:fixed;top:0;left:0;width:82%;max-width:320px;height:100vh;
  background:var(--ivory);z-index:1999;
  transform:translateX(-100%);transition:transform .35s var(--ease);
  overflow-y:auto;padding:1.5rem;
}
.drawer.open{transform:translateX(0)}
.drawer__close{position:absolute;top:1rem;right:1rem;font-size:1.3rem;color:var(--dark);cursor:pointer}
.drawer__logo{font-family:var(--f-head);font-size:1.1rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dark);display:block;margin:2.5rem 0 1.5rem}
.drawer__links a{display:block;font-family:var(--f-body);font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--dark);padding:.85rem 0;border-bottom:1px solid var(--border)}
.drawer__links a:hover{color:var(--rose)}
body.drawer-open{overflow:hidden}

/* ── INNER PAGE SPACING ──────────────────────────────────────────── */
body{padding-top:var(--total-top)}
body.home{padding-top:0}

/* ── HERO ────────────────────────────────────────────────────────── */
.hero{position:relative;overflow:hidden;width:100%;height:100vh;min-height:560px}
.hero__track{display:flex;height:100%;transition:transform .8s cubic-bezier(.77,0,.18,1)}
.hero__slide{flex:0 0 100%;width:100%;height:100%;position:relative;overflow:hidden}
.hero__slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(20,12,10,.55) 0%,rgba(20,12,10,.12) 60%,transparent 100%)}
.hero__content{position:absolute;bottom:12%;left:6%;max-width:500px}
.hero__eyebrow{display:block;font-family:var(--f-body);font-size:10px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:.7rem}
.hero__title{font-family:var(--f-head);font-size:clamp(2.8rem,6vw,5.5rem);font-weight:300;color:#fff;line-height:1.05;letter-spacing:.04em;margin-bottom:1.2rem;text-shadow:0 2px 24px rgba(0,0,0,.18)}
.hero__sub{font-family:var(--f-desc);font-size:13px;color:rgba(255,255,255,.78);margin-bottom:2rem;line-height:1.7}
.hero__btns{display:flex;gap:.8rem;flex-wrap:wrap}
.btn-ghost{display:inline-flex;align-items:center;font-family:var(--f-body);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;padding:.75rem 2rem;border:1px solid rgba(255,255,255,.7);color:#fff;background:transparent;transition:all .25s;cursor:pointer}
.btn-ghost:hover{background:#fff;color:var(--dark);border-color:#fff}
.btn-dark{display:inline-flex;align-items:center;font-family:var(--f-body);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;padding:.75rem 2rem;background:var(--dark);color:var(--ivory);border:1px solid var(--dark);transition:all .25s;cursor:pointer}
.btn-dark:hover{background:transparent;color:var(--dark)}
.hero__arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;font-size:20px;transition:background .25s}
.hero__arrow:hover{background:rgba(255,255,255,.3)}
.hero__arrow--prev{left:1.5rem}
.hero__arrow--next{right:1.5rem}
.hero__dots{position:absolute;bottom:5rem;left:50%;transform:translateX(-50%);display:flex;gap:.4rem;z-index:10}
.hero__dot{width:24px;height:2px;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:all .3s}
.hero__dot.active{width:40px;background:#fff}
.hero__scroll-btn{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:20;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.45);backdrop-filter:blur(6px);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;animation:bounceDown 1.8s ease infinite}
@keyframes bounceDown{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* ── MARQUEE ─────────────────────────────────────────────────────── */
.marquee{background:var(--ivory);overflow:hidden;padding:1.2rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.marquee__track{display:flex;gap:2.5rem;width:max-content;animation:marquee 30s linear infinite}
.marquee__track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee__item{font-family:var(--f-head);font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dark);opacity:.4;white-space:nowrap;flex-shrink:0}
.marquee__dot{opacity:.2;color:var(--rose);flex-shrink:0}

/* ── SECTION HEADERS ─────────────────────────────────────────────── */
.sec-head{text-align:center;margin-bottom:2.5rem}
.sec-head--row{display:flex;align-items:flex-end;justify-content:space-between;text-align:left;margin-bottom:1.5rem}
.sec-head__eye{display:block;font-family:var(--f-body);font-size:10px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--rose);margin-bottom:.5rem}
.sec-head__title{font-family:var(--f-head);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:var(--dark);letter-spacing:.02em}
.sec-viewall{font-family:var(--f-body);font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--dark);border-bottom:1px solid var(--border);padding-bottom:2px;white-space:nowrap}

/* ── HOME COLLECTIONS GRID ───────────────────────────────────────── */
.home-cats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}
.home-cat-card{background:#fff;overflow:hidden;position:relative;display:block}
.home-cat-card__img{aspect-ratio:2/3;overflow:hidden}
.home-cat-card__img img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .6s var(--ease)}
.home-cat-card:hover .home-cat-card__img img{transform:scale(1.05)}
.home-cat-card__info{padding:.7rem .7rem .9rem;background:#fff}
.home-cat-card__name{font-family:var(--f-body);font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--dark)}

/* ── PRODUCT GRID — shared across home + shop + collection ──────── */
.woocommerce ul.products,
.woocommerce-page ul.products,
ul.products.home-products{
  display:grid!important;
  grid-template-columns:repeat(4,1fr)!important;
  gap:0!important;
  list-style:none!important;padding:0!important;margin:0!important;
  width:100%!important;float:none!important;clear:both!important;
}
/* Home: fixed, never switchable */
ul.products.home-products{grid-template-columns:repeat(4,1fr)!important}

/* Column data-attr overrides (shop/collection only) */
.woocommerce ul.products[data-cols="3"]{grid-template-columns:repeat(3,1fr)!important}
.woocommerce ul.products[data-cols="4"]{grid-template-columns:repeat(4,1fr)!important}
.woocommerce ul.products[data-cols="6"]{grid-template-columns:repeat(6,1fr)!important}

/* Card */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
ul.products.home-products li.product{
  width:100%!important;float:none!important;clear:none!important;
  margin:0!important;padding:0!important;
  border:none!important;border-radius:0!important;
  overflow:hidden!important;background:transparent!important;
  box-shadow:none!important;position:relative!important;display:block!important;
}
/* Image */
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img,
ul.products.home-products li.product .product__img-link img,
ul.products.home-products li.product img{
  display:block!important;width:100%!important;
  aspect-ratio:3/4!important;object-fit:cover!important;
  object-position:top center!important;
  height:auto!important;max-height:none!important;
  transition:transform .55s var(--ease)!important;
}
.woocommerce ul.products li.product:hover a img,
ul.products.home-products li.product:hover img{transform:scale(1.04)!important}

/* Title + price */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products.home-products li.product .product__title{
  font-family:var(--f-body)!important;font-size:11px!important;font-weight:400!important;
  color:var(--dark)!important;
  padding:.55rem .55rem .1rem!important;margin:0!important;
  white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;
  letter-spacing:.02em!important;display:block!important;
}
.woocommerce ul.products li.product .price,
ul.products.home-products li.product .product__price{
  font-family:var(--f-body)!important;font-size:11px!important;
  color:var(--warm-grey)!important;font-weight:400!important;
  padding:0 .55rem .5rem!important;display:block!important;margin:0!important;
}

/* Hide ALL size pills/forms in grid */
.woocommerce ul.products li.product ul,
.woocommerce ul.products li.product form,
.woocommerce ul.products li.product .variations,
.woocommerce ul.products li.product .woocommerce-variation,
.woocommerce-page ul.products li.product ul,
.woocommerce-page ul.products li.product form,
.woocommerce-page ul.products li.product .variations,
ul.products.home-products li.product ul,
ul.products.home-products li.product form{display:none!important}

/* Hide WC default button in grid — we use our own qa-btn */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button,
.woocommerce-page ul.products li.product .button{display:none!important}

/* ── QUICK ADD BUTTON ────────────────────────────────────────────── */
.product__qa-btn{
  position:absolute;bottom:3.8rem;right:.55rem;
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.93);
  border:1px solid rgba(28,28,28,.15);
  display:flex;align-items:center;justify-content:center;
  color:var(--dark);
  opacity:0;pointer-events:none;
  transition:opacity .2s,background .2s;
  box-shadow:0 2px 8px rgba(0,0,0,.1);
  cursor:pointer;
}
.woocommerce ul.products li.product:hover .product__qa-btn,
ul.products.home-products li.product:hover .product__qa-btn{
  opacity:1;pointer-events:auto;
}
.product__qa-btn:hover{background:var(--dark);color:#fff}
@media(hover:none){.product__qa-btn{opacity:1;pointer-events:auto}}

/* ── BADGES ──────────────────────────────────────────────────────── */
/* Sale — solid red pill like Nishat "NEW IN" */
.woocommerce span.onsale,
.badge--sale{
  position:absolute!important;top:.55rem!important;left:.55rem!important;
  background:var(--sale-red)!important;color:#fff!important;
  font-family:var(--f-body)!important;font-size:9px!important;font-weight:700!important;
  letter-spacing:.1em!important;text-transform:uppercase!important;
  padding:.18rem .5rem!important;border-radius:2px!important;
  line-height:1.4!important;min-height:auto!important;min-width:auto!important;
  box-shadow:none!important;border:none!important;
}

/* ── GRID COLUMN SWITCHER (shop/collection pages) ───────────────── */
.col-switcher{display:flex;align-items:center;gap:.3rem;margin-bottom:1.2rem;justify-content:flex-end}
.col-switcher__label{font-family:var(--f-body);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--warm-grey);margin-right:.4rem}
.col-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:none;border:1px solid var(--border);color:var(--warm-grey);transition:all .2s;padding:0}
.col-btn svg{display:block}
.col-btn.active,.col-btn:hover{border-color:var(--dark);color:var(--dark)}

/* ── BREADCRUMBS ─────────────────────────────────────────────────── */
.woocommerce .woocommerce-breadcrumb,
.breadcrumb-wrap{
  font-family:var(--f-body)!important;font-size:10px!important;
  color:var(--warm-grey)!important;letter-spacing:.08em!important;
  padding:0 0 1.2rem!important;margin:0!important;
}
.woocommerce .woocommerce-breadcrumb a{color:var(--warm-grey)!important;transition:color .2s!important}
.woocommerce .woocommerce-breadcrumb a:hover{color:var(--dark)!important}

/* ── SHOP PAGE HEADER ────────────────────────────────────────────── */
.woocommerce-products-header{margin-bottom:.5rem!important}
.woocommerce-products-header p,
.woocommerce-products-header .page-description{display:none!important}
.woocommerce h1.page-title{font-family:var(--f-head)!important;font-size:clamp(1.8rem,3vw,2.6rem)!important;font-weight:400!important;color:var(--dark)!important;letter-spacing:.02em!important;margin-bottom:.3rem!important}
.woocommerce-result-count{font-family:var(--f-body)!important;font-size:11px!important;color:var(--warm-grey)!important}
.woocommerce-ordering select{font-family:var(--f-body)!important;font-size:11px!important;border:1px solid var(--border)!important;border-radius:0!important;padding:.35rem .7rem!important;background:#fff!important;color:var(--dark)!important}

/* ── PRODUCT SINGLE ──────────────────────────────────────────────── */
.woocommerce div.product{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:4rem!important;align-items:start!important;
  max-width:1240px!important;margin:0 auto!important;padding:2rem!important;
}
.woocommerce div.product div.images,
.woocommerce div.product .woocommerce-product-gallery{
  grid-column:1!important;grid-row:1!important;
  width:100%!important;float:none!important;
}
.woocommerce div.product .woocommerce-product-gallery__wrapper{
  display:grid!important;grid-template-columns:1fr 1fr!important;gap:.4rem!important;
}
.woocommerce div.product .woocommerce-product-gallery__image img{
  width:100%!important;aspect-ratio:3/4!important;
  object-fit:cover!important;object-position:top center!important;
  height:auto!important;max-height:none!important;display:block!important;
}
.woocommerce div.product .woocommerce-product-gallery__image:first-child{grid-column:1/-1!important}
.woocommerce div.product .woocommerce-product-gallery__image:first-child img{aspect-ratio:3/2!important}
.woocommerce div.product div.images img{
  width:100%!important;aspect-ratio:3/4!important;
  object-fit:cover!important;object-position:top center!important;
  height:auto!important;max-height:none!important;display:block!important;
}
.woocommerce div.product div.summary,
.woocommerce div.product .entry-summary{
  grid-column:2!important;grid-row:1!important;
  padding:0!important;float:none!important;width:100%!important;
  position:sticky!important;top:calc(var(--total-top) + 1rem)!important;
}
.woocommerce div.product .product_title{font-family:var(--f-head)!important;font-size:clamp(1.6rem,2.5vw,2.2rem)!important;font-weight:400!important;color:var(--dark)!important;line-height:1.2!important;margin-bottom:.6rem!important;letter-spacing:.02em!important}
.woocommerce div.product p.price,.woocommerce div.product span.price{font-family:var(--f-body)!important;font-size:1.1rem!important;color:var(--dark)!important;font-weight:400!important;margin-bottom:1.2rem!important;display:block!important}
.woocommerce div.product .woocommerce-product-details__short-description{font-family:var(--f-desc)!important;font-size:12px!important;color:var(--warm-grey)!important;line-height:1.85!important;border-top:1px solid var(--border)!important;border-bottom:1px solid var(--border)!important;padding:1rem 0!important;margin:1rem 0!important}
.woocommerce div.product form.cart{display:flex!important;align-items:stretch!important;gap:.6rem!important;margin:1.2rem 0 .8rem!important;flex-wrap:wrap!important}
.woocommerce div.product form.cart .qty{width:54px!important;height:46px!important;border:1px solid var(--border)!important;border-radius:0!important;text-align:center!important;font-size:14px!important;color:var(--dark)!important;background:#fff!important;flex-shrink:0!important;padding:0!important}
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce div.product form.cart button[type="submit"]{flex:1!important;height:46px!important;background:var(--dark)!important;color:#fff!important;border:1px solid var(--dark)!important;border-radius:0!important;font-family:var(--f-body)!important;font-size:11px!important;font-weight:500!important;letter-spacing:.2em!important;text-transform:uppercase!important;padding:0 1.2rem!important;cursor:pointer!important;transition:all .25s!important;margin:0!important}
.woocommerce div.product form.cart .single_add_to_cart_button:hover{background:transparent!important;color:var(--dark)!important}
.woocommerce div.product .product_meta{margin-top:1.2rem!important;padding-top:.9rem!important;border-top:1px solid var(--border)!important;font-family:var(--f-body)!important;font-size:11px!important;color:var(--warm-grey)!important;line-height:2!important}
.woocommerce div.product .product_meta a{color:var(--rose)!important}
/* Hide stock info everywhere */
.woocommerce div.product .stock,
.woocommerce div.product p.stock,
.woocommerce .stock,
.woocommerce-page .stock,
.in-stock,.out-of-stock{display:none!important}

/* Tabs */
.woocommerce-tabs{grid-column:1/-1!important;margin-top:3rem!important;border-top:1px solid var(--border)!important}
.woocommerce-tabs ul.tabs{padding:0!important;margin:0!important;border-bottom:1px solid var(--border)!important;display:flex!important;background:none!important;list-style:none!important}
.woocommerce-tabs ul.tabs li{background:none!important;border:none!important;border-bottom:2px solid transparent!important;border-radius:0!important;margin:0!important;padding:0!important}
.woocommerce-tabs ul.tabs li a{font-family:var(--f-body)!important;font-size:10px!important;font-weight:500!important;letter-spacing:.18em!important;text-transform:uppercase!important;color:var(--warm-grey)!important;padding:.9rem 1.4rem!important;display:block!important;background:none!important;border:none!important}
.woocommerce-tabs ul.tabs li.active{border-bottom:2px solid var(--dark)!important}
.woocommerce-tabs ul.tabs li.active a,.woocommerce-tabs ul.tabs li a:hover{color:var(--dark)!important;background:none!important}
.woocommerce-tabs .panel{padding:2rem!important;background:var(--ivory)!important;border:none!important}
/* Related */
.related.products,.upsells.products{grid-column:1/-1!important;padding:3rem 0!important;border-top:1px solid var(--border)!important}
.related.products h2,.upsells.products h2{font-family:var(--f-head)!important;font-size:1.6rem!important;font-weight:400!important;color:var(--dark)!important;margin-bottom:2rem!important}
.related.products ul.products,.upsells.products ul.products{grid-template-columns:repeat(4,1fr)!important}

/* ── QUICK ADD MODAL ─────────────────────────────────────────────── */
.qa-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;opacity:0;pointer-events:none;transition:opacity .25s}
.qa-overlay.open{opacity:1;pointer-events:all}
.qa-modal{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-48%) scale(.97);
  z-index:2001;background:#fff;width:90%;max-width:680px;
  opacity:0;pointer-events:none;
  transition:all .28s var(--ease);
  max-height:90vh;overflow-y:auto;
}
.qa-modal.open{opacity:1;pointer-events:all;transform:translate(-50%,-50%) scale(1)}
.qa-close{position:absolute;top:.9rem;right:1rem;font-size:1.4rem;color:var(--dark);cursor:pointer;z-index:2;background:none;border:none;line-height:1}
.qa-body{display:grid;grid-template-columns:1fr 1fr;min-height:300px}
.qa-img-wrap{overflow:hidden;background:var(--blush)}
.qa-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}
.qa-info{padding:2rem 1.8rem;display:flex;flex-direction:column}
.qa-title{font-family:var(--f-head);font-size:1.15rem;font-weight:400;color:var(--dark);margin-bottom:.4rem}
.qa-price{font-family:var(--f-body);font-size:.95rem;color:var(--dark);margin-bottom:1.2rem;font-weight:400}
.qa-variants{margin-bottom:1.2rem}
.qa-variants-title{font-family:var(--f-body);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--warm-grey);margin-bottom:.5rem;display:block}
.qa-pills{display:flex;flex-wrap:wrap;gap:.35rem}
.qa-pill{
  border:1px solid var(--border);padding:.3rem .7rem;
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.04em;color:var(--dark);
  background:transparent;cursor:pointer;transition:all .18s;
}
.qa-pill.active,.qa-pill:hover{background:var(--dark);color:#fff;border-color:var(--dark)}
.qa-pill.disabled{opacity:.35;cursor:not-allowed;text-decoration:line-through}
.qa-qty-row{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.qa-qty-btn{width:30px;height:30px;border:1px solid var(--border);background:transparent;color:var(--dark);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}
.qa-qty-btn:hover{background:var(--dark);color:#fff;border-color:var(--dark)}
.qa-qty-input{width:44px;height:30px;border:1px solid var(--border);text-align:center;font-size:13px;color:var(--dark);background:#fff;border-radius:0;outline:none}
.qa-atc{display:block;width:100%;padding:.8rem;background:var(--dark);color:#fff;font-family:var(--f-body);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;text-align:center;border:1px solid var(--dark);cursor:pointer;transition:all .25s;margin-bottom:.5rem;text-decoration:none}
.qa-atc:hover{background:transparent;color:var(--dark)}
.qa-view{display:block;font-family:var(--f-body);font-size:11px;color:var(--warm-grey);text-align:center;letter-spacing:.06em;text-decoration:underline;margin-top:.2rem}

/* ── PHILOSOPHY ──────────────────────────────────────────────────── */
.philosophy{padding:5rem 0;background:var(--ivory)}
.philosophy__inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem}
.philosophy__eye{display:block;font-family:var(--f-body);font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--rose);margin-bottom:1rem}
.philosophy__title{font-family:var(--f-head);font-size:clamp(2rem,3.5vw,3rem);font-weight:400;color:var(--dark);margin-bottom:1.5rem}
.philosophy__body{font-family:var(--f-desc);font-size:13px;line-height:1.9;color:var(--warm-grey);margin-bottom:1.2rem}
.philosophy__image img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top center}

/* ── REVIEWS ─────────────────────────────────────────────────────── */
.reviews-sec{padding:5rem 0;background:#fff}
.reviews-wrap{overflow:hidden;position:relative}
.reviews-track{display:flex;gap:1.5rem;transition:transform .5s var(--ease);width:max-content}
.review-card{width:320px;flex-shrink:0;background:var(--ivory);padding:2rem 1.75rem;border:1px solid var(--border)}
.review-stars{display:flex;gap:3px;margin-bottom:.9rem;color:var(--rose);font-size:13px}
.review-text{font-family:var(--f-head);font-size:1.05rem;font-style:italic;color:var(--dark);line-height:1.65;margin-bottom:1.4rem}
.review-author{display:flex;align-items:center;gap:.65rem}
.review-avatar{width:34px;height:34px;border-radius:50%;background:var(--blush);display:flex;align-items:center;justify-content:center;font-family:var(--f-head);font-size:.95rem;color:var(--rose-d);flex-shrink:0}
.review-name{font-family:var(--f-body);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--dark);display:block}
.review-loc{font-family:var(--f-desc);font-size:11px;color:var(--warm-grey)}
.reviews-nav{display:flex;justify-content:center;gap:.75rem;margin-top:2rem}
.reviews-btn{width:36px;height:36px;border:1px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--dark);font-size:18px;transition:all .25s}
.reviews-btn:hover{background:var(--dark);color:#fff;border-color:var(--dark)}

/* ── LOOKBOOK ────────────────────────────────────────────────────── */
.lookbook{padding:4rem 0;background:var(--ivory)}
.lookbook__grid{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(2,260px);gap:3px}
.lookbook__item{overflow:hidden;position:relative;cursor:pointer}
.lookbook__item:nth-child(1){grid-column:span 2;grid-row:span 2}
.lookbook__item:nth-child(4){grid-column:span 2}
.lookbook__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.lookbook__item:hover img{transform:scale(1.05)}
.lookbook__overlay{position:absolute;inset:0;background:rgba(28,28,28,0);display:flex;align-items:center;justify-content:center;transition:background .3s}
.lookbook__item:hover .lookbook__overlay{background:rgba(28,28,28,.3)}
.lookbook__plus{color:#fff;font-size:1.4rem;opacity:0;transition:opacity .3s}
.lookbook__item:hover .lookbook__plus{opacity:1}

/* ── NEWSLETTER ──────────────────────────────────────────────────── */
.newsletter{position:relative;overflow:hidden;padding:6rem 2rem;text-align:center;background:var(--mauve)}
.newsletter__bg{position:absolute;inset:0;background-size:cover;background-position:center top;opacity:.18}
.newsletter__inner{position:relative;z-index:1;max-width:520px;margin:0 auto}
.newsletter__eye{display:block;font-family:var(--f-body);font-size:10px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.8rem}
.newsletter__title{font-family:var(--f-head);font-size:clamp(2rem,4vw,3rem);font-weight:300;color:#fff;margin-bottom:.6rem}
.newsletter__sub{font-family:var(--f-desc);font-size:12px;color:rgba(255,255,255,.65);margin-bottom:2rem}
.newsletter__form{display:flex;max-width:420px;margin:0 auto}
.newsletter__input{flex:1;padding:.8rem 1.1rem;border:1px solid rgba(255,255,255,.3);border-right:none;background:rgba(255,255,255,.1);color:#fff;font-family:var(--f-body);font-size:12px;outline:none}
.newsletter__input::placeholder{color:rgba(255,255,255,.45)}
.newsletter__btn{padding:.8rem 1.4rem;background:#fff;color:var(--mauve);font-family:var(--f-body);font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;border:1px solid #fff;cursor:pointer;flex-shrink:0;transition:all .25s}
.newsletter__btn:hover{background:transparent;color:#fff}
.newsletter__fine{margin-top:.8rem;font-size:10px;color:rgba(255,255,255,.35)}

/* ── TRUST BADGES ────────────────────────────────────────────────── */
.trust{background:var(--ivory);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.8rem 0}
.trust__grid{display:grid;grid-template-columns:repeat(4,1fr);max-width:1200px;margin:0 auto;padding:0 2rem}
.trust__item{display:flex;align-items:center;gap:.9rem;padding:.6rem 1.2rem;border-right:1px solid var(--border)}
.trust__item:last-child{border-right:none}
.trust__icon{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--rose)}
.trust__title{display:block;font-family:var(--f-body);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--dark);margin-bottom:.1rem}
.trust__text{font-family:var(--f-desc);font-size:11px;color:var(--warm-grey);margin:0;line-height:1.4}

/* ── FOOTER ──────────────────────────────────────────────────────── */
.site-footer{background:var(--dark);color:rgba(255,255,255,.5);padding:4rem 0 0}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto;padding:0 2rem 3rem;border-bottom:1px solid rgba(255,255,255,.06)}
.footer__logo{font-family:var(--f-head);font-size:1.2rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:.9rem;display:block}
.footer__about{font-family:var(--f-desc);font-size:12px;line-height:1.8;color:rgba(255,255,255,.4);margin-bottom:1.4rem}
.footer__social{display:flex;gap:.5rem}
.footer__slink{width:30px;height:30px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);font-size:13px;transition:all .25s;text-decoration:none}
.footer__slink:hover{background:var(--rose);border-color:var(--rose);color:#fff}
.footer__col-title{display:block;font-family:var(--f-body);font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:1.1rem}
.footer__links{display:flex;flex-direction:column;gap:.55rem}
.footer__links a{font-family:var(--f-desc);font-size:12px;color:rgba(255,255,255,.4);transition:color .2s;text-decoration:none}
.footer__links a:hover{color:rgba(255,255,255,.9)}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:1.25rem 2rem;border-top:1px solid rgba(255,255,255,.05)}
.footer__copy{font-family:var(--f-body);font-size:10px;color:rgba(255,255,255,.2)}
.pay-icons{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap}
.pi{height:22px;min-width:36px;padding:0 6px;background:rgba(255,255,255,.9);border-radius:3px;display:inline-flex;align-items:center;justify-content:center}
.pi--visa{font-style:italic;font-weight:800;font-size:11px;color:#1a1f71;font-family:serif}
.pi--pp{font-family:sans-serif;font-size:9px;font-weight:800;color:#003087;letter-spacing:-.5px}
.pi--pp span{color:#009cde}
.pi--ideal{font-family:sans-serif;font-size:9px;font-weight:800;color:#cc0066}
.pi--bc{font-family:sans-serif;font-size:8px;font-weight:700;color:#005498;letter-spacing:-.5px}

/* ── GO TO TOP ───────────────────────────────────────────────────── */
.go-top{position:fixed;bottom:5rem;right:1.5rem;z-index:990;width:36px;height:36px;background:var(--dark);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;transform:translateY(8px);border:none;cursor:pointer}
.go-top.visible{opacity:1;pointer-events:all;transform:translateY(0)}
.go-top:hover{background:var(--rose)}

/* ── CHATBOT ─────────────────────────────────────────────────────── */
.chatbot-bubble{position:fixed;bottom:1.5rem;right:1.5rem;z-index:995;width:44px;height:44px;border-radius:50%;background:var(--dark);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.2);font-size:18px;transition:transform .25s,background .25s}
.chatbot-bubble:hover{transform:scale(1.1);background:var(--rose)}
.chatbot-window{position:fixed;bottom:5.5rem;right:1.5rem;z-index:994;width:320px;height:440px;background:#fff;border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,0,0,.15);display:flex;flex-direction:column;opacity:0;pointer-events:none;transform:translateY(12px) scale(.96);transition:all .3s var(--ease)}
.chatbot-window.open{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}
.chatbot-header{background:var(--dark);color:#fff;padding:.9rem 1.1rem;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.chatbot-header__title{font-family:var(--f-body);font-size:12px;font-weight:500;letter-spacing:.1em}
.chatbot-header__close{cursor:pointer;font-size:16px;opacity:.6}
.chatbot-header__close:hover{opacity:1}
.chatbot-msgs{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}
.chat-msg{max-width:85%;padding:.6rem .85rem;font-family:var(--f-desc);font-size:12px;line-height:1.55;border-radius:2px;color:var(--dark)}
.chat-msg--bot{background:var(--ivory);align-self:flex-start;border:1px solid var(--border)}
.chat-msg--user{background:var(--dark);color:#fff;align-self:flex-end}
.chatbot-input-row{display:flex;border-top:1px solid var(--border);flex-shrink:0}
.chatbot-input{flex:1;padding:.7rem .9rem;border:none;outline:none;font-family:var(--f-desc);font-size:12px;background:#fff;color:var(--dark)}
.chatbot-send{width:40px;background:var(--dark);color:#fff;border:none;cursor:pointer;font-size:14px;transition:background .2s;flex-shrink:0}
.chatbot-send:hover{background:var(--rose)}

/* ── SCROLL REVEAL ───────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
.delay-1{transition-delay:.08s}.delay-2{transition-delay:.16s}.delay-3{transition-delay:.24s}

/* ── RESPONSIVE ──────────────────────────────────────────────────── */
@media(max-width:1024px){
  .woocommerce ul.products,.woocommerce-page ul.products{grid-template-columns:repeat(3,1fr)!important}
  .related.products ul.products,.upsells.products ul.products{grid-template-columns:repeat(3,1fr)!important}
  .footer__grid{grid-template-columns:1fr 1fr;gap:2rem}
  .philosophy__inner{gap:3rem}
  .home-cats{grid-template-columns:repeat(2,1fr)}
  ul.products.home-products{grid-template-columns:repeat(3,1fr)!important}
}
@media(max-width:768px){
  :root{--ann-h:28px;--hdr-h:54px;--total-top:82px}
  /* Header: show hamburger, hide desktop nav */
  .header__nav{display:none!important}
  .menu-toggle{display:flex!important}
  .header__inner{grid-template-columns:auto 1fr auto}
  /* Hero */
  .hero{height:88vh;min-height:480px}
  .hero__content{left:5%;right:5%;max-width:100%}
  .hero__title{font-size:clamp(2rem,9vw,3rem)}
  /* Grids */
  .woocommerce ul.products,.woocommerce-page ul.products{grid-template-columns:repeat(2,1fr)!important}
  .woocommerce ul.products[data-cols="1"]{grid-template-columns:1fr!important}
  .woocommerce ul.products[data-cols="2"]{grid-template-columns:repeat(2,1fr)!important}
  ul.products.home-products{grid-template-columns:repeat(2,1fr)!important}
  .related.products ul.products,.upsells.products ul.products{grid-template-columns:repeat(2,1fr)!important}
  .home-cats{grid-template-columns:repeat(2,1fr)}
  /* Product single */
  .woocommerce div.product{grid-template-columns:1fr!important;gap:1.5rem!important;padding:1rem!important}
  .woocommerce div.product div.images,.woocommerce div.product .woocommerce-product-gallery{grid-column:1!important;grid-row:1!important;width:100%!important;float:none!important;position:static!important}
  .woocommerce div.product div.summary,.woocommerce div.product .entry-summary{grid-column:1!important;grid-row:2!important;position:static!important}
  .woocommerce-tabs{grid-column:1!important}.related.products,.upsells.products{grid-column:1!important}
  /* Philosophy */
  .philosophy__inner{grid-template-columns:1fr!important;gap:2rem}
  .philosophy__text{order:1}.philosophy__image{order:2}
  /* Reviews */
  .review-card{width:calc(88vw - 2rem)}
  /* Lookbook */
  .lookbook__grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,140px)}
  .lookbook__item:nth-child(1){grid-column:span 3;grid-row:span 1}
  .lookbook__item:nth-child(4){grid-column:span 1}
  /* Trust */
  .trust__grid{grid-template-columns:repeat(2,1fr)}
  .trust__item{border-right:none;border-bottom:1px solid var(--border)}
  .trust__item:nth-child(odd){border-right:1px solid var(--border)}
  .trust__item:nth-child(3),.trust__item:nth-child(4){border-bottom:none}
  /* Footer */
  .footer__grid{grid-template-columns:1fr;gap:1.8rem}
  .footer__bottom{flex-direction:column;gap:.9rem;text-align:center}
  .pay-icons{justify-content:center}
  /* Newsletter */
  .newsletter__form{flex-direction:column}
  .newsletter__input{border-right:1px solid rgba(255,255,255,.3);border-bottom:none}
  /* QA Modal */
  .qa-body{grid-template-columns:1fr}
  .qa-img-wrap{height:240px}
  .chatbot-window{width:calc(100vw - 2rem);right:1rem}
}

/* ════════════════════════════════════════════════════════
   v6 ADDITIONS & FIXES
════════════════════════════════════════════════════════ */

/* ── Announcement bar: small font, always fixed ────────────────── */
.ann-bar{font-size:10px!important;letter-spacing:.12em!important;height:28px!important}
.ann-bar p{font-size:10px!important;letter-spacing:.12em!important;line-height:1!important;color:#fff!important}
:root{--ann-h:28px!important;--total-top:88px!important}

/* ── Col switcher: sticky top, below header ────────────────────── */
.col-switcher{
  position:sticky!important;
  top:calc(var(--ann-h) + var(--hdr-h))!important;
  z-index:50!important;
  background:var(--ivory)!important;
  padding:.5rem 0!important;
  border-bottom:1px solid var(--border)!important;
  margin-bottom:.8rem!important;
}

/* ── Sale badge: 0 border-radius (square pill) ─────────────────── */
.woocommerce span.onsale,
.badge--sale{
  border-radius:0!important;
  background:var(--sale-red)!important;
  color:#fff!important;
  font-family:var(--f-body)!important;
  font-size:9px!important;font-weight:700!important;
  letter-spacing:.12em!important;text-transform:uppercase!important;
  padding:.2rem .5rem!important;
  min-height:auto!important;min-width:auto!important;
  line-height:1.3!important;border:none!important;box-shadow:none!important;
  /* Remove the WC default circular shape */
  width:auto!important;height:auto!important;
}
/* WC default positions it absolutely */
.woocommerce ul.products li.product .onsale{position:absolute!important;top:.55rem!important;left:.55rem!important;right:auto!important}

/* ── Product grid: kill empty first li gap ─────────────────────── */
.woocommerce ul.products li.product:empty{display:none!important}
/* Remove WC clearfix ghost elements */
.woocommerce ul.products::before,
.woocommerce ul.products::after{display:none!important;content:none!important}
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after{display:none!important}

/* ── No gap between image and title ─────────────────────────────── */
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  margin-top:0!important;padding-top:.4rem!important;
}
.woocommerce ul.products li.product .price{
  padding-top:0!important;margin-top:0!important;
}

/* ── Shop page header: remove dummy description ─────────────────── */
.woocommerce-products-header .page-description,
.woocommerce h1.page-title + p{display:none!important}

/* ════════════════════════════════════════════════════════
   SINGLE PRODUCT PAGE — custom 2-col layout
════════════════════════════════════════════════════════ */

/* WC wraps product in .product — override to be grid */
.woocommerce .wc-main,
.woocommerce-page .wc-main{
  max-width:1320px!important;
  margin:0 auto!important;
  padding:1.5rem 2rem 4rem!important;
}

/* Our custom .ab-single grid */
.ab-single{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  grid-template-rows:auto auto!important;
  gap:0 4rem!important;
  align-items:start!important;
}
.ab-single__gallery{grid-column:1;grid-row:1}
.ab-single__summary{
  grid-column:2;grid-row:1;
  position:sticky!important;
  top:calc(var(--ann-h) + var(--hdr-h) + 1.5rem)!important;
  max-height:calc(100vh - var(--total-top) - 2rem)!important;
  overflow-y:auto!important;
  padding-right:.5rem!important;
}
.ab-single__tabs{grid-column:1/-1;grid-row:2;margin-top:3rem;border-top:1px solid var(--border)}
.ab-single__related{grid-column:1/-1;grid-row:3}

/* ── ab-gallery: 2×2 mosaic grid ─────────────────────────────────── */
.ab-gallery{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:4px!important;
}
.ab-gallery__item img{
  width:100%!important;aspect-ratio:3/4!important;
  object-fit:cover!important;object-position:top center!important;
  display:block!important;height:auto!important;
}
/* First image spans both columns (hero image) */
.ab-gallery__item--main{grid-column:1/-1!important}
.ab-gallery__item--main img{aspect-ratio:3/2!important}
.ab-gallery__zoom{display:block;overflow:hidden}
.ab-gallery__zoom img{transition:transform .5s cubic-bezier(.4,0,.2,1)}
.ab-gallery__zoom:hover img{transform:scale(1.04)}

/* ── Product summary: clean styles ──────────────────────────────── */
.ab-single__summary .woocommerce-breadcrumb{
  font-size:10px!important;color:var(--warm-grey)!important;
  font-family:var(--f-body)!important;letter-spacing:.06em!important;
  margin-bottom:.8rem!important;display:block!important;
}
.ab-single__summary .product_title{
  font-family:var(--f-head)!important;
  font-size:clamp(1.5rem,2.2vw,2rem)!important;
  font-weight:400!important;color:var(--dark)!important;
  line-height:1.2!important;margin-bottom:.5rem!important;
  letter-spacing:.02em!important;
}
.ab-single__summary .price{
  font-family:var(--f-body)!important;font-size:1.05rem!important;
  color:var(--dark)!important;margin-bottom:1rem!important;display:block!important;
}
.ab-single__summary .woocommerce-product-details__short-description{
  font-family:var(--f-desc)!important;font-size:12px!important;
  color:var(--warm-grey)!important;line-height:1.85!important;
  border-top:1px solid var(--border)!important;
  border-bottom:1px solid var(--border)!important;
  padding:.9rem 0!important;margin:.9rem 0!important;
}
/* Hide stock */
.ab-single__summary .stock,.woocommerce .stock,.in-stock,.out-of-stock,.woocommerce-no-js-add-to-cart{display:none!important}

/* Variations */
.ab-single__summary .variations{width:100%!important;border:none!important;margin-bottom:1rem!important}
.ab-single__summary .variations td,.ab-single__summary .variations th{
  padding:.3rem 0!important;border:none!important;vertical-align:middle!important;
}
.ab-single__summary .variations label{
  font-family:var(--f-body)!important;font-size:10px!important;font-weight:600!important;
  letter-spacing:.14em!important;text-transform:uppercase!important;color:var(--warm-grey)!important;
}
.ab-single__summary .variations select{
  border:1px solid var(--border)!important;border-radius:0!important;
  font-family:var(--f-body)!important;font-size:12px!important;
  padding:.4rem .7rem!important;color:var(--dark)!important;
  background:#fff!important;min-width:120px!important;
}

/* ATC form */
.ab-single__summary form.cart{
  display:flex!important;gap:.5rem!important;
  align-items:stretch!important;margin:1rem 0 .6rem!important;
  flex-wrap:wrap!important;
}
.ab-single__summary form.cart .qty{
  width:52px!important;height:46px!important;
  border:1px solid var(--border)!important;border-radius:0!important;
  text-align:center!important;font-size:14px!important;
  color:var(--dark)!important;background:#fff!important;padding:0!important;
}
.ab-single__summary form.cart .single_add_to_cart_button{
  flex:1!important;height:46px!important;
  background:var(--dark)!important;color:#fff!important;
  border:1px solid var(--dark)!important;border-radius:0!important;
  font-family:var(--f-body)!important;font-size:11px!important;
  font-weight:500!important;letter-spacing:.18em!important;
  text-transform:uppercase!important;cursor:pointer!important;
  padding:0 1rem!important;margin:0!important;transition:all .25s!important;
}
.ab-single__summary form.cart .single_add_to_cart_button:hover{
  background:transparent!important;color:var(--dark)!important;
}
/* Buy now button */
.ab-single__summary .buy-now-btn,
.ab-single__summary .wc-buy-now{
  display:block!important;width:100%!important;
  padding:.75rem!important;
  background:transparent!important;color:var(--dark)!important;
  border:1px solid var(--border)!important;
  font-family:var(--f-body)!important;font-size:11px!important;
  font-weight:500!important;letter-spacing:.18em!important;
  text-transform:uppercase!important;text-align:center!important;
  margin-bottom:.8rem!important;cursor:pointer!important;
  transition:all .25s!important;
}
.ab-single__summary .buy-now-btn:hover{background:var(--dark)!important;color:#fff!important;border-color:var(--dark)!important}

/* Meta */
.ab-single__summary .product_meta{
  margin-top:1rem!important;padding-top:.8rem!important;
  border-top:1px solid var(--border)!important;
  font-family:var(--f-body)!important;font-size:11px!important;
  color:var(--warm-grey)!important;line-height:2.2!important;
}
.ab-single__summary .product_meta a{color:var(--rose)!important}

/* ── Accordion tabs ──────────────────────────────────────────────── */
.ab-tabs{margin-top:2.5rem}
.ab-tab{border-bottom:1px solid var(--border)}
.ab-tab__trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:1rem 0;background:none;border:none;cursor:pointer;
  font-family:var(--f-body);font-size:11px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--dark);
  text-align:left;
}
.ab-tab__chevron{transition:transform .25s;flex-shrink:0}
.ab-tab__trigger[aria-expanded="true"] .ab-tab__chevron{transform:rotate(180deg)}
.ab-tab__panel{padding:.8rem 0 1.5rem;font-family:var(--f-desc);font-size:13px;color:var(--warm-grey);line-height:1.85}
.ab-tab__panel h2,.ab-tab__panel h3{font-family:var(--f-head);font-size:1.1rem;margin-bottom:.6rem;color:var(--dark)}
.ab-tab__panel table{width:100%;border-collapse:collapse}
.ab-tab__panel table td,.ab-tab__panel table th{border:1px solid var(--border);padding:.5rem .75rem;font-size:12px}

/* ── Related products ────────────────────────────────────────────── */
.ab-single__related{padding:3rem 0}
.ab-single__related h2{font-family:var(--f-head)!important;font-size:1.5rem!important;font-weight:400!important;color:var(--dark)!important;margin-bottom:2rem!important;letter-spacing:.02em!important}
.ab-single__related ul.products{grid-template-columns:repeat(4,1fr)!important}
.ab-single__related ul.products li.product .onsale{position:absolute!important;top:.55rem!important;left:.55rem!important;border-radius:0!important;background:var(--sale-red)!important;color:#fff!important;font-size:9px!important;font-weight:700!important;letter-spacing:.12em!important;width:auto!important;height:auto!important;min-height:auto!important;min-width:auto!important;padding:.2rem .5rem!important}

/* ── Quick add modal: square close btn, no round ─────────────────── */
.product__qa-btn{border-radius:0!important}

/* ── Quick add popup: Buy Now + size chart ───────────────────────── */
.qa-buy-now{
  display:block;width:100%;
  padding:.72rem;
  background:transparent;color:var(--dark);
  border:1px solid var(--border);
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;text-align:center;
  cursor:pointer;transition:all .25s;text-decoration:none;
  margin-bottom:.5rem;
}
.qa-buy-now:hover{background:var(--dark);color:#fff;border-color:var(--dark)}
.qa-size-chart-link{
  display:block;font-family:var(--f-body);font-size:10px;
  color:var(--warm-grey);text-align:right;letter-spacing:.08em;
  text-decoration:underline;cursor:pointer;margin-bottom:.8rem;
}

/* ════════════════════════════════════════════════════════
   MOBILE FIXES (max 768px) — comprehensive
════════════════════════════════════════════════════════ */
@media(max-width:768px){
  :root{--ann-h:28px;--hdr-h:52px;--total-top:80px}

  /* Ann bar */
  .ann-bar{height:28px!important;font-size:10px!important}

  /* Header */
  .site-header{top:28px!important}
  .header__inner{padding:0 1rem!important}
  .header__logo span,.header__logo{font-size:.85rem!important;letter-spacing:.1em!important}
  .header__logo img,.header__logo .custom-logo{height:36px!important;max-height:36px!important;max-width:130px!important}
  /* Logo ALWAYS visible dark on mobile (no hero overlap issues) */
  body.home .site-header .header__logo,
  body.home .site-header:not(.scrolled) .header__logo{color:var(--dark)!important}
  body.home .site-header:not(.scrolled) .header__logo img,
  body.home .site-header:not(.scrolled) .custom-logo{filter:none!important}
  body.home .site-header:not(.scrolled) .header__icon{color:var(--dark)!important}
  body.home .site-header:not(.scrolled) .menu-toggle span{background:var(--dark)!important}
  /* Give hero extra top padding so header doesn't overlap content */
  .hero{padding-top:var(--total-top)!important;height:100vh!important;box-sizing:border-box!important}

  /* Product single: FULL stack */
  .ab-single{
    display:flex!important;flex-direction:column!important;gap:0!important;
    padding:0!important;
  }
  .ab-gallery{grid-template-columns:1fr!important}
  .ab-gallery__item--main{grid-column:1!important}
  .ab-gallery__item--main img{aspect-ratio:3/4!important}
  .ab-gallery__item img{aspect-ratio:3/4!important}
  .ab-single__summary{
    position:static!important;max-height:none!important;overflow:visible!important;
    padding:1.2rem 1rem!important;
  }
  .ab-single__tabs{padding:0 1rem!important}
  .ab-single__related{padding:1.5rem 1rem!important}
  .ab-single__related ul.products{grid-template-columns:repeat(2,1fr)!important}

  /* Shop grid */
  .woocommerce ul.products,.woocommerce-page ul.products{grid-template-columns:repeat(2,1fr)!important}
  .woocommerce ul.products[data-cols="1"]{grid-template-columns:1fr!important}
  ul.products.home-products{grid-template-columns:repeat(2,1fr)!important}

  /* Col switcher on mobile */
  .col-switcher{top:calc(28px + 52px)!important;padding:.4rem 1rem!important}

  /* WC main padding */
  .woocommerce .wc-main,.woocommerce-page .wc-main{padding:1rem!important}

  /* Philosophy */
  .philosophy__inner{grid-template-columns:1fr!important;gap:2rem!important}
  .philosophy__text{order:1}.philosophy__image{order:2}

  /* Footer */
  .footer__grid{grid-template-columns:1fr!important;gap:1.8rem!important}
  .footer__bottom{flex-direction:column!important;gap:.9rem!important;text-align:center!important}
  .pay-icons{justify-content:center!important}

  /* Trust */
  .trust__grid{grid-template-columns:repeat(2,1fr)!important}
  .trust__item{border-right:none!important;border-bottom:1px solid var(--border)!important}
  .trust__item:nth-child(odd){border-right:1px solid var(--border)!important}
  .trust__item:nth-child(3),.trust__item:nth-child(4){border-bottom:none!important}

  /* Collections */
  .home-cats{grid-template-columns:repeat(2,1fr)!important}

  /* QA modal */
  .qa-body{grid-template-columns:1fr!important}
  .qa-img-wrap{height:260px!important}
  .qa-info{padding:1.2rem!important}

  /* Newsletter */
  .newsletter__form{flex-direction:column!important}
  .newsletter__input{border-right:1px solid rgba(255,255,255,.3)!important;border-bottom:none!important}

  /* Lookbook */
  .lookbook__grid{grid-template-columns:repeat(3,1fr)!important;grid-template-rows:repeat(3,120px)!important}
  .lookbook__item:nth-child(1){grid-column:span 3!important;grid-row:span 1!important}
  .lookbook__item:nth-child(4){grid-column:span 1!important}

  /* Reviews card */
  .review-card{width:calc(90vw - 2rem)!important}

  /* Hero */
  .hero__content{left:5%!important;right:5%!important;max-width:100%!important;bottom:8%!important}
  .hero__title{font-size:clamp(2rem,9vw,3rem)!important}
  .hero__sub{display:none!important}
}
