/* =====================================================================
   Labe'l · Optimisations mobile partagées
   Améliore chaque page sans toucher au CSS inline des templates.
   ===================================================================== */

/* ---------- BURGER (caché en desktop, visible en mobile) ---------- */
.mb-burger{display:none;width:44px;height:44px;border-radius:12px;background:#fff;
  border:1px solid #ECE3D2;align-items:center;justify-content:center;cursor:pointer;
  padding:0;flex-shrink:0;transition:background .15s;font-family:inherit}
.mb-burger:hover{background:#FBF3E6}
.mb-burger span{position:relative;width:20px;height:2px;background:#111;border-radius:2px;
  transition:background .2s;display:block}
.mb-burger span::before,.mb-burger span::after{content:"";position:absolute;left:0;right:0;
  height:2px;background:#111;border-radius:2px;transition:transform .25s,top .25s}
.mb-burger span::before{top:-7px}
.mb-burger span::after{top:7px}
.mb-burger.on span{background:transparent}
.mb-burger.on span::before{top:0;transform:rotate(45deg)}
.mb-burger.on span::after{top:0;transform:rotate(-45deg)}

/* ---------- OVERLAY NAV PLEIN ÉCRAN ---------- */
.mb-nav{position:fixed;inset:0;background:#FBF3E6;z-index:998;
  transform:translateY(-100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);
  display:flex;flex-direction:column;padding:90px 32px 32px;overflow:auto}
.mb-nav.on{transform:translateY(0)}

/* Bouton fermer (X) */
.mb-close{position:absolute;top:18px;right:18px;width:44px;height:44px;
  border-radius:50%;background:#fff;border:1px solid #ECE3D2;display:flex;
  align-items:center;justify-content:center;cursor:pointer;padding:0;
  transition:background .15s, transform .15s;font-family:inherit;z-index:2}
.mb-close:hover{background:#D94466;border-color:#D94466;transform:rotate(90deg)}
.mb-close:hover .mb-close-bar{background:#fff}
.mb-close-bar{position:absolute;width:20px;height:2px;background:#111;
  border-radius:2px;transition:background .15s}
.mb-close-bar:nth-child(1){transform:rotate(45deg)}
.mb-close-bar:nth-child(2){transform:rotate(-45deg)}

.mb-nav ul.mb-list,.mb-nav ul.mb-sub{list-style:none;display:flex;flex-direction:column;gap:4px;margin:0;padding:0}
.mb-nav .mb-list > li > a{display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px;border-radius:14px;font-size:18px;font-weight:700;color:#111;
  background:#fff;border:1px solid #ECE3D2;transition:all .15s;letter-spacing:-.2px;text-decoration:none}
.mb-nav .mb-list > li > a:hover,.mb-nav .mb-list > li > a.active{background:#D94466;color:#fff;border-color:#D94466}
.mb-nav .mb-list > li > a::after{content:"\2192";opacity:.4;transition:transform .15s}
.mb-nav .mb-list > li > a:hover::after,.mb-nav .mb-list > li > a.active::after{opacity:1;transform:translateX(2px)}

/* Groupe accordéon (Boutique) */
.mb-group{display:flex;flex-direction:column;gap:4px}
.mb-group-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:18px 20px;border-radius:14px;font-size:18px;font-weight:700;color:#111;
  background:#fff;border:1px solid #ECE3D2;cursor:pointer;font-family:inherit;
  letter-spacing:-.2px;transition:all .15s;text-align:left}
.mb-group-trigger:hover{background:#FBF3E6}
.mb-group.open .mb-group-trigger{background:#D94466;color:#fff;border-color:#D94466;border-radius:14px 14px 0 0}
.mb-caret{display:inline-block;width:10px;height:10px;border:solid #111;
  border-width:0 2px 2px 0;transform:rotate(45deg);transition:transform .2s;margin-bottom:4px}
.mb-group.open .mb-caret{transform:rotate(-135deg);margin-bottom:-4px;border-color:#fff}

.mb-sub{max-height:0;overflow:hidden;transition:max-height .3s ease;
  background:#fff;border-radius:0 0 14px 14px;border:1px solid #ECE3D2;border-top:none;padding:0 !important}
.mb-group.open .mb-sub{max-height:500px;padding:8px !important}
.mb-sub li a{display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-radius:10px;font-size:15px;font-weight:600;color:#333;
  background:transparent;border:none;transition:all .15s;text-decoration:none;letter-spacing:.1px}
.mb-sub li a::after{content:"\2192";opacity:.4;transition:transform .15s;color:#D94466;font-weight:700}
.mb-sub li a:hover{background:#FDEFF1;color:#D94466}
.mb-sub li a:hover::after{opacity:1;transform:translateX(2px)}

.mb-nav .mb-foot{margin-top:auto;padding-top:30px;font-size:12px;color:#8a7a65;
  text-align:center;letter-spacing:.5px}

body.mb-lock{overflow:hidden}

/* ---------- BREAKPOINTS GLOBAUX ---------- */
@media (max-width:960px){
  .mb-burger{display:inline-flex}
  /* Réduit le padding du conteneur */
  .container{padding-left:20px;padding-right:20px}
  /* Cart button : on n'affiche pas le libellé "Votre panier" */
  .cart > span:first-child{display:none}
  .header-inner{gap:12px;justify-content:space-between}
  .nav{display:none !important}

  /* Mobile header :
     · logo à gauche
     · panier (juste le cercle rose avec icône + badge count) à gauche du burger
     · burger (dropdown) en haut à droite dans l'angle */
  .logo{order:1 !important;height:auto !important;max-height:none !important;overflow:visible !important}
  /* Logo agrandi visuellement sans modifier la hauteur du header.
     La boîte de l'image reste à 54px, seul le rendu est zoomé.
     Scale ajusté : 1.40625 (après réduction -10% depuis 1.5625) */
  .logo img{
    height:54px !important;
    width:auto !important;
    transform:scale(1.40625);
    transform-origin:left center;
  }
  .cart{
    order:2 !important;
    margin-left:auto !important;
    background:transparent !important;
    border:none !important;
    box-shadow:none !important;
    padding:0 !important;
    gap:0 !important;
    min-height:44px;
  }
  /* On garde le cercle rose d'origine (.bubble) avec le badge count */
  .mb-burger{order:3 !important}
  /* Hero plus compact */
  .hero{padding:30px 0 40px !important}
  .hero-title,h1.hero-title{font-size:clamp(36px,9vw,56px) !important;line-height:1.05 !important}
  .hero-script{font-size:clamp(32px,8vw,52px) !important}
  /* Products stacking */
  .products{grid-template-columns:repeat(2,1fr) !important;gap:14px !important}
  .section{padding:36px 0 !important}
  .section-title{font-size:26px !important}
  /* How grid */
  .how{padding:40px 0 !important}
  .how-grid{grid-template-columns:1fr 1fr !important;gap:22px !important}
  .how-intro h2{font-size:28px !important}
  /* Stats 2 colonnes */
  .stats-grid{grid-template-columns:repeat(2,1fr) !important;gap:16px !important}
  /* Heritage : image au-dessus, texte cartouche en dessous */
  .heritage-wrap{grid-template-columns:1fr !important}
  .heritage{background:var(--cream)}
  .heritage-full{display:flex;flex-direction:column}
  .heritage-full img{aspect-ratio:16/10;object-fit:cover;width:100%;height:auto}
  .heritage-overlay{position:static !important;display:block !important;padding:34px 0 40px !important;background:var(--cream)}
  .heritage-overlay > .container{padding:0 24px !important;pointer-events:auto !important}
  .heritage-text{max-width:none !important;pointer-events:auto !important}
  .heritage-text h2{font-size:30px !important;line-height:1.15 !important;letter-spacing:-.4px !important}
  .heritage-text h2 em{font-size:1.15em !important}
  .heritage-text p{margin-top:14px !important;font-size:15px !important;line-height:1.6 !important;color:#333}
  .heritage-text p br{display:none}
  .heritage-btn{margin-top:20px !important;padding:14px 24px !important;font-size:15px !important}
  /* Footer */
  .foot-grid{grid-template-columns:1fr 1fr !important;gap:24px !important}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:10px}
  /* Pro band stacking */
  .pro-inner{flex-direction:column;align-items:flex-start !important;gap:18px !important}
  .pro-inner .btn-outline-rose{width:100%;justify-content:center}
  /* CTA rose (pro.html) : titre équilibré, pas de saut forcé, pas de ? orphelin */
  .cta-section{padding:50px 0 !important}
  .cta-card{padding:44px 28px !important;border-radius:20px !important}
  .cta-card h2{font-size:32px !important;line-height:1.15 !important;letter-spacing:-.3px !important;text-wrap:balance;hyphens:none}
  .cta-card h2 br{display:none}
  .cta-card h2 em{font-size:1em !important}
  .cta-card p{font-size:15.5px !important;margin-top:14px !important;line-height:1.55 !important}
  .cta-actions{flex-direction:column !important;gap:10px !important}
  .cta-actions .btn{width:100%;justify-content:center}
  /* Cart-bar pro.html : empile en mobile */
  .cart-bar-inner{grid-template-columns:1fr !important;gap:12px !important;padding:12px 20px !important}
  .cart-cta{width:100%}
  .cart-cta .checkout{flex:1;justify-content:center}
}

@media (max-width:640px){
  .container{padding-left:16px;padding-right:16px}
  .products{grid-template-columns:1fr !important;gap:14px !important}
  .ribbon-inner{grid-template-columns:1fr !important}
  .how-grid{grid-template-columns:1fr !important}
  .stats-grid{grid-template-columns:1fr !important}
  /* CTA : encore plus compact sous 640px */
  .cta-card{padding:36px 20px !important;border-radius:18px !important}
  .cta-card h2{font-size:26px !important;line-height:1.18 !important}
  .cta-card p{font-size:14.5px !important;line-height:1.55 !important}
  .foot-grid{grid-template-columns:1fr !important;gap:20px !important}
  /* Footer allégé sur mobile : on masque les colonnes de liens (placeholders),
     on garde logo + copyright, réseaux sociaux et newsletter */
  .foot-grid > .foot-col:nth-of-type(2),
  .foot-grid > .foot-col:nth-of-type(3),
  .foot-grid > .foot-col:nth-of-type(4){display:none !important}
  /* Footer bottom : un seul lien suffit sur mobile */
  .foot-bottom ul{flex-wrap:wrap;gap:6px 10px}
  .section-head{flex-direction:column;align-items:flex-start !important;gap:10px}
  /* Logo plus petit */
  .logo img{height:54px !important}
  /* Header padding */
  .header{padding:14px 0 0 !important}
  /* Section titles */
  .section-title,.how-intro h2{font-size:24px !important;letter-spacing:-.4px !important}
  /* Heritage */
  .heritage-left{padding:22px !important}
  .heritage-left h2,.heritage-text h2{font-size:26px !important}
  .heritage-overlay{padding:28px 0 34px !important}
  .heritage-text p{font-size:14.5px !important}
  /* Stamp plus petit en mobile */
  .stamp{top:-10px !important;left:auto !important;right:10px !important;
    width:110px !important;height:110px !important;transform:none !important}
  /* Hero image fluide */
  .hero-photo{width:100% !important;height:auto !important;margin-left:0 !important;margin-top:0 !important}
  .hero-visual{min-height:260px !important}
  /* Mb-nav padding plus tight */
  .mb-nav{padding:80px 20px 24px}
  .mb-nav .mb-list > li > a,.mb-group-trigger{font-size:16px;padding:16px 18px}
  .mb-sub li a{font-size:14px;padding:12px 16px}
  .mb-close{top:14px;right:14px}
  /* Boutons partout : min 44px tactile */
  button,.btn,.btn-outline-rose,.heritage-btn{min-height:44px}
}

@media (max-width:420px){
  .hero{padding:24px 0 30px !important}
  .section{padding:28px 0 !important}
  .how{padding:30px 0 !important}
  /* Card image ratio plus mesuré */
  .card-img{height:180px !important}
  /* Cart bar pro ultra compact */
  .cart-summary{flex-direction:column;align-items:flex-start;gap:4px !important}
  .cart-summary .total{font-size:18px !important}
}

/* ---------- QUELQUES BLESSURES UX SYSTÉMIQUES ---------- */
/* Eviter les débordements horizontaux dus à la galerie ou aux images */
html,body{overflow-x:hidden}

/* Flèches décoratives pointillées : masquées en mobile (elles flottent mal entre les étapes empilées) */
@media (max-width:960px){
  .dash-arrow{display:none !important}
}
/* Touch targets plus lisibles */
@media (hover:none){
  .card:hover{transform:none !important}
  .card-link:hover .card-img{transform:none !important}
}

/* =====================================================================
   CORRECTIFS MOBILE SPÉCIFIQUES (pages maison, mode-d-emploi, produits)
   Ces classes ne sont pas gérées par les règles globales ci-dessus.
   ===================================================================== */

/* ---------- 960px : grandes tablettes / petits ordinateurs portables ---------- */
@media (max-width:960px){
  /* MAISON · hero, valeurs, histoire, promesse, newsletter */
  .qsm-hero-grid{grid-template-columns:1fr !important;gap:20px !important}
  .values-grid{grid-template-columns:repeat(2,1fr) !important;gap:18px !important}
  .story-grid{grid-template-columns:1fr !important;gap:22px !important}
  .story .side{position:static !important;top:auto !important}
  .promise-wrap{grid-template-columns:1fr !important;padding:40px 28px !important}
  .news-wrap{grid-template-columns:1fr !important;padding:36px 28px !important;gap:22px !important}

  /* PRODUIT · pair callout chocolat+pain */
  .pairing{grid-template-columns:1fr !important;row-gap:14px !important}
  .pairing img{width:100% !important;height:auto !important;aspect-ratio:16/10;object-fit:cover}
  .pairing .go{grid-column:1 / -1 !important;width:100% !important;justify-self:stretch !important;justify-content:center !important}

  /* MODE D'EMPLOI · bandeau de confiance */
  .trust{gap:16px !important;padding:18px 20px !important;flex-wrap:wrap !important}
  .trust span{font-size:11px !important}
}

/* ---------- 640px : grand mobile ---------- */
@media (max-width:640px){
  /* MAISON */
  .values-grid{grid-template-columns:1fr !important;gap:14px !important}
  .promise-wrap{padding:32px 20px !important}
  .news-wrap{padding:28px 20px !important}
  .pull-box{padding:32px 22px !important}
  .qsm-hero-grid .portrait{max-width:100% !important}
  .hero-title{font-size:clamp(30px,7vw,44px) !important}

  /* MODE D'EMPLOI · carte recette */
  .recipe-grid{grid-template-columns:1fr !important;gap:20px !important}
  .recipe-card{padding:22px 22px 18px !important}
  .recipe-media{height:170px !important;margin:12px 0 6px !important}
  .recipe-title{font-size:24px !important}
  .recipe-lede{max-width:100% !important;font-size:14px !important}
  .recipe-step p{font-size:14px !important}
  .recipe-foot{flex-wrap:wrap !important;gap:10px !important}
  .recipe-btn{padding:10px 16px !important;font-size:11px !important}
  .recipe-meta{font-size:11px !important}

  /* FICHE PRODUIT · bloc achat */
  .buy{flex-direction:column !important;align-items:stretch !important}
  .cta-buy{flex:1 1 auto !important;min-width:0 !important;width:100% !important;justify-content:center !important}
  .qty-pick{width:100% !important;justify-content:center !important}
  .gallery-thumbs{gap:8px !important}

  /* PRO · boutons CTA en colonne */
  .hero-cta{flex-direction:column !important;align-items:stretch !important;gap:10px !important}
  .hero-cta .btn{width:100% !important;justify-content:center !important}

  /* PRO · price-row plus compacte */
  .price-row .pro-cell{font-size:15px !important}
  .price-row .pub-cell{font-size:13px !important}
  .price-row .prod-cell{padding:14px 14px 12px !important}
  .terms-card{padding:26px 22px !important}
  .terms-card h3{font-size:22px !important}
}

/* ---------- 420px : très petit mobile ---------- */
@media (max-width:420px){
  /* FICHE PRODUIT · 2×2 au lieu de 4 colonnes pour les thumbnails */
  .gallery-thumbs{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}

  /* MODE D'EMPLOI */
  .recipe-card{padding:18px 16px 16px !important}
  .recipe-media{height:140px !important}
  .recipe-title{font-size:22px !important}
  .step-num{width:24px !important;height:24px !important;font-size:11px !important;flex-shrink:0}
  .step-row{gap:10px !important}

  /* MAISON */
  .pull-box{padding:26px 18px !important}
  .promise-wrap{padding:28px 18px !important}
  .news-wrap{padding:26px 18px !important}

  /* PRO · price-row ultra-compacte */
  .price-row .pro-cell{font-size:14px !important}
  .price-row .pub-cell{font-size:12px !important}
  .price-row .prod-cell .name{font-size:13px !important}
  .price-row .qty-group input{width:36px !important}
  .price-row .qty-group button{width:28px !important;height:28px !important}

  /* Logo plus compact */
  .logo img{height:48px !important}
}

/* ---------- Garanties systémiques : images et CTAs ne débordent jamais ---------- */
@media (max-width:960px){
  img{max-width:100%;height:auto}
  .btn,.cta-buy,.heritage-btn,.recipe-btn{max-width:100%}
}
