/* ============================================================================
   Sproutelm — design system (archétype H : CRAFT-BOUTIQUE)
   Préfixe de classes : .se-  | Palette éco terreux : kraft + vert feuille + crème
   Polices : DM Serif Text (titres) + Karla (corps)
   ============================================================================ */
:root{
  --se-green:#3f5a37;        /* vert feuille profond — primaire */
  --se-green-2:#4f6e44;
  --se-kraft:#9a7b4f;        /* kraft / secondaire */
  --se-kraft-dark:#6f5836;
  --se-accent:#7a9a5e;       /* vert clair accent */
  --se-cream:#f3ecde;        /* crème fond */
  --se-cream-2:#ece2cf;
  --se-paper:#f7f1e6;
  --se-ink:#2c2a23;          /* encre */
  --se-ink-soft:#5a554a;
  --se-line:#d9cdb4;         /* liseré */
  --se-white:#fffdf8;
  --se-sale:#a6502e;         /* terracotta pour promo */
  --se-star:#c8902f;
  --se-shadow:0 12px 34px rgba(44,42,35,.12);
  --se-shadow-sm:0 4px 14px rgba(44,42,35,.10);
  --se-radius:14px;
  --se-maxw:1180px;
  --se-serif:"DM Serif Text",Georgia,serif;
  --se-body:"Karla",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--se-body);color:var(--se-ink);
  background-color:var(--se-cream);
  background-image:
    radial-gradient(circle at 20% 10%, rgba(154,123,79,.06), transparent 40%),
    radial-gradient(circle at 80% 60%, rgba(122,154,94,.07), transparent 45%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--se-serif);font-weight:400;line-height:1.12;color:var(--se-green);margin:0 0 .4em}
h1{font-size:clamp(2.3rem,5vw,3.7rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.7rem)}
h3{font-size:1.4rem}
p{margin:0 0 1em}
a{color:var(--se-green);text-decoration:none}
img{max-width:100%;display:block}
.se-wrap{max-width:var(--se-maxw);margin:0 auto;padding:0 24px}
.se-eyebrow{font-family:var(--se-body);font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--se-kraft);font-weight:700;margin:0 0 .9em;display:inline-block}
.se-center{text-align:center}
.se-muted{color:var(--se-ink-soft)}
section{position:relative}

/* ---------- Boutons ---------- */
.se-btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--se-body);font-weight:700;
  font-size:.95rem;letter-spacing:.02em;padding:.85em 1.6em;border-radius:40px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .18s ease,background .2s,color .2s,box-shadow .2s;text-align:center}
.se-btn-primary{background:var(--se-green);color:var(--se-white);box-shadow:var(--se-shadow-sm)}
.se-btn-primary:hover{background:var(--se-green-2);transform:translateY(-2px)}
.se-btn-ghost{background:transparent;color:var(--se-green);border-color:var(--se-green)}
.se-btn-ghost:hover{background:var(--se-green);color:var(--se-white)}
.se-btn-kraft{background:var(--se-kraft);color:var(--se-white)}
.se-btn-kraft:hover{background:var(--se-kraft-dark)}
.se-btn-block{width:100%;justify-content:center}
.se-btn-lg{padding:1.05em 2em;font-size:1.05rem}

/* ---------- Sceau / cachet (stamp) ---------- */
.se-seal{position:relative;width:108px;height:108px;border-radius:50%;display:grid;place-items:center;text-align:center;
  border:2px dashed var(--se-kraft);color:var(--se-kraft-dark);background:rgba(255,253,248,.5);
  font-family:var(--se-serif);transform:rotate(-7deg)}
.se-seal::after{content:"";position:absolute;inset:7px;border-radius:50%;border:1.5px solid var(--se-kraft)}
.se-seal span{font-size:.66rem;font-family:var(--se-body);letter-spacing:.16em;text-transform:uppercase;line-height:1.25;padding:0 12px;font-weight:700}
.se-seal strong{display:block;font-size:1.5rem;color:var(--se-green)}

/* ---------- Ruban (ribbon label) ---------- */
.se-ribbon{position:relative;display:inline-block;background:var(--se-green);color:var(--se-white);
  font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.42em 1em;
  box-shadow:var(--se-shadow-sm)}
.se-ribbon::before,.se-ribbon::after{content:"";position:absolute;top:0;border:0 solid transparent;
  border-width:calc(.86em + 2px) 9px;border-top-color:var(--se-green);border-bottom-color:var(--se-green)}
.se-ribbon::before{left:-18px;border-left-color:transparent}
.se-ribbon::after{right:-18px;border-right-color:transparent}
.se-ribbon.se-ribbon-sale{background:var(--se-sale)}
.se-ribbon.se-ribbon-sale::before,.se-ribbon.se-ribbon-sale::after{border-top-color:var(--se-sale);border-bottom-color:var(--se-sale)}
.se-ribbon.se-ribbon-kraft{background:var(--se-kraft)}
.se-ribbon.se-ribbon-kraft::before,.se-ribbon.se-ribbon-kraft::after{border-top-color:var(--se-kraft);border-bottom-color:var(--se-kraft)}

/* ---------- Étoiles ---------- */
.se-stars{display:inline-flex;gap:1px;color:var(--se-star);vertical-align:middle}
.se-stars svg{width:16px;height:16px}
.se-rate{font-size:.86rem;color:var(--se-ink-soft);font-weight:600}

/* ---------- Barre d'annonce ---------- */
.se-announce{background:var(--se-green);color:var(--se-cream);font-size:.82rem;letter-spacing:.06em;
  text-align:center;padding:.6em 16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.6em}
.se-announce strong{color:#e7d8a8}
.se-announce svg{width:16px;height:16px;color:#e7d8a8;flex:none}

/* ---------- Header (logo à gauche + nav inline sur une seule rangée) ---------- */
.se-header{position:sticky;top:0;z-index:60;background:rgba(247,241,230,.94);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--se-line)}
.se-bar{display:flex;align-items:center;gap:24px;max-width:var(--se-maxw);margin:0 auto;padding:14px 24px}
.se-logo{display:flex;align-items:center;gap:13px;flex:none}
.se-logo img{height:40px;width:auto}
.se-logo-tag{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--se-kraft);font-weight:700;
  border-left:1px solid var(--se-line);padding-left:13px;max-width:9.5em;line-height:1.25}
.se-nav{margin-left:auto}
.se-nav ul{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:28px}
.se-nav a{font-size:.81rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--se-ink-soft);
  position:relative;padding:5px 0;transition:color .15s}
.se-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-1px;height:2px;background:var(--se-kraft);transition:right .22s ease}
.se-nav a:hover,.se-nav a.is-active{color:var(--se-green)}
.se-nav a:hover::after,.se-nav a.is-active::after{right:0}
.se-header-actions{display:flex;align-items:center;gap:6px;flex:none}
.se-iconbtn{background:none;border:none;cursor:pointer;color:var(--se-green);padding:6px;display:grid;place-items:center;
  position:relative;border-radius:8px;transition:background .15s}
.se-iconbtn:hover{background:var(--se-cream-2)}
.se-iconbtn svg{width:24px;height:24px}
.se-cart-count{position:absolute;top:-2px;right:-3px;background:var(--se-sale);color:#fff;font-size:.62rem;
  font-weight:700;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px;font-family:var(--se-body)}
.se-burger{display:none}

/* ---------- Mobile menu ---------- */
.se-mobile{position:fixed;inset:0;z-index:90;background:var(--se-cream);transform:translateX(-100%);
  transition:transform .3s ease;padding:24px;display:flex;flex-direction:column;overflow:auto}
.se-mobile.open{transform:translateX(0)}
.se-mobile-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.se-mobile a{display:block;font-family:var(--se-serif);font-size:1.7rem;color:var(--se-green);padding:.45em 0;border-bottom:1px solid var(--se-line)}

/* ---------- Hero ---------- */
.se-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--se-line)}
.se-hero-grid{display:grid;grid-template-columns:1.05fr 1fr;align-items:stretch;min-height:560px}
.se-hero-copy{padding:64px clamp(24px,5vw,72px);display:flex;flex-direction:column;justify-content:center;position:relative}
.se-hero-copy h1{margin-bottom:.3em}
.se-hero-copy .se-lead{font-size:1.2rem;color:var(--se-ink-soft);max-width:30em;margin-bottom:1.6em}
.se-hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.se-hero-media{position:relative;background:var(--se-cream-2)}
.se-hero-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.se-hero-seal{position:absolute;right:26px;bottom:24px;z-index:3}
.se-hero-trust{display:flex;gap:26px;flex-wrap:wrap;margin-top:2em;padding-top:1.4em;border-top:1px dashed var(--se-line)}
.se-hero-trust div{font-size:.82rem;color:var(--se-ink-soft);max-width:11em}
.se-hero-trust strong{display:block;font-family:var(--se-serif);font-size:1.05rem;color:var(--se-green)}

/* ---------- Bandeau de réassurance (icônes dessinées) ---------- */
.se-assure{background:var(--se-green);color:var(--se-cream)}
.se-assure-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:30px 24px}
.se-assure-item{display:flex;gap:13px;align-items:center}
.se-assure-item svg{width:34px;height:34px;flex:none;color:#e7d8a8}
.se-assure-item strong{display:block;font-family:var(--se-serif);font-size:1.05rem;color:var(--se-white)}
.se-assure-item span{font-size:.8rem;color:rgba(243,236,222,.82)}

/* ---------- Section générique ---------- */
.se-sec{padding:clamp(56px,8vw,96px) 0}
.se-sec-head{max-width:38em;margin:0 auto 48px}
.se-sec-head.left{margin-left:0;text-align:left}

/* ---------- Liste produits verticale (signature craft-boutique) ---------- */
.se-list{display:flex;flex-direction:column;gap:46px}
.se-listrow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,64px);align-items:center}
.se-listrow:nth-child(even) .se-listrow-media{order:2}
.se-listrow-media{position:relative;border-radius:var(--se-radius);overflow:hidden;box-shadow:var(--se-shadow);
  background:var(--se-cream-2);aspect-ratio:4/3}
.se-listrow-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.se-listrow:hover .se-listrow-media img{transform:scale(1.04)}
.se-listrow-badges{position:absolute;top:16px;left:0;display:flex;flex-direction:column;gap:8px;z-index:2}
.se-listrow-body .se-cat{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--se-kraft);font-weight:700}
.se-listrow-body h3{font-size:clamp(1.5rem,2.6vw,2rem);margin:.25em 0 .3em}
.se-listrow-body .se-short{color:var(--se-ink-soft);margin-bottom:1em}
.se-listrow-bul{list-style:none;padding:0;margin:0 0 1.2em;display:flex;flex-direction:column;gap:.45em}
.se-listrow-bul li{display:flex;gap:.6em;align-items:flex-start;font-size:.92rem}
.se-listrow-bul svg{width:18px;height:18px;color:var(--se-accent);flex:none;margin-top:2px}
.se-priceline{display:flex;align-items:baseline;gap:12px;margin-bottom:1.1em;flex-wrap:wrap}
.se-price{font-family:var(--se-serif);font-size:1.7rem;color:var(--se-green)}
.se-was{text-decoration:line-through;color:var(--se-ink-soft);font-size:1.05rem}
.se-save{background:var(--se-sale);color:#fff;font-size:.72rem;font-weight:700;padding:.2em .6em;border-radius:5px}
.se-listrow-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

/* ---------- Cartes produit (portrait, shop + related) ---------- */
.se-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.se-card{position:relative;background:var(--se-white);border:1px solid var(--se-line);border-radius:var(--se-radius);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--se-shadow-sm);transition:transform .2s,box-shadow .2s}
.se-card:hover{transform:translateY(-4px);box-shadow:var(--se-shadow)}
.se-card-media{position:relative;aspect-ratio:1/1;background:var(--se-cream-2);overflow:hidden}
.se-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.se-card:hover .se-card-media img{transform:scale(1.05)}
.se-card-badges{position:absolute;top:12px;left:0;display:flex;flex-direction:column;gap:7px;z-index:2}
.se-card-body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.se-card-body .se-cat{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--se-kraft);font-weight:700}
.se-card-body h3{font-size:1.18rem;margin:.3em 0 .35em;line-height:1.2}
.se-card-body h3 a{color:var(--se-green)}
.se-card-rate{display:flex;align-items:center;gap:6px;margin-bottom:.5em}
.se-card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:12px}
.se-card .se-price{font-size:1.3rem}
.se-quickadd{border:1.5px solid var(--se-green);background:transparent;color:var(--se-green);border-radius:30px;
  padding:.5em 1em;font-weight:700;font-size:.82rem;cursor:pointer;transition:background .15s,color .15s}
.se-quickadd:hover{background:var(--se-green);color:#fff}

/* ---------- Timeline de fabrication ---------- */
.se-craft{background:var(--se-paper);border-top:1px solid var(--se-line);border-bottom:1px solid var(--se-line)}
.se-timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;position:relative}
.se-step{background:var(--se-white);border:1px solid var(--se-line);border-radius:var(--se-radius);overflow:hidden;box-shadow:var(--se-shadow-sm)}
.se-step-media{aspect-ratio:4/3;overflow:hidden;background:var(--se-cream-2)}
.se-step-media img{width:100%;height:100%;object-fit:cover}
.se-step-body{padding:22px}
.se-step-num{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--se-green);
  color:var(--se-cream);font-family:var(--se-serif);font-size:1.15rem;margin-bottom:.5em}
.se-step-body h3{font-size:1.25rem}

/* ---------- Bandeau catégorie illustré ---------- */
.se-splits{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.se-split{position:relative;border-radius:var(--se-radius);overflow:hidden;min-height:300px;display:flex;align-items:flex-end;
  box-shadow:var(--se-shadow)}
.se-split img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.se-split-inner{position:relative;z-index:2;padding:30px;color:#fff;
  background:linear-gradient(0deg,rgba(31,38,26,.78),transparent 70%);width:100%}
.se-split-inner h3{color:#fff;font-size:1.7rem;margin-bottom:.2em}
.se-split-inner p{color:rgba(255,255,255,.9);margin-bottom:.8em}
.se-split .se-btn-ghost{color:#fff;border-color:#fff}
.se-split .se-btn-ghost:hover{background:#fff;color:var(--se-green)}

/* ---------- Avis mis en avant ---------- */
.se-reviews{background:var(--se-green);color:var(--se-cream)}
.se-reviews h2{color:var(--se-white)}
.se-reviews .se-eyebrow{color:#e7d8a8}
.se-rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.se-rev{background:rgba(255,253,248,.07);border:1px solid rgba(231,216,168,.3);border-radius:var(--se-radius);padding:26px;position:relative}
.se-rev .se-stars{color:#e7d8a8;margin-bottom:.6em}
.se-rev p{font-family:var(--se-serif);font-size:1.12rem;line-height:1.45;color:var(--se-white)}
.se-rev cite{font-style:normal;font-size:.84rem;color:rgba(243,236,222,.78);font-weight:700}
.se-rev-mark{position:absolute;top:16px;right:18px;color:rgba(231,216,168,.4);line-height:1}
.se-rev-mark svg{width:26px;height:26px}

/* ---------- Editorial story / journal ---------- */
.se-story{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,60px);align-items:center}
.se-story-media{border-radius:var(--se-radius);overflow:hidden;box-shadow:var(--se-shadow);aspect-ratio:4/3}
.se-story-media img{width:100%;height:100%;object-fit:cover}

/* ---------- Newsletter ---------- */
.se-news{background:var(--se-kraft);color:var(--se-cream);text-align:center}
.se-news h2{color:var(--se-white)}
.se-news-form{display:flex;gap:10px;max-width:480px;margin:18px auto 0;flex-wrap:wrap;justify-content:center}
.se-news-form input{flex:1;min-width:220px;padding:.9em 1.1em;border-radius:40px;border:1.5px solid rgba(255,255,255,.5);
  background:rgba(255,255,255,.12);color:#fff;font-family:var(--se-body);font-size:.95rem}
.se-news-form input::placeholder{color:rgba(255,255,255,.7)}
.se-news-note{font-size:.78rem;color:rgba(243,236,222,.8);margin-top:.9em}

/* ---------- Bande de compteurs / manifeste chiffré ---------- */
.se-stats{background:var(--se-paper);border-top:1px solid var(--se-line);border-bottom:1px solid var(--se-line)}
.se-stats .se-wrap{padding:clamp(46px,7vw,76px) 24px}
.se-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:8px}
.se-stat{text-align:center;padding:20px 14px;position:relative}
.se-stat+.se-stat::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:1px;background:var(--se-line)}
.se-stat svg{width:26px;height:26px;color:var(--se-kraft);margin-bottom:.5em}
.se-stat strong{display:block;font-family:var(--se-serif);font-size:clamp(2rem,3.6vw,2.7rem);color:var(--se-green);line-height:1}
.se-stat span{display:block;font-size:.84rem;color:var(--se-ink-soft);margin-top:.5em;letter-spacing:.02em}

/* ---------- Footer (variante NEWSLETTER-DOMINANT) ---------- */
.se-footer{background:var(--se-ink);color:#cbc4b4;font-size:.92rem}
.se-footer a{color:#cbc4b4;transition:color .15s}
.se-footer a:hover{color:#e7d8a8}

/* grand bloc d'inscription en haut */
.se-foot-news{position:relative;overflow:hidden;color:var(--se-cream);
  background:linear-gradient(135deg,var(--se-green) 0%,var(--se-green-2) 48%,var(--se-kraft-dark) 130%);
  padding:clamp(48px,7vw,82px) 0;border-bottom:1px solid rgba(231,216,168,.18)}
.se-foot-news::after{content:"";position:absolute;right:-60px;bottom:-60px;width:240px;height:240px;border-radius:50%;
  border:2px dashed rgba(231,216,168,.22);pointer-events:none}
.se-foot-news-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;position:relative;z-index:2}
.se-foot-news .se-eyebrow{color:#e7d8a8}
.se-foot-news h2{color:var(--se-white);font-size:clamp(1.9rem,3.8vw,2.9rem);margin-bottom:.25em}
.se-foot-news p{color:rgba(243,236,222,.86);max-width:30em;margin:0}
.se-foot-news-field{display:flex;gap:10px;flex-wrap:wrap}
.se-foot-news-field input{flex:1;min-width:230px;padding:1em 1.25em;border-radius:40px;border:1.5px solid rgba(255,255,255,.42);
  background:rgba(255,255,255,.12);color:#fff;font-family:var(--se-body);font-size:1rem}
.se-foot-news-field input::placeholder{color:rgba(255,255,255,.72)}
.se-foot-news-field .se-btn-kraft{background:var(--se-cream);color:var(--se-green)}
.se-foot-news-field .se-btn-kraft:hover{background:#fff}
.se-foot-news-note{font-size:.78rem;color:rgba(243,236,222,.72);margin:.95em 0 0}
.se-foot-news-note svg{width:14px;height:14px;vertical-align:-2px;margin-right:.3em}

/* liens compacts au milieu */
.se-foot-mid{display:grid;grid-template-columns:1.4fr 2fr;gap:clamp(28px,5vw,56px);padding:46px 24px 40px}
.se-footer-word{font-family:var(--se-serif);font-size:1.9rem;color:var(--se-cream);margin-bottom:.25em}
.se-foot-brand p{max-width:24em;margin:0 0 1em}
.se-foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.se-footer h4{color:var(--se-cream);font-family:var(--se-body);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;margin:0 0 1em}
.se-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5em;font-size:.9rem}
.se-social{display:flex;gap:12px}
.se-social a{display:grid;place-items:center;width:38px;height:38px;border:1px solid rgba(203,196,180,.3);border-radius:50%}
.se-social svg{width:18px;height:18px}

/* pied : paiement + légal */
.se-foot-base{border-top:1px solid rgba(203,196,180,.16);background:rgba(0,0,0,.18)}
.se-foot-base-row{display:flex;justify-content:space-between;align-items:center;gap:18px 30px;flex-wrap:wrap;padding:20px 24px}
.se-pay{display:flex;gap:8px;flex-wrap:wrap}
.se-pay svg{height:24px;width:auto;border-radius:4px}
.se-foot-legal{display:flex;flex-direction:column;gap:2px;font-size:.76rem;color:#9a9385;text-align:right;margin-left:auto}

/* ---------- Cart drawer ---------- */
.se-overlay{position:fixed;inset:0;background:rgba(44,42,35,.5);z-index:95;opacity:0;visibility:hidden;transition:opacity .25s}
.se-overlay.open{opacity:1;visibility:visible}
.se-drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,100%);background:var(--se-cream);z-index:100;
  transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;box-shadow:-10px 0 40px rgba(0,0,0,.2)}
.se-drawer.open{transform:translateX(0)}
.se-drawer-head{display:flex;justify-content:space-between;align-items:center;padding:20px 22px;border-bottom:1px solid var(--se-line)}
.se-drawer-head h3{margin:0}
.se-ship-bar{padding:14px 22px;background:var(--se-paper);border-bottom:1px solid var(--se-line);font-size:.82rem}
.se-ship-track{height:7px;background:var(--se-cream-2);border-radius:4px;margin-top:8px;overflow:hidden}
.se-ship-fill{height:100%;background:var(--se-accent);width:0;transition:width .4s}
.se-drawer-items{flex:1;overflow:auto;padding:8px 22px}
.se-ci{display:grid;grid-template-columns:64px 1fr auto;gap:12px;padding:16px 0;border-bottom:1px solid var(--se-line)}
.se-ci img{width:64px;height:64px;object-fit:cover;border-radius:8px;background:var(--se-cream-2)}
.se-ci-name{font-weight:700;font-size:.92rem;line-height:1.2}
.se-ci-qty{display:inline-flex;align-items:center;gap:8px;margin-top:6px;border:1px solid var(--se-line);border-radius:20px;padding:2px 6px}
.se-ci-qty button{border:none;background:none;cursor:pointer;font-size:1rem;color:var(--se-green);width:22px}
.se-ci-rm{background:none;border:none;color:var(--se-ink-soft);cursor:pointer;font-size:.74rem;text-decoration:underline;
  display:inline-flex;align-items:center;gap:4px;padding:0;margin-top:6px}
.se-ci-rm svg{width:12px;height:12px}
.se-ci-price{font-weight:700;color:var(--se-green)}
.se-drawer-foot{padding:18px 22px;border-top:1px solid var(--se-line);background:var(--se-paper)}
.se-drawer-total{display:flex;justify-content:space-between;font-size:1.1rem;font-weight:700;margin-bottom:12px}
.se-drawer-empty{padding:50px 22px;text-align:center;color:var(--se-ink-soft)}

/* ---------- Sticky ATC mobile ---------- */
.se-sticky-atc{position:fixed;left:0;right:0;bottom:0;z-index:55;background:var(--se-cream);border-top:1px solid var(--se-line);
  padding:10px 16px;display:none;align-items:center;gap:12px;box-shadow:0 -6px 20px rgba(0,0,0,.08)}
.se-sticky-atc .se-price{font-size:1.25rem}
.se-sticky-atc .se-btn{flex:1}

/* ---------- PDP ---------- */
.se-pdp{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,4vw,56px);padding:42px 0}
.se-gallery-main{border-radius:var(--se-radius);overflow:hidden;background:var(--se-cream-2);aspect-ratio:1/1;box-shadow:var(--se-shadow);position:relative}
.se-gallery-main img{width:100%;height:100%;object-fit:cover}
.se-gallery-badges{position:absolute;top:16px;left:0;display:flex;flex-direction:column;gap:8px;z-index:2}
.se-thumbs{display:flex;gap:12px;margin-top:14px}
.se-thumb{width:84px;height:84px;border-radius:10px;overflow:hidden;border:2px solid transparent;cursor:pointer;background:var(--se-cream-2)}
.se-thumb.active{border-color:var(--se-green)}
.se-thumb img{width:100%;height:100%;object-fit:cover}
.se-pdp-info .se-cat{font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--se-kraft);font-weight:700}
.se-pdp-info h1{font-size:clamp(2rem,3.4vw,2.7rem);margin:.2em 0 .3em}
.se-pdp-rate{display:flex;align-items:center;gap:8px;margin-bottom:1em}
.se-pdp-rate a{font-size:.85rem;color:var(--se-ink-soft);text-decoration:underline}
.se-pdp-price{display:flex;align-items:baseline;gap:14px;margin:0 0 1.1em;flex-wrap:wrap}
.se-pdp-price .se-price{font-size:2.1rem}
.se-bul{list-style:none;padding:0;margin:1.2em 0;display:flex;flex-direction:column;gap:.6em}
.se-bul li{display:flex;gap:.6em;align-items:flex-start}
.se-bul svg{width:20px;height:20px;color:var(--se-accent);flex:none;margin-top:3px}
.se-qtyrow{display:flex;gap:14px;align-items:center;margin:1.4em 0}
.se-qty{display:inline-flex;align-items:center;border:1.5px solid var(--se-line);border-radius:30px;overflow:hidden}
.se-qty button{border:none;background:var(--se-white);width:42px;height:46px;font-size:1.2rem;cursor:pointer;color:var(--se-green)}
.se-qty input{width:42px;text-align:center;border:none;font-size:1rem;font-family:var(--se-body);background:transparent}
.se-pdp-assure{display:flex;flex-wrap:wrap;gap:18px;margin:1.4em 0;padding:1.2em 0;border-top:1px dashed var(--se-line);border-bottom:1px dashed var(--se-line)}
.se-pdp-assure div{display:flex;gap:8px;align-items:center;font-size:.82rem;color:var(--se-ink-soft)}
.se-pdp-assure svg{width:22px;height:22px;color:var(--se-green);flex:none}
.se-pdp-seals{display:flex;gap:14px;flex-wrap:wrap;margin-top:1em}

/* PDP sections détaillées */
.se-pdp-sections{display:grid;grid-template-columns:1fr;gap:0;max-width:880px;margin:0 auto}
.se-acc{border-bottom:1px solid var(--se-line)}
.se-acc-head{width:100%;background:none;border:none;text-align:left;padding:20px 4px;font-family:var(--se-serif);
  font-size:1.3rem;color:var(--se-green);cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.se-acc-head svg{width:20px;height:20px;transition:transform .2s;flex:none}
.se-acc.open .se-acc-head svg{transform:rotate(45deg)}
.se-acc-body{display:none;padding:0 4px 22px}
.se-acc.open .se-acc-body{display:block}
.se-spec{width:100%;border-collapse:collapse}
.se-spec th,.se-spec td{text-align:left;padding:.7em 0;border-bottom:1px solid var(--se-line);font-size:.92rem;vertical-align:top}
.se-spec th{color:var(--se-ink-soft);font-weight:700;width:35%}
.se-faq dt{font-weight:700;margin-top:1em}
.se-faq dd{margin:.2em 0 0;color:var(--se-ink-soft)}

/* Reviews breakdown */
.se-rb{display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center;background:var(--se-paper);
  border:1px solid var(--se-line);border-radius:var(--se-radius);padding:26px;margin-bottom:24px}
.se-rb-score{text-align:center}
.se-rb-score strong{font-family:var(--se-serif);font-size:3rem;color:var(--se-green);display:block;line-height:1}
.se-rb-bars{display:flex;flex-direction:column;gap:6px}
.se-rb-bar{display:flex;align-items:center;gap:10px;font-size:.8rem}
.se-rb-n{display:inline-flex;align-items:center;gap:2px;min-width:24px;color:var(--se-ink-soft);font-weight:600}
.se-rb-n svg{width:12px;height:12px;color:var(--se-star)}
.se-rb-bar .t{height:7px;background:var(--se-cream-2);border-radius:4px;flex:1;overflow:hidden}
.se-rb-bar .t i{display:block;height:100%;background:var(--se-star)}
.se-revlist{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.se-revcard{background:var(--se-white);border:1px solid var(--se-line);border-radius:var(--se-radius);padding:20px}
.se-revcard .se-stars{margin-bottom:.4em}
.se-revcard cite{font-style:normal;font-weight:700;font-size:.85rem}
.se-revcard .d{font-size:.74rem;color:var(--se-ink-soft)}

/* ---------- Shop ---------- */
.se-shop-head{background:var(--se-paper);border-bottom:1px solid var(--se-line);position:relative;overflow:hidden}
.se-shop-head .se-wrap{position:relative;z-index:2;padding:48px 24px}
.se-shop-bg{position:absolute;inset:0;opacity:.16}
.se-shop-bg img{width:100%;height:100%;object-fit:cover}
.se-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:30px}
.se-filters{display:flex;gap:8px;flex-wrap:wrap}
.se-chip{border:1.5px solid var(--se-line);background:var(--se-white);color:var(--se-ink-soft);border-radius:30px;
  padding:.45em 1em;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .15s}
.se-chip:hover{border-color:var(--se-kraft)}
.se-chip.active{background:var(--se-green);color:#fff;border-color:var(--se-green)}
.se-select{border:1.5px solid var(--se-line);border-radius:30px;padding:.5em 1em;font-family:var(--se-body);background:var(--se-white);color:var(--se-ink);font-weight:600}

/* ---------- Page intro / breadcrumb ---------- */
.se-page-head{text-align:center;padding:54px 0 10px}
.se-crumb{font-size:.8rem;color:var(--se-ink-soft);margin-bottom:1.4em}
.se-crumb a{color:var(--se-kraft)}

/* ---------- Prose (legal/about) ---------- */
.se-prose{max-width:760px;margin:0 auto;padding:20px 0 40px}
.se-prose h2{font-size:1.6rem;margin-top:1.4em}
.se-prose h3{margin-top:1.2em}
.se-prose ul{padding-left:1.2em}

/* ---------- Contact ---------- */
.se-contact{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.se-field{margin-bottom:16px}
.se-field label{display:block;font-size:.82rem;font-weight:700;margin-bottom:.4em;color:var(--se-ink-soft)}
.se-field input,.se-field textarea{width:100%;padding:.8em 1em;border:1.5px solid var(--se-line);border-radius:10px;
  font-family:var(--se-body);font-size:.95rem;background:var(--se-white)}
.se-field textarea{min-height:140px;resize:vertical}

/* ---------- Reveal (avec FILET de sécurité) ---------- */
.se-reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.se-reveal.in,.se-shown .se-reveal{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .se-reveal{opacity:1!important;transform:none!important}
}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .se-hero-grid{grid-template-columns:1fr}
  .se-hero-media{min-height:340px;order:-1}
  .se-assure-grid{grid-template-columns:repeat(2,1fr)}
  .se-cards{grid-template-columns:repeat(2,1fr)}
  .se-timeline,.se-rev-grid{grid-template-columns:1fr}
  .se-pdp{grid-template-columns:1fr}
  .se-story,.se-splits,.se-contact{grid-template-columns:1fr}
  .se-listrow{grid-template-columns:1fr;gap:18px}
  .se-listrow:nth-child(even) .se-listrow-media{order:0}
  .se-revlist{grid-template-columns:1fr}
  .se-stats-grid{grid-template-columns:repeat(2,1fr)}
  .se-stat:nth-child(3)::before{display:none}
  .se-foot-news-grid{grid-template-columns:1fr}
  .se-foot-mid{grid-template-columns:1fr}
}
@media (max-width:640px){
  body{font-size:16px}
  .se-nav{display:none}
  .se-burger{display:grid}
  .se-logo-tag{display:none}
  .se-bar{gap:12px}
  .se-header-actions{margin-left:auto}
  .se-logo img{height:36px}
  .se-cards{grid-template-columns:1fr}
  .se-foot-cols{grid-template-columns:1fr 1fr}
  .se-foot-base-row{flex-direction:column;align-items:flex-start}
  .se-foot-legal{text-align:left;margin-left:0}
  .se-sticky-atc{display:flex}
  .se-rb{grid-template-columns:1fr;text-align:center}
  body.se-has-sticky{padding-bottom:74px}
}
