/* ======= PANIER — CSS specifique ======= */

/* Breadcrumb */
.breadcrumb{padding:15px 40px;font-size:13px;color:var(--gris);max-width:1400px;margin:0 auto}
.breadcrumb a{color:var(--gris);text-decoration:none;transition:.3s}
.breadcrumb a:hover{color:var(--rouge)}
.breadcrumb .sep{margin:0 8px;color:var(--gris2)}

/* Countdown expiration */
.panier-countdown{background:#FFF8E1;border:2px solid #FFE082;padding:14px 20px;margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:600;color:#F57F17;border-radius:8px}
.panier-countdown svg{width:20px;height:20px;stroke:#F57F17;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.panier-countdown .countdown-timer{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--rouge);letter-spacing:1px;min-width:55px;text-align:center}

/* Layout panier */
.panier-layout{display:grid;grid-template-columns:1fr 380px;gap:40px;max-width:1400px;margin:0 auto;padding:0 40px 60px;align-items:start}

/* Colonne gauche */
.panier-gauche{min-width:0;grid-column:1}

/* Resume a droite */
.panier-resume{grid-column:2;grid-row:1/3}

/* Upsells sous les articles, colonne gauche */
.upsell-section{grid-column:1}
.panier-titre{font-size:36px;letter-spacing:4px;margin-bottom:30px;display:flex;align-items:baseline;gap:10px}
.panier-titre .nb-articles{font-size:18px;color:var(--gris);font-family:'Roboto',sans-serif;font-weight:400;letter-spacing:0}

/* Article panier */
.panier-article{display:flex;gap:20px;padding:25px 0;border-bottom:1px solid var(--gris2);position:relative;transition:all .4s ease;overflow:hidden}
.panier-article.suppression{transform:translateX(-100%);opacity:0;max-height:0;padding:0;margin:0;border:none}
.panier-article-img{width:120px;height:120px;flex-shrink:0;border:2px solid var(--gris2);overflow:hidden;background:var(--gris3);border-radius:10px}
.panier-article-img img{width:100%;height:100%;object-fit:cover}
.panier-article-infos{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0}
.panier-article-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.panier-article-nom{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:1px;line-height:1.2}
.panier-article-suppr{background:none;border:none;cursor:pointer;color:var(--gris);transition:.3s;padding:5px;flex-shrink:0}
.panier-article-suppr:hover{color:var(--rouge)}
.panier-article-suppr svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.panier-article-taille{display:inline-block;background:var(--noir);color:#fff;padding:4px 12px;font-size:12px;font-weight:700;letter-spacing:1px;margin-top:6px;border-radius:4px}
.panier-article-prix{display:none}
.panier-article-economie{display:none}
.panier-article-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:8px}

/* Selecteur quantite — touch target 44x44 minimum */
.quantite-select{display:flex;align-items:center;border:2px solid var(--gris2);border-radius:8px;overflow:hidden}
.quantite-btn{width:44px;height:44px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--noir);transition:.3s;display:flex;align-items:center;justify-content:center;font-weight:700}
.quantite-btn:hover{background:var(--noir);color:#fff}
.quantite-btn:disabled{opacity:.3;cursor:not-allowed}
.quantite-btn:disabled:hover{background:none;color:var(--noir)}
.quantite-val{width:40px;text-align:center;font-size:15px;font-weight:700;font-family:'Roboto',sans-serif;border-left:2px solid var(--gris2);border-right:2px solid var(--gris2);display:flex;align-items:center;justify-content:center;height:44px}
.panier-article-total{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.panier-article-total .total-ancien{text-decoration:line-through;color:var(--gris);font-size:14px;font-family:'Roboto',sans-serif;font-weight:400;letter-spacing:0}
.panier-article-total .total-actuel{font-family:'Bebas Neue',sans-serif;font-size:26px;color:var(--rouge);letter-spacing:1px}

/* Barre livraison gratuite */
.livraison-barre{background:#fff;padding:22px 24px 18px;margin:20px 0;border:2px solid var(--gris2);position:relative;overflow:hidden;border-radius:10px}
.livraison-barre.atteinte{border-color:var(--vert);background:linear-gradient(135deg,#f0fff4,#e8f5e9)}
.livraison-barre-texte{font-size:15px;margin-bottom:14px;font-weight:600;display:flex;align-items:center;gap:10px;line-height:1.3}
.livraison-barre-texte svg{width:22px;height:22px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.livraison-barre-texte strong{color:var(--vert)}
.livraison-barre-texte .montant-restant{color:var(--rouge);font-weight:800;font-size:17px}
.livraison-progress-wrap{position:relative;padding-bottom:22px}
.livraison-barre-track{height:22px;background:var(--gris3);border-radius:11px;overflow:hidden;border:1px solid var(--gris2);position:relative}
.livraison-barre-fill{height:100%;border-radius:11px;transition:width 1s cubic-bezier(.25,.46,.45,.94);width:0;position:relative;overflow:hidden}
.livraison-barre-fill.fill-progress{background:linear-gradient(90deg,#FF6B6B,var(--rouge))}
.livraison-barre-fill.fill-atteinte{background:var(--vert)}
.livraison-barre-fill::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);animation:shineBar 2.5s ease-in-out infinite}
.livraison-barre-fill.fill-atteinte::after{animation:none}
.livraison-barre-label{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:800;color:#fff;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap}
.livraison-barre-label.label-outside{position:static;transform:none;color:var(--gris);text-shadow:none;margin-top:4px;text-align:right;font-size:12px}
.livraison-steps{display:flex;justify-content:space-between;position:absolute;bottom:0;left:0;right:0}
.livraison-step{font-size:11px;color:var(--gris);font-weight:600;position:relative}
.livraison-step.passed{color:var(--vert)}
.livraison-step::before{content:'';width:2px;height:6px;background:var(--gris2);position:absolute;top:-8px;left:50%;transform:translateX(-50%)}
.livraison-step.passed::before{background:var(--vert)}
.livraison-step:first-child::before,.livraison-step:last-child::before{display:none}
@keyframes shineBar{0%{left:-100%}50%{left:100%}100%{left:100%}}

/* Section upsell */
.upsell-section{margin-top:40px;padding-top:30px;border-top:2px solid var(--noir)}
.upsell-section h3{font-size:24px;letter-spacing:3px;margin-bottom:20px}
.upsell-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}
.upsell-card{border:2px solid var(--gris2);padding:15px;text-align:center;transition:.3s;border-radius:10px;overflow:hidden}
@media(hover:hover){.upsell-card:hover{border-color:var(--rouge);transform:translateY(-3px);box-shadow:0 8px 25px rgba(0,0,0,0.08)}}
.upsell-card-img{width:80px;height:80px;margin:0 auto 10px;background:var(--gris3);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:32px}
.upsell-card h4{font-size:13px;letter-spacing:1px;margin-bottom:6px;line-height:1.3}
.upsell-card .upsell-prix{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--rouge);margin-bottom:10px}
.upsell-card .btn-upsell{display:block;width:100%;padding:10px;background:var(--noir);color:#fff;border:none;font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:2px;cursor:pointer;transition:.3s;border-radius:8px}
@media(hover:hover){.upsell-card .btn-upsell:hover{background:var(--rouge)}}
.upsell-card .btn-upsell.ajoute{background:var(--vert);pointer-events:none}

/* Colonne droite — Resume */
.panier-resume{position:sticky;top:80px;border:2px solid var(--noir);padding:30px;background:#fff;border-radius:12px}
.resume-titre{font-size:24px;letter-spacing:3px;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid var(--noir)}
.resume-ligne{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px}
.resume-ligne.economie{color:var(--vert);font-weight:700}
.resume-ligne.economie span:last-child{font-family:'Bebas Neue',sans-serif;font-size:18px}
.resume-ligne .livraison-gratuit{color:var(--vert);font-weight:700}
.resume-ligne .livraison-payant{color:var(--noir);font-weight:600}
.resume-sep{height:2px;background:var(--noir);margin:15px 0}
.resume-total{display:flex;justify-content:space-between;align-items:center;padding:5px 0}
.resume-total span:first-child{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:2px}
.resume-total span:last-child{font-family:'Bebas Neue',sans-serif;font-size:36px;color:var(--rouge);letter-spacing:1px}

/* Code promo */
.promo-wrapper{margin-top:20px}
.promo-toggle{background:none;border:none;color:var(--gris);font-size:13px;cursor:pointer;text-decoration:underline;transition:.3s;padding:0;font-family:'Roboto',sans-serif}
.promo-toggle:hover{color:var(--rouge)}
.promo-form{display:none;margin-top:12px}
.promo-form.open{display:flex}
.promo-form input{flex:1;padding:12px 15px;border:2px solid var(--gris2);font-size:14px;outline:none;font-family:'Roboto',sans-serif;border-radius:8px 0 0 8px}
.promo-form input:focus{border-color:var(--noir)}
.promo-form button{padding:12px 20px;background:var(--noir);color:#fff;border:2px solid var(--noir);font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:2px;cursor:pointer;transition:.3s;white-space:nowrap;border-radius:0 8px 8px 0}
.promo-form button:hover{background:var(--rouge);border-color:var(--rouge)}
.promo-msg{font-size:12px;margin-top:8px;font-weight:600}
.promo-msg.succes{color:var(--vert)}
.promo-msg.erreur{color:var(--rouge)}
.resume-ligne.promo{color:var(--vert);font-weight:700}

/* Bouton commander */
.btn-commander{display:block;width:100%;padding:20px;background:var(--noir);color:#fff;font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:4px;border:none;cursor:pointer;transition:.3s;margin-top:20px;text-align:center;text-decoration:none;border-radius:10px}
@media(hover:hover){.btn-commander:hover{background:var(--rouge)}}

/* Social proof resume */
.resume-social-proof{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:12px;font-size:13px;color:var(--gris);line-height:1.3}
.resume-social-proof .tp-stars{display:inline-flex;gap:2px}
.resume-social-proof .tp-star{width:16px;height:16px;background:var(--vert);display:inline-flex;align-items:center;justify-content:center;border-radius:3px}
.resume-social-proof .tp-star svg{width:10px;height:10px;fill:#fff}

/* Badges confiance */
.resume-badges{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}
.resume-badge{display:flex;align-items:center;gap:8px;padding:10px;border:1px solid var(--gris2);font-size:11px;line-height:1.3;border-radius:8px}
.resume-badge svg{width:18px;height:18px;flex-shrink:0;stroke:var(--noir);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.resume-badge strong{display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px}

/* Moyens de paiement */
.resume-paiements{display:flex;justify-content:center;gap:12px;margin-top:18px;padding-top:15px;border-top:1px solid var(--gris2)}
.resume-paiement-icon{width:42px;height:28px;border:1px solid var(--gris2);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--gris);background:#fff}
.resume-securite{text-align:center;font-size:11px;color:var(--gris);margin-top:12px;line-height:1.4}

/* Panier vide */
.panier-vide{text-align:center;padding:80px 20px;max-width:500px;margin:0 auto}
.panier-vide-icon{font-size:64px;margin-bottom:20px;opacity:.3}
.panier-vide h2{font-size:36px;letter-spacing:3px;margin-bottom:10px}
.panier-vide p{color:var(--gris);font-size:15px;margin-bottom:30px;line-height:1.6}
.panier-vide .btn-decouvrir{display:inline-block;background:var(--noir);color:#fff;padding:18px 50px;font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:4px;text-decoration:none;transition:.3s;border-radius:8px}
@media(hover:hover){.panier-vide .btn-decouvrir:hover{background:var(--rouge)}}

/* Produits suggeres */
.suggestions-section{max-width:1400px;margin:0 auto;padding:60px 40px}
.sug-dots{display:none}
.suggestions-section h2{font-size:36px;letter-spacing:4px;margin-bottom:30px;position:relative;display:inline-block}
.suggestions-section h2::after{content:'';position:absolute;bottom:-5px;left:0;width:100%;height:4px;background:var(--rouge)}
.suggestions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.sug-card{border:2px solid var(--gris2);overflow:hidden;cursor:pointer;transition:.3s;text-decoration:none;color:var(--noir);display:block;border-radius:10px}
.sug-card img{width:100%;aspect-ratio:1;object-fit:cover;border-bottom:2px solid var(--gris2);transition:.3s}
@media(hover:hover){
.sug-card:hover{border-color:var(--rouge);transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,0.1)}
.sug-card:hover img{border-bottom-color:var(--rouge)}
}
.sug-card-info{padding:15px}
.sug-card-info h4{font-size:13px;letter-spacing:1px;margin-bottom:6px;line-height:1.3}
.sug-card-prix{display:flex;align-items:center;gap:8px}
.sug-card-prix .old{text-decoration:line-through;color:var(--gris);font-size:13px}
.sug-card-prix .new{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--rouge)}

/* Garanties */
.garanties-strip{background:var(--gris3);padding:40px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.gar-item .gar-icon{width:36px;height:36px;margin:0 auto 10px;color:var(--noir)}
.gar-item .gar-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.gar-item h4{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:2px;margin-bottom:4px}
.gar-item p{color:var(--gris);font-size:12px}

/* Barre fixe mobile (total + CTA) */
.mobile-checkout-bar{display:none}

/* ======= RESPONSIVE ======= */
@media(max-width:1024px){
.panier-layout{grid-template-columns:1fr 340px;gap:30px}
.suggestions-grid{grid-template-columns:repeat(3,1fr)}
.upsell-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
.breadcrumb{padding:16px 15px 8px;font-size:12px}

/* Bloquer tout scroll horizontal */
body{overflow-x:hidden}

/* Layout 1 colonne */
.panier-layout{grid-template-columns:1fr;padding:0 15px 90px;gap:0;overflow:hidden}
.panier-gauche{min-width:0}
.panier-resume{position:static;grid-column:1;grid-row:auto;background:var(--gris3);border:2px solid var(--gris2);border-radius:12px;padding:20px 18px;margin-top:24px}
.upsell-section{grid-column:1;margin-top:28px;padding-top:22px;border-top:1px solid var(--gris2)}

/* Titre */
.panier-titre{font-size:24px;margin-bottom:8px;margin-top:8px}

/* Countdown */
.panier-countdown{margin-bottom:16px}

/* Articles */
.panier-article{gap:14px;padding:18px 0;border-bottom:1px solid var(--gris2)}
.panier-article-img{width:90px;height:90px;flex-shrink:0}
.panier-article-nom{font-size:14px;line-height:1.3}
.panier-article-taille{padding:3px 10px;font-size:11px;margin-top:6px}
.panier-article-bottom{margin-top:10px}
.panier-article-total .total-ancien{font-size:12px}
.panier-article-total .total-actuel{font-size:22px}

/* Touch targets mobile */
.quantite-btn{width:44px;height:44px;font-size:16px}
.quantite-val{width:38px;height:44px;font-size:13px}

/* Barre livraison simplifiee mobile */
.livraison-barre{padding:12px 15px;margin:12px 0;border:none;border-radius:8px;background:var(--gris3)}
.livraison-barre.atteinte{background:linear-gradient(135deg,#f0fff4,#e8f5e9)}
.livraison-barre-texte{font-size:13px;margin-bottom:8px}
.livraison-barre-texte .montant-restant{font-size:14px}
.livraison-progress-wrap{padding-bottom:0}
.livraison-barre-track{height:8px;border-radius:4px;border:none}
.livraison-barre-fill{border-radius:4px}
.livraison-barre-label{display:none}
.livraison-steps{display:none}

/* Resume compact */
.resume-titre{font-size:20px;margin-bottom:14px;padding-bottom:12px;border-bottom:2px solid var(--noir)}
.resume-ligne{padding:6px 0;font-size:13px}
.resume-total span:first-child{font-size:18px}
.resume-total span:last-child{font-size:28px}
.resume-sep{margin:12px 0}
.resume-badges{margin-top:14px}
.btn-commander{display:none}
.resume-paiements{display:none}
.resume-securite{display:none}
.resume-social-proof{display:none}

/* Upsells compact */
.upsell-section h3{font-size:18px;margin-bottom:12px}
.upsell-grid{grid-template-columns:repeat(3,1fr);gap:10px}
.upsell-card{padding:10px}
.upsell-card-img{width:45px;height:45px;margin-bottom:6px;font-size:22px}
.upsell-card h4{font-size:10px;letter-spacing:.3px;margin-bottom:4px}
.upsell-card .upsell-prix{font-size:16px;margin-bottom:6px}
.upsell-card .btn-upsell{padding:7px;font-size:10px;letter-spacing:1px}

/* Suggestions — slider horizontal mobile */
.suggestions-section{padding:16px 15px 30px}
.suggestions-section h2{font-size:22px;margin-bottom:16px}
.suggestions-grid{display:flex !important;grid-template-columns:none !important;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:8px;flex-wrap:nowrap}
.suggestions-grid::-webkit-scrollbar{display:none}
.sug-card{width:calc(50% - 6px);min-width:calc(50% - 6px);max-width:calc(50% - 6px);flex-shrink:0;scroll-snap-align:start}
.sug-card img{width:100%;aspect-ratio:1;object-fit:cover}
.sug-card-info{padding:10px 12px}
.sug-card-info h4{font-size:11px}
.sug-card-prix .new{font-size:20px}
/* Dots du slider suggestions */
.sug-dots{display:flex;justify-content:center;gap:8px;margin-top:14px}
.sug-dot{width:8px;height:8px;border-radius:50%;background:var(--gris2);border:none;padding:0;cursor:pointer;transition:.3s}
.sug-dot.active{background:var(--rouge);width:22px;border-radius:4px}

/* Garanties 2 colonnes */
.garanties-strip{grid-template-columns:repeat(2,1fr);padding:25px 15px;gap:15px}
.gar-item h4{font-size:13px}

/* BARRE FIXE EN BAS */
.mobile-checkout-bar{display:flex;flex-direction:column;position:fixed;bottom:0;left:0;right:0;z-index:900;background:#fff;border-top:2px solid var(--noir);padding:12px 15px calc(env(safe-area-inset-bottom,0px) + 8px);gap:8px;box-shadow:0 -6px 24px rgba(0,0,0,0.12);-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}
.mobile-checkout-top{display:flex;align-items:center;gap:12px}
.mobile-checkout-total{flex-shrink:0}
.mobile-checkout-total small{display:block;font-family:'Roboto',sans-serif;font-size:11px;color:var(--gris);font-weight:400;letter-spacing:0;line-height:1}
.mobile-checkout-total .mobile-amount{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--rouge);letter-spacing:1px;line-height:1.2}
.mobile-checkout-btn{flex:1;background:var(--noir);color:#fff;border:none;padding:15px 20px;font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:3px;cursor:pointer;transition:.3s;text-align:center;border-radius:10px}
.mobile-checkout-btn:active{background:var(--rouge)}
@media(hover:hover){.mobile-checkout-btn:hover{background:var(--rouge)}}
.mobile-checkout-trust{display:flex;align-items:center;justify-content:center;gap:4px;font-size:11px;color:var(--gris);font-weight:400;letter-spacing:.2px}
.mobile-checkout-trust svg.lock-icon{width:13px;height:13px;flex-shrink:0;color:var(--vert)}
.mobile-checkout-trust .trust-methods{color:var(--noir);font-weight:600;font-size:11px}
}
@media(max-width:480px){
.panier-article-img{width:75px;height:75px}
.panier-article-bottom{flex-wrap:wrap;gap:8px}
.mobile-checkout-bar{padding:10px 12px calc(env(safe-area-inset-bottom,0px) + 6px)}
.mobile-checkout-total .mobile-amount{font-size:22px}
.mobile-checkout-btn{font-size:15px;padding:13px 15px;letter-spacing:2px}
}
