:root{
  --paper:#f7f5ef; --ink:#1a1916; --ink-2:#26241f; --ink-d:#141311;
  --ac:#cf6336; --ac-tint:#fbf1ea; --ac-border:#f0c4a8; --ac-hover:#f4d4be; --dispo:#3a4d3f;
  --line:#e6e2d8; --line-2:#eceae3; --mut:#6f6b61; --mut-2:#9b958a;
  --mono:'Space Mono',monospace; --disp:'Bricolage Grotesque',sans-serif; --body:'Archivo',system-ui,sans-serif;
  --wrap:1240px;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 40px}
.eyebrow{font:700 12px var(--mono);letter-spacing:.16em;color:var(--ac);text-transform:uppercase}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--ac);color:#fff;border:none;border-radius:7px;padding:11px 20px;font:600 13.5px var(--body);cursor:pointer}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
h1,h2,h3{font-family:var(--disp);font-weight:700;letter-spacing:-.02em;color:var(--ink);margin:0}

/* ====== HEADER ====== */
.site-header{position:sticky;top:0;z-index:40;background:#f7f5efee;backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
.hdr{height:74px;display:flex;align-items:center;justify-content:space-between}
.wordmark{font:700 16px var(--mono);letter-spacing:.10em;color:var(--ink);border:2px solid var(--ink);padding:7px 12px}
.hdr-nav{display:flex;align-items:center;gap:30px}
.hdr-nav a{font:600 13.5px var(--body);color:#33312c}
.hdr-tools{display:flex;align-items:center;gap:16px}
.hdr-cart{width:40px;height:40px;border:1.5px solid #d8d3c8;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px}
.lang{font:700 11px var(--mono);letter-spacing:.05em;border:1px solid #46433c;border-radius:20px;padding:3px 11px;color:var(--ink)}

/* ====== FOOTER ====== */
.site-footer{margin-top:64px;background:var(--ink-d);color:#bdb8ac}
.ftr-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-top:56px;padding-bottom:30px}
.ftr-wordmark{font:700 15px var(--mono);letter-spacing:.10em;color:#fff;border:2px solid #46433c;padding:7px 12px;display:inline-block}
.ftr-tagline{font:400 13.5px/1.6 var(--body);color:#9b958a;max-width:300px;margin:16px 0 22px}
.ftr-info{display:flex;gap:34px}
.ftr-label{font:700 9.5px var(--mono);letter-spacing:.1em;color:#6c675d}
.ftr-value{font:500 13px var(--body);color:#e0dbcf;margin-top:5px}
.ftr-col{display:flex;flex-direction:column;gap:0}
.ftr-col-title{font:700 12px var(--body);color:#fff;margin-bottom:14px}
.ftr-col a{font:400 13px var(--body);color:#9b958a;margin-bottom:10px}
.ftr-legal{border-top:1px solid #2a2824}
.ftr-legal .wrap{padding-top:18px;padding-bottom:18px;font:400 11.5px var(--body);color:#6c675d}

/* ====== HERO ====== */
.hero{position:relative;overflow:hidden}
.hero__bg{height:600px;background:linear-gradient(105deg,rgba(18,16,14,.82) 0%,rgba(18,16,14,.45) 48%,rgba(18,16,14,.12) 100%),repeating-linear-gradient(46deg,#2a2823 0 15px,#322f29 15px 30px)}
.hero__content{position:absolute;top:0;left:50%;transform:translateX(-50%);height:600px;display:flex;align-items:center;width:100%}
.hero__text{max-width:680px}
.hero__eyebrow{color:var(--ac);margin:0 0 16px}
.hero__title{font-size:clamp(40px,6vw,74px);font-weight:800;line-height:.96;letter-spacing:-.025em;color:#fff;margin:0 0 20px}
.hero__sub{font:400 17px/1.55 var(--body);color:#e3ddd0;max-width:520px;margin:0}
.hero__search-wrap{position:relative;z-index:5;margin-top:-46px}

/* ====== RECHERCHE (date-search floating card) ====== */
.recherche{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 44px -18px rgba(26,25,22,.40);padding:14px}
.recherche__form{display:flex;align-items:stretch;gap:6px}
.recherche__field{flex:1;padding:12px 18px;border-radius:9px}
.recherche__label{display:block;font:700 10px var(--mono);letter-spacing:.1em;color:#a39e92;margin-bottom:3px}
.recherche__input{width:100%;border:none;outline:none;font:600 15px var(--body);color:var(--ink);background:transparent;cursor:pointer}
.recherche__sep{width:1px;background:#ece8de;margin:8px 0}
.recherche__btn{border-radius:9px;padding:0 28px;height:auto;align-self:stretch;font:600 15px var(--body)}

/* ====== TRUST STRIP ====== */
.trust{display:flex;gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:34px}
.trust__item{flex:1;padding:20px 22px;display:flex;align-items:center;gap:12px;border-right:1px solid var(--line);font:500 13px var(--body);color:#4a463e}
.trust__item:last-child{border-right:none}
.trust__diamond{width:7px;height:7px;background:var(--ac);transform:rotate(45deg);display:inline-block;flex-shrink:0}

/* ====== SECTIONS (generic) ====== */
.sec{margin-top:84px}
.sec__hdr{margin-bottom:30px}
.sec__hdr .eyebrow{display:block;margin-bottom:10px}
.sec-h{font-size:clamp(28px,3.5vw,42px);font-weight:700}
.sec__link-wrap{margin-top:24px;text-align:right}
.sec__link{font:600 14px var(--body);color:var(--ink);border-bottom:2px solid var(--ac);padding-bottom:3px}

/* ====== PACKS GRID ====== */
.grille-packs{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}

/* ====== CARTE PACK ====== */
.carte-pack{background:#fff;border:1px solid #ebe7dd;border-radius:13px;overflow:hidden}
.carte-pack__inner{display:block;text-decoration:none;color:inherit}
.carte-pack__img-wrap{position:relative;aspect-ratio:4/3;background:repeating-linear-gradient(44deg,#efece4 0 10px,#e6e2d9 10px 20px)}
.carte-pack__img{width:100%;height:100%;object-fit:cover;display:block}
.carte-pack__img-placeholder{width:100%;height:100%}
.carte-pack__body{padding:15px 16px 17px}
.carte-pack__composants{display:block;font:700 10px var(--mono);letter-spacing:.08em;color:var(--mut-2);margin:0 0 5px;text-transform:uppercase}
.carte-pack__nom{font:600 15.5px var(--body);color:var(--ink);line-height:1.25;margin:0 0 12px;min-height:38px}
.carte-pack__prix{display:flex;align-items:baseline;gap:4px;margin:0}
.carte-pack__prix-val{font-family:var(--disp);font-weight:700;font-size:21px;color:var(--ac)}
.carte-pack__prix-unit{font:400 12px var(--body);color:var(--mut-2)}

/* ====== CATEGORIES GRID ====== */
.grille-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:0}
.cat-pill{display:flex;align-items:center;justify-content:space-between;gap:8px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 18px;text-decoration:none;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.cat-pill:hover{border-color:var(--ac);box-shadow:0 4px 16px -6px rgba(207,99,54,.25)}
.cat-pill__nom{font:600 14px var(--body);color:var(--ink)}
.cat-pill__arrow{font-size:14px;color:var(--ac)}

/* ====== CATALOGUE PAGE ====== */
.catalogue-page{padding-bottom:80px}
.breadcrumb{display:flex;align-items:center;gap:8px;padding:18px 0 12px;font:500 11.5px var(--mono);color:var(--mut)}
.breadcrumb a{color:var(--mut);text-decoration:none}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb__sep{color:var(--line)}
.catalogue-hdr{display:flex;align-items:flex-end;justify-content:space-between;padding:0 0 18px;border-bottom:1px solid var(--line)}
.catalogue-hdr__titre{font-size:clamp(20px,3vw,28px);font-weight:700}
.catalogue-hdr__count{font:400 12.5px var(--body);color:var(--mut);margin:4px 0 0}

/* Catalogue body: sidebar + grid */
.catalogue-body{display:flex;gap:0;border-top:1px solid var(--line)}

/* Filter sidebar */
.catalogue-filtres{width:200px;flex-shrink:0;padding:22px 18px 22px 0;border-right:1px solid var(--line);background:var(--paper)}
.catalogue-filtres__titre{font:700 12px var(--body);color:var(--ink);margin:0 0 12px;text-transform:uppercase;letter-spacing:.06em}
.catalogue-filtres__liste{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.catalogue-filtre-lien{display:block;padding:7px 10px;border-radius:6px;font:500 13px var(--body);color:var(--mut);text-decoration:none;transition:background .12s,color .12s}
.catalogue-filtre-lien:hover{background:var(--ac-tint);color:var(--ink)}
.catalogue-filtre-lien--actif{background:var(--ac-tint);color:var(--ac);font-weight:600}

/* Product grid area */
.catalogue-grille{flex:1;padding:22px 0 0 28px;display:flex;flex-direction:column;gap:40px}
.catalogue-section__titre{display:block;margin-bottom:16px}
.catalogue-vide{font:400 14px var(--body);color:var(--mut);padding:20px 0}

/* Articles grid */
.grille-articles{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}

/* ====== CARTE ARTICLE ====== */
.carte-art{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:8px;overflow:hidden;text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s}
.carte-art:hover{border-color:var(--ac);box-shadow:0 4px 16px -6px rgba(207,99,54,.20)}
.carte-art__img{position:relative;height:84px;background:repeating-linear-gradient(45deg,#edebe6 0 9px,#e3e1da 9px 18px)}
.badge-dispo{position:absolute;top:6px;left:6px;font:700 9.5px var(--mono);color:#fff;background:var(--dispo);padding:2px 7px;border-radius:10px;letter-spacing:.04em}
.badge-complet{position:absolute;top:6px;left:6px;font:700 9.5px var(--mono);color:#fff;background:#8a8a8a;padding:2px 7px;border-radius:10px;letter-spacing:.04em}
.is-complet{opacity:.55;filter:grayscale(.4)}
.is-complet:hover{border-color:var(--line);box-shadow:none}
.carte-art__body{padding:9px 10px 11px}
.carte-art__nom{font:700 10px var(--mono);color:var(--mut-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.carte-art__pied{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.carte-art__prix{font:700 13px var(--disp);color:var(--ac)}
.carte-art__prix small{font-weight:400;color:var(--mut-2);font-size:10px}
.carte-art__voir{border:1.5px solid var(--ink);border-radius:5px;padding:3px 9px;font:600 11px var(--body);color:var(--ink)}

/* ====== PRODUIT PAGE ====== */
.produit-page{padding-bottom:80px}
.produit-layout{display:grid;grid-template-columns:1fr 380px;gap:48px;margin-top:24px;align-items:start}
.produit-titre{font-size:clamp(24px,3.5vw,36px);font-weight:700;margin:24px 0 12px}
.produit-desc{font:400 15px/1.6 var(--body);color:var(--ink-2);margin:0 0 24px}

/* Gallery */
.produit-galerie__main{width:100%;aspect-ratio:4/3;background:repeating-linear-gradient(45deg,#edebe6 0 10px,#e3e1da 10px 20px);border-radius:10px;overflow:hidden}
.produit-galerie__main--placeholder{background:repeating-linear-gradient(44deg,#efece4 0 12px,#e6e2d9 12px 24px)}
.produit-galerie__img{width:100%;height:100%;object-fit:cover;display:block}
.produit-galerie__thumbs{display:flex;gap:8px;margin-top:10px}
.produit-galerie__thumb{width:72px;height:72px;background:repeating-linear-gradient(44deg,#efece4 0 8px,#e6e2d9 8px 16px);border-radius:6px;flex-shrink:0}

/* Pack composants list */
.pack-composants{list-style:none;margin:0 0 20px;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.pack-composants__item{display:block}
.pack-composants__lien{display:inline-block;background:var(--ac-tint);color:var(--ac);border:1px solid var(--ac-border);border-radius:6px;padding:5px 12px;font:600 12.5px var(--body);text-decoration:none}
.pack-composants__lien:hover{background:var(--ac-hover)}

/* Cross-sell */
.xsell{margin-top:28px;padding-top:20px;border-top:1px solid var(--line)}
.xsell__titre{margin:0 0 12px}
.xsell__liens{display:flex;flex-wrap:wrap;gap:8px}
.xsell__lien{display:inline-block;border:1.5px solid var(--ink);border-radius:6px;padding:6px 14px;font:600 12.5px var(--body);color:var(--ink);text-decoration:none}
.xsell__lien:hover{border-color:var(--ac);color:var(--ac)}

/* ====== CARTE DEVIS ====== */
.carte-devis{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 28px -12px rgba(26,25,22,.12)}
.mono-lab{font:700 10px var(--mono);letter-spacing:.1em;color:var(--mut-2);text-transform:uppercase}
.carte-devis input[type="text"]{width:100%;border:1.5px solid var(--line);border-radius:8px;padding:10px 14px;font:500 14px var(--body);color:var(--ink);background:var(--paper);outline:none}
.carte-devis input[type="text"]:focus{border-color:var(--ac)}

/* Tailles */
.tailles{display:flex;flex-wrap:wrap;gap:6px}
.sz{width:42px;height:42px;border:1.5px solid var(--line);border-radius:7px;background:#fff;font:600 13px var(--body);color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .12s,background .12s}
.sz:hover{border-color:var(--ac);color:var(--ac)}
.sz.selected{border-color:var(--ac);background:var(--ac);color:#fff}

/* Dispo */
.dispo{padding:10px 14px;border-radius:8px;font:500 13px var(--body)}

/* Recap */
.recap{display:flex;flex-direction:column;gap:10px;background:var(--ac-tint);border-radius:8px;padding:14px}
.recap-l{display:flex;justify-content:space-between;align-items:center;font:400 13px var(--body);color:var(--ink)}
.recap-tot{font-weight:700;font-size:15px;border-top:1px solid var(--ac-border);padding-top:10px;margin-top:2px}
.recap-g{display:flex;align-items:center;gap:8px;font:400 12.5px var(--body);color:var(--ink);cursor:pointer}

/* CTA button */
.carte-devis .btn.cta{width:100%;justify-content:center;padding:13px;font-size:14.5px}
.carte-devis .btn.cta:disabled{opacity:.45;cursor:not-allowed}
.note{font:400 12px var(--body);color:var(--mut);margin:0;text-align:center;min-height:16px}

/* ====== HEADER CART COUNTER ====== */
.hdr-cart{position:relative}
.hdr-cart__n{position:absolute;top:-6px;right:-6px;background:var(--ac);color:#fff;font:700 10px var(--mono);min-width:17px;height:17px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 3px}

/* ====== PANIER PAGE ====== */
.panier-page{padding-bottom:80px}
.panier-titre{font-size:clamp(22px,3vw,32px);font-weight:700;margin:24px 0 20px}
.panier-vide{font:400 15px var(--body);color:var(--mut);margin:40px 0}
.panier-dates{font:400 13.5px var(--body);color:var(--ink);margin:0 0 20px;padding:12px 16px;background:var(--ac-tint);border-radius:8px;border:1px solid var(--ac-border)}
.panier-layout{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.panier-lignes{display:flex;flex-direction:column;gap:12px}
.panier-ligne{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 16px}
.panier-ligne--indispo{border-color:#e8a8a8;background:#fff8f8}
.panier-ligne__info{flex:1;display:flex;flex-direction:column;gap:3px}
.panier-ligne__nom{font:600 14.5px var(--body);color:var(--ink)}
.panier-ligne__taille,.panier-ligne__garantie{font:400 12px var(--body);color:var(--mut)}
.panier-ligne__indispo{font:700 11px var(--mono);color:#c0392b;text-transform:uppercase;letter-spacing:.04em}
.panier-ligne__prix{font:600 14px var(--disp);color:var(--ac);white-space:nowrap}
.panier-retirer{background:none;border:none;color:var(--mut);font:400 12.5px var(--body);cursor:pointer;padding:4px 8px;border-radius:5px;transition:color .12s,background .12s}
.panier-retirer:hover{color:#c0392b;background:#fff0f0}
.panier-vider-form{margin-top:8px}
.panier-vider-btn{font-size:12.5px;padding:8px 14px}
.panier-recap{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 28px -12px rgba(26,25,22,.10);position:sticky;top:90px}
.panier-indispo-msg{font:400 12.5px var(--body);color:#c0392b;margin:0;padding:10px 14px;background:#fff8f8;border:1px solid #e8a8a8;border-radius:7px}
.panier-cta{width:100%;justify-content:center;padding:13px;font-size:14.5px;text-align:center;text-decoration:none;display:flex}
.panier-cta--disabled{opacity:.45;pointer-events:none;cursor:not-allowed}

/* ====== FLASH MESSAGES ====== */
.flash{padding:12px 18px;border-radius:8px;font:500 14px var(--body);margin:16px 0 0}
.flash--error,.flash--erreur{background:#fff2f2;color:#8b1a1a;border:1px solid #f0b4b4}
.flash--success{background:#f2faf4;color:#1a5e2e;border:1px solid #a8dbb8}
.flash--warning{background:#fffbf0;color:#7a5200;border:1px solid #f0d888}
.flash--info{background:#f0f5ff;color:#1a3a7a;border:1px solid #a8c0f0}

/* ====== CHECKOUT PAGE ====== */
.checkout-page{padding-bottom:80px}
.checkout-titre{font-size:clamp(22px,3vw,32px);font-weight:700;margin:24px 0 8px}
.checkout-retrait{font:500 13.5px var(--body);color:var(--mut);margin:0 0 28px;padding:10px 16px;background:var(--ac-tint);border:1px solid var(--ac-border);border-radius:8px;display:inline-block}
.checkout-form{max-width:520px;display:flex;flex-direction:column;gap:20px}
.checkout-form .form-group{display:flex;flex-direction:column;gap:6px}
.checkout-form .form-group label{font:700 11px var(--mono);letter-spacing:.1em;color:var(--mut-2);text-transform:uppercase}
.checkout-form .form-group input{border:1.5px solid var(--line);border-radius:8px;padding:11px 14px;font:500 14.5px var(--body);color:var(--ink);background:#fff;outline:none;transition:border-color .15s}
.checkout-form .form-group input:focus{border-color:var(--ac)}
.checkout-submit{width:100%;justify-content:center;padding:14px;font-size:15px;margin-top:4px}

/* ====== PAIEMENT PAGE ====== */
.paiement-page{padding-bottom:80px}
.paiement-titre{font-size:clamp(22px,3vw,32px);font-weight:700;margin:24px 0 24px}
.paiement-recap{max-width:560px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px 30px;box-shadow:0 8px 28px -12px rgba(26,25,22,.10)}
.paiement-details{margin:0 0 24px;padding:0;display:flex;flex-direction:column;gap:16px}
.paiement-details dt{font:700 10.5px var(--mono);letter-spacing:.1em;color:var(--mut-2);text-transform:uppercase;margin:0}
.paiement-details dd{font:500 15px var(--body);color:var(--ink);margin:4px 0 0}
.paiement-reference{font:700 22px var(--mono);color:var(--ac);letter-spacing:.06em;background:var(--ac-tint);border:1px solid var(--ac-border);border-radius:7px;padding:8px 14px;display:inline-block;margin-top:6px}
.paiement-a-venir{font:400 13.5px var(--body);color:var(--mut);margin:0;padding:14px 16px;background:var(--line-2);border-radius:8px;border:1px solid var(--line)}

/* ====== CONFIRMATION PAGE ====== */
.confirmation-page{padding-bottom:80px}
.confirmation-card{max-width:480px;margin:40px auto;background:#fff;border-radius:4px;box-shadow:0 2px 10px rgba(40,35,30,.10);overflow:hidden;text-align:center;padding:30px 26px}
.confirmation-icon{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font:26px var(--body);margin:0 auto}
.confirmation-icon--ok{background:var(--dispo);color:#fff}
.confirmation-icon--attente{background:var(--ac-tint);color:var(--ac);font-size:28px}
.confirmation-heading{font:700 21px var(--disp);color:var(--ink-2);margin:14px 0 0}
.confirmation-sub{font:400 12.5px var(--body);color:var(--mut);margin:4px 0 0}
.confirmation-ref{font:13px var(--mono);color:var(--ac);margin:8px 0 0}
.confirmation-ref__val{font-weight:700;letter-spacing:.04em}
.confirmation-encart{text-align:left;border:1px solid var(--line-2);border-radius:9px;padding:15px;margin-top:18px}
.confirmation-encart__titre{font:700 12.5px var(--body);color:var(--ink-2);margin-bottom:8px}
.confirmation-encart__lieu{font:500 13px var(--body);color:var(--ink-2)}
.confirmation-encart__dates{font:400 12px var(--body);color:var(--mut);margin-top:2px}
.confirmation-encart__total{font:700 13px var(--mono);color:var(--mut-2);margin-top:8px}

/* ── Pages de contenu ─────────────────────────────────── */
.page-wrap {
  max-width: 760px;
  padding-top: 3rem;
  padding-bottom: 4rem;
}

.page-titre {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 800;
  margin-bottom: 2rem;
  color: var(--ink);
}

.page-contenu h2 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  margin-top: 2rem;
  margin-bottom: .5rem;
  color: var(--ink);
}

.page-contenu p {
  margin-bottom: 1rem;
  line-height: 1.7;
  color: var(--mut);
}

.page-contenu a {
  color: var(--ac);
  text-decoration: underline;
}

/* ====== IMAGES PRODUITS ====== */

/* Carte article : image couvrant le placeholder */
.carte-art__img{position:relative;height:84px;background:repeating-linear-gradient(45deg,#edebe6 0 9px,#e3e1da 9px 18px);overflow:hidden}
.carte-art__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* Galerie produit : vignettes composants pack */
.produit-galerie__thumb{width:72px;height:72px;background:repeating-linear-gradient(44deg,#efece4 0 8px,#e6e2d9 8px 16px);border-radius:6px;flex-shrink:0;overflow:hidden;display:block;border:1.5px solid var(--line);transition:border-color .15s}
.produit-galerie__thumb:hover{border-color:var(--ac)}
.produit-galerie__thumb-img{width:100%;height:100%;object-fit:cover;display:block}

/* ====== LOGO HEADER ====== */
.wordmark{display:inline-flex;align-items:center;border:none;padding:0}
.hdr-logo{height:50px;width:auto;display:block;object-fit:contain}

/* ====== LOGO FOOTER ====== */
.ftr-logo-link{display:inline-block;text-decoration:none;margin-bottom:8px}
.ftr-logo-pill{display:inline-block;background:#fff;border-radius:6px;padding:5px 10px}
.ftr-logo{height:40px;width:auto;display:block;object-fit:contain}

/* ====== PAGE LOGIN ====== */
.login-wrap{min-height:calc(100vh - 160px);display:flex;align-items:center;justify-content:center;padding:40px 16px}
.login-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:40px 36px;width:100%;max-width:420px;box-shadow:0 12px 40px -16px rgba(26,25,22,.18)}
.login-logo-link{display:flex;justify-content:center;margin-bottom:24px}
.login-logo{height:44px;width:auto;object-fit:contain}
.login-titre{font-family:var(--disp);font-size:1.45rem;font-weight:700;text-align:center;margin:0 0 24px;color:var(--ink)}
.login-form{display:flex;flex-direction:column;gap:18px;margin-top:4px}
.login-group{display:flex;flex-direction:column;gap:6px}
.login-label{font:700 11px var(--mono);letter-spacing:.1em;color:var(--mut-2);text-transform:uppercase}
.login-input{border:1.5px solid var(--line);border-radius:8px;padding:11px 14px;font:500 14.5px var(--body);color:var(--ink);background:var(--paper);outline:none;transition:border-color .15s;width:100%}
.login-input:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(207,99,54,.12)}
.login-btn{width:100%;justify-content:center;padding:13px;font-size:15px;border-radius:8px;margin-top:4px}

/* ====== CALENDRIER — JOURS FERMÉS ====== */
/* Jours grisés visuellement (boutique fermée) mais sélectionnables (couverture autorisée) */
.flatpickr-day.jour-ferme{color:var(--mut-2);opacity:.55;text-decoration:line-through;text-decoration-color:var(--mut-2)}
.flatpickr-day.jour-ferme:hover{color:var(--ac);opacity:.85;text-decoration:none}
/* Ne pas interférer avec les jours déjà désactivés par minDate */
.flatpickr-day.jour-ferme.flatpickr-disabled{color:var(--mut-2);opacity:.35;text-decoration:line-through}

/* ====== HORAIRES RETRAIT ====== */
.note--horaires{color:var(--mut-2);font-size:11.5px}
.confirmation-encart__horaires{font:400 12px var(--body);color:var(--mut);margin-top:4px}

/* ======================================================
   RESPONSIVE — breakpoints :
     Tablette : max-width 900px
     Mobile   : max-width 600px
   ====================================================== */

/* ---- Burger menu : caché par défaut (desktop) ---- */
.hdr-burger-input{display:none}
.hdr-burger{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:40px;height:40px;
  cursor:pointer;
  border:1.5px solid #d8d3c8;
  border-radius:50%;
  align-items:center;
  flex-shrink:0;
}
.hdr-burger__bar{
  display:block;width:18px;height:2px;
  background:var(--ink);
  border-radius:2px;
  transition:transform .2s,opacity .2s;
}

/* ============= TABLETTE (≤ 900 px) ============= */
@media (max-width:900px){

  /* Wrap padding réduit */
  .wrap{padding:0 20px}

  /* Header : cacher le bouton CTA réserver (bouton texte), afficher burger */
  .hdr-cta-reserver{display:none}
  .hdr-burger{display:flex}

  /* Nav masquée par défaut, dépliée quand checkbox cochée */
  .hdr-nav{
    display:none;
    position:fixed;
    top:74px;left:0;right:0;
    background:#f7f5ef;
    border-bottom:1px solid var(--line);
    flex-direction:column;
    gap:0;
    z-index:39;
    padding:8px 0 16px;
    box-shadow:0 8px 24px -8px rgba(26,25,22,.18);
  }
  .hdr-nav a{
    padding:14px 24px;
    font-size:15px;
    border-top:1px solid var(--line-2);
  }
  /* Ouverture burger */
  .hdr-burger-input:checked ~ .hdr-nav{display:flex}
  /* Animation barres : X quand ouvert */
  .hdr-burger-input:checked ~ .hdr-tools .hdr-burger .hdr-burger__bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .hdr-burger-input:checked ~ .hdr-tools .hdr-burger .hdr-burger__bar:nth-child(2){opacity:0}
  .hdr-burger-input:checked ~ .hdr-tools .hdr-burger .hdr-burger__bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  /* Footer : 2 colonnes */
  .ftr-grid{grid-template-columns:1fr 1fr;gap:28px;padding-top:36px}

  /* Recherche */
  .recherche__btn{display:none} /* bouton visible uniquement sur desktop, remplacé en mobile */

  /* Trust strip : 2×2 */
  .trust{flex-wrap:wrap}
  .trust__item{width:50%;flex:none;border-bottom:1px solid var(--line)}
  .trust__item:nth-child(2){border-right:none}
  .trust__item:nth-child(3){border-right:1px solid var(--line);border-bottom:none}
  .trust__item:last-child{border-bottom:none;border-right:none}

  /* Produit layout : empiler */
  .produit-layout{grid-template-columns:1fr;gap:24px}

  /* Panier layout : empiler */
  .panier-layout{grid-template-columns:1fr;gap:24px}
  .panier-recap{position:static;top:auto}

  /* Catalogue : sidebar au-dessus */
  .catalogue-body{flex-direction:column;border-top:none}
  .catalogue-filtres{
    width:100%;
    padding:16px 0;
    border-right:none;
    border-bottom:1px solid var(--line);
  }
  .catalogue-filtres__liste{flex-direction:row;flex-wrap:wrap;gap:6px}
  .catalogue-filtre-lien{padding:5px 12px;border:1px solid var(--line);border-radius:20px;font-size:12.5px}
  .catalogue-filtre-lien--actif{border-color:var(--ac)}
  .catalogue-grille{padding:16px 0 0}
}

/* ============= MOBILE (≤ 600 px) ============= */
@media (max-width:600px){

  /* Wrap encore plus compact */
  .wrap{padding:0 16px}

  /* Header : hauteur légèrement réduite */
  .hdr{height:60px}
  .hdr-logo{height:40px}
  .hdr-nav{top:60px}

  /* Hero : hauteur réduite */
  .hero__bg{height:380px}
  .hero__content{height:380px}
  .hero__search-wrap{margin-top:-36px}
  .hero__sub{display:none} /* sous-titre trop long sur très petit écran */

  /* Recherche : empiler les champs */
  .recherche{padding:12px}
  .recherche__form{flex-direction:column;gap:8px}
  .recherche__sep{display:none}
  .recherche__field{border:1.5px solid var(--line);border-radius:9px}
  .recherche__btn{
    display:flex;
    width:100%;
    justify-content:center;
    padding:13px;
    font-size:15px;
  }

  /* Trust : 1 colonne */
  .trust__item{width:100%;border-right:none!important;border-bottom:1px solid var(--line)}
  .trust__item:last-child{border-bottom:none}

  /* Footer : 1 colonne */
  .ftr-grid{grid-template-columns:1fr;gap:20px}
  .ftr-info{flex-direction:column;gap:14px}

  /* Packs & cats grilles : 1 colonne min 200px (auto-fill déjà OK, on affine) */
  .grille-packs{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  .grille-cats{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}

  /* Panier : ligne info + prix empilés */
  .panier-ligne{flex-wrap:wrap;gap:10px}
  .panier-ligne__prix{white-space:normal}

  /* Paiement recap : padding réduit */
  .paiement-recap{padding:18px 16px}

  /* Checkout form pleine largeur */
  .checkout-form{max-width:100%}

  /* Sec marges */
  .sec{margin-top:48px}
}
