/* ============================================================================
   Campslate — DESIGN SYSTEM "BRUTALIST-UTILITY"
   Grille 1px visible · blocs encadrés à bords nets · libellés mono majuscules ·
   fort contraste monochrome (encre/papier) + 1 accent braise · tableaux de specs
   apparents · cartes à inversion de couleur au hover · glyphes géométriques épais.
   Palette de marque conservée : vert forêt #274b32 / braise #df5a26 · Oswald + Asap.
   Préfixe de classes propre à la marque : cs-
============================================================================ */
:root{
  /* — Palette marque (conservée) — */
  --forest:#274b32; --forest-900:#15291c;
  --ember:#df5a26;  --ember-700:#bd4517;
  --stone:#ece5d6;  --paper:#f5f1e6;  --sand:#cab896;
  --ink:#15190f;    --ink-soft:#5b6152;
  --ok:#356b45;
  /* — Brutalisme : la bordure EST l'encre, traits nets et présents — */
  --line:#15190f;
  --bw:1.6px;       /* trait fin de la grille */
  --bw2:2.6px;      /* trait fort (cadres majeurs) */
  --maxw:1300px;
  --gut:clamp(14px,3.5vw,30px);
  --f-display:"Oswald",Impact,"Arial Narrow",sans-serif;
  --f-body:"Asap",-apple-system,system-ui,sans-serif;
  --f-mono:ui-monospace,"SFMono-Regular",Menlo,Consolas,"Liberation Mono",monospace;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--f-body);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4,h5{font-family:var(--f-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.01em;line-height:1.02;margin:0}
::selection{background:var(--ember);color:#fff}
.cs-wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}

/* — Briques mono utilitaires (signature brutaliste) — */
.cs-mono{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.12em;
  font-size:.7rem;font-weight:500}
.cs-tag{display:inline-block;font-family:var(--f-mono);text-transform:uppercase;
  letter-spacing:.1em;font-size:.64rem;font-weight:600;padding:.32em .6em;
  border:var(--bw) solid var(--ink);background:var(--paper);color:var(--ink);line-height:1}
.cs-muted{color:var(--ink-soft)}

/* ── Boutons (carrés, nets, snap) ───────────────────────────────────────── */
.cs-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.1em;font-weight:600;
  font-size:.78rem;padding:.85em 1.4em;border:var(--bw2) solid var(--ink);background:var(--paper);
  color:var(--ink);border-radius:0;transition:background .08s linear,color .08s linear}
.cs-btn:hover{background:var(--ink);color:var(--paper)}
.cs-btn-ember{background:var(--ember);border-color:var(--ink);color:#fff}
.cs-btn-ember:hover{background:var(--ink);color:var(--ember)}
.cs-btn-forest{background:var(--forest);border-color:var(--ink);color:#fff}
.cs-btn-forest:hover{background:var(--ink);color:#fff}
.cs-btn-block{display:flex;width:100%}
.cs-btn-lg{padding:1.05em 1.6em;font-size:.85rem}
.cs-btn-sm{padding:.6em 1em;font-size:.7rem;border-width:var(--bw)}
.cs-btn svg{width:1.1em;height:1.1em}

/* ── Barre annonce + Header dense (PAS un header centré standard) ───────── */
.cs-announce{background:var(--ink);color:var(--paper);font-family:var(--f-mono);
  text-transform:uppercase;letter-spacing:.14em;font-size:.66rem}
.cs-announce .cs-wrap{display:flex;gap:.9rem;align-items:center;justify-content:center;
  flex-wrap:wrap;padding:.5rem var(--gut)}
.cs-announce .sep{color:var(--ember);font-weight:700}

.cs-head{position:sticky;top:0;z-index:60;background:var(--paper);
  border-bottom:var(--bw2) solid var(--ink)}
/* HEADER variante : logo centré + nav scindée gauche/droite (grille 3 zones) */
.cs-head-split{display:grid;grid-template-columns:1fr auto 1fr;align-items:stretch;
  max-width:var(--maxw);margin-inline:auto}
.cs-navside{display:flex;align-items:stretch;overflow:auto}
.cs-navside-l{justify-content:flex-end}
.cs-navside-r{justify-content:flex-start}
.cs-navside a{display:flex;align-items:center;padding:1.05rem 1.1rem;font-family:var(--f-mono);
  text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:500;
  white-space:nowrap;transition:background .08s,color .08s}
.cs-navside-l a{border-left:var(--bw) solid var(--ink)}
.cs-navside-r a{border-right:var(--bw) solid var(--ink)}
.cs-navside a:hover{background:var(--ink);color:var(--paper)}
.cs-logo-c{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.6rem 1.6rem;
  border-inline:var(--bw2) solid var(--ink)}
.cs-logo-c img{height:34px;width:auto}
.cs-logo-c b{font-family:var(--f-display);text-transform:uppercase;font-weight:700;
  font-size:1.3rem;letter-spacing:.04em}
.cs-head-tools{display:flex;align-items:stretch;margin-left:auto}
.cs-icon-btn{display:flex;align-items:center;justify-content:center;width:54px;
  background:var(--paper);border:0;border-left:var(--bw) solid var(--ink);color:var(--ink);
  transition:background .08s,color .08s}
.cs-icon-btn:hover{background:var(--ink);color:var(--paper)}
.cs-icon-btn svg{width:22px;height:22px}
.cs-cart-btn{position:relative}
.cs-cart-count{position:absolute;top:7px;right:7px;min-width:18px;height:18px;
  display:none;place-items:center;background:var(--ember);color:#fff;font-family:var(--f-mono);
  font-size:.62rem;font-weight:700;padding:0 3px;border:var(--bw) solid var(--ink)}
.cs-burger{display:none}

/* Menu mobile plein écran */
.cs-mobnav{position:fixed;inset:0;z-index:80;background:var(--paper);display:none;
  flex-direction:column}
.cs-mobnav.open{display:flex}
.cs-mobnav-head{display:flex;justify-content:space-between;align-items:center;
  border-bottom:var(--bw2) solid var(--ink);padding:.7rem var(--gut)}
.cs-mobnav-head b{font-family:var(--f-display);text-transform:uppercase;font-size:1.3rem}
.cs-mobnav a{display:flex;justify-content:space-between;align-items:center;
  padding:1.1rem var(--gut);border-bottom:var(--bw) solid var(--ink);
  font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.08em;font-size:.95rem}
.cs-mobnav a .n{color:var(--ember);font-weight:700}
.cs-mobnav a:active{background:var(--ink);color:var(--paper)}

/* ── Sections génériques ────────────────────────────────────────────────── */
.cs-section{padding:clamp(2.6rem,6vw,4.4rem) 0}
.cs-section.alt{background:var(--stone)}
.cs-sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;
  border-bottom:var(--bw2) solid var(--ink);padding-bottom:.9rem;margin-bottom:1.8rem;flex-wrap:wrap}
.cs-sec-head .cs-mono{color:var(--ember);margin-bottom:.5rem;display:block}
.cs-sec-head h2{font-size:clamp(1.5rem,3.4vw,2.3rem)}
.cs-sec-link{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.1em;
  font-size:.72rem;font-weight:600;border-bottom:var(--bw2) solid var(--ember);padding-bottom:2px}
.cs-sec-link:hover{color:var(--ember)}

/* ── HERO : cadre encadré + bandeau de specs (data-first) ───────────────── */
.cs-hero{border-bottom:var(--bw2) solid var(--ink)}
.cs-hero-grid{display:grid;grid-template-columns:1.05fr 1fr;max-width:var(--maxw);margin-inline:auto}
.cs-hero-copy{padding:clamp(1.8rem,4vw,3.4rem) var(--gut);background:var(--forest);color:var(--paper);
  border-right:var(--bw2) solid var(--ink);display:flex;flex-direction:column;justify-content:center}
.cs-hero-copy .cs-mono{color:var(--ember);margin-bottom:1rem}
.cs-hero-copy h1{font-size:clamp(2.3rem,5.5vw,4rem);font-weight:700;line-height:.96}
.cs-hero-copy h1 em{font-style:normal;color:var(--ember)}
.cs-hero-lede{margin:1.2rem 0 1.8rem;max-width:46ch;color:#e7e0cf;font-size:1.02rem}
.cs-hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.cs-hero-cta .cs-btn{border-color:var(--paper)}
.cs-hero-cta .cs-btn:not(.cs-btn-ember){background:transparent;color:var(--paper)}
.cs-hero-cta .cs-btn:not(.cs-btn-ember):hover{background:var(--paper);color:var(--ink)}
.cs-hero-media{position:relative;min-height:340px;overflow:hidden}
.cs-hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cs-hero-stats{display:grid;grid-template-columns:repeat(4,1fr);max-width:var(--maxw);
  margin-inline:auto;border-top:var(--bw2) solid var(--ink)}
.cs-hero-stats div{padding:1rem var(--gut);border-right:var(--bw) solid var(--ink)}
.cs-hero-stats div:last-child{border-right:0}
.cs-hero-stats b{font-family:var(--f-display);font-size:1.7rem;display:block;line-height:1}
.cs-hero-stats span{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.08em;
  font-size:.6rem;color:var(--ink-soft)}

/* ── Grille réassurance (cellules encadrées, hover invert) ──────────────── */
.cs-feat{display:grid;grid-template-columns:repeat(4,1fr);
  border-top:var(--bw) solid var(--ink);border-left:var(--bw) solid var(--ink)}
.cs-feat>div{padding:1.5rem var(--gut);border-right:var(--bw) solid var(--ink);
  border-bottom:var(--bw) solid var(--ink);transition:background .08s,color .08s}
.cs-feat>div:hover{background:var(--ink);color:var(--paper)}
.cs-feat svg{width:30px;height:30px;color:var(--ember);margin-bottom:.7rem}
.cs-feat h4{font-size:1.05rem;margin-bottom:.3rem}
.cs-feat p{margin:0;font-size:.86rem;color:var(--ink-soft)}
.cs-feat>div:hover p{color:#cfc9b8}

/* ── Table catégories = tableau de specs apparent (signature) ───────────── */
.cs-cattable{border:var(--bw2) solid var(--ink);background:var(--paper)}
.cs-cattable a{display:grid;grid-template-columns:54px 1fr 110px 90px 40px;align-items:center;
  border-bottom:var(--bw) solid var(--ink);font-family:var(--f-mono);
  transition:background .08s,color .08s}
.cs-cattable a:last-child{border-bottom:0}
.cs-cattable a:hover{background:var(--ink);color:var(--paper)}
.cs-cattable a:hover .ar{color:var(--ember)}
.cs-cattable .ix{padding:1rem;color:var(--ember);font-weight:700;border-right:var(--bw) solid var(--ink);text-align:center}
.cs-cattable a:hover .ix{color:#fff}
.cs-cattable .nm{padding:1rem;font-family:var(--f-display);text-transform:uppercase;
  font-size:1.15rem;letter-spacing:.01em;font-weight:600}
.cs-cattable .ct,.cs-cattable .pr{padding:1rem;text-transform:uppercase;letter-spacing:.08em;
  font-size:.66rem;border-left:var(--bw) solid var(--ink)}
.cs-cattable a:hover .ct,.cs-cattable a:hover .pr{border-color:#3a4030}
.cs-cattable .ar{padding:1rem;text-align:center;font-size:1.1rem;border-left:var(--bw) solid var(--ink)}

/* ── Cartes produit : rectangulaires, grille 1px, hover = inversion ─────── */
.cs-prodgrid{display:grid;grid-template-columns:repeat(4,1fr);
  border-top:var(--bw) solid var(--ink);border-left:var(--bw) solid var(--ink)}
.cs-prodgrid.cols3{grid-template-columns:repeat(3,1fr)}
.cs-card{display:flex;flex-direction:column;background:var(--paper);color:var(--ink);
  border-right:var(--bw) solid var(--ink);border-bottom:var(--bw) solid var(--ink);
  transition:background .08s linear,color .08s linear}
.cs-card:hover{background:var(--ink);color:var(--paper)}
.cs-card-media{position:relative;display:block;aspect-ratio:1/1;overflow:hidden;
  border-bottom:var(--bw) solid var(--ink);background:var(--stone)}
.cs-card-media img{width:100%;height:100%;object-fit:cover}
.cs-badges{position:absolute;top:8px;left:8px;display:flex;flex-direction:column;gap:5px;z-index:2}
.cs-badge{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.08em;font-size:.58rem;
  font-weight:700;padding:.3em .5em;background:var(--paper);color:var(--ink);border:var(--bw) solid var(--ink)}
.cs-badge.is-sale{background:var(--ember);color:#fff}
.cs-badge.is-new{background:var(--forest);color:#fff}
.cs-card-body{padding:.85rem .9rem;display:flex;flex-direction:column;gap:.32rem;flex:1}
.cs-card-cat{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.1em;
  font-size:.6rem;color:var(--ember)}
.cs-card:hover .cs-card-cat{color:var(--ember)}
.cs-card-name{font-family:var(--f-display);text-transform:uppercase;font-weight:500;
  font-size:1rem;line-height:1.05;letter-spacing:.01em}
.cs-card-rating{font-family:var(--f-mono);font-size:.64rem;letter-spacing:.04em;color:var(--ink-soft)}
.cs-card:hover .cs-card-rating{color:#bdb8a6}
.cs-stars{color:var(--ember);letter-spacing:1px}
.cs-card-foot{display:flex;align-items:baseline;gap:.5rem;margin-top:auto;padding-top:.4rem}
.cs-price{font-family:var(--f-display);font-size:1.2rem;font-weight:600}
.cs-price-old{font-size:.85rem;text-decoration:line-through;color:var(--ink-soft)}
.cs-card:hover .cs-price-old{color:#9a957f}
.cs-save{font-family:var(--f-mono);font-size:.62rem;font-weight:700;color:#fff;background:var(--ember);
  padding:.15em .45em;border:var(--bw) solid var(--ink)}
.cs-card-add{display:flex;width:100%;align-items:center;justify-content:center;gap:.4em;
  font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.1em;font-weight:600;font-size:.7rem;
  padding:.8rem;background:var(--ember);color:#fff;border:0;border-top:var(--bw) solid var(--ink);
  transition:background .08s,color .08s}
.cs-card-add:hover{background:var(--forest);color:#fff}

/* ── Split éditorial encadré (méthode) ──────────────────────────────────── */
.cs-split{display:grid;grid-template-columns:1fr 1fr;border:var(--bw2) solid var(--ink);background:var(--paper)}
.cs-split-media{position:relative;min-height:300px;border-right:var(--bw2) solid var(--ink);overflow:hidden;background:var(--stone)}
.cs-split.rev .cs-split-media{order:2;border-right:0;border-left:var(--bw2) solid var(--ink)}
.cs-split-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cs-split-copy{padding:clamp(1.6rem,3.5vw,2.8rem)}
.cs-split-copy .cs-mono{color:var(--ember);margin-bottom:.7rem;display:block}
.cs-split-copy h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:.8rem}
.cs-checklist{list-style:none;margin:1.2rem 0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.cs-checklist li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;
  border-bottom:var(--bw) solid var(--ink);padding-bottom:.55rem}
.cs-checklist svg{width:18px;height:18px;color:var(--ember);flex:none;margin-top:3px}

/* ── Journal : cartes éditoriales encadrées (toutes les images d'ambiance) ─ */
.cs-journal{display:grid;grid-template-columns:1fr 1fr;
  border-top:var(--bw) solid var(--ink);border-left:var(--bw) solid var(--ink)}
.cs-jcard{display:flex;flex-direction:column;border-right:var(--bw) solid var(--ink);
  border-bottom:var(--bw) solid var(--ink);background:var(--paper);transition:background .08s,color .08s}
.cs-jcard:hover{background:var(--ink);color:var(--paper)}
.cs-jcard-media{aspect-ratio:16/9;overflow:hidden;border-bottom:var(--bw) solid var(--ink);background:var(--stone)}
.cs-jcard-media img{width:100%;height:100%;object-fit:cover}
.cs-jcard-body{padding:1.3rem}
.cs-jcard-body .cs-mono{color:var(--ember);display:block;margin-bottom:.5rem}
.cs-jcard-body h3{font-size:1.4rem;margin-bottom:.5rem}
.cs-jcard-body p{margin:0 0 .9rem;font-size:.92rem;color:var(--ink-soft)}
.cs-jcard:hover p{color:#cfc9b8}
.cs-jcard-link{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.1em;
  font-size:.7rem;font-weight:600;border-bottom:var(--bw2) solid var(--ember);padding-bottom:2px}

/* ── Comparatif / matrice (data-first, signature brutaliste) ─────────────── */
.cs-matrix{border:var(--bw2) solid var(--ink);background:var(--paper)}
.cs-matrix-row{display:grid;grid-template-columns:1.6fr 1fr 1fr;
  border-bottom:var(--bw) solid var(--ink)}
.cs-matrix-row:last-child{border-bottom:0}
.cs-matrix-row>div{padding:.95rem 1.2rem;border-right:var(--bw) solid var(--ink);
  display:flex;align-items:center;gap:.5rem;font-size:.9rem}
.cs-matrix-row>div:last-child{border-right:0}
.cs-matrix-head{background:var(--ink);color:var(--paper)}
.cs-matrix-head>div{font-family:var(--f-display);text-transform:uppercase;font-weight:600;
  font-size:1.05rem;letter-spacing:.02em;border-color:#3a4030}
.cs-matrix-head .us{color:var(--ember)}
.cs-matrix .ft{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.06em;
  font-size:.72rem;color:var(--ink-soft)}
.cs-matrix .us-col{background:var(--stone);font-weight:600}
.cs-matrix svg{width:20px;height:20px;flex:none}
.cs-matrix .yes svg{color:var(--ok)}
.cs-matrix .no svg{color:#b6502f}

/* ── Avis ───────────────────────────────────────────────────────────────── */
.cs-rev-top{display:flex;gap:2rem;align-items:center;flex-wrap:wrap;margin-bottom:1.6rem}
.cs-rev-big{font-family:var(--f-display);font-size:3.4rem;line-height:.9;font-weight:700}
.cs-reviews{display:grid;grid-template-columns:repeat(3,1fr);
  border-top:var(--bw) solid var(--ink);border-left:var(--bw) solid var(--ink)}
.cs-review{padding:1.4rem;border-right:var(--bw) solid var(--ink);border-bottom:var(--bw) solid var(--ink);
  background:var(--paper);display:flex;flex-direction:column;gap:.6rem}
.cs-review p{margin:0;font-size:.95rem}
.cs-rev-by{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.06em;
  font-size:.64rem;margin-top:auto}
.cs-rev-ver{color:var(--ok)}
/* distribution étoiles (barres brutales) */
.cs-rev-bars{flex:1;min-width:240px;display:flex;flex-direction:column;gap:.35rem}
.cs-rev-bar{display:grid;grid-template-columns:34px 1fr 42px;align-items:center;gap:.6rem;
  font-family:var(--f-mono);font-size:.66rem}
.cs-rev-bar .bt{height:12px;border:var(--bw) solid var(--ink);background:var(--paper)}
.cs-rev-bar .bf{height:100%;background:var(--ember)}

/* ── Newsletter (bloc encre encadré) ────────────────────────────────────── */
.cs-news{border:var(--bw2) solid var(--ink);background:var(--ink);color:var(--paper);
  padding:clamp(1.8rem,4vw,3rem);text-align:center}
.cs-news .cs-mono{color:var(--ember);display:block;margin-bottom:.8rem}
.cs-news h2{font-size:clamp(1.6rem,3.4vw,2.3rem);margin-bottom:.6rem}
.cs-news p{color:#cfc9b8;margin:0 auto 1.4rem;max-width:48ch}
.cs-news form{display:flex;gap:0;max-width:480px;margin-inline:auto}
.cs-news input{flex:1;padding:.95em 1.1em;border:var(--bw2) solid var(--paper);background:var(--paper);
  color:var(--ink);font-family:var(--f-mono);font-size:.85rem;border-right:0}
.cs-news button{border-color:var(--paper)}

/* ── Bandeaux de page (shop, cart, about, contact, legal) ───────────────── */
.cs-pagehead{border-bottom:var(--bw2) solid var(--ink);background:var(--forest);color:var(--paper)}
.cs-pagehead .cs-wrap{padding-block:clamp(2rem,5vw,3.4rem)}
.cs-pagehead .cs-mono{color:var(--ember);display:block;margin-bottom:.7rem}
.cs-pagehead h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:700}
.cs-pagehead p{color:#e7e0cf;max-width:60ch;margin:.8rem 0 0}

/* ── Shop ───────────────────────────────────────────────────────────────── */
.cs-shop{display:grid;grid-template-columns:240px 1fr;gap:0;align-items:start}
.cs-filters{border:var(--bw2) solid var(--ink);position:sticky;top:118px;background:var(--paper)}
.cs-filters h4{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.12em;padding:.8rem 1rem;
  border-bottom:var(--bw) solid var(--ink);background:var(--ink);color:var(--paper)}
.cs-filters button{display:flex;justify-content:space-between;width:100%;text-align:left;
  background:var(--paper);border:0;border-bottom:var(--bw) solid var(--ink);padding:.7rem 1rem;
  font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.06em;font-size:.66rem;
  color:var(--ink);transition:background .08s,color .08s}
.cs-filters button:last-child{border-bottom:0}
.cs-filters button:hover{background:var(--stone)}
.cs-filters button.sel{background:var(--ink);color:var(--paper)}
.cs-filters button.sel .n,.cs-filters button:hover .n{color:var(--ember)}
.cs-filters .n{color:var(--ink-soft)}
.cs-shop-main{min-width:0;border-left:var(--bw2) solid var(--ink)}
.cs-shop-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  border-bottom:var(--bw2) solid var(--ink);padding:.7rem 1rem;flex-wrap:wrap}
.cs-shop-bar .cnt{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.1em;font-size:.66rem}
.cs-shop select{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.06em;font-size:.66rem;
  padding:.55em .8em;border:var(--bw) solid var(--ink);background:var(--paper);color:var(--ink);border-radius:0}
.cs-shop .cs-prodgrid{border-left:0;border-top:0}
.cs-shop .cs-card{border-bottom:var(--bw) solid var(--ink)}
/* chips mobiles (filtres horizontaux) */
.cs-fchips{display:none;gap:0;overflow:auto;border-bottom:var(--bw2) solid var(--ink)}
.cs-fchips button{flex:none;background:var(--paper);border:0;border-right:var(--bw) solid var(--ink);
  padding:.7rem 1rem;font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.06em;
  font-size:.66rem;color:var(--ink)}
.cs-fchips button.sel{background:var(--ink);color:var(--paper)}

/* ── PDP ────────────────────────────────────────────────────────────────── */
.cs-crumb{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.08em;font-size:.64rem;
  padding:1rem 0;color:var(--ink-soft)}
.cs-crumb a:hover{color:var(--ember)}
.cs-pdp{display:grid;grid-template-columns:1fr 1fr;border:var(--bw2) solid var(--ink);background:var(--paper)}
.cs-pdp-gallery{border-right:var(--bw2) solid var(--ink)}
.cs-pdp-main{aspect-ratio:1/1;overflow:hidden;border-bottom:var(--bw) solid var(--ink);background:var(--stone)}
.cs-pdp-main img{width:100%;height:100%;object-fit:cover}
.cs-pdp-thumbs{display:flex}
.cs-pdp-thumbs img{width:33.333%;aspect-ratio:1/1;object-fit:cover;cursor:pointer;
  border-right:var(--bw) solid var(--ink);background:var(--stone);opacity:.66;transition:opacity .1s}
.cs-pdp-thumbs img:last-child{border-right:0}
.cs-pdp-thumbs img.sel,.cs-pdp-thumbs img:hover{opacity:1}
.cs-pdp-info{padding:clamp(1.3rem,3vw,2.2rem)}
.cs-pdp-info h1{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;margin:.5rem 0 .6rem}
.cs-pdp-rating{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.04em;color:var(--ink-soft)}
.cs-pdp-price{display:flex;align-items:baseline;gap:.7rem;border-block:var(--bw) solid var(--ink);
  padding:.9rem 0;margin:1rem 0}
.cs-pdp-price .cs-price{font-size:2rem}
.cs-pdp-bul{list-style:none;padding:0;margin:1.1rem 0;display:flex;flex-direction:column;gap:.5rem}
.cs-pdp-bul li{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem}
.cs-pdp-bul svg{width:17px;height:17px;color:var(--ember);flex:none;margin-top:3px}
.cs-vlabel{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.1em;font-size:.64rem;
  display:block;margin:1rem 0 .5rem}
.cs-variants{display:flex;gap:0;flex-wrap:wrap;border-top:var(--bw) solid var(--ink);border-left:var(--bw) solid var(--ink)}
.cs-variants button{padding:.6em 1.1em;font-family:var(--f-mono);text-transform:uppercase;
  letter-spacing:.06em;font-size:.68rem;background:var(--paper);border:0;
  border-right:var(--bw) solid var(--ink);border-bottom:var(--bw) solid var(--ink);color:var(--ink)}
.cs-variants button.sel{background:var(--ink);color:var(--paper)}
.cs-lowstock{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.06em;font-size:.66rem;
  color:#fff;background:var(--ember);border:var(--bw) solid var(--ink);padding:.5em .8em;margin:1rem 0;display:inline-block}
.cs-qty{display:flex;align-items:center;border:var(--bw2) solid var(--ink)}
.cs-qty button{width:42px;height:46px;background:var(--paper);border:0;font-size:1.2rem;color:var(--ink)}
.cs-qty button:hover{background:var(--ink);color:var(--paper)}
.cs-qty span{min-width:38px;text-align:center;font-family:var(--f-mono);font-weight:600;
  border-inline:var(--bw) solid var(--ink);align-self:stretch;display:grid;place-items:center}
.cs-pdp-buy{display:flex;gap:.7rem;align-items:stretch;margin:1.2rem 0 .7rem}
.cs-pdp-reassure{display:grid;grid-template-columns:repeat(3,1fr);border:var(--bw) solid var(--ink);margin-top:1rem}
.cs-pdp-reassure span{display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center;
  padding:.8rem .4rem;border-right:var(--bw) solid var(--ink);font-family:var(--f-mono);
  text-transform:uppercase;letter-spacing:.05em;font-size:.56rem}
.cs-pdp-reassure span:last-child{border-right:0}
.cs-pdp-reassure svg{width:22px;height:22px;color:var(--ember)}

/* Blocs PDP (specs, desc, faq, livraison) en cadres */
.cs-block{border:var(--bw2) solid var(--ink);background:var(--paper);margin-top:1.6rem}
.cs-block-h{font-family:var(--f-display);text-transform:uppercase;font-size:1.2rem;font-weight:600;
  padding:.9rem 1.2rem;border-bottom:var(--bw2) solid var(--ink);background:var(--stone)}
.cs-block-b{padding:1.2rem}
.cs-spectable{width:100%;border-collapse:collapse;font-family:var(--f-mono);font-size:.74rem}
.cs-spectable td{padding:.7rem 1.2rem;border-bottom:var(--bw) solid var(--ink)}
.cs-spectable tr:last-child td{border-bottom:0}
.cs-spectable td:first-child{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);
  width:42%;border-right:var(--bw) solid var(--ink);background:var(--stone)}
.cs-acc details{border-bottom:var(--bw) solid var(--ink)}
.cs-acc details:last-child{border-bottom:0}
.cs-acc summary{cursor:pointer;list-style:none;padding:.95rem 1.2rem;font-family:var(--f-mono);
  text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;font-weight:600;
  display:flex;justify-content:space-between;align-items:center}
.cs-acc summary::-webkit-details-marker{display:none}
.cs-acc summary::after{content:"+";color:var(--ember);font-size:1.3rem;font-weight:700;line-height:1}
.cs-acc details[open] summary::after{content:"\2212"}
.cs-acc-body{padding:0 1.2rem 1.2rem;font-size:.92rem;color:var(--ink-soft)}
.cs-sticky-atc{position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;gap:.8rem;align-items:center;
  background:var(--paper);border-top:var(--bw2) solid var(--ink);padding:.6rem var(--gut)}
.cs-sticky-atc.show{display:flex}
.cs-sticky-atc .nm{font-family:var(--f-display);text-transform:uppercase;font-weight:600;font-size:.9rem;line-height:1}

/* ── Drawer panier ──────────────────────────────────────────────────────── */
.cs-ov{position:fixed;inset:0;background:rgba(21,25,15,.55);opacity:0;visibility:hidden;
  transition:opacity .12s;z-index:90}
.cs-ov.open{opacity:1;visibility:visible}
.cs-drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,92vw);background:var(--paper);
  border-left:var(--bw2) solid var(--ink);transform:translateX(100%);transition:transform .14s ease-out;
  z-index:95;display:flex;flex-direction:column}
.cs-drawer.open{transform:none}
.cs-drawer-head{display:flex;justify-content:space-between;align-items:center;
  border-bottom:var(--bw2) solid var(--ink);padding:.7rem 1rem}
.cs-drawer-head h3{font-size:1.2rem}
.cs-drawer-head .cs-icon-btn{border:var(--bw) solid var(--ink)}
.cs-ship{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.05em;font-size:.64rem;
  padding:.8rem 1rem;border-bottom:var(--bw) solid var(--ink);background:var(--stone)}
.cs-track{height:12px;border:var(--bw) solid var(--ink);background:var(--paper);margin-top:.5rem}
.cs-fill{height:100%;background:var(--ember)}
.cs-drawer-items{flex:1;overflow:auto}
.cs-ci{display:grid;grid-template-columns:64px 1fr auto;gap:.8rem;padding:.9rem 1rem;
  border-bottom:var(--bw) solid var(--ink)}
.cs-ci img{width:64px;height:64px;object-fit:cover;border:var(--bw) solid var(--ink);background:var(--stone)}
.cs-ci-name{font-family:var(--f-display);text-transform:uppercase;font-weight:500;font-size:.92rem;line-height:1.05}
.cs-ci .cs-qty{margin-top:.45rem;border-width:var(--bw)}
.cs-ci .cs-qty button{width:30px;height:30px;font-size:1rem}
.cs-ci .cs-qty span{min-width:30px}
.cs-ci-rm{background:none;border:0;font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.06em;
  font-size:.58rem;color:var(--ink-soft);text-decoration:underline;padding:0;margin-top:.4rem}
.cs-ci-rm:hover{color:var(--ember)}
.cs-drawer-foot{border-top:var(--bw2) solid var(--ink);padding:1rem}
.cs-drawer-sub{display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--f-display);text-transform:uppercase;font-size:1.3rem;margin-bottom:.3rem}
.cs-drawer-empty{padding:3rem 1.5rem;text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center}

/* ── Cart page ──────────────────────────────────────────────────────────── */
.cs-cartrows{border:var(--bw2) solid var(--ink);background:var(--paper)}
.cs-cartrows .cs-ci{border-bottom:var(--bw) solid var(--ink)}
.cs-cartrows .cs-ci:last-child{border-bottom:0}
.cs-cartsum{border:var(--bw2) solid var(--ink);background:var(--paper);margin-top:1.4rem;padding:1.2rem}

/* ── Prose (about / legal) ──────────────────────────────────────────────── */
.cs-prose{max-width:760px}
.cs-prose h2{font-size:1.4rem;margin:2rem 0 .6rem;padding-bottom:.4rem;border-bottom:var(--bw2) solid var(--ink)}
.cs-prose p{margin:0 0 1rem}
.cs-prose em{font-style:normal;color:var(--ember);font-weight:600}
.cs-cols2{display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:var(--bw) solid var(--ink);border-left:var(--bw) solid var(--ink);margin:1.6rem 0}
.cs-cols2>div{border-right:var(--bw) solid var(--ink);border-bottom:var(--bw) solid var(--ink);padding:1.4rem}
.cs-cols2 b{font-family:var(--f-display);font-size:2.2rem;color:var(--ember);display:block;line-height:1}
.cs-form{display:grid;gap:0;border-top:var(--bw2) solid var(--ink);border-left:var(--bw2) solid var(--ink)}
.cs-form label{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.08em;font-size:.62rem;
  padding:.7rem 1rem .2rem;border-right:var(--bw2) solid var(--ink)}
.cs-form input,.cs-form textarea{padding:.7rem 1rem;border:0;border-right:var(--bw2) solid var(--ink);
  border-bottom:var(--bw2) solid var(--ink);background:var(--paper);font-family:var(--f-body);font-size:.95rem;color:var(--ink)}
.cs-form input:focus,.cs-form textarea:focus{outline:0;background:var(--stone)}
.cs-form button{border-right:var(--bw2) solid var(--ink);border-bottom:var(--bw2) solid var(--ink)}

/* ── Footer F4 BIG-TYPE CTA (phrase géante + 1 bouton, liens minuscules) ─── */
.cs-foot{border-top:var(--bw2) solid var(--ink);background:var(--ink);color:var(--paper)}
.cs-foot-cta{text-align:center;padding-block:clamp(3rem,9vw,6.5rem) clamp(2rem,5vw,3.2rem)}
.cs-foot-cta .cs-mono{color:var(--ember);display:block;margin-bottom:1.1rem}
.cs-foot-big{font-family:var(--f-display);text-transform:uppercase;font-weight:700;
  font-size:clamp(2.6rem,9.5vw,6.4rem);line-height:.92;letter-spacing:.01em;
  margin:0 auto 2rem;max-width:18ch}
.cs-foot-big em{font-style:normal;color:var(--ember)}
.cs-foot-go{font-size:1rem;padding:1.15em 2.6em;border-color:var(--paper)}
.cs-foot-go:hover{background:var(--paper);color:var(--ink)}
/* newsletter discrète */
.cs-foot-news{display:flex;gap:1rem 1.6rem;align-items:center;justify-content:center;flex-wrap:wrap;
  border-top:var(--bw) solid #3a4030;padding:1.1rem var(--gut)}
.cs-foot-news .cs-mono{color:#cfc9b8;font-size:.62rem}
.cs-foot-news form{display:flex;max-width:380px;width:100%}
.cs-foot-news input{flex:1;padding:.6em .9em;border:var(--bw) solid var(--paper);border-right:0;
  background:var(--ink);font-family:var(--f-mono);font-size:.72rem;color:var(--paper)}
.cs-foot-news input::placeholder{color:#9a957f}
.cs-foot-sub{background:var(--ember);border-color:var(--paper);color:#fff}
.cs-foot-sub:hover{background:var(--paper);color:var(--ink)}
/* liens minuscules, en ligne */
.cs-foot-mini{display:flex;flex-wrap:wrap;gap:.6rem 1.5rem;align-items:center;justify-content:center;
  border-top:var(--bw) solid #3a4030;padding:1rem var(--gut)}
.cs-foot-mini a{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.1em;
  font-size:.62rem;color:#cfc9b8}
.cs-foot-mini a:hover{color:var(--ember)}
/* paiement discret + légal */
.cs-foot-base{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  border-top:var(--bw) solid #3a4030;padding:.9rem var(--gut)}
.cs-foot-base .leg{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.06em;
  font-size:.58rem;color:#9a957f}
.cs-foot-pay{display:flex;gap:.45rem;align-items:center;flex-wrap:wrap}
.cs-foot-pay svg{width:34px;height:22px;border:var(--bw) solid #3a4030}

/* ── Toast ──────────────────────────────────────────────────────────────── */
.cs-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,140%);z-index:120;
  background:var(--ink);color:var(--paper);border:var(--bw2) solid var(--ember);
  font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;
  padding:.8em 1.3em;transition:transform .16s ease-out}
.cs-toast.show{transform:translate(-50%,0)}

/* ── Reveal (snap sec + filet anti-contenu invisible) ───────────────────── */
.cs-reveal{opacity:0;transition:opacity .26s linear}
.cs-reveal.in{opacity:1}
@media (prefers-reduced-motion: reduce){
  .cs-reveal{opacity:1 !important;transition:none}
  *{transition:none !important}
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width:960px){
  .cs-hero-grid{grid-template-columns:1fr}
  .cs-hero-copy{border-right:0;border-bottom:var(--bw2) solid var(--ink)}
  .cs-hero-media{min-height:300px}
  .cs-prodgrid{grid-template-columns:repeat(3,1fr)}
  .cs-shop{grid-template-columns:1fr}
  .cs-filters{display:none}
  .cs-fchips{display:flex}
  .cs-shop-main{border-left:0}
  .cs-matrix-row{grid-template-columns:1.2fr 1fr 1fr}
}
@media (max-width:760px){
  .cs-navside{display:none}
  .cs-head-split{grid-template-columns:auto 1fr}
  .cs-logo-c{border-left:0;justify-content:flex-start}
  .cs-burger{display:flex}
  .cs-hero-stats{grid-template-columns:repeat(2,1fr)}
  .cs-hero-stats div:nth-child(2){border-right:0}
  .cs-hero-stats div:nth-child(-n+2){border-bottom:var(--bw) solid var(--ink)}
  .cs-feat{grid-template-columns:repeat(2,1fr)}
  .cs-feat>div:nth-child(2n){border-right:0}
  .cs-prodgrid,.cs-prodgrid.cols3{grid-template-columns:repeat(2,1fr)}
  .cs-journal,.cs-reviews,.cs-cols2{grid-template-columns:1fr}
  .cs-split,.cs-split.rev{grid-template-columns:1fr}
  .cs-split-media{border-right:0;border-bottom:var(--bw2) solid var(--ink);min-height:240px}
  .cs-split.rev .cs-split-media{order:0;border-left:0;border-bottom:var(--bw2) solid var(--ink)}
  .cs-pdp{grid-template-columns:1fr}
  .cs-pdp-gallery{border-right:0;border-bottom:var(--bw2) solid var(--ink)}
  .cs-cattable a{grid-template-columns:40px 1fr 50px}
  .cs-cattable .ct,.cs-cattable .ar{display:none}
  .cs-foot-base{justify-content:center;text-align:center}
  .cs-matrix-row{grid-template-columns:1.2fr 1fr 1fr;font-size:.82rem}
}
@media (max-width:440px){
  .cs-prodgrid,.cs-prodgrid.cols3{grid-template-columns:1fr}
  .cs-hero-stats{grid-template-columns:1fr}
  .cs-hero-stats div{border-right:0;border-bottom:var(--bw) solid var(--ink)}
  .cs-feat{grid-template-columns:1fr}
  .cs-feat>div{border-right:0}
}
