/*
Theme Name: Abeerah
Theme URI: https://abeerahboutique.com
Author: Abeerah
Description: Thème autonome (standalone, sans framework) pour Abeerah Boutique — mode féminine traditionnelle pakistanaise. Grammaire éditoriale inspirée des codes du prêt-à-porter premium (charbon sur blanc, sans-serif MAJUSCULE, angles droits, cartes portrait). WooCommerce-ready. Couleurs éditables sans code via l'outil de personnalisation.
Version: 13.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: abeerah
*/

/* ============================================================
   0. TOKENS  (les --ab-* couleurs sont ré-émis par le Customizer
   via functions.php : modifiables SANS toucher au code)
   ============================================================ */
:root{
  --ab-ink:#1C1C1C;          /* charbon : texte, boutons, bordures fortes */
  --ab-bg:#FFFFFF;           /* fond */
  --ab-soft:#F6F5F3;         /* fond alterné doux */
  --ab-line:#E5E5E5;         /* filets/séparateurs */
  --ab-muted:#8A8A8A;        /* texte secondaire */
  --ab-sale:#E32C2B;         /* rouge : UNIQUEMENT promo/SALE */
  --ab-accent:#1C1C1C;       /* accent (=ink par défaut) */

  --ab-head:'Instrument Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --ab-body:'Nunito',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --ab-max:1440px;
  --ab-pad:16px;
  --ab-ease:cubic-bezier(.785,.135,.15,.86);
  --ab-radius:0px;

  --ab-h1:clamp(1.6rem,4.5vw,2.6rem);
  --ab-h2:clamp(1.15rem,2.4vw,1.5rem);
  --ab-h3:clamp(1rem,1.8vw,1.15rem);
}
@media(min-width:768px){ :root{ --ab-pad:40px; } }

/* ============================================================
   1. RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--ab-bg);color:var(--ab-ink);
  font-family:var(--ab-body);font-size:15px;line-height:1.6;
  font-weight:400;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5,h6{
  font-family:var(--ab-head);font-weight:500;
  text-transform:uppercase;letter-spacing:.04em;line-height:1.2;margin:0;
}
:root,*{border-radius:var(--ab-radius) !important}

.ab-wrap{max-width:var(--ab-max);margin:0 auto;padding-left:var(--ab-pad);padding-right:var(--ab-pad)}
.ab-section{padding:44px 0}
@media(min-width:768px){ .ab-section{padding:64px 0} }
.ab-sec-soft{background:var(--ab-soft)}

/* section heading (centré, filet fin comme Nishat) */
.ab-sechead{text-align:center;margin:0 0 26px}
.ab-sechead h2{font-size:var(--ab-h2);letter-spacing:.14em}
.ab-sechead p{color:var(--ab-muted);font-size:13.5px;margin:8px 0 0;text-transform:none;letter-spacing:.02em}
.ab-sechead .ab-rule{width:44px;height:2px;background:var(--ab-ink);margin:14px auto 0}

/* boutons */
.ab-btn{
  display:inline-block;background:var(--ab-ink);color:#fff;border:1px solid var(--ab-ink);
  font-family:var(--ab-head);text-transform:uppercase;letter-spacing:.16em;font-size:12px;font-weight:500;
  padding:14px 30px;transition:background .3s var(--ab-ease),color .3s var(--ab-ease);
}
.ab-btn:hover{background:#fff;color:var(--ab-ink)}
.ab-btn--ghost{background:transparent;color:var(--ab-ink)}
.ab-btn--ghost:hover{background:var(--ab-ink);color:#fff}
.ab-btn--light{background:#fff;color:var(--ab-ink);border-color:#fff}
.ab-btn--light:hover{background:transparent;color:#fff;border-color:#fff}

/* reveal-on-scroll */
.ab-reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ab-ease),transform .7s var(--ab-ease)}
.ab-reveal.is-visible{opacity:1;transform:none}

/* ============================================================
   2. ANNOUNCEMENT MARQUEE
   ============================================================ */
.ab-marquee{background:var(--ab-ink);color:#fff;overflow:hidden;white-space:nowrap;font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-family:var(--ab-head)}
.ab-marquee__track{display:inline-block;padding:9px 0;animation:ab-scroll 24s linear infinite}
.ab-marquee__track span{padding:0 34px;position:relative}
.ab-marquee__track span::after{content:"◆";position:absolute;right:-4px;top:0;color:rgba(255,255,255,.4);font-size:9px}
@keyframes ab-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   3. HEADER
   ============================================================ */
.ab-header{position:sticky;top:0;z-index:60;background:#fff;border-bottom:1px solid var(--ab-line)}
.ab-header__bar{display:flex;align-items:center;justify-content:space-between;gap:16px;height:72px}
@media(min-width:768px){ .ab-header__bar{height:88px} }
.ab-logo{display:inline-flex;align-items:center;height:100%;max-width:56vw;font-family:var(--ab-head);font-size:20px;letter-spacing:.24em;text-transform:uppercase;line-height:1;overflow:hidden}
.ab-logo .custom-logo-link{display:inline-flex;align-items:center;height:100%}
/* cap global : le_custom_logo génère .custom-logo hors de tout scope fiable */
.custom-logo,.ab-logo img{max-height:34px !important;width:auto !important;height:auto !important;display:block}
@media(min-width:768px){ .custom-logo,.ab-logo img{max-height:44px !important} .ab-logo{max-width:none} }

/* primary nav (desktop) */
.ab-nav{display:none}
@media(min-width:960px){ .ab-nav{display:flex;gap:26px;align-items:center} }
.ab-nav>li>a{font-family:var(--ab-head);text-transform:uppercase;font-size:12.5px;letter-spacing:.13em;padding:12px 0;position:relative;display:inline-block}
.ab-nav>li>a::after{content:"";position:absolute;left:0;bottom:6px;width:0;height:1px;background:var(--ab-ink);transition:width .3s var(--ab-ease)}
.ab-nav>li:hover>a::after{width:100%}
.ab-nav>li.ab-sale>a{color:var(--ab-sale)}

/* mega menu */
.ab-nav .ab-mega{
  position:absolute;left:0;right:0;top:100%;background:#fff;border-top:1px solid var(--ab-line);
  box-shadow:0 24px 40px -24px rgba(0,0,0,.25);
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .25s var(--ab-ease),transform .25s var(--ab-ease),visibility .25s;
  padding:34px var(--ab-pad);
}
.ab-nav>li{position:static}
.ab-nav>li:hover .ab-mega{opacity:1;visibility:visible;transform:none}
.ab-mega__grid{max-width:var(--ab-max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.ab-mega h4{font-size:12px;letter-spacing:.14em;margin:0 0 14px;color:var(--ab-ink)}
.ab-mega ul li{margin:0 0 9px}
.ab-mega ul li a{font-size:13.5px;color:var(--ab-muted);text-transform:none;letter-spacing:0;transition:color .2s}
.ab-mega ul li a:hover{color:var(--ab-ink)}

/* header icons */
.ab-icons{display:flex;align-items:center;gap:16px}
.ab-icons a,.ab-icons button{background:none;border:0;padding:0;display:inline-flex;color:var(--ab-ink)}
.ab-icons svg{width:22px;height:22px}
.ab-cartcount{position:relative}
.ab-cartcount .ab-badge{position:absolute;top:-7px;right:-9px;background:var(--ab-ink);color:#fff;font-family:var(--ab-head);font-size:10px;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;padding:0 3px}
.ab-burger{display:inline-flex}
@media(min-width:960px){ .ab-burger{display:none} }

/* mobile drawer */
.ab-drawer{position:fixed;inset:0 auto 0 0;width:86%;max-width:340px;background:#fff;z-index:120;transform:translateX(-100%);transition:transform .35s var(--ab-ease);overflow-y:auto;padding:22px}
.ab-drawer.is-open{transform:none}
.ab-scrim{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;visibility:hidden;transition:opacity .3s;z-index:110}
.ab-scrim.is-open{opacity:1;visibility:visible}
.ab-drawer__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.ab-drawer nav>ul>li{border-bottom:1px solid var(--ab-line)}
.ab-drawer nav>ul>li>a{display:block;padding:15px 4px;font-family:var(--ab-head);text-transform:uppercase;font-size:13.5px;letter-spacing:.1em}
.ab-drawer .ab-sub{padding:0 0 10px 14px}
.ab-drawer .ab-sub a{display:block;padding:7px 0;font-size:13.5px;color:var(--ab-muted)}
.ab-drawer .ab-acc-toggle{float:right;font-size:18px;color:var(--ab-muted)}

/* ============================================================
   4. HERO (slideshow / éditorial)
   ============================================================ */
.ab-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;background:var(--ab-ink);overflow:hidden}
@media(min-width:768px){ .ab-hero{min-height:78vh} }
.ab-hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.86;transform:scale(1.04);animation:ab-kenburns 12s var(--ab-ease) forwards}
@keyframes ab-kenburns{to{transform:scale(1)}}
.ab-hero__veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,20,20,.68),rgba(20,20,20,.05) 55%)}
.ab-hero__inner{position:relative;z-index:2;color:#fff;width:100%;min-width:0;padding:0 var(--ab-pad) 56px;max-width:640px}
.ab-hero__eyebrow{font-family:var(--ab-head);text-transform:uppercase;letter-spacing:.32em;font-size:11.5px;color:#e9dcc6;margin:0 0 14px;overflow-wrap:break-word}
@media(max-width:520px){ .ab-hero__eyebrow{letter-spacing:.18em;font-size:10.5px} }
.ab-hero__title{font-size:var(--ab-h1);color:#fff;letter-spacing:.06em;margin:0 0 16px;line-height:1.1;overflow-wrap:break-word;word-break:break-word}
.ab-hero__sub{font-family:var(--ab-body);text-transform:none;font-size:15px;line-height:1.6;color:rgba(255,255,255,.9);margin:0 0 26px;max-width:440px}

/* ============================================================
   5. CATEGORY TILES (collection-list)
   ============================================================ */
.ab-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:768px){ .ab-tiles{grid-template-columns:repeat(4,1fr);gap:16px} }
.ab-tile{position:relative;display:block;overflow:hidden;aspect-ratio:3/4;background:var(--ab-soft)}
.ab-tile img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ab-ease)}
.ab-tile:hover img{transform:scale(1.06)}
.ab-tile__label{position:absolute;left:0;right:0;bottom:0;padding:16px;background:linear-gradient(to top,rgba(20,20,20,.65),transparent);color:#fff;font-family:var(--ab-head);text-transform:uppercase;letter-spacing:.12em;font-size:13px;text-align:center}
.ab-tile--ph{display:flex;align-items:center;justify-content:center;color:var(--ab-muted);font-family:var(--ab-head);letter-spacing:.12em;font-size:12px;text-transform:uppercase;border:1px solid var(--ab-line)}

/* ============================================================
   6. EDITORIAL (rich-text / 3 ways)
   ============================================================ */
.ab-editorial{text-align:center;max-width:720px;margin:0 auto}
.ab-editorial h2{font-size:var(--ab-h2);letter-spacing:.1em;margin:0 0 16px}
.ab-editorial p{color:var(--ab-muted);font-size:15px;line-height:1.8;text-transform:none;margin:0 0 24px}

/* ============================================================
   7. PRODUCT GRID + CARD  (WooCommerce loop)
   ============================================================ */
.woocommerce ul.products,
ul.products{
  display:grid !important;grid-template-columns:repeat(2,1fr);gap:12px 10px;margin:0;padding:0;list-style:none;
}
@media(min-width:768px){ .woocommerce ul.products,ul.products{grid-template-columns:repeat(4,1fr);gap:34px 22px} }
/* sélecteur de colonnes — fonctionne sur TOUS les écrans */
body.ab-cols-2 ul.products{grid-template-columns:repeat(2,1fr) !important}
body.ab-cols-3 ul.products{grid-template-columns:repeat(3,1fr) !important}
body.ab-cols-4 ul.products{grid-template-columns:repeat(4,1fr) !important}

ul.products li.product{margin:0;padding:0;text-align:center;position:relative}
.ab-card{display:block;position:relative}
.ab-card__media{position:relative;overflow:hidden;aspect-ratio:2/3;background:var(--ab-soft);display:block}
.ab-card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .5s var(--ab-ease),transform .8s var(--ab-ease)}
.ab-card__media img.ab-hover-img{opacity:0}
.ab-card:hover .ab-card__media img.ab-primary-img{opacity:0}
.ab-card:hover .ab-card__media img.ab-hover-img{opacity:1}
.ab-card:hover .ab-card__media img{transform:scale(1.04)}
.ab-card__info{padding:14px 6px 4px}
.ab-card__title{font-family:var(--ab-head);text-transform:uppercase;font-size:12px;letter-spacing:.06em;line-height:1.4;color:var(--ab-ink);margin:0 0 6px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}
.ab-card__price{font-family:var(--ab-head);font-size:12.5px;letter-spacing:.02em}
.ab-card__price .ab-old{color:var(--ab-muted);text-decoration:line-through;margin-right:8px;font-weight:400}
.ab-card__price .ab-new,.ab-card__price ins{color:var(--ab-sale);text-decoration:none;font-weight:600}
.ab-card__price del{color:var(--ab-muted);margin-right:8px}
.ab-card__price ins{color:var(--ab-sale)}
/* badges */
.ab-flag{position:absolute;top:10px;z-index:3;font-family:var(--ab-head);text-transform:uppercase;letter-spacing:.08em;font-size:10px;padding:5px 9px;line-height:1}
.ab-flag--sale{left:10px;background:var(--ab-sale);color:#fff}
.ab-flag--new{right:10px;background:var(--ab-ink);color:#fff}
/* on masque tout le clutter Woo natif dans la boucle : swatches, meta, bouton */
ul.products li.product .button,
ul.products li.product .added_to_cart,
ul.products li.product .variations,
ul.products li.product .cfvsw_variations_form,
ul.products li.product .entry-meta,
ul.products li.product .meta-categories{display:none !important}

/* barre outils grille */
.ab-grid-tools{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 22px;padding-bottom:14px;border-bottom:1px solid var(--ab-line)}
.ab-grid-tools__count{font-size:12.5px;color:var(--ab-muted);letter-spacing:.02em}
.ab-grid-cols{display:flex;gap:8px;align-items:center}
.ab-grid-cols button{width:32px;height:32px;border:1px solid var(--ab-line);background:#fff;display:inline-flex;align-items:center;justify-content:center;color:var(--ab-muted);font-family:var(--ab-head);font-size:12px}
.ab-grid-cols button.is-active{border-color:var(--ab-ink);color:var(--ab-ink)}

/* ============================================================
   8. SINGLE PRODUCT (léger — WooCommerce par défaut, restylé)
   ============================================================ */
.single-product .product{max-width:var(--ab-max);margin:0 auto;padding:36px 0}
.single-product div.product .product_title{font-size:var(--ab-h2);letter-spacing:.06em;margin:0 0 12px}
.single-product div.product p.price,.single-product div.product span.price{font-family:var(--ab-head);font-size:18px}
.single-product .price ins{color:var(--ab-sale)}
.single-product .single_add_to_cart_button{background:var(--ab-ink) !important;color:#fff !important;text-transform:uppercase;letter-spacing:.14em;font-family:var(--ab-head);border:1px solid var(--ab-ink);padding:15px 34px !important}
.single-product .single_add_to_cart_button:hover{background:#fff !important;color:var(--ab-ink) !important}
.woocommerce-tabs .tabs{border-bottom:1px solid var(--ab-line)}

/* ============================================================
   9. TRUST BAR (footer-icons)
   ============================================================ */
.ab-trust{border-top:1px solid var(--ab-line);border-bottom:1px solid var(--ab-line);background:#fff}
.ab-trust__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;padding:34px 0}
@media(min-width:768px){ .ab-trust__grid{grid-template-columns:repeat(4,1fr)} }
.ab-trust__item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}
.ab-trust__item svg{width:30px;height:30px;stroke:var(--ab-ink);stroke-width:1.3;fill:none}
.ab-trust__item h5{font-size:11.5px;letter-spacing:.1em;margin:0}
.ab-trust__item p{font-size:12px;color:var(--ab-muted);text-transform:none;margin:0;letter-spacing:0}

/* ============================================================
   10. FOOTER
   ============================================================ */
.ab-footer{background:var(--ab-ink);color:#CFCFCF;font-family:var(--ab-body)}
.ab-footer a{color:#CFCFCF;transition:color .2s}
.ab-footer a:hover{color:#fff}
.ab-footer__top{max-width:var(--ab-max);margin:0 auto;padding:56px var(--ab-pad) 40px;display:grid;gap:38px;grid-template-columns:1.6fr 1fr 1fr 1.4fr}
@media(max-width:1000px){ .ab-footer__top{grid-template-columns:1fr 1fr;gap:32px} }
@media(max-width:560px){ .ab-footer__top{grid-template-columns:1fr} }
.ab-footer h4{font-family:var(--ab-head);color:#fff;font-size:12px;letter-spacing:.18em;margin:0 0 18px;font-weight:500}
.ab-footer li{margin:0 0 11px;font-size:13.5px}
.ab-flogo{font-family:var(--ab-head);color:#fff;font-size:22px;letter-spacing:.26em;text-transform:uppercase;margin:0 0 16px}
.ab-fabout{font-size:13.5px;line-height:1.7;color:#A9A9A9;max-width:300px;margin:0 0 20px}
.ab-social{display:flex;gap:14px}
.ab-social a{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #3A3A3A}
.ab-social a:hover{background:#fff;color:var(--ab-ink);border-color:#fff}
.ab-social svg{width:17px;height:17px;fill:currentColor}
.ab-fnews p{font-size:13.5px;line-height:1.6;color:#A9A9A9;margin:0 0 16px}
.ab-news{display:flex}
.ab-news input{flex:1;min-width:0;background:transparent;border:1px solid #4A4A4A;color:#fff;padding:12px 14px;font-family:var(--ab-body);font-size:13px}
.ab-news input::placeholder{color:#8A8A8A}
.ab-news button{background:#fff;color:var(--ab-ink);border:1px solid #fff;font-family:var(--ab-head);text-transform:uppercase;letter-spacing:.12em;font-size:11px;padding:12px 18px;white-space:nowrap}
.ab-news button:hover{background:transparent;color:#fff}
.ab-footer__bottom{border-top:1px solid #333;max-width:var(--ab-max);margin:0 auto;padding:20px var(--ab-pad);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ab-pay{display:flex;gap:8px;flex-wrap:wrap}
.ab-pay span{border:1px solid #3A3A3A;color:#B8B8B8;font-family:var(--ab-head);font-size:10px;letter-spacing:.06em;padding:5px 9px}
.ab-copy{font-size:12px;color:#8A8A8A}

/* ============================================================
   11. PAGES / BLOG génériques
   ============================================================ */
.ab-page{max-width:860px;margin:0 auto;padding:48px var(--ab-pad)}
.ab-page h1{font-size:var(--ab-h1);letter-spacing:.05em;margin:0 0 24px;text-align:center}
.ab-page-hero{background:var(--ab-soft);text-align:center;padding:48px var(--ab-pad)}
.ab-page-hero h1{font-size:var(--ab-h1);letter-spacing:.05em;margin:0}
.ab-prose p{margin:0 0 16px;line-height:1.8}
.ab-prose h2{font-size:var(--ab-h3);margin:28px 0 12px}
.ab-blog-grid{display:grid;grid-template-columns:1fr;gap:26px}
@media(min-width:768px){ .ab-blog-grid{grid-template-columns:repeat(3,1fr)} }
.ab-post img{aspect-ratio:3/2;object-fit:cover;width:100%}
.ab-post h3{font-size:14px;margin:14px 0 8px;letter-spacing:.04em}
.ab-post .ab-excerpt{color:var(--ab-muted);font-size:13.5px;text-transform:none}

/* utilitaires */
.ab-center{text-align:center}
.ab-mt{margin-top:32px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ============================================================
   12. ADDITIONS templates (front-page, blog, single) + fixes
   ============================================================ */
/* méga-menu : ouverture au tap (mobile/tablette) */
.ab-nav>li.is-open .ab-mega{opacity:1;visibility:visible;transform:none}

/* header condensé au scroll */
.ab-header.is-scrolled{box-shadow:0 8px 24px -18px rgba(0,0,0,.35)}
.ab-header.is-scrolled .ab-header__bar{height:64px;transition:height .3s var(--ab-ease)}

/* boutons alias */
.ab-btn--solid{background:#fff;color:var(--ab-ink);border-color:#fff}
.ab-btn--solid:hover{background:transparent;color:#fff;border-color:#fff}
.ab-btn--line{background:transparent;color:var(--ab-ink);border-color:var(--ab-ink)}
.ab-btn--line:hover{background:var(--ab-ink);color:#fff}

/* hero sans image : bloc typographique centré, hauteur en px (jamais un vide en vh) */
.ab-hero--plain{min-height:0;background:var(--ab-soft);align-items:center;text-align:center;border-bottom:1px solid var(--ab-line)}
.ab-hero--plain .ab-hero__inner{color:var(--ab-ink);width:100%;max-width:640px;margin:0 auto;padding:76px var(--ab-pad)}
@media(min-width:768px){ .ab-hero--plain .ab-hero__inner{padding:104px var(--ab-pad)} }
.ab-hero--plain .ab-hero__sub{margin-left:auto;margin-right:auto}
.ab-hero--plain .ab-hero__eyebrow{color:var(--ab-muted)}
.ab-hero--plain .ab-hero__title{color:var(--ab-ink)}
.ab-hero--plain .ab-hero__sub{color:var(--ab-muted)}
.ab-hero--plain .ab-btn--solid{background:var(--ab-ink);color:#fff;border-color:var(--ab-ink)}
.ab-hero--plain .ab-btn--solid:hover{background:transparent;color:var(--ab-ink)}

/* eyebrow générique */
.ab-eyebrow{font-family:var(--ab-head);text-transform:uppercase;letter-spacing:.24em;font-size:11px;color:var(--ab-muted);display:block;margin:0 0 12px}

/* section head (titre + lien) */
.ab-section__head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:0 0 24px;flex-wrap:wrap}
.ab-section__head h2{font-size:var(--ab-h2);letter-spacing:.12em}
.ab-section__head p{color:var(--ab-muted);font-size:13.5px;text-transform:none;letter-spacing:.02em;margin:0}
.ab-section__link{font-family:var(--ab-head);text-transform:uppercase;font-size:11.5px;letter-spacing:.14em;border-bottom:1px solid var(--ab-ink);padding-bottom:2px}

/* tuiles catégories : wrapper media + placeholder + label sous l'image */
.ab-tile{background:transparent;aspect-ratio:auto}
.ab-tile__media{position:relative;overflow:hidden;aspect-ratio:3/4;background:var(--ab-soft);display:block}
.ab-tile__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ab-ease)}
.ab-tile:hover .ab-tile__media img{transform:scale(1.06)}
.ab-tile__ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--ab-head);font-size:44px;color:var(--ab-muted)}
.ab-tile>.ab-tile__label{position:static;background:none;color:var(--ab-ink);padding:12px 4px 0;text-align:center}

/* éditorial 2 colonnes */
.ab-editorial{background:var(--ab-soft);text-align:left;max-width:none;margin:0}
.ab-editorial__grid{display:grid;grid-template-columns:1fr;gap:32px;padding:52px 0;align-items:center}
@media(min-width:900px){ .ab-editorial__grid{grid-template-columns:1.2fr 1fr;gap:56px} }
.ab-editorial__text h2{font-size:var(--ab-h2);letter-spacing:.08em;margin:0 0 16px;text-align:left}
.ab-editorial__text p{color:var(--ab-muted);font-size:15px;line-height:1.8;text-transform:none;margin:0 0 22px}
.ab-editorial__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ab-editorial__stats>div{text-align:center;border-left:1px solid var(--ab-line);padding:6px 10px}
.ab-editorial__stats strong{display:block;font-family:var(--ab-head);text-transform:uppercase;font-size:15px;letter-spacing:.06em;margin:0 0 6px}
.ab-editorial__stats span{font-size:12px;color:var(--ab-muted)}

/* carrousel produits (scroll horizontal) */
.ab-carousel{position:relative}
.ab-carousel__track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px var(--ab-pad);-ms-overflow-style:none;scrollbar-width:none}
.ab-carousel__track::-webkit-scrollbar{display:none}
.ab-carousel__track.is-drag{cursor:grabbing;scroll-snap-type:none}
.ab-carousel__track>li.product{flex:0 0 62%;max-width:62%;scroll-snap-align:start}
@media(min-width:600px){ .ab-carousel__track>li.product{flex-basis:38%;max-width:38%} }
@media(min-width:960px){ .ab-carousel__track>li.product{flex-basis:23%;max-width:23%} }
.ab-car-arrow{position:absolute;top:38%;transform:translateY(-50%);z-index:4;width:40px;height:40px;background:#fff;border:1px solid var(--ab-line);color:var(--ab-ink);font-size:22px;line-height:1;display:none;align-items:center;justify-content:center}
@media(min-width:960px){ .ab-car-arrow{display:inline-flex} }
.ab-car-arrow--prev{left:6px}
.ab-car-arrow--next{right:6px}
.ab-car-arrow:hover{background:var(--ab-ink);color:#fff;border-color:var(--ab-ink)}

/* fix swap image de survol (aligné sur content-product.php) */
.ab-card__img--hover{opacity:0}
.ab-card__inner:hover .ab-card__img{transform:scale(1.04)}
.ab-card__inner:hover .ab-card__img--hover{opacity:1}
.ab-card__inner{display:block}
.ab-card__inner:hover .ab-card__title{text-decoration:underline;text-underline-offset:3px}

/* média-grille (2 blocs collection) */
.ab-mediagrid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:768px){ .ab-mediagrid{grid-template-columns:1fr 1fr;gap:18px} }
.ab-media{position:relative;display:block;overflow:hidden;aspect-ratio:4/3;background:var(--ab-ink)}
.ab-media__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.8;transition:transform .8s var(--ab-ease),opacity .4s}
.ab-media:hover .ab-media__bg{transform:scale(1.05);opacity:.7}
.ab-media__cap{position:absolute;left:0;right:0;bottom:0;padding:26px;color:#fff;background:linear-gradient(to top,rgba(20,20,20,.7),transparent)}
.ab-media__cap .ab-eyebrow{color:#e9dcc6}
.ab-media__cap h3{color:#fff;font-size:var(--ab-h3);letter-spacing:.08em;margin:0 0 8px}
.ab-media__cta{font-family:var(--ab-head);text-transform:uppercase;font-size:11.5px;letter-spacing:.14em}

/* pages / titres */
.ab-page__head{text-align:center;margin:0 0 30px}
.ab-page__head h1{font-size:var(--ab-h1);letter-spacing:.05em;margin:0}
.ab-page__head .ab-eyebrow{text-align:center}
.ab-single__media{margin:0 0 28px}
.ab-single__media img{width:100%;object-fit:cover}

/* blog grid (index) */
.ab-postgrid{display:grid;grid-template-columns:1fr;gap:26px}
@media(min-width:768px){ .ab-postgrid{grid-template-columns:repeat(3,1fr)} }
.ab-post__media img{aspect-ratio:3/2;object-fit:cover;width:100%}
.ab-post__title{font-size:14px;margin:14px 0 8px;letter-spacing:.04em}
.ab-post__excerpt{color:var(--ab-muted);font-size:13.5px;text-transform:none}
.ab-pagination{margin:40px 0 0;text-align:center}
.ab-pagination .page-numbers{display:inline-flex;gap:8px;list-style:none;padding:0;justify-content:center}
.ab-pagination .page-numbers li a,.ab-pagination .page-numbers li span{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border:1px solid var(--ab-line);font-family:var(--ab-head);font-size:12px}
.ab-pagination .page-numbers li .current{background:var(--ab-ink);color:#fff;border-color:var(--ab-ink)}

/* woo main padding */
.ab-woo{padding-top:32px;padding-bottom:56px}
.ab-main{min-height:40vh}
