/* ============================================================
   DOUDI & MOUMOUNE — main.css v1.0.0
   ============================================================ */

/* ── VARIABLES ── */
:root {
  --ink:        #1a1209;
  --ink2:       #3d2e1a;
  --ink3:       #7a6a55;
  --cream:      #faf6f0;
  --cream2:     #f3ece1;
  --cream3:     #e8ddd0;
  --terracotta: #c4653a;
  --terra-dark: #8f3f1f;
  --terra-light:#e8906e;
  --gold:       #c9a96e;
  --gold-light: #f0e0b8;
  --sage:       #6b8f71;
  --white:      #ffffff;
  --border:     rgba(26,18,9,.1);
  --border2:    rgba(26,18,9,.18);
  --shadow-sm:  0 2px 12px rgba(26,18,9,.08);
  --shadow-md:  0 8px 32px rgba(26,18,9,.12);
  --shadow-lg:  0 20px 60px rgba(26,18,9,.18);
  --r:          10px;
  --r2:         18px;
  --ease:       .28s cubic-bezier(.4,0,.2,1);
  --font-d:     'Cormorant Garamond',Georgia,serif;
  --font-b:     'Jost',sans-serif;
  --hh:         70px;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-b);background:var(--cream);color:var(--ink);overflow-x:hidden;line-height:1.65}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}
::selection{background:var(--terracotta);color:#fff}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--cream2)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}

/* ── UTILITIES ── */
.container{max-width:1300px;margin:0 auto;padding:0 28px}
.section{padding:90px 0}
.section--sm{padding:56px 0}
.section--alt{background:var(--cream2)}
.section-eyebrow{font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:14px;display:block}
.section-title{font-family:var(--font-d);font-size:clamp(26px,4vw,48px);font-weight:400;line-height:1.1}
.section-title em{font-style:italic;color:var(--terracotta)}
.section-sub{color:var(--ink3);font-size:15px;margin-top:10px;font-weight:300;max-width:520px}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:36px;gap:16px;flex-wrap:wrap}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 30px;border-radius:50px;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:var(--ease);white-space:nowrap;cursor:pointer}
.btn-primary{background:var(--terracotta);color:#fff;box-shadow:0 4px 20px rgba(196,101,58,.35)}
.btn-primary:hover{background:var(--terra-dark);transform:translateY(-2px);box-shadow:0 8px 28px rgba(196,101,58,.45)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--border2)}
.btn-outline:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-white{background:#fff;color:var(--terracotta)}
.btn-white:hover{background:var(--cream2);transform:translateY(-2px)}
.btn-ghost{padding:12px 22px;color:var(--ink3);font-size:13px;font-weight:500;letter-spacing:.02em;text-transform:none}
.btn-ghost:hover{color:var(--terracotta)}
.btn-icon{width:44px;height:44px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--ease)}
.btn-icon:hover{background:var(--cream3)}

/* ── TAGS ── */
.tag{display:inline-block;padding:4px 12px;border-radius:50px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.tag-new{background:var(--terracotta);color:#fff}
.tag-promo{background:var(--gold);color:var(--ink)}
.tag-perso{background:var(--sage);color:#fff}
.tag-dispo{background:var(--cream3);color:var(--ink3)}

/* ── ANNOUNCE BAR ── */
.announce{background:var(--ink);color:rgba(255,255,255,.8);text-align:center;font-size:12.5px;font-weight:400;letter-spacing:.04em;padding:10px 16px}
.announce strong{color:var(--gold)}
.announce a{color:var(--terra-light);text-decoration:underline;text-decoration-style:dotted}

/* ── HEADER ── */
.site-header{position:sticky;top:0;z-index:1000;height:var(--hh);background:rgba(250,246,240,.96);backdrop-filter:blur(16px) saturate(1.4);border-bottom:1px solid var(--border)}
.header-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:100%;gap:16px}
.header-left{display:flex;align-items:center;gap:8px}
.header-right{display:flex;align-items:center;gap:4px;justify-content:flex-end}

.logo{display:flex;flex-direction:column;line-height:1.1;text-decoration:none}
.logo-main{font-family:var(--font-d);font-size:24px;font-weight:400;color:var(--ink);letter-spacing:-.01em;font-style:italic}
.logo-main span{color:var(--terracotta)}
.logo-sub{font-size:9.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3);margin-top:1px}

/* Search form */
.header-search{position:relative;display:flex;align-items:center}
.header-search .search-field{background:var(--cream2);border:1.5px solid transparent;border-radius:50px;padding:9px 40px 9px 18px;font-size:13.5px;color:var(--ink);outline:none;width:260px;transition:var(--ease)}
.header-search .search-field:focus{border-color:var(--terracotta);background:#fff;box-shadow:0 0 0 3px rgba(196,101,58,.1)}
.header-search .search-field::placeholder{color:var(--ink3)}
.header-search .search-submit{position:absolute;right:12px;background:none;border:none;color:var(--ink3);cursor:pointer;display:flex;align-items:center;padding:0;transition:var(--ease)}
.header-search .search-submit:hover{color:var(--terracotta)}
.search-form{display:flex;align-items:center}

.cart-wrap{position:relative}
.cart-badge{position:absolute;top:4px;right:4px;width:17px;height:17px;border-radius:50%;background:var(--terracotta);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;pointer-events:none}

/* ── HAMBURGER — base mobile uniquement ── */
.hamburger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;
  padding:9px;border-radius:8px;
  background:none;border:none;cursor:pointer;
  transition:background .2s;
}
.hamburger span{
  display:block;width:20px;height:1.5px;
  background:var(--ink);border-radius:2px;
  transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .2s,background .2s;
  transform-origin:center;
}
.hamburger.is-active span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.is-active span:nth-child(2){opacity:0}
.hamburger.is-active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── MEGA NAV — supprimée ── */
.mega-nav{display:none !important}

/* Drawer plus large sur desktop */
@media(min-width:901px){
  .drawer{width:min(380px,90vw);}
}

/* ── BOUTON MENU FLOTTANT DESKTOP (injecté via JS) ── */
.desktop-menu-btn{
  display:none;
  position:fixed;
  top:50%;left:0;
  transform:translateY(-50%);
  z-index:1050;
  width:46px;height:60px;
  border-radius:0 12px 12px 0;
  background:var(--ink,#1a1209);
  border:none;cursor:pointer;
  box-shadow:4px 0 20px rgba(26,18,9,.25);
  flex-direction:column;
  align-items:center;justify-content:center;
  gap:5px;
  transition:background .25s,width .25s,box-shadow .25s;
  padding:0;
}
.desktop-menu-btn::after{
  content:'Menu';
  font-size:8px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.45);
  display:block;margin-top:3px;
  font-family:inherit;
  transition:color .2s;
}
.desktop-menu-btn span{
  display:block;width:20px;height:1.5px;
  background:#fff;border-radius:2px;
  transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .2s;
  transform-origin:center;
}
.desktop-menu-btn:hover{
  background:var(--terracotta,#c4653a);
  width:54px;
  box-shadow:4px 0 24px rgba(196,101,58,.4);
}
.desktop-menu-btn:hover::after{color:rgba(255,255,255,.85);}
.desktop-menu-btn.is-active{background:var(--terracotta,#c4653a);}
.desktop-menu-btn.is-active::after{content:'Fermer';}
.desktop-menu-btn.is-active span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.desktop-menu-btn.is-active span:nth-child(2){opacity:0}
.desktop-menu-btn.is-active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
@media(min-width:901px){
  .desktop-menu-btn{display:flex;}
}
@media(max-width:900px){
  .desktop-menu-btn{display:none !important;}
  .hamburger{display:flex !important;}
}
.mega-nav-inner{display:flex;align-items:stretch;overflow-x:auto;scrollbar-width:none}
.mega-nav-inner::-webkit-scrollbar{display:none}

.nav-item{position:relative;flex-shrink:0}
.nav-link{display:flex;align-items:center;gap:5px;padding:0 20px;height:48px;font-size:13px;font-weight:500;letter-spacing:.03em;color:var(--ink2);white-space:nowrap;border-bottom:2px solid transparent;transition:var(--ease);background:none;border-top:none;border-left:none;border-right:none;cursor:pointer}
.nav-link:hover,.nav-item.open .nav-link,.nav-link.active{color:var(--terracotta);border-bottom-color:var(--terracotta)}
.nav-link--promo{color:var(--terracotta);font-weight:600}
.nav-chevron{font-size:9px;transition:transform var(--ease)}
.nav-item.open .nav-chevron{transform:rotate(180deg)}

.mega-panel{position:absolute;top:calc(100% + 1px);left:0;background:#fff;border:1px solid var(--border);border-radius:0 var(--r2) var(--r2) var(--r2);box-shadow:var(--shadow-lg);padding:0;min-width:760px;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity var(--ease),transform var(--ease);z-index:900}
.nav-item.open .mega-panel{opacity:1;pointer-events:all;transform:none}
.mega-panel-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:32px}
.mega-panel .mega-col{padding:0 16px}
.mega-panel .mega-col:first-child{padding-left:0}
.mega-col h4{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--terracotta);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.mega-col a{display:block;font-size:13.5px;color:var(--ink3);padding:5px 0;transition:var(--ease)}
.mega-col a:hover{color:var(--terracotta);padding-left:5px}
.mega-promo-card{background:linear-gradient(135deg,var(--ink) 0%,var(--ink2) 100%);border-radius:var(--r);padding:22px;display:flex;flex-direction:column;gap:8px}
.mega-promo-card .eyebrow{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}
.mega-promo-card .title{font-family:var(--font-d);font-size:18px;color:#fff;font-style:italic;line-height:1.2}
.mega-promo-card a{font-size:12px;font-weight:600;color:var(--terra-light);letter-spacing:.05em}

/* ── MOBILE DRAWER ── */
/* ── OVERLAY ── */
.overlay{position:fixed;inset:0;background:rgba(26,18,9,.45);z-index:1100;opacity:0;pointer-events:none;transition:opacity .3s ease;backdrop-filter:blur(2px)}
.overlay.open{opacity:1;pointer-events:all}
/* Le bouton menu desktop doit toujours être au-dessus de l'overlay */
#desktopMenuBtn{z-index:9999999 !important;}

/* ── MOBILE DRAWER ── */
.drawer{
  position:fixed;top:0;left:0;bottom:0;
  width:min(340px,90vw);
  background:var(--ink);
  z-index:1200;
  transform:translateX(-100%);
  transition:transform .32s cubic-bezier(.32,0,.15,1);
  display:flex;flex-direction:column;
  overflow:hidden;
  box-shadow:8px 0 40px rgba(26,18,9,.3);
}
/* Tablet: wider drawer */
@media(min-width:481px) and (max-width:900px){
  .drawer{width:min(400px,75vw)}
}
.drawer.open{transform:none}

/* Header du drawer */
.drawer-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px;
  background:var(--ink);
  flex-shrink:0;
}
.drawer-top .logo{text-decoration:none}
.drawer-top .logo-main{font-family:var(--font-d);font-size:18px;color:#fff;font-style:italic;letter-spacing:.01em}
.drawer-top .logo-main span,.drawer-top .logo-main em{color:var(--terra-light)}
.drawer-close{
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.1);border:none;cursor:pointer;
  color:#fff;font-size:16px;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.drawer-close:hover{background:rgba(255,255,255,.22)}

/* Corps scrollable */
.drawer-body{flex:1;overflow-y:auto;padding:10px 0 4px}
.drawer-body::-webkit-scrollbar{width:3px}
.drawer-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2)}

/* Liens principaux */
.drawer-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:15px 22px;
  font-size:15px;font-weight:400;color:rgba(255,255,255,.85);
  cursor:pointer;text-decoration:none;
  background:none;border:none;width:100%;text-align:left;
  transition:color .2s,background .2s,padding-left .2s;
  border-left:3px solid transparent;
  line-height:1.2;
  letter-spacing:.01em;
}
.drawer-link span{
  font-size:14px;color:rgba(255,255,255,.35);
  transition:transform .2s,color .2s;
  display:inline-block;
}
.drawer-link:hover,.drawer-link.active{
  color:#fff;
  background:rgba(255,255,255,.07);
  border-left-color:var(--terracotta);
  padding-left:26px;
}
.drawer-link:hover span{color:var(--terra-light);transform:translateX(3px)}

/* Divider léger entre groupes */
.drawer-divider{height:1px;background:rgba(255,255,255,.1);margin:8px 22px}
.drawer-section-label{
  font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.3);padding:14px 22px 4px;display:block;
}

/* Sous-menus accordéon */
.drawer-sub{
  display:none;
  background:rgba(0,0,0,.2);
  border-left:3px solid var(--terracotta);
  margin-left:0;
}
.drawer-sub.open{display:block;animation:subSlide .2s ease}
@keyframes subSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.drawer-sub a{
  display:flex;align-items:center;gap:8px;
  padding:11px 20px 11px 24px;
  font-size:13.5px;color:rgba(255,255,255,.6);text-decoration:none;
  transition:color .2s,padding-left .2s;
  border-bottom:none;
}
.drawer-sub a::before{content:'·';color:var(--gold);font-size:16px;line-height:1;flex-shrink:0}
.drawer-sub a:hover{color:#fff;padding-left:28px}

/* Footer drawer */
.drawer-footer{
  padding:16px 20px;
  border-top:1px solid rgba(255,255,255,.1);
  background:rgba(0,0,0,.25);
  display:flex;flex-direction:column;gap:10px;
  flex-shrink:0;
}
.drawer-footer .btn{font-size:13px;padding:11px 16px}
.drawer-footer a[href^="tel"]{
  font-size:12px;color:rgba(255,255,255,.5);text-align:center;
  display:flex;align-items:center;justify-content:center;gap:6px;
  text-decoration:none;transition:color .2s;
}
.drawer-footer a[href^="tel"]:hover{color:#fff}

/* ── MOBILE BOTTOM NAV BAR ── */
.mobile-bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  height:62px;
  background:rgba(26,18,9,.97);
  backdrop-filter:blur(16px) saturate(1.4);
  border-top:1px solid rgba(255,255,255,.1);
  z-index:1050;
  align-items:stretch;
  justify-content:space-around;
  padding:0 4px;
  padding-bottom:env(safe-area-inset-bottom, 0px);
}
@media(max-width:900px){
  .mobile-bottom-nav{display:flex}
  /* Add bottom padding to page so content not hidden behind bottom nav */
  #page-wrap{padding-bottom:62px}
}
.mobile-bottom-nav__item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;flex:1;
  color:rgba(255,255,255,.5);
  text-decoration:none;font-size:10px;font-weight:500;letter-spacing:.04em;
  transition:color .2s;background:none;border:none;cursor:pointer;
  padding:6px 4px;
}
.mobile-bottom-nav__item:hover,
.mobile-bottom-nav__item.active{color:#fff}
.mobile-bottom-nav__item svg{transition:transform .2s}
.mobile-bottom-nav__item:hover svg{transform:scale(1.1)}
.mobile-bottom-nav__icon{position:relative;display:flex;align-items:center;justify-content:center}
.mobile-bottom-nav__badge{
  position:absolute;top:-4px;right:-7px;
  min-width:16px;height:16px;border-radius:50%;
  background:var(--terracotta);color:#fff;
  font-size:9px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  padding:0 2px;
}

/* ── CART SIDEBAR ── */
.cart-overlay{position:fixed;inset:0;background:rgba(26,18,9,.5);z-index:1300;opacity:0;pointer-events:none;transition:opacity var(--ease)}
.cart-overlay.open{opacity:1;pointer-events:all}
.cart-sidebar{position:fixed;top:0;right:0;bottom:0;width:min(420px,95vw);background:#fff;z-index:1400;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.cart-sidebar.open{transform:none}
.cart-head{padding:22px 26px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.cart-head h2{font-family:var(--font-d);font-size:22px;font-weight:400;font-style:italic}
.cart-body{flex:1;overflow-y:auto;padding:20px 26px}
.cart-footer{padding:20px 26px;border-top:1px solid var(--border)}
.cart-total{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cart-total-label{font-size:14px;color:var(--ink3)}
.cart-total-price{font-family:var(--font-d);font-size:26px;color:var(--terracotta);font-style:italic}
.cart-secure{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:var(--ink3);margin-top:10px}

/* WC cart widget overrides */
.cart-sidebar .woocommerce.widget_shopping_cart .product_list_widget{}
.cart-sidebar .cart_list li{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}
.cart-sidebar .cart_list li a.remove{color:var(--ink3)!important;background:none!important;float:none;margin-right:8px}
.cart-sidebar .cart_list li img{width:70px;height:70px;object-fit:cover;border-radius:var(--r)}

/* ── HERO ── */
.hero{position:relative;overflow:hidden;min-height:calc(100vh - var(--hh) - 49px);display:flex;align-items:center;background:var(--ink)}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 65% 40%,#3d2010 0%,#1a1209 60%)}
.hero-grain{position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}
.hero-orb{position:absolute;right:-8%;top:-20%;width:70vw;height:70vw;max-width:700px;max-height:700px;border-radius:50%;background:radial-gradient(circle,rgba(196,101,58,.22) 0%,transparent 65%);pointer-events:none}
.hero-orb2{position:absolute;left:40%;bottom:-15%;width:40vw;height:40vw;border-radius:50%;background:radial-gradient(circle,rgba(201,169,110,.1) 0%,transparent 65%);pointer-events:none}
.hero-content{position:relative;z-index:2;padding:80px 0;max-width:620px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.hero-eyebrow::before{content:'';width:32px;height:1px;background:var(--gold)}
.hero-title{font-family:var(--font-d);font-size:clamp(46px,7.5vw,92px);font-weight:300;line-height:1.0;color:#fff;margin-bottom:28px;letter-spacing:-.02em}
.hero-title em{font-style:italic;color:var(--terra-light)}
.hero-title strong{font-weight:600}
.hero-desc{font-size:16px;font-weight:300;color:rgba(255,255,255,.6);max-width:480px;margin-bottom:40px;line-height:1.75}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-btn-secondary{border-color:rgba(255,255,255,.3)!important;color:rgba(255,255,255,.85)!important}
.hero-btn-secondary:hover{background:rgba(255,255,255,.1)!important;color:#fff!important}
.hero-stats{display:flex;gap:40px;margin-top:64px;padding-top:40px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap}
.hero-stat-num{font-family:var(--font-d);font-size:36px;font-weight:400;color:var(--gold);font-style:italic;line-height:1;margin-bottom:4px}
.hero-stat-label{font-size:12px;color:rgba(255,255,255,.45);letter-spacing:.05em}

/* ── TRUST BAR ── */
.trust-bar{background:var(--cream2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0}
.trust-inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;padding:10px 28px;border-right:1px solid var(--border);font-size:13px;font-weight:500;color:var(--ink2);white-space:nowrap}
.trust-item:last-child{border-right:none}
.trust-icon{width:36px;height:36px;border-radius:50%;background:var(--terracotta);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.trust-title{font-weight:600;font-size:13.5px}
.trust-sub{font-size:11.5px;color:var(--ink3);font-weight:300}

/* ── CATEGORY GRID ── */
.cat-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:14px;height:580px}
.cat-card--large{grid-row:1/3}
.cat-card{position:relative;overflow:hidden;border-radius:var(--r2);cursor:pointer;display:block;text-decoration:none}
.cat-card-inner{width:100%;height:100%;display:flex;align-items:flex-end}
.cat-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.cat-card:hover .cat-bg{transform:scale(1.05)}
.cat-bg--color-0{background:linear-gradient(135deg,#c9956b 0%,#8f5a2c 50%,#5c3518 100%)}
.cat-bg--color-1{background:linear-gradient(135deg,#d4836a 0%,#a04020 50%,#6b2810 100%)}
.cat-bg--color-2{background:linear-gradient(135deg,#6b9e73 0%,#3d6645 50%,#244030 100%)}
.cat-bg--color-3{background:linear-gradient(135deg,#6a80b0 0%,#2c3d6b 50%,#1a2445 100%)}
.cat-bg--color-4{background:linear-gradient(135deg,#b07a9e 0%,#6b3068 50%,#3d1a40 100%)}
.cat-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(26,18,9,.75) 0%,rgba(26,18,9,.1) 55%,transparent 100%)}
.cat-content{position:relative;z-index:2;padding:22px 24px;width:100%}
.cat-tag{display:inline-block;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 11px;border-radius:50px;margin-bottom:8px}
.cat-title{font-family:var(--font-d);font-size:clamp(16px,2.5vw,26px);color:#fff;font-weight:400;font-style:italic;line-height:1.2;margin-bottom:4px}
.cat-count{font-size:12px;color:rgba(255,255,255,.6);letter-spacing:.04em}
.cat-arrow{position:absolute;top:18px;right:18px;z-index:2;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;opacity:0;transform:scale(.8);transition:var(--ease)}
.cat-card:hover .cat-arrow{opacity:1;transform:scale(1)}

/* ── PRODUCT CARDS ── */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.product-card{background:#fff;border-radius:var(--r2);border:1px solid var(--border);overflow:hidden;transition:box-shadow var(--ease),transform var(--ease)}
.product-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.product-thumb-link{display:block;text-decoration:none}
.product-thumb{position:relative;aspect-ratio:1;overflow:hidden}
.product-thumb-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.product-card:hover .product-thumb-img{transform:scale(1.06)}
.product-thumb-bg{width:100%;height:100%;background:var(--cream2)}
.product-thumb-placeholder{display:flex;align-items:center;justify-content:center;font-size:64px}
.product-tags{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:5px;z-index:2}
.product-actions{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:7px;opacity:0;transform:translateX(6px);transition:var(--ease);z-index:2}
.product-card:hover .product-actions{opacity:1;transform:none}
.product-action-btn{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);border:1px solid rgba(26,18,9,.1);display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:var(--shadow-sm);transition:var(--ease);cursor:pointer;text-decoration:none}
.product-action-btn:hover{background:var(--terracotta);color:#fff;border-color:var(--terracotta)}
.product-quick-add{position:absolute;bottom:0;left:0;right:0;background:var(--terracotta);color:#fff;padding:12px;text-align:center;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;transform:translateY(100%);transition:transform var(--ease);border:none;cursor:pointer;width:100%}
.product-card:hover .product-quick-add{transform:none}
.product-body{padding:16px 18px 18px}
.product-cat{font-size:10.5px;color:var(--terracotta);font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px}
.product-name{font-size:14.5px;font-weight:500;line-height:1.35;margin-bottom:8px}
.product-name a{color:var(--ink);text-decoration:none;transition:var(--ease)}
.product-name a:hover{color:var(--terracotta)}
.product-stars{display:flex;align-items:center;gap:5px;margin-bottom:10px}
.stars{color:var(--gold);font-size:12px;letter-spacing:1.5px}
.star-count{font-size:11.5px;color:var(--ink3)}
.product-bottom{display:flex;align-items:center;justify-content:space-between}
.product-price-wrap .price{font-family:var(--font-d);font-size:20px;font-weight:400;color:var(--terracotta);font-style:italic}
.product-price-wrap ins{text-decoration:none}
.product-price-wrap del{font-size:12.5px;color:var(--ink3);font-family:var(--font-b);font-style:normal;margin-left:4px}
.add-btn{width:38px;height:38px;border-radius:50%;background:var(--terracotta);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:300;box-shadow:0 3px 12px rgba(196,101,58,.3);transition:var(--ease);border:none;cursor:pointer;flex-shrink:0}
.add-btn:hover{background:var(--terra-dark);transform:scale(1.1)}

/* Filter row */
.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.filter-tab{padding:8px 20px;border-radius:50px;border:1.5px solid var(--border2);font-size:13px;font-weight:500;color:var(--ink3);transition:var(--ease);cursor:pointer;background:none}
.filter-tab:hover,.filter-tab.active{background:var(--terracotta);border-color:var(--terracotta);color:#fff}

/* ── PROMO BANNER ── */
.promo-banner{background:var(--ink);border-radius:var(--r2);padding:64px 72px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:48px;position:relative;overflow:hidden}
.promo-banner::before{content:'';position:absolute;right:-80px;top:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(196,101,58,.2),transparent 65%)}
.promo-text{position:relative;z-index:1}
.promo-eyebrow{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:block}
.promo-title{font-family:var(--font-d);font-size:clamp(26px,4vw,46px);font-weight:300;color:#fff;line-height:1.1;font-style:italic;margin-bottom:14px}
.promo-title strong{font-weight:600;font-style:normal;color:var(--terra-light)}
.promo-desc{color:rgba(255,255,255,.6);font-size:15px;font-weight:300;margin-bottom:32px;line-height:1.7}
.promo-actions{display:flex;gap:12px;flex-wrap:wrap;position:relative;z-index:1}
.promo-btn-outline{border-color:rgba(255,255,255,.3)!important;color:rgba(255,255,255,.85)!important}
.promo-btn-outline:hover{background:rgba(255,255,255,.1)!important}
.promo-visual{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.promo-mini-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:18px;text-align:center}
.promo-mini-card .icon{font-size:28px;margin-bottom:8px;display:block}
.promo-mini-card .label{font-size:12px;color:rgba(255,255,255,.6);font-weight:300}
.promo-mini-card .value{font-family:var(--font-d);font-size:20px;color:#fff;font-style:italic}

/* ── REVIEWS ── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review-card{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:28px;transition:box-shadow var(--ease)}
.review-card:hover{box-shadow:var(--shadow-md)}
.review-top{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.review-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;color:#fff;flex-shrink:0}
.av1{background:var(--terracotta)} .av2{background:var(--gold)} .av3{background:var(--sage)}
.review-name{font-weight:600;font-size:14.5px;color:var(--ink)}
.review-platform{font-size:11px;color:var(--ink3)}
.review-stars{color:var(--gold);font-size:13px;letter-spacing:2px;margin-bottom:14px}
.review-text{font-family:var(--font-d);font-size:17px;font-weight:300;font-style:italic;line-height:1.65;color:var(--ink2)}
.review-text::before{content:'"';font-size:60px;line-height:.6;color:var(--cream3);float:left;margin-right:6px;margin-top:10px;font-family:var(--font-d)}

/* ── NEWSLETTER ── */
.newsletter-wrap{background:linear-gradient(135deg,var(--cream2),var(--cream3));border-radius:var(--r2);padding:72px;text-align:center;border:1px solid var(--border);position:relative;overflow:hidden}
.newsletter-wrap::before{content:'';position:absolute;left:-60px;top:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(196,101,58,.1),transparent 60%)}
.newsletter-title{font-family:var(--font-d);font-size:clamp(22px,3.5vw,36px);font-weight:400;font-style:italic;margin-bottom:10px;position:relative;z-index:1}
.newsletter-sub{color:var(--ink3);font-size:15px;font-weight:300;margin-bottom:32px;position:relative;z-index:1}
.newsletter-form{display:flex;max-width:500px;margin:0 auto;background:#fff;border:1.5px solid var(--border2);border-radius:50px;overflow:hidden;transition:var(--ease);position:relative;z-index:1}
.newsletter-form:focus-within{border-color:var(--terracotta);box-shadow:0 0 0 4px rgba(196,101,58,.1)}
.newsletter-form input[type=email]{flex:1;border:none;padding:14px 22px;font-family:inherit;font-size:14.5px;background:none;outline:none;color:var(--ink)}
.newsletter-form input::placeholder{color:var(--ink3)}
.newsletter-form button,.newsletter-form [type=submit]{padding:12px 24px;background:var(--terracotta);color:#fff;font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;border-radius:50px;margin:4px;transition:var(--ease);border:none;cursor:pointer}
.newsletter-form button:hover{background:var(--terra-dark)}
.newsletter-note{font-size:12px;color:var(--ink3);margin-top:14px;position:relative;z-index:1}

/* ── SHOP PAGE ── */
.page-hero{background:var(--cream2);border-bottom:1px solid var(--border);padding:40px 0}
.page-hero-title{font-family:var(--font-d);font-size:clamp(28px,4vw,44px);font-weight:400;font-style:italic;margin-top:10px}
.page-hero-title em{color:var(--terracotta)}
.page-hero-desc{color:var(--ink3);font-size:15px;margin-top:6px;font-weight:300}
.shop-layout{display:block}
.products-grid--shop{grid-template-columns:repeat(3,1fr)}
.shop-sidebar{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:24px;position:sticky;top:calc(var(--hh) + 60px)}
.sidebar-section{margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--border)}
.sidebar-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.sidebar-title{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:14px}
.sidebar-item{display:flex;align-items:center;gap:10px;padding:7px 0}
.sidebar-item label{font-size:13.5px;color:var(--ink2);cursor:pointer;flex:1}
.sidebar-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--terracotta);cursor:pointer}
.sidebar-cat-link{display:flex;justify-content:space-between;font-size:13.5px;color:var(--ink3);padding:6px 0;transition:var(--ease);text-decoration:none;width:100%}
.sidebar-cat-link:hover,.sidebar-cat-link.active{color:var(--terracotta)}
.sidebar-cat-link .count{font-size:12px;color:var(--ink3)}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.shop-count{font-size:14px;color:var(--ink3)}
.woocommerce-ordering select{padding:9px 16px;border:1.5px solid var(--border2);border-radius:50px;font-size:13px;font-family:inherit;color:var(--ink);background:#fff;outline:none;cursor:pointer}
.products-grid--shop{grid-template-columns:repeat(3,1fr)}
.shop-empty{text-align:center;padding:80px 0}
.shop-empty-icon{font-size:60px;margin-bottom:20px}
.shop-empty h2{font-family:var(--font-d);font-size:28px;font-style:italic;margin-bottom:10px}
.shop-empty p{color:var(--ink3);margin-bottom:24px}
.pagination-wrap{display:flex;justify-content:center;margin-top:48px}
.woocommerce-pagination ul{display:flex;gap:8px;list-style:none}
.woocommerce-pagination ul li a,.woocommerce-pagination ul li span{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;color:var(--ink2);transition:var(--ease);text-decoration:none}
.woocommerce-pagination ul li span.current,.woocommerce-pagination ul li a:hover{background:var(--terracotta);border-color:var(--terracotta);color:#fff}

/* ── PRODUCT DETAIL ── */
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin-bottom:64px}
.product-gallery{position:sticky;top:calc(var(--hh)+50px)}
.gallery-main{aspect-ratio:1;border-radius:var(--r2);overflow:hidden;background:var(--cream2);margin-bottom:12px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center}
.gallery-main-img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.gallery-thumb{aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:var(--cream2);border:2px solid transparent;display:flex;align-items:center;justify-content:center;font-size:28px;cursor:pointer;transition:var(--ease);padding:0}
.gallery-thumb img{width:100%;height:100%;object-fit:cover}
.gallery-thumb:hover,.gallery-thumb.active{border-color:var(--terracotta)}
.gallery-placeholder{font-size:120px;display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.product-detail-title{font-family:var(--font-d);font-size:clamp(24px,3.5vw,38px);font-weight:400;font-style:italic;line-height:1.15;margin-bottom:14px}
.product-detail-rating{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.rating-stars{color:var(--gold);font-size:15px;letter-spacing:2px}
.rating-text{font-size:13.5px;color:var(--ink3)}
.product-detail-price{display:flex;align-items:baseline;gap:12px;margin-bottom:24px;padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.product-detail-price .price{font-family:var(--font-d);font-size:36px;color:var(--terracotta);font-style:italic}
.product-detail-price ins{text-decoration:none}
.product-detail-price del{font-size:16px;color:var(--ink3)}
.price-save{background:var(--terracotta);color:#fff;font-size:12px;font-weight:700;padding:3px 10px;border-radius:50px}
.product-desc{font-size:15px;color:var(--ink2);line-height:1.75;font-weight:300;margin-bottom:26px}
/* WC form overrides in product detail */
.product-detail-info .quantity{display:flex;align-items:center;border:1.5px solid var(--border2);border-radius:50px;overflow:hidden;background:#fff;max-width:fit-content}
.product-detail-info .qty{width:52px;text-align:center;font-size:16px;font-weight:600;border:none;outline:none;background:none;padding:10px 0}
.product-detail-info .single_add_to_cart_button{background:var(--terracotta)!important;color:#fff!important;border:none!important;border-radius:50px!important;padding:14px 32px!important;font-size:14px!important;font-weight:600!important;letter-spacing:.06em!important;text-transform:uppercase!important;transition:var(--ease)!important;cursor:pointer!important}
.product-detail-info .single_add_to_cart_button:hover{background:var(--terra-dark)!important;transform:translateY(-2px)!important}
.product-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.product-badge{display:flex;align-items:center;gap:7px;padding:10px 16px;border-radius:var(--r);background:var(--cream2);border:1px solid var(--border);font-size:12.5px;font-weight:500;color:var(--ink2)}
.product-badge svg{color:var(--sage)}
.product-meta{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
.meta-row{display:flex;gap:8px;font-size:13px;color:var(--ink3);margin-bottom:6px}
.meta-row strong{color:var(--ink);font-weight:500;min-width:100px}
.product-tabs-wrap{margin:48px 0}
.product-tabs-wrap .woocommerce-tabs ul.tabs{display:flex;gap:0;border-bottom:2px solid var(--border2);margin-bottom:32px;list-style:none;padding:0}
.product-tabs-wrap .woocommerce-tabs ul.tabs li{margin:0}
.product-tabs-wrap .woocommerce-tabs ul.tabs li a{display:block;padding:12px 24px;font-size:14px;font-weight:500;color:var(--ink3);border-bottom:2px solid transparent;margin-bottom:-2px;text-decoration:none;transition:var(--ease)}
.product-tabs-wrap .woocommerce-tabs ul.tabs li.active a{color:var(--terracotta);border-bottom-color:var(--terracotta)}

/* ── PAGE HERO ── */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink3);margin-bottom:16px;flex-wrap:wrap}
.breadcrumb a{color:var(--ink3);text-decoration:none;transition:var(--ease)}
.breadcrumb a:hover{color:var(--terracotta)}
.breadcrumb-sep{color:var(--border2)}

/* ── ABOUT PAGE ── */
.about-hero{background:var(--ink);border-radius:var(--r2);padding:80px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative;overflow:hidden;margin-bottom:64px}
.about-hero::before{content:'';position:absolute;right:-60px;top:-60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(196,101,58,.25),transparent 65%)}
.about-title{font-family:var(--font-d);font-size:clamp(30px,5vw,52px);font-weight:300;font-style:italic;color:#fff;line-height:1.1;margin-bottom:18px}
.about-title strong{font-weight:600;font-style:normal;color:var(--terra-light)}
.about-lead{font-size:15px;color:rgba(255,255,255,.6);line-height:1.8;font-weight:300}
.about-img-placeholder{aspect-ratio:1;border-radius:var(--r2);background:linear-gradient(135deg,rgba(196,101,58,.3),rgba(201,169,110,.2));display:flex;align-items:center;justify-content:center;font-size:80px;position:relative;z-index:1}
.about-img-wrap{border-radius:var(--r2);overflow:hidden;position:relative;z-index:1}
.about-img{width:100%;height:100%;object-fit:cover}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:64px}
.value-card{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:32px;text-align:center;transition:box-shadow var(--ease)}
.value-card:hover{box-shadow:var(--shadow-md)}
.value-icon{font-size:36px;margin-bottom:16px;display:block}
.value-title{font-family:var(--font-d);font-size:20px;font-style:italic;margin-bottom:10px}
.value-text{font-size:14px;color:var(--ink3);line-height:1.7;font-weight:300}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:720px;margin:0 auto}
.team-card{background:#fff;border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;text-align:center}
.team-img{height:200px;display:flex;align-items:center;justify-content:center;font-size:80px}
.team-img.t1{background:linear-gradient(135deg,#f0d4b8,#e8c09a)}
.team-img.t2{background:linear-gradient(135deg,#d4e8d4,#b8d4bc)}
.team-body{padding:22px}
.team-name{font-family:var(--font-d);font-size:22px;font-style:italic;margin-bottom:4px}
.team-role{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--terracotta);margin-bottom:10px}
.team-bio{font-size:13.5px;color:var(--ink3);line-height:1.65;font-weight:300}

/* ── INFO PAGE (Livraison) ── */
.info-page-hero{background:var(--cream2);border-radius:var(--r2);padding:56px;text-align:center;margin-bottom:48px;border:1px solid var(--border)}
.info-sections{display:flex;flex-direction:column;gap:28px}
.info-card{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:36px}
.info-card h2,.info-card h3{font-family:var(--font-d);font-size:24px;font-style:italic;margin-bottom:18px;color:var(--ink);display:flex;align-items:center;gap:12px}
.info-card h2 span,.info-card h3 span{font-size:28px;font-style:normal}
.info-card p{font-size:14.5px;color:var(--ink2);line-height:1.8;font-weight:300;margin-bottom:14px}
.info-card p:last-child{margin-bottom:0}
.info-card a{color:var(--terracotta)}
.info-table{width:100%;border-collapse:collapse;margin-top:16px}
.info-table th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);padding:10px 14px;background:var(--cream2);border-bottom:1px solid var(--border)}
.info-table td{padding:12px 14px;font-size:14px;color:var(--ink2);border-bottom:1px solid var(--border);font-weight:300}
.info-table tr:last-child td{border-bottom:none}
.info-highlight{background:rgba(196,101,58,.07);border:1px solid rgba(196,101,58,.2);border-radius:var(--r);padding:16px 20px;font-size:14px;color:var(--ink2);margin-top:14px;display:flex;align-items:flex-start;gap:10px}

/* ── DEFAULT PAGE ── */
.page-article-title{font-family:var(--font-d);font-size:clamp(28px,4vw,44px);font-style:italic;margin-bottom:28px}
.page-content{font-size:15px;color:var(--ink2);line-height:1.8;font-weight:300;max-width:780px}
.page-content h2,.page-content h3{font-family:var(--font-d);font-style:italic;margin:32px 0 14px}
.page-content a{color:var(--terracotta)}
.page-content ul,.page-content ol{margin:14px 0 14px 24px}
.page-content ul{list-style:disc}
.page-content ol{list-style:decimal}

/* ── FOOTER ── */
.site-footer{background:var(--ink);padding:80px 0 0}
@media(max-width:900px){
  .site-footer{padding-bottom:calc(62px + env(safe-area-inset-bottom,0px))}
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:56px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-logo-main{color:rgba(255,255,255,.9);font-size:26px}
.footer-brand .logo-sub{color:rgba(255,255,255,.3)}
.footer-brand-desc{font-size:14px;color:rgba(255,255,255,.45);line-height:1.8;margin:18px 0 26px;font-weight:300;max-width:260px}
.footer-made{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}
.footer-made::before{content:'';width:28px;height:1px;background:var(--gold)}
.socials{display:flex;gap:9px;margin-top:24px}
.social-btn{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:15px;color:rgba(255,255,255,.4);transition:var(--ease)}
.social-btn:hover{background:var(--terracotta);border-color:var(--terracotta);color:#fff}
.footer-col h4{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:20px}
.footer-col a{display:block;font-size:13.5px;color:rgba(255,255,255,.4);padding:5px 0;transition:var(--ease);font-weight:300;text-decoration:none}
.footer-col a:hover{color:var(--terra-light);padding-left:5px}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}
.footer-contact-item .icon{font-size:15px;color:var(--terracotta);margin-top:1px;flex-shrink:0}
.footer-contact-item p{font-size:13px;color:rgba(255,255,255,.4);font-weight:300;line-height:1.5}
.footer-contact-item strong{color:rgba(255,255,255,.7);display:block;font-weight:500;margin-bottom:1px}
.footer-contact-item a{color:rgba(255,255,255,.6);text-decoration:none;display:inline}
.footer-payments{margin-top:20px}
.footer-payments span{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.25);display:block;margin-bottom:10px}
.payment-icons{display:flex;gap:7px;flex-wrap:wrap}
.pay-badge{padding:5px 11px;border-radius:5px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);font-size:11px;font-weight:700;color:rgba(255,255,255,.4)}
.footer-bottom{padding:22px 0;display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:rgba(255,255,255,.25);flex-wrap:wrap;gap:12px}
.footer-bottom-links{display:flex;gap:22px}
.footer-bottom-links a{color:rgba(255,255,255,.3);transition:var(--ease);text-decoration:none}
.footer-bottom-links a:hover{color:var(--terra-light)}

/* ── SCROLL TOP ── */
.scroll-top{position:fixed;bottom:28px;right:28px;z-index:500;width:46px;height:46px;border-radius:50%;background:var(--terracotta);color:#fff;box-shadow:0 4px 20px rgba(196,101,58,.4);display:flex;align-items:center;justify-content:center;font-size:20px;opacity:0;pointer-events:none;transform:translateY(12px);transition:var(--ease)}
.scroll-top.show{opacity:1;pointer-events:all;transform:none}
.scroll-top:hover{background:var(--terra-dark);transform:translateY(-3px)}

/* ── WOOCOMMERCE NOTICES ── */
.woocommerce-message,.woocommerce-info,.woocommerce-error{padding:14px 20px;border-radius:var(--r);margin-bottom:20px;font-size:14px;border-left:4px solid var(--terracotta);background:rgba(196,101,58,.06)}
.woocommerce-error{border-left-color:#c0392b;background:rgba(192,57,43,.06)}
.woocommerce-info{border-left-color:var(--gold);background:var(--gold-light)}

/* ── RESPONSIVE ── */
@media(max-width:1200px){
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .shop-layout{grid-template-columns:230px 1fr}
}
@media(max-width:1024px){
  .products-grid--shop{grid-template-columns:repeat(2,1fr)}
  .shop-layout{grid-template-columns:1fr}
  .shop-sidebar{position:static}
  .product-layout{grid-template-columns:1fr;gap:36px}
  .product-gallery{position:static}
  .promo-banner{grid-template-columns:1fr;padding:48px 36px}
  .promo-visual{display:none}
  .about-hero{grid-template-columns:1fr;padding:48px 36px}
  .about-img-placeholder,.about-img-wrap{display:none}
  .hero-stats{gap:24px}
}
@media(max-width:900px){
  .mega-nav{display:none !important}
  .hamburger{display:flex !important}
  .cat-grid{grid-template-columns:1fr 1fr;height:auto}
  .cat-card--large{grid-row:1/2;aspect-ratio:1}
  .products-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .reviews-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  :root{--hh:62px}
  .header-search{display:none}
  .hero{min-height:70vh}
  .hero-title{font-size:clamp(38px,10vw,56px)}
  .trust-item{padding:10px 16px;font-size:12px}
  .trust-sub{display:none}
  .newsletter-wrap{padding:44px 24px}
  .footer-grid{grid-template-columns:1fr}
  .section{padding:56px 0}
  .cat-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .products-grid{grid-template-columns:1fr 1fr;gap:10px}
  .product-body{padding:12px 14px 14px}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .section-header{flex-direction:column;align-items:flex-start}
  .hero-stats{gap:16px}
  .hero-stat-num{font-size:28px}
  .promo-banner{padding:32px 20px}
}

/* ══════════════════════════════════════════
   CART PAGE
══════════════════════════════════════════ */
.cart-page-wrap{padding:48px 0}
.cart-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:12px}
.cart-page-title{font-family:var(--font-d);font-size:clamp(26px,4vw,40px);font-style:italic}
.cart-page-title em{color:var(--terracotta)}
.cart-continue{font-size:13px;color:var(--ink3);text-decoration:none;transition:var(--ease)}
.cart-continue:hover{color:var(--terracotta)}
.cart-empty{text-align:center;padding:80px 0}
.cart-empty-icon{font-size:72px;margin-bottom:24px;display:block}
.cart-empty h2{font-family:var(--font-d);font-size:30px;font-style:italic;margin-bottom:12px}
.cart-empty p{color:var(--ink3);margin-bottom:28px}
.cart-page-layout{display:grid;grid-template-columns:1fr 380px;gap:40px;align-items:start}
.cart-page-items{background:#fff;border:1px solid var(--border);border-radius:var(--r2);overflow:hidden}
.cart-items-list{}
.cart-page-item{display:flex;gap:18px;padding:22px 28px;border-bottom:1px solid var(--border)}
.cart-page-item:last-child{border-bottom:none}
.cart-page-thumb{width:100px;height:100px;border-radius:var(--r);background:var(--cream2);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}
.cart-page-thumb img{width:100%;height:100%;object-fit:cover}
.cart-page-info{flex:1}
.cart-page-name{font-size:15px;font-weight:500;margin-bottom:4px;line-height:1.35}
.cart-page-name a{color:var(--ink);text-decoration:none;transition:var(--ease)}
.cart-page-name a:hover{color:var(--terracotta)}
.cart-page-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:12px}
.cart-page-price{font-family:var(--font-d);font-size:20px;color:var(--terracotta);font-style:italic;margin-left:auto}
.cart-remove-link{font-size:12px;color:var(--ink3);text-decoration:underline;cursor:pointer;transition:var(--ease);background:none;border:none}
.cart-remove-link:hover{color:var(--terracotta)}
.cart-qty-wrap .quantity{display:flex;align-items:center;border:1.5px solid var(--border2);border-radius:50px;overflow:hidden;background:#fff;width:fit-content}
.cart-qty-wrap .qty{width:48px;text-align:center;font-size:15px;font-weight:600;border:none;background:none;padding:8px 0;outline:none}
.cart-actions{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-top:1px solid var(--border);flex-wrap:wrap;gap:12px}
.cart-coupon{display:flex;gap:10px;align-items:center}
.cart-coupon .input-text{padding:9px 18px;border:1.5px solid var(--border2);border-radius:50px;font-family:inherit;font-size:14px;outline:none;transition:var(--ease);width:180px}
.cart-coupon .input-text:focus{border-color:var(--terracotta)}
.update-cart{font-size:13px;color:var(--ink3);background:none;border:none;cursor:pointer;transition:var(--ease);font-family:inherit}
.update-cart:hover{color:var(--terracotta)}
.order-summary,.cart-summary-sticky{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:28px;position:sticky;top:calc(var(--hh)+30px)}
.summary-title{font-family:var(--font-d);font-size:22px;font-style:italic;margin-bottom:22px}
.summary-lines{margin-bottom:16px}
.summary-line{display:flex;justify-content:space-between;font-size:14px;color:var(--ink2);margin-bottom:10px;align-items:center}
.summary-line--discount{color:var(--sage)}
.discount-amount{color:var(--sage);font-weight:600}
.summary-total{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:16px;padding-top:16px;margin-top:8px;border-top:1px solid var(--border);margin-bottom:20px}
.summary-total-price{font-family:var(--font-d);font-size:26px;color:var(--terracotta);font-style:italic;font-weight:400}
.summary-total-price .woocommerce-Price-amount{color:var(--terracotta)!important;font-family:var(--font-d);font-size:26px;font-style:italic}
.checkout-main-btn{width:100%;justify-content:center;margin-bottom:10px}
.continue-btn{width:100%;justify-content:center;padding:12px;margin-bottom:14px}
.cart-secure-note{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:var(--ink3);margin-bottom:12px}
.cart-payment-logos{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}

/* ══════════════════════════════════════════
   CHECKOUT PAGE
══════════════════════════════════════════ */
.checkout-steps{display:flex;align-items:center;margin-bottom:40px;overflow-x:auto;padding-bottom:4px}
.checkout-step{display:flex;align-items:center;gap:10px;padding:12px 20px;font-size:13px;font-weight:500;color:var(--ink3);white-space:nowrap;flex-shrink:0}
.checkout-step.active{color:var(--terracotta)}
.checkout-step.done{color:var(--sage)}
.step-num{width:28px;height:28px;border-radius:50%;border:1.5px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.checkout-step.active .step-num{background:var(--terracotta);border-color:var(--terracotta);color:#fff}
.checkout-step.done .step-num{background:var(--sage);border-color:var(--sage);color:#fff}
.step-divider{width:40px;height:1px;background:var(--border2);flex-shrink:0}
.checkout-layout{display:grid;grid-template-columns:1fr 420px;gap:56px;align-items:start}
.checkout-forms{}
.checkout-card{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:40px;margin-bottom:24px}
.checkout-card h2{font-family:var(--font-d);font-size:22px;font-style:italic;font-weight:400;margin-bottom:28px}
.checkout-card .form-row{margin-bottom:20px}
.checkout-summary-col{position:sticky;top:calc(var(--hh)+30px)}
.checkout-card .woocommerce-input-wrapper{width:100%}
/* Livraison options */
.livraison-options{display:flex;flex-direction:column;gap:10px}
.livraison-option{display:flex;align-items:center;gap:16px;padding:16px 20px;border:1.5px solid var(--border2);border-radius:var(--r);cursor:pointer;transition:var(--ease)}
.livraison-option.selected,.livraison-option:has(input:checked){border-color:var(--terracotta);background:rgba(196,101,58,.04)}
.livraison-option input[type=radio]{accent-color:var(--terracotta);width:18px;height:18px;flex-shrink:0;cursor:pointer}
.livraison-option-info{flex:1}
.livraison-option-name{font-size:14.5px;font-weight:500;color:var(--ink);margin-bottom:2px}
.livraison-option-desc{font-size:12.5px;color:var(--ink3)}
.livraison-option-price{font-family:var(--font-d);font-size:18px;color:var(--terracotta);font-style:italic;white-space:nowrap}
.livraison-icon{font-size:22px;width:40px;height:40px;background:var(--cream2);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
/* WC checkout payment block */
#payment .payment_methods{padding:0!important;list-style:none!important}
#payment .payment_methods li{padding:14px 0;border-bottom:1px solid var(--border)}
#payment .payment_methods li:last-child{border-bottom:none}
#payment .payment_methods li label{font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:10px}
#payment .place-order{margin-top:0;padding:0}
#payment #place_order{width:100%!important;padding:16px!important;font-size:15px!important;margin-top:20px}

/* ══════════════════════════════════════════
   CONFIRMATION PAGE
══════════════════════════════════════════ */
.confirmation-wrap{max-width:660px;margin:0 auto;text-align:center;padding:80px 0}
.confirmation-icon{width:80px;height:80px;border-radius:50%;background:var(--sage);color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 28px;box-shadow:0 0 0 16px rgba(107,143,113,.12)}
.confirmation-title{font-family:var(--font-d);font-size:clamp(28px,4vw,42px);font-style:italic;margin-bottom:14px}
.confirmation-sub{font-size:15px;color:var(--ink3);font-weight:300;line-height:1.75;margin-bottom:36px}
.confirmation-order{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:28px;margin-bottom:28px;text-align:left}
.confirmation-order h3{font-family:var(--font-d);font-size:20px;font-style:italic;margin-bottom:18px}
.conf-line{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--ink2);padding:10px 0;border-bottom:1px solid var(--border)}
.conf-line:last-child{border-bottom:none}
.conf-line .label{color:var(--ink3);font-weight:300}
.conf-line--total{font-weight:600;font-size:16px}
.conf-line--total .woocommerce-Price-amount{color:var(--terracotta)!important;font-family:var(--font-d);font-style:italic;font-size:22px}
.conf-status{background:rgba(107,143,113,.15);color:var(--sage);font-weight:600;padding:3px 10px;border-radius:50px;font-size:12px}
.conf-items{border-top:1px solid var(--border);padding-top:16px;margin-top:8px;margin-bottom:8px}
.conf-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}
.conf-item:last-child{border-bottom:none}
.conf-item img{width:52px;height:52px;border-radius:var(--r);object-fit:cover}
.conf-item-info{flex:1}
.conf-item-name{font-size:13.5px;font-weight:500}
.conf-item-price{font-family:var(--font-d);font-size:16px;color:var(--terracotta);font-style:italic}
.conf-address{background:var(--cream2);border-radius:var(--r2);padding:20px 24px;margin-bottom:28px;text-align:left}
.conf-address h3{font-family:var(--font-d);font-size:18px;font-style:italic;margin-bottom:10px}
.conf-address address{font-style:normal;font-size:14px;color:var(--ink2);line-height:1.7;font-weight:300}
.confirmation-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ══════════════════════════════════════════
   CONTACT PAGE
══════════════════════════════════════════ */
.contact-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:56px}
.contact-info-col{}
.contact-info-block{margin-bottom:32px}
.contact-info-block h3{font-family:var(--font-d);font-size:22px;font-style:italic;margin-bottom:18px}
.contact-info-item{display:flex;gap:14px;margin-bottom:18px}
.contact-icon{width:44px;height:44px;background:var(--cream2);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;border:1px solid var(--border)}
.contact-detail strong{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);display:block;margin-bottom:3px}
.contact-detail p{font-size:14px;color:var(--ink3);font-weight:300;line-height:1.6}
.contact-detail a{color:var(--terracotta);text-decoration:none}
.contact-detail a:hover{text-decoration:underline}
.contact-perso-block{background:var(--cream2);border-radius:var(--r2);padding:26px;border:1px solid var(--border);margin-bottom:28px}
.contact-perso-icon{font-size:28px;margin-bottom:10px;display:block}
.contact-perso-block h3{font-family:var(--font-d);font-size:20px;font-style:italic;margin-bottom:10px;color:var(--ink)}
.contact-perso-block p{font-size:14px;color:var(--ink3);line-height:1.7;font-weight:300}
.contact-socials{margin-top:4px}
.contact-socials-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);margin-bottom:12px}
.socials-row{display:flex;gap:8px;flex-wrap:wrap}
.contact-social-btn{display:flex;align-items:center;gap:7px;padding:9px 16px;border-radius:50px;border:1.5px solid var(--border2);font-size:13px;font-weight:500;color:var(--ink2);text-decoration:none;transition:var(--ease)}
.contact-social-btn:hover{background:var(--terracotta);border-color:var(--terracotta);color:#fff}
.contact-form-card{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:40px}
.contact-form-card h2{font-family:var(--font-d);font-size:28px;font-style:italic;margin-bottom:8px}
.contact-form-card>p{font-size:14px;color:var(--ink3);margin-bottom:28px;font-weight:300}
.contact-form{display:flex;flex-direction:column;gap:16px}
.contact-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2)}
.form-group .req{color:var(--terracotta)}
.form-group input,.form-group select,.form-group textarea{padding:12px 16px;border:1.5px solid var(--border2);border-radius:var(--r);font-family:inherit;font-size:14px;color:var(--ink);background:#fff;outline:none;transition:var(--ease)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--terracotta);box-shadow:0 0 0 3px rgba(196,101,58,.1)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--ink3)}
.form-submit-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.form-note{font-size:12px;color:var(--ink3)}
.form-success{background:rgba(107,143,113,.1);border:1px solid rgba(107,143,113,.3);border-radius:var(--r);padding:16px 20px;font-size:14px;color:var(--sage);margin-bottom:20px}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

/* ══════════════════════════════════════════
   MY ACCOUNT
══════════════════════════════════════════ */
.myaccount-wrap{display:grid;grid-template-columns:220px 1fr;gap:40px;align-items:start;padding:56px 0}
.myaccount-sidebar{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r2);padding:16px;
  position:sticky;top:calc(var(--hh)+30px);
  min-width:0;
}
.myaccount-content{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:40px}
.woocommerce-MyAccount-navigation ul{list-style:none;margin:0;padding:0}
.woocommerce-MyAccount-navigation ul li{margin:0}
.woocommerce-MyAccount-navigation ul li a{
  display:block;
  padding:11px 16px;
  border-radius:var(--r);
  font-size:14px;font-weight:500;
  color:var(--ink2);
  text-decoration:none;
  transition:var(--ease);
  margin-bottom:3px;
  white-space:nowrap;      /* empêche le texte de passer à la ligne */
  overflow:hidden;
  text-overflow:ellipsis;
}
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover{
  background:var(--terracotta);color:#fff;
}

/* ══════════════════════════════════════════
   RELATED PRODUCTS
══════════════════════════════════════════ */
.related-section{margin-top:64px;padding-top:48px;border-top:1px solid var(--border)}

/* ══════════════════════════════════════════
   ADDITIONAL RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:1100px){
  .cart-page-layout{grid-template-columns:1fr}
  .cart-summary-sticky{position:static}
  .checkout-layout{grid-template-columns:1fr}
  .checkout-summary-col{position:static;order:-1}
  .contact-layout{grid-template-columns:1fr}
  .myaccount-wrap{grid-template-columns:1fr}
  .myaccount-sidebar{position:static}
}
@media(max-width:640px){
  .cart-page-item{flex-direction:column}
  .cart-page-thumb{width:80px;height:80px}
  .checkout-steps{gap:0}
  .checkout-step{padding:10px 12px}
  .step-divider{width:20px}
  .contact-form .form-grid{grid-template-columns:1fr}
  .confirmation-wrap{padding:48px 0}
}

/* ── PAGINATION — paginate_links() ── */
.pagination-wrap{display:flex;justify-content:center;margin-top:48px;padding-bottom:8px}
.pagination-wrap ul{display:flex;gap:8px;list-style:none;padding:0;margin:0;flex-wrap:wrap;justify-content:center}
.pagination-wrap ul li a,
.pagination-wrap ul li span{
  min-width:40px;height:40px;padding:0 10px;border-radius:50px;
  border:1.5px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:500;color:var(--ink2);
  transition:var(--ease);text-decoration:none;
  background:#fff;
}
.pagination-wrap ul li span.current,
.pagination-wrap ul li a:hover{
  background:var(--terracotta);border-color:var(--terracotta);color:#fff;
}
.pagination-wrap ul li .prev,
.pagination-wrap ul li .next{
  min-width:auto;padding:0 18px;border-radius:50px;
  font-size:13px;font-weight:600;letter-spacing:.03em;
}

/* ── NEWSLETTER SUCCESS ── */
.newsletter-success{
  background:rgba(107,143,113,.15);border:1.5px solid rgba(107,143,113,.4);
  border-radius:var(--r);padding:12px 20px;
  font-size:14px;font-weight:600;color:var(--sage);
  margin-bottom:20px;position:relative;z-index:1;
}

/* ── FOOTER BOTTOM — correction liens en ligne ── */
.footer-bottom-links{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.footer-bottom-links a{color:rgba(255,255,255,.35);text-decoration:none;font-size:12.5px;transition:var(--ease)}
.footer-bottom-links a:hover{color:var(--terra-light)}


/* ── SIDEBAR FILTRES BOUTIQUE — améliorée ── */
.shop-sidebar{background:#fff;border:1px solid var(--border);border-radius:var(--r2);padding:0;overflow:hidden;position:sticky;top:calc(var(--hh) + 16px)}

/* ── BOUTON FILTRES MOBILE ── */
.shop-filter-toggle{
  display:none;
  align-items:center;gap:8px;
  padding:10px 18px;
  background:#fff;border:1.5px solid var(--border2);border-radius:50px;
  font-size:13px;font-weight:600;color:var(--ink);
  cursor:pointer;transition:var(--ease);
  white-space:nowrap;flex-shrink:0;
}
.shop-filter-toggle:hover{border-color:var(--terracotta);color:var(--terracotta)}
.shop-filter-toggle svg{flex-shrink:0}
.shop-filter-active-count{
  display:none;background:var(--terracotta);color:#fff;
  font-size:10px;font-weight:700;
  padding:1px 6px;border-radius:50px;
}
.shop-filter-toggle.has-filters .shop-filter-active-count{display:inline-flex}

/* ── OVERLAY FILTRES MOBILE ── */
.shop-sidebar-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(26,18,9,.5);z-index:1150;
  backdrop-filter:blur(2px);
}
.shop-sidebar-overlay.open{display:block}

@media(max-width:900px){
  .shop-sidebar{
    position:fixed !important;
    bottom:0;left:0;right:0;top:auto !important;
    max-height:85vh;
    border-radius:var(--r2) var(--r2) 0 0;
    z-index:1160;
    transform:translateY(100%);
    transition:transform .35s cubic-bezier(.32,0,.15,1);
    overflow-y:auto;
    padding-bottom:env(safe-area-inset-bottom,0px);
    /* Retirer du flux grid */
    grid-row:1;grid-column:1;
    width:100%;
  }
  .shop-sidebar.open{transform:translateY(0)}
  .shop-filter-toggle{display:flex}
  .shop-layout{grid-template-columns:1fr !important}
  /* Réordonner : les produits en premier, sidebar hors flux */
  .shop-layout > .shop-main{order:1}
  .shop-layout > .shop-sidebar{order:2}
  .shop-sidebar-mobile-head{
    display:flex !important;
    align-items:center;justify-content:space-between;
    padding:16px 20px 12px;
    border-bottom:1px solid var(--border);
    position:sticky;top:0;background:#fff;z-index:1;
  }
  .shop-sidebar-mobile-head h3{
    font-family:var(--font-d);font-size:18px;font-style:italic;font-weight:400;color:var(--ink);
  }
  .shop-sidebar-mobile-close{
    width:34px;height:34px;border-radius:50%;
    background:var(--cream2);border:none;cursor:pointer;
    color:var(--ink);font-size:16px;display:flex;align-items:center;justify-content:center;
    transition:var(--ease);
  }
  .shop-sidebar-mobile-close:hover{background:var(--terracotta);color:#fff}
}
.shop-sidebar-mobile-head{display:none}
.sidebar-section{padding:20px 20px 16px;border-bottom:1px solid var(--border)}
.sidebar-section:last-child{border-bottom:none}
.sidebar-title{font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:12px}
.sidebar-cat-link{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;color:var(--ink2);padding:7px 10px;border-radius:var(--r);text-decoration:none;transition:var(--ease);width:100%}
.sidebar-cat-link:hover{background:var(--cream2);color:var(--terracotta)}
.sidebar-cat-link.active{background:rgba(196,101,58,.1);color:var(--terracotta);font-weight:600}
.sidebar-cat-link .count{font-size:11px;color:var(--ink3);background:var(--cream2);padding:1px 7px;border-radius:50px;flex-shrink:0}
.sidebar-cat-link.active .count{background:rgba(196,101,58,.15);color:var(--terracotta)}
/* Groupe avec sous-catégories */
.sidebar-cat-group{}
.sidebar-cat-row{display:flex;align-items:center;gap:4px}
.sidebar-cat-row .sidebar-cat-link{flex:1}
.sidebar-cat-toggle{width:26px;height:26px;border-radius:50%;background:none;border:none;cursor:pointer;color:var(--ink3);font-size:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--ease)}
.sidebar-cat-toggle:hover{background:var(--cream2);color:var(--terracotta)}
.sidebar-cat-children{display:none;padding-left:10px;margin-top:2px}
.sidebar-cat-group.open .sidebar-cat-children{display:block}
.sidebar-cat-group.open .sidebar-cat-toggle{transform:rotate(180deg)}
.sidebar-cat-child{font-size:13px;padding:5px 10px}
/* Reset */
.sidebar-reset{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink3);text-decoration:none;padding:8px 10px;border-radius:var(--r);border:1px solid var(--border2);transition:var(--ease)}
.sidebar-reset:hover{background:var(--terracotta);color:#fff;border-color:var(--terracotta)}







/* ══════════════════════════════════════════
   CHECKOUT 2 ÉTAPES — Doudi & Moumoune
══════════════════════════════════════════ */

/* Conteneur global */
.doudi-checkout { max-width: 1100px; margin: 0 auto; padding: 48px 24px 100px; }
/* Espacement des cartes */
.dco-card { background: #fff; border: 1px solid var(--border); border-radius: var(--r2); padding: 36px 40px; margin-bottom: 24px; }

/* Barre de progression */
.dco-progress { margin-bottom: 48px; }
.dco-progress-inner { display: flex; align-items: center; justify-content: center; gap: 0; }
.dco-step { display: flex; flex-direction: column; align-items: center; gap: 8px; min-width: 120px; }
.dco-step-bubble {
  width: 40px; height: 40px; border-radius: 50%;
  border: 2px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 600; color: var(--ink3);
  background: #fff; transition: all .3s ease;
}
.dco-step span { font-size: 12px; font-weight: 500; color: var(--ink3); text-align: center; }
.dco-step--active .dco-step-bubble { background: var(--terracotta); border-color: var(--terracotta); color: #fff; }
.dco-step--active span { color: var(--terracotta); font-weight: 600; }
.dco-step--done .dco-step-bubble { background: var(--sage); border-color: var(--sage); color: #fff; }
.dco-step--done span { color: var(--sage); }
.dco-progress-line { flex: 1; height: 2px; background: var(--border); max-width: 100px; }

/* ── CHECKOUT LAYOUT UNIFIÉ ── */
.dco-checkout-layout{
  display:grid;
  grid-template-columns:1fr 400px;
  gap:48px;
  align-items:start;
}
.dco-checkout-main{}
.dco-checkout-aside{}
.dco-recap--sticky{position:sticky;top:calc(var(--hh) + 24px)}
.dco-recap-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}
.dco-recap-header h3{font-family:var(--font-d);font-size:18px;font-style:italic;font-weight:400}
.dco-recap-edit{font-size:12px;color:var(--terracotta);text-decoration:none;font-weight:600}
.dco-recap-items{padding:8px 0;max-height:360px;overflow-y:auto}
.dco-recap-item{display:flex;gap:14px;padding:14px 24px;border-bottom:1px solid var(--border)}
.dco-recap-item:last-child{border-bottom:none}
.dco-recap-img-wrap{position:relative;flex-shrink:0}
.dco-recap-img-wrap img{width:56px;height:56px;object-fit:cover;border-radius:var(--r)}
.dco-recap-qty{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:var(--ink);color:#fff;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.dco-recap-info{flex:1;min-width:0}
.dco-recap-name{font-size:13px;font-weight:500;line-height:1.35;margin-bottom:4px;color:var(--ink)}
.dco-recap-price{font-size:13px;color:var(--terracotta);font-weight:600}
.dco-recap-totals{padding:16px 24px}
.dco-coupon-bar{margin-bottom:24px}
.dco-coupon-bar .woocommerce-form-coupon{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
/* Responsive checkout */
@media(max-width:900px){
  .dco-checkout-layout{
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
  }
  .dco-checkout-aside{order:1}
  .dco-checkout-main{order:2}
  .dco-recap--sticky{position:static}
}
@media(max-width:600px){
  .doudi-checkout{padding:20px 16px 100px}
  .dco-card{padding:22px 18px}
  .dco-card .form-row{width:100% !important;float:none !important;padding:0 !important}
  .dco-card .form-row-first,.dco-card .form-row-last{width:100% !important;float:none !important}
}

/* Cartes */
.dco-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: var(--r2); padding: 36px 40px;
  margin-bottom: 24px;
}
.dco-card--sm { padding: 24px 32px; }
.dco-card-header { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 28px; }
.dco-card-icon { font-size: 22px; flex-shrink: 0; margin-top: 2px; }
.dco-card-header h2 { font-family: var(--font-d); font-size: 20px; font-style: italic; font-weight: 400; margin: 0 0 4px; }
.dco-card-header p { font-size: 13px; color: var(--ink3); margin: 0; }

/* Bouton retour */
.dco-btn-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13.5px; font-weight: 500; color: var(--ink3);
  background: none; border: none; cursor: pointer; padding: 0;
  margin-bottom: 24px; transition: color var(--ease);
}
.dco-btn-back:hover { color: var(--terracotta); }

/* Bouton suivant */
.dco-panel-footer { margin-top: 8px; display: flex; justify-content: flex-end; }
.dco-btn-next {
  background: var(--terracotta); color: #fff;
  border: none; border-radius: 50px;
  padding: 16px 40px; font-size: 15px; font-weight: 600;
  letter-spacing: .04em; cursor: pointer;
  transition: background var(--ease), transform var(--ease);
  display: inline-flex; align-items: center; gap: 8px;
}
.dco-btn-next:hover { background: var(--terracotta-d, #a8522f); transform: translateY(-1px); }

/* Récapitulatif panier */
.dco-recap {
  background: var(--cream2); border: 1px solid var(--border);
  border-radius: var(--r2); overflow: hidden;
  position: sticky; top: calc(var(--hh) + 24px);
}
.dco-recap--sticky { position: sticky; top: calc(var(--hh) + 24px); }
.dco-recap-header {
  padding: 20px 24px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.dco-recap-header h3 { font-family: var(--font-d); font-size: 18px; font-style: italic; font-weight: 400; margin: 0; }
.dco-recap-edit { font-size: 12.5px; color: var(--terracotta); text-decoration: none; font-weight: 500; }
.dco-recap-edit:hover { text-decoration: underline; }

/* Items panier dans recap */
.dco-recap-items { padding: 16px 24px; border-bottom: 1px solid var(--border); display: flex; flex-direction: column; gap: 14px; max-height: 320px; overflow-y: auto; }
.dco-recap-item { display: flex; align-items: center; gap: 12px; }
.dco-recap-thumb { position: relative; flex-shrink: 0; }
.dco-recap-thumb img { width: 56px; height: 56px; object-fit: cover; border-radius: var(--r); border: 1px solid var(--border); }
.dco-recap-qty { position: absolute; top: -6px; right: -6px; background: var(--ink); color: #fff; font-size: 10px; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.dco-recap-item-info { flex: 1; min-width: 0; }
.dco-recap-item-name { font-size: 13.5px; font-weight: 500; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dco-recap-item-price { font-size: 13.5px; font-weight: 600; color: var(--ink); flex-shrink: 0; }
/* Version compacte étape 2 */
.dco-recap-item--sm { flex-direction: row; justify-content: space-between; }
.dco-recap-item--sm .dco-recap-item-info { display: flex; gap: 8px; align-items: center; }
.dco-recap-item-qty { font-size: 12px; color: var(--ink3); }

/* Totaux */
.dco-recap-totals { padding: 16px 24px; border-bottom: 1px solid var(--border); display: flex; flex-direction: column; gap: 10px; }
.dco-recap-row { display: flex; justify-content: space-between; align-items: center; font-size: 13.5px; color: var(--ink2); }
.dco-recap-row--promo { color: var(--sage); }
.dco-recap-row--total { font-size: 16px; font-weight: 700; color: var(--ink); padding-top: 10px; border-top: 1px solid var(--border); margin-top: 4px; }
.dco-shipping-calc { font-size: 12px; color: var(--ink3); font-style: italic; }

/* Coupon */
.dco-coupon { padding: 14px 24px; border-bottom: 1px solid var(--border); }
.dco-coupon-toggle { background: none; border: none; cursor: pointer; font-size: 13px; color: var(--ink3); padding: 0; display: flex; align-items: center; gap: 6px; width: 100%; text-align: left; transition: color var(--ease); }
.dco-coupon-toggle:hover { color: var(--terracotta); }
.dco-coupon-form { display: none; margin-top: 12px; }
.dco-coupon-form.open { display: block; }
.dco-coupon-row { display: flex; gap: 8px; }
.dco-coupon-row input { flex: 1; border: 1px solid var(--border2); border-radius: var(--r); padding: 9px 14px; font-size: 13.5px; font-family: var(--font-b); }
.dco-btn-coupon { background: var(--ink); color: #fff; border: none; border-radius: var(--r); padding: 9px 18px; font-size: 13px; font-weight: 600; cursor: pointer; white-space: nowrap; }

/* Récap infos (étape 2) */
.dco-recap-infos { padding: 14px 24px; border-bottom: 1px solid var(--border); }
.dco-recap-who { font-size: 13px; color: var(--ink2); line-height: 1.6; }

/* Trust bar dans recap */
.dco-trust { padding: 14px 24px; display: flex; flex-direction: column; gap: 6px; }
.dco-trust span { font-size: 12px; color: var(--ink3); display: flex; align-items: center; gap: 6px; }

/* Options de livraison */
.dco-shipping-list { display: flex; flex-direction: column; gap: 10px; }
.dco-shipping-option {
  display: flex; align-items: center; gap: 16px;
  padding: 16px 20px; border: 2px solid var(--border);
  border-radius: var(--r2); cursor: pointer;
  transition: all .2s ease; background: #fff;
}
.dco-shipping-option:hover { border-color: var(--terracotta); background: rgba(196,101,58,.03); }
.dco-shipping-option--selected { border-color: var(--terracotta); background: rgba(196,101,58,.05); }
.dco-shipping-option input[type="radio"] { display: none; }
.dco-shipping-icon { font-size: 22px; flex-shrink: 0; width: 36px; text-align: center; }
.dco-shipping-info { flex: 1; }
.dco-shipping-name { font-size: 14.5px; font-weight: 600; color: var(--ink); }
.dco-shipping-delay { font-size: 12px; color: var(--ink3); margin-top: 2px; }
.dco-shipping-price { font-size: 15px; font-weight: 700; color: var(--ink); flex-shrink: 0; }
.dco-free { color: var(--sage); font-weight: 700; }
.dco-shipping-check { width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--border2); display: flex; align-items: center; justify-content: center; font-size: 11px; color: transparent; flex-shrink: 0; transition: all .2s; }
.dco-shipping-option--selected .dco-shipping-check { background: var(--terracotta); border-color: var(--terracotta); color: #fff; }

/* Paiement card */
.dco-card--payment { border-color: var(--terracotta); }
.dco-card--payment .dco-card-icon { color: var(--terracotta); }

/* Responsive */
@media (max-width: 900px) {
  .dco-recap { position: static !important; }
  .dco-recap--sticky { position: static !important; }
  .dco-progress-inner { gap: 0; }
  .dco-step { min-width: 80px; }
  .dco-step span { font-size: 11px; }
}
@media (max-width: 600px) {
  .doudi-checkout { padding: 20px 16px 80px; }
  .dco-card { padding: 20px 18px; }
  .dco-panel-footer { justify-content: stretch; }
  .dco-btn-next { width: 100%; justify-content: center; }
  .dco-step span { display: none; }
  .dco-progress-line { max-width: 60px; }
  /* Champs de formulaire pleine largeur */
  .dco-card .form-row { width: 100% !important; float: none !important; padding: 0 !important; }
  .dco-card .form-row-first,
  .dco-card .form-row-last { width: 100% !important; float: none !important; }
  /* Recap panier compact */
  .dco-recap-header { padding: 16px 18px; }
  .dco-recap-items { max-height: 220px; }
  .dco-recap-item { padding: 12px 18px; gap: 10px; }
  .dco-recap-img { width: 48px; height: 48px; }
  /* Progress bar plus compacte */
  .dco-progress { margin-bottom: 28px; }
  .dco-step-bubble { width: 32px; height: 32px; font-size: 13px; }
}

/* ── CHECKOUT : Nouveaux styles 2 étapes ── */
.dco-panel--hidden { display: none !important; }

/* Carte résumé infos étape 2 */
.dco-card--recap-info { padding: 20px 28px !important; background: var(--cream2) !important; }
.dco-card-header--inline { display: flex; align-items: center; gap: 14px; margin-bottom: 0 !important; flex-wrap: wrap; }
.dco-card-header--inline .dco-recap-who { flex: 1; font-size: 13.5px; color: var(--ink2); line-height: 1.7; }
.dco-recap-info-edit { background: none; border: none; cursor: pointer; font-size: 12.5px; font-weight: 600; color: var(--terracotta); padding: 0; white-space: nowrap; flex-shrink: 0; }
.dco-recap-info-edit:hover { text-decoration: underline; }

/* Champ en erreur */
.dco-field-error { border-color: #c0392b !important; box-shadow: 0 0 0 3px rgba(192,57,43,.1) !important; }

/* Récap mobile */
.dco-mobile-recap { display: none; margin-bottom: 20px; background: var(--cream2); border: 1px solid var(--border); border-radius: var(--r2); overflow: hidden; }
.dco-mobile-recap-toggle { width: 100%; display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; background: none; border: none; cursor: pointer; font-size: 13.5px; font-weight: 500; color: var(--terracotta); gap: 8px; }
.dco-mobile-recap-toggle-left { display: flex; align-items: center; gap: 8px; }
.dco-mobile-recap-total { font-size: 15px; font-weight: 700; color: var(--ink); }
.dco-mobile-recap-arrow { font-size: 11px; }
.dco-mobile-recap-body { padding: 0 20px 16px; }
.dco-mobile-recap-totals { border-top: 1px solid var(--border); margin-top: 12px; padding-top: 12px; font-size: 13px; }

/* Méthodes WooCommerce dans le bloc livraison */
.dco-wc-shipping .woocommerce-shipping-methods { list-style: none; display: flex; flex-direction: column; gap: 10px; padding: 0; margin: 0; }
.dco-wc-shipping .woocommerce-shipping-methods li { border: 2px solid var(--border); border-radius: var(--r2); padding: 16px 20px; cursor: pointer; transition: border-color .2s, background .2s; display: flex; align-items: center; gap: 12px; }
.dco-wc-shipping .woocommerce-shipping-methods li:hover { border-color: var(--terracotta); background: rgba(196,101,58,.03); }
.dco-wc-shipping .woocommerce-shipping-methods li input[type="radio"] { accent-color: var(--terracotta); width: 18px; height: 18px; flex-shrink: 0; }

/* Responsive checkout */
@media(max-width:900px){
  .dco-checkout-layout { display: flex !important; flex-direction: column !important; gap: 24px !important; }
  .dco-checkout-aside { order: 1; }
  .dco-checkout-main  { order: 2; }
  .dco-checkout-aside .dco-recap { display: none; } /* remplacé par le récap mobile */
  .dco-mobile-recap { display: block; }
  .dco-recap--sticky { position: static !important; }
}
@media(max-width:600px){
  .doudi-checkout { padding: 20px 16px 80px; }
  .dco-card { padding: 22px 18px; }
  .dco-panel-footer { justify-content: stretch; }
  .dco-btn-next { width: 100%; justify-content: center; }
  .dco-step span { display: none; }
  .dco-progress-line { max-width: 60px; }
  .dco-card .form-row { width: 100% !important; float: none !important; padding: 0 !important; }
  .dco-card .form-row-first, .dco-card .form-row-last { width: 100% !important; float: none !important; }
}


.dco-step1-cart-list{display:flex;flex-direction:column;gap:14px}
.dco-recap-item--line{padding:0;border-bottom:none}
.dco-step2-order-review > .woocommerce-checkout-review-order-table{margin-bottom:20px!important}
.dco-step2-order-review #payment{margin-top:18px;background:var(--cream2);border:1px solid var(--border);border-radius:var(--r2)}
.dco-step2-order-review .shop_table{margin-bottom:0!important}
.dco-step2-order-review .woocommerce-shipping-methods li.is-selected{border-color:var(--terracotta);background:rgba(196,101,58,.05)}
.woocommerce-checkout .dco-step2-order-review .payment_methods>li{padding:14px 0}
.woocommerce-checkout .dco-step2-order-review .payment_methods label{display:inline-block!important;margin-bottom:0!important}
@media (max-width:900px){
  .dco-step2-order-review #payment{padding:18px}
  .dco-step1-cart-list .dco-recap-item-price{font-size:13px}
}


.dco-step1-errors{margin:0 0 12px;padding:12px 14px;border:1px solid rgba(192,57,43,.22);background:rgba(192,57,43,.08);color:#8e2b21;border-radius:14px;font-size:14px;line-height:1.45}


/* Step 2 desktop cleanup */
.doudi-checkout-form.is-step-2 .dco-checkout-layout{
  grid-template-columns:minmax(0,1fr);
}
.doudi-checkout-form.is-step-2 .dco-checkout-aside{
  display:none;
}
.doudi-checkout-form.is-step-2 .dco-checkout-main{
  max-width:860px;
}
.doudi-checkout-form.is-step-2 .dco-panel[data-step="2"]{
  max-width:860px;
}
.doudi-checkout-form.is-step-2 .dco-card--payment{
  margin-bottom:0;
}
.doudi-checkout-form.is-step-2 .dco-step2-order-review .shop_table,
.doudi-checkout-form.is-step-2 .dco-step2-order-review #payment{
  width:100%;
}
@media (max-width: 980px){
  .doudi-checkout-form.is-step-2 .dco-checkout-aside{
    display:block;
  }
  .doudi-checkout-form.is-step-2 .dco-checkout-main,
  .doudi-checkout-form.is-step-2 .dco-panel[data-step="2"]{
    max-width:none;
  }
}


/* ===== Checkout — messages & coupon plus alignés à la charte ===== */
.doudi-coupon-box{background:#fff;border:1.5px solid var(--border);border-radius:22px;padding:18px 18px 16px;box-shadow:0 10px 28px rgba(40,30,20,.05)}
.doudi-coupon-intro{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;padding:14px 16px;background:linear-gradient(180deg,var(--gold-light) 0%, rgba(255,255,255,.92) 100%);border:1px solid rgba(196,101,58,.22);border-radius:16px}
.doudi-coupon-intro-icon{font-size:20px;line-height:1;margin-top:1px}
.doudi-coupon-intro strong{display:block;font-size:15px;color:var(--ink);margin-bottom:4px}
.doudi-coupon-intro p{margin:0;font-size:13px;color:var(--ink3);line-height:1.5}
.doudi-coupon-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.doudi-coupon-row .input-text{flex:1;min-width:190px;border:1.5px solid var(--border2);border-radius:999px;padding:13px 18px;font-size:14px;font-family:var(--font-b);background:#fff;transition:var(--ease)}
.doudi-coupon-row .input-text:focus{border-color:var(--terracotta);box-shadow:0 0 0 4px rgba(196,101,58,.10);outline:none}
.doudi-coupon-row .button{border:none;border-radius:999px;padding:13px 22px;font-size:13px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;background:var(--terracotta);color:#fff;cursor:pointer;transition:transform .18s ease, box-shadow .18s ease}
.doudi-coupon-row .button:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(196,101,58,.22)}
.dco-card .woocommerce-form-coupon-toggle,.dco-card .woocommerce-info{margin:0}
.dco-card .woocommerce-info{padding:0;border:none;background:transparent}
.dco-trust span{line-height:1.45}
@media (max-width: 640px){.doudi-coupon-box{padding:14px}.doudi-coupon-intro{padding:12px 13px;border-radius:14px}.doudi-coupon-row .input-text,.doudi-coupon-row .button{width:100%}}

/* ══════════════════════════════════════════
   CHECKOUT PAYMENT METHODS — skin premium
══════════════════════════════════════════ */
.woocommerce-checkout #payment{
  background:linear-gradient(180deg,var(--cream2) 0%, #f7f2ea 100%) !important;
  border:1px solid var(--border) !important;
  border-radius:var(--r2) !important;
  box-shadow:0 12px 34px rgba(57,44,31,.05);
}
.woocommerce-checkout #payment ul.payment_methods{
  border:0 !important;
  margin:0 !important;
  padding:0 !important;
}
.woocommerce-checkout #payment ul.payment_methods > li{
  padding:18px 0 !important;
  border-bottom:1px solid var(--border) !important;
}
.woocommerce-checkout #payment ul.payment_methods > li:last-child{
  border-bottom:none !important;
}
.woocommerce-checkout #payment ul.payment_methods > li > label{
  display:flex !important;
  align-items:center;
  gap:12px;
  font-size:15px !important;
  font-weight:600 !important;
  color:var(--ink) !important;
  cursor:pointer;
}
.woocommerce-checkout #payment input[type="radio"]{
  accent-color:var(--terracotta);
}

/* Boîte interne des moyens de paiement */
.woocommerce-checkout #payment div.payment_box,
.woocommerce-checkout #payment .payment_box{
  background:#fff !important;
  border:1px solid var(--border) !important;
  border-radius:20px !important;
  padding:18px !important;
  margin:14px 0 4px 28px !important;
  box-shadow:0 10px 24px rgba(57,44,31,.05);
  color:var(--ink2) !important;
}
.woocommerce-checkout #payment div.payment_box::before,
.woocommerce-checkout #payment .payment_box::before{
  border-bottom-color:#fff !important;
}
.woocommerce-checkout #payment .payment_box p,
.woocommerce-checkout #payment .payment_box label,
.woocommerce-checkout #payment .payment_box legend{
  color:var(--ink2) !important;
}

/* Stripe / CB */
.woocommerce-checkout #payment .payment_method_stripe .payment_box,
.woocommerce-checkout #payment .payment_method_woocommerce_payments .payment_box,
.woocommerce-checkout #payment .payment_method_wc_stripe .payment_box,
.woocommerce-checkout #payment .payment_method_stripe_cc .payment_box{
  background:linear-gradient(180deg,#fff 0%, #fbf8f3 100%) !important;
}
.woocommerce-checkout #payment .payment_method_stripe .payment_box fieldset,
.woocommerce-checkout #payment .payment_method_woocommerce_payments .payment_box fieldset,
.woocommerce-checkout #payment .payment_method_wc_stripe .payment_box fieldset,
.woocommerce-checkout #payment .payment_method_stripe_cc .payment_box fieldset{
  border:1px solid var(--border) !important;
  border-radius:16px !important;
  padding:16px !important;
  background:var(--cream);
}
.woocommerce-checkout #payment .payment_method_stripe .payment_box fieldset legend,
.woocommerce-checkout #payment .payment_method_woocommerce_payments .payment_box fieldset legend,
.woocommerce-checkout #payment .payment_method_wc_stripe .payment_box fieldset legend,
.woocommerce-checkout #payment .payment_method_stripe_cc .payment_box fieldset legend{
  font-size:11px !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
  color:var(--ink3) !important;
  padding:0 10px !important;
}
.woocommerce-checkout #payment .StripeElement,
.woocommerce-checkout #payment .wc-stripe-elements-field,
.woocommerce-checkout #payment .wc-stripe-upe-element,
.woocommerce-checkout #payment div.woocommerce-SavedPaymentMethods-token,
.woocommerce-checkout #payment input.wc-credit-card-form-card-number,
.woocommerce-checkout #payment input.wc-credit-card-form-card-expiry,
.woocommerce-checkout #payment input.wc-credit-card-form-card-cvc{
  background:#fff !important;
  border:1.5px solid var(--border2) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
  box-shadow:none !important;
}
.woocommerce-checkout #payment .StripeElement--focus,
.woocommerce-checkout #payment .wc-stripe-elements-field:focus-within,
.woocommerce-checkout #payment .wc-stripe-upe-element:focus-within{
  border-color:var(--terracotta) !important;
  box-shadow:0 0 0 3px rgba(196,101,58,.10) !important;
}
.woocommerce-checkout #payment .wc-stripe-upe-form label,
.woocommerce-checkout #payment .wc-stripe-cc-form label,
.woocommerce-checkout #payment .payment_box .form-row label{
  font-size:11px !important;
  font-weight:700 !important;
  letter-spacing:.12em !important;
  text-transform:uppercase !important;
  color:var(--ink2) !important;
}
.woocommerce-checkout #payment .wc-stripe-payment-request-button,
.woocommerce-checkout #payment .payment_request,
.woocommerce-checkout #payment .google-pay-button,
.woocommerce-checkout #payment .apple-pay-button{
  border-radius:14px !important;
  overflow:hidden;
}

/* Klarna / autres wallets */
.woocommerce-checkout #payment .payment_method_klarna_payments .payment_box,
.woocommerce-checkout #payment .payment_method_klarna_checkout .payment_box,
.woocommerce-checkout #payment .payment_method_ppcp-gateway .payment_box,
.woocommerce-checkout #payment .payment_method_paypal .payment_box{
  background:#fff !important;
}
.woocommerce-checkout #payment .payment_method_klarna_payments > label img,
.woocommerce-checkout #payment .payment_method_klarna_checkout > label img,
.woocommerce-checkout #payment .payment_method_paypal > label img,
.woocommerce-checkout #payment .payment_method_stripe > label img,
.woocommerce-checkout #payment .payment_method_woocommerce_payments > label img{
  max-height:22px;
  width:auto;
  border-radius:8px;
}

/* Bouton final */
.woocommerce-checkout #payment #place_order{
  min-height:56px;
  border-radius:999px !important;
  font-size:14px !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
  box-shadow:0 12px 28px rgba(196,101,58,.18);
}

@media (max-width: 767px){
  .woocommerce-checkout #payment div.payment_box,
  .woocommerce-checkout #payment .payment_box{
    margin:12px 0 4px 0 !important;
    padding:14px !important;
    border-radius:16px !important;
  }
  .woocommerce-checkout #payment .payment_method_stripe .payment_box fieldset,
  .woocommerce-checkout #payment .payment_method_woocommerce_payments .payment_box fieldset,
  .woocommerce-checkout #payment .payment_method_wc_stripe .payment_box fieldset,
  .woocommerce-checkout #payment .payment_method_stripe_cc .payment_box fieldset{
    padding:12px !important;
    border-radius:14px !important;
  }
}
