/* ==========================================================================
   Playbirch — design system SOFT-ORGANIC (archétype C)
   Préfixe de classes : .pb-  | Polices : Baloo 2 (display) + Nunito (body)
   Palette : jaune soleil #FFC83D · bleu ciel #54B9E8 · tomate #FF6B54
   ========================================================================== */
:root{
  --pb-yellow:#FFC83D; --pb-yellow-deep:#F4A92E;
  --pb-sky:#54B9E8; --pb-sky-deep:#2E9BD0;
  --pb-tomato:#FF6B54; --pb-tomato-deep:#EF5038;
  --pb-leaf:#7FCB6B; --pb-grape:#7C6CF0;
  --pb-ink:#2C2A4A; --pb-ink-soft:#5A5775;
  --pb-cream:#FFF8EE; --pb-cream-2:#FFF2DD;
  --pb-wood:#E9C893; --pb-white:#ffffff;
  --pb-sky-tint:#EAF6FC; --pb-yellow-tint:#FFF3D2; --pb-tomato-tint:#FFE8E2;
  --pb-shadow:0 18px 40px -16px rgba(44,42,74,.28);
  --pb-shadow-sm:0 8px 20px -10px rgba(44,42,74,.30);
  --pb-radius:30px; --pb-radius-lg:44px; --pb-radius-pill:999px;
  --pb-display:'Baloo 2', system-ui, sans-serif;
  --pb-body:'Nunito', system-ui, sans-serif;
  --pb-maxw:1200px;
  --pb-ease:cubic-bezier(.34,1.56,.64,1); /* élastique */
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:var(--pb-body); color:var(--pb-ink);
  background:var(--pb-cream); line-height:1.6; font-size:17px;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
h1,h2,h3,h4,.pb-display{font-family:var(--pb-display); line-height:1.1; margin:0 0 .4em; font-weight:700; letter-spacing:-.01em}
h1{font-size:clamp(2.3rem,5.4vw,4.1rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.9rem)}
h3{font-size:1.35rem}
p{margin:0 0 1rem}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
button{font-family:inherit; cursor:pointer; border:none; background:none}
.pb-wrap{max-width:var(--pb-maxw); margin:0 auto; padding:0 clamp(18px,4vw,40px)}
.pb-section{padding:clamp(48px,7vw,96px) 0; position:relative}
.pb-eyebrow{display:inline-flex; align-items:center; gap:8px; font-family:var(--pb-display);
  font-weight:600; font-size:.85rem; text-transform:uppercase; letter-spacing:.12em;
  color:var(--pb-tomato-deep); background:var(--pb-tomato-tint); padding:7px 16px; border-radius:var(--pb-radius-pill)}
.pb-center{text-align:center}
.pb-muted{color:var(--pb-ink-soft)}

/* ---- Boutons ---- */
.pb-btn{display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--pb-display); font-weight:600; font-size:1.02rem;
  padding:15px 30px; border-radius:var(--pb-radius-pill); transition:transform .25s var(--pb-ease), box-shadow .25s, background .2s;
  border:3px solid transparent; white-space:nowrap}
.pb-btn:hover{transform:translateY(-3px) scale(1.02)}
.pb-btn:active{transform:translateY(0) scale(.98)}
.pb-btn--primary{background:var(--pb-tomato); color:#fff; box-shadow:0 10px 0 -2px var(--pb-tomato-deep)}
.pb-btn--primary:hover{box-shadow:0 14px 0 -2px var(--pb-tomato-deep)}
.pb-btn--sky{background:var(--pb-sky); color:#fff; box-shadow:0 10px 0 -2px var(--pb-sky-deep)}
.pb-btn--sky:hover{box-shadow:0 14px 0 -2px var(--pb-sky-deep)}
.pb-btn--sun{background:var(--pb-yellow); color:var(--pb-ink); box-shadow:0 10px 0 -2px var(--pb-yellow-deep)}
.pb-btn--ghost{background:#fff; color:var(--pb-ink); border-color:var(--pb-ink)}
.pb-btn--ghost:hover{background:var(--pb-ink); color:#fff}
.pb-btn--block{width:100%}
.pb-btn--lg{padding:18px 38px; font-size:1.12rem}
.pb-btn--sm{padding:10px 18px; font-size:.92rem; box-shadow:none!important}

/* ---- Blobs déco ---- */
.pb-blob{position:absolute; border-radius:50% 50% 48% 52%/55% 48% 52% 45%; filter:blur(2px); opacity:.6; z-index:0; pointer-events:none}
.pb-blob--y{background:var(--pb-yellow-tint)}
.pb-blob--s{background:var(--pb-sky-tint)}
.pb-blob--t{background:var(--pb-tomato-tint)}

/* ---- Séparateur ondulé ---- */
.pb-wave{display:block; width:100%; height:54px; line-height:0}
.pb-wave svg{width:100%; height:100%; display:block}

/* ==========================================================================
   Barre d'annonce + marquee
   ========================================================================== */
.pb-announce{background:var(--pb-ink); color:#fff; font-family:var(--pb-display); font-weight:500; font-size:.92rem; overflow:hidden; white-space:nowrap}
.pb-marquee{display:inline-block; padding:9px 0; animation:pb-scroll 26s linear infinite}
.pb-marquee span{padding:0 26px; display:inline-flex; align-items:center; gap:9px}
.pb-marquee .pb-dot{color:var(--pb-yellow)}
@keyframes pb-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ==========================================================================
   Header — barre double soft-organic (rangée principale + ruban catégories)
   ========================================================================== */
.pb-header{position:sticky; top:0; z-index:60}
.pb-headbar{background:rgba(255,248,238,.93); backdrop-filter:blur(12px);
  box-shadow:0 14px 32px -22px rgba(44,42,74,.55); border-bottom:3px solid var(--pb-yellow)}
.pb-headrow{display:flex; align-items:center; gap:18px; padding:12px 0}
.pb-subbar{background:var(--pb-cream-2); border-bottom:2px solid rgba(44,42,74,.06)}
.pb-subrow{display:flex; align-items:center; gap:18px; padding:8px 0}
.pb-subnote{display:inline-flex; align-items:center; gap:9px; font-family:var(--pb-display);
  font-weight:700; font-size:.9rem; color:var(--pb-tomato-deep); flex-shrink:0}
.pb-subnote svg{width:22px; height:22px}
.pb-catstrip{display:flex; gap:3px; margin-left:auto; flex-wrap:wrap; justify-content:flex-end}
.pb-catstrip a{font-family:var(--pb-display); font-weight:600; font-size:.85rem; padding:6px 13px;
  border-radius:var(--pb-radius-pill); color:var(--pb-ink-soft); transition:background .2s, color .2s, box-shadow .2s}
.pb-catstrip a:hover{background:#fff; color:var(--pb-tomato-deep); box-shadow:var(--pb-shadow-sm)}
.pb-logo{display:flex; align-items:center; gap:10px; flex-shrink:0}
.pb-logo img{height:34px; width:auto}
.pb-nav{display:flex; gap:6px; margin:0 auto}
.pb-nav a{font-family:var(--pb-display); font-weight:600; font-size:1rem; padding:9px 16px;
  border-radius:var(--pb-radius-pill); color:var(--pb-ink); transition:background .2s, color .2s}
.pb-nav a:hover,.pb-nav a.is-active{background:var(--pb-yellow-tint); color:var(--pb-tomato-deep)}
.pb-head-tools{display:flex; align-items:center; gap:8px; flex-shrink:0}
.pb-icon-btn{width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:var(--pb-sky-tint); color:var(--pb-ink); transition:transform .25s var(--pb-ease), background .2s}
.pb-icon-btn:hover{transform:scale(1.1); background:var(--pb-sky); color:#fff}
.pb-cart-btn{position:relative; background:var(--pb-yellow)}
.pb-cart-btn:hover{background:var(--pb-yellow-deep)}
.pb-cart-count{position:absolute; top:-4px; right:-4px; min-width:22px; height:22px; padding:0 6px;
  background:var(--pb-tomato); color:#fff; border-radius:999px; font-family:var(--pb-display);
  font-weight:700; font-size:.74rem; display:grid; place-items:center; border:2px solid #fff}
.pb-burger{display:none}
.pb-lang{display:flex; align-items:center; gap:2px; font-family:var(--pb-display); font-weight:600; font-size:.85rem}
.pb-lang a{padding:4px 7px; border-radius:8px; color:var(--pb-ink-soft)}
.pb-lang a.is-active{background:var(--pb-ink); color:#fff}

/* mobile nav */
.pb-mobile{position:fixed; inset:0; z-index:120; background:var(--pb-cream); transform:translateY(-100%);
  transition:transform .4s var(--pb-ease); display:flex; flex-direction:column; padding:24px; overflow:auto}
.pb-mobile.is-open{transform:translateY(0)}
.pb-mobile a{font-family:var(--pb-display); font-weight:700; font-size:1.8rem; padding:14px 0; border-bottom:2px dashed var(--pb-wood)}

/* ==========================================================================
   HERO
   ========================================================================== */
.pb-hero{position:relative; padding:clamp(30px,5vw,60px) 0 clamp(60px,7vw,90px); overflow:hidden}
.pb-hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(24px,4vw,56px); align-items:center; position:relative; z-index:2}
.pb-hero h1 span{color:var(--pb-tomato)}
.pb-hero .pb-lead{font-size:1.22rem; max-width:32ch; color:var(--pb-ink-soft); margin-bottom:1.8rem}
.pb-hero-cta{display:flex; gap:14px; flex-wrap:wrap; align-items:center}
.pb-hero-trust{display:flex; gap:22px; margin-top:26px; flex-wrap:wrap}
.pb-hero-trust div{display:flex; align-items:center; gap:9px; font-weight:700; font-size:.95rem}
.pb-hero-media{position:relative}
.pb-hero-media .pb-hero-img{border-radius:46% 54% 56% 44%/50% 44% 56% 50%; box-shadow:var(--pb-shadow);
  aspect-ratio:1/1; object-fit:cover; width:100%; border:6px solid #fff}
.pb-hero-badge{position:absolute; background:#fff; border-radius:24px; box-shadow:var(--pb-shadow-sm); padding:12px 16px;
  display:flex; align-items:center; gap:10px; font-family:var(--pb-display); font-weight:700; font-size:.92rem}
.pb-hero-badge--1{top:6%; left:-4%; color:var(--pb-sky-deep)}
.pb-hero-badge--2{bottom:8%; right:-3%; color:var(--pb-tomato-deep)}
.pb-hero-badge .pb-emoji{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--pb-yellow-tint)}

/* ---- Bandeau de confiance (pastilles) ---- */
.pb-trustrow{display:flex; flex-wrap:wrap; justify-content:center; gap:14px}
.pb-trustrow .pb-pill{display:flex; align-items:center; gap:12px; background:#fff; border-radius:var(--pb-radius-pill);
  padding:12px 22px; box-shadow:var(--pb-shadow-sm); font-weight:700; font-size:.96rem}
.pb-trustrow .pb-pill .pb-ico{color:var(--pb-tomato)}

/* ==========================================================================
   Grille catégories (tuiles blob)
   ========================================================================== */
.pb-cats{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.pb-cat{position:relative; border-radius:var(--pb-radius-lg); padding:26px; min-height:180px;
  display:flex; flex-direction:column; justify-content:flex-end; overflow:hidden; color:var(--pb-ink);
  transition:transform .35s var(--pb-ease), box-shadow .3s; box-shadow:var(--pb-shadow-sm)}
.pb-cat:hover{transform:translateY(-6px) rotate(-1deg); box-shadow:var(--pb-shadow)}
.pb-cat:nth-child(6n+1){background:var(--pb-yellow-tint)}
.pb-cat:nth-child(6n+2){background:var(--pb-sky-tint)}
.pb-cat:nth-child(6n+3){background:var(--pb-tomato-tint)}
.pb-cat:nth-child(6n+4){background:#EAF7E6}
.pb-cat:nth-child(6n+5){background:#EFEBFE}
.pb-cat:nth-child(6n+6){background:var(--pb-cream-2)}
.pb-cat h3{font-size:1.4rem; margin-bottom:2px}
.pb-cat .pb-cat-n{font-weight:700; color:var(--pb-ink-soft); font-size:.9rem}
.pb-cat .pb-cat-ico{position:absolute; top:18px; right:18px; width:58px; height:58px; border-radius:50%;
  background:#fff; display:grid; place-items:center; box-shadow:var(--pb-shadow-sm)}
.pb-cat .pb-cat-arrow{margin-top:14px; display:inline-flex; align-items:center; gap:8px; font-family:var(--pb-display); font-weight:700; color:var(--pb-tomato-deep)}

/* ==========================================================================
   Cartes produit (très arrondies, badges ronds)
   ========================================================================== */
.pb-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:24px}
.pb-grid--3{grid-template-columns:repeat(3,1fr)}
.pb-card{background:#fff; border-radius:var(--pb-radius); overflow:hidden; box-shadow:var(--pb-shadow-sm);
  display:flex; flex-direction:column; position:relative; transition:transform .35s var(--pb-ease), box-shadow .3s}
.pb-card:hover{transform:translateY(-8px); box-shadow:var(--pb-shadow)}
.pb-card-media{position:relative; aspect-ratio:1/1; background:var(--pb-cream-2); overflow:hidden}
.pb-card-media img{width:100%; height:100%; object-fit:cover; transition:transform .5s var(--pb-ease)}
.pb-card:hover .pb-card-media img{transform:scale(1.06) rotate(-1deg)}
.pb-card-badges{position:absolute; top:12px; left:12px; display:flex; flex-direction:column; gap:6px; z-index:2}
.pb-badge{display:inline-flex; align-items:center; gap:5px; font-family:var(--pb-display); font-weight:700; font-size:.76rem;
  padding:6px 12px; border-radius:var(--pb-radius-pill); color:#fff; box-shadow:var(--pb-shadow-sm)}
.pb-badge--best{background:var(--pb-tomato)}
.pb-badge--new{background:var(--pb-sky-deep)}
.pb-badge--love{background:var(--pb-grape)}
.pb-badge--prem{background:var(--pb-ink)}
.pb-badge--sale{background:var(--pb-leaf); color:#fff}
.pb-card-fav{position:absolute; top:12px; right:12px; width:40px; height:40px; border-radius:50%; background:#fff;
  display:grid; place-items:center; box-shadow:var(--pb-shadow-sm); color:var(--pb-tomato); z-index:2}
.pb-quickadd{position:absolute; left:12px; right:12px; bottom:12px; transform:translateY(140%); opacity:0;
  transition:transform .35s var(--pb-ease), opacity .3s; z-index:2}
.pb-card:hover .pb-quickadd{transform:translateY(0); opacity:1}
.pb-card-body{padding:18px 20px 22px; display:flex; flex-direction:column; flex:1}
.pb-card-cat{font-family:var(--pb-display); font-weight:600; font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; color:var(--pb-sky-deep)}
.pb-card-title{font-family:var(--pb-display); font-weight:700; font-size:1.12rem; margin:3px 0 6px; line-height:1.2}
.pb-card-title a:hover{color:var(--pb-tomato-deep)}
.pb-stars{display:inline-flex; align-items:center; gap:5px; font-size:.86rem; font-weight:700; color:var(--pb-ink-soft)}
.pb-stars .pb-starsvg{color:var(--pb-yellow-deep)}
.pb-card-foot{margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top:14px}
.pb-price{display:flex; align-items:baseline; gap:8px}
.pb-price .pb-now{font-family:var(--pb-display); font-weight:700; font-size:1.4rem; color:var(--pb-ink)}
.pb-price .pb-was{font-size:.95rem; color:var(--pb-ink-soft); text-decoration:line-through}
.pb-age{font-size:.8rem; font-weight:700; color:var(--pb-ink-soft); background:var(--pb-cream-2); padding:4px 10px; border-radius:999px}

/* ==========================================================================
   Bandeau marquee défilant (ticker produits / arguments)
   ========================================================================== */
.pb-ticker{background:var(--pb-sky); color:#fff; overflow:hidden; white-space:nowrap; padding:14px 0}
.pb-ticker .pb-marquee{animation-duration:30s}
.pb-ticker .pb-marquee span{font-family:var(--pb-display); font-weight:700; font-size:1.3rem}
.pb-ticker .pb-dot{color:var(--pb-yellow)}

/* ==========================================================================
   Split éditorial / valeurs
   ========================================================================== */
.pb-split{display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,60px); align-items:center}
.pb-split-media img{border-radius:var(--pb-radius-lg); box-shadow:var(--pb-shadow); aspect-ratio:4/3; object-fit:cover; width:100%; border:6px solid #fff}
.pb-split--rev .pb-split-media{order:2}
.pb-values{display:grid; gap:18px; margin-top:24px}
.pb-value{display:flex; gap:16px; align-items:flex-start}
.pb-value .pb-vico{flex-shrink:0; width:56px; height:56px; border-radius:20px; display:grid; place-items:center}
.pb-value:nth-child(1) .pb-vico{background:var(--pb-yellow-tint); color:var(--pb-yellow-deep)}
.pb-value:nth-child(2) .pb-vico{background:var(--pb-sky-tint); color:var(--pb-sky-deep)}
.pb-value:nth-child(3) .pb-vico{background:var(--pb-tomato-tint); color:var(--pb-tomato-deep)}
.pb-value h3{margin-bottom:3px; font-size:1.15rem}
.pb-value p{margin:0; color:var(--pb-ink-soft); font-size:.97rem}

/* ---- bénéfices 4 icônes ---- */
.pb-benefits{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
.pb-benefit{background:#fff; border-radius:var(--pb-radius); padding:28px 22px; text-align:center; box-shadow:var(--pb-shadow-sm);
  transition:transform .35s var(--pb-ease)}
.pb-benefit:hover{transform:translateY(-6px)}
.pb-benefit .pb-bico{width:72px; height:72px; border-radius:50%; margin:0 auto 14px; display:grid; place-items:center}
.pb-benefit:nth-child(4n+1) .pb-bico{background:var(--pb-yellow-tint); color:var(--pb-yellow-deep)}
.pb-benefit:nth-child(4n+2) .pb-bico{background:var(--pb-sky-tint); color:var(--pb-sky-deep)}
.pb-benefit:nth-child(4n+3) .pb-bico{background:var(--pb-tomato-tint); color:var(--pb-tomato-deep)}
.pb-benefit:nth-child(4n+4) .pb-bico{background:#EAF7E6; color:var(--pb-leaf)}
.pb-benefit h3{font-size:1.1rem; margin-bottom:5px}
.pb-benefit p{margin:0; font-size:.92rem; color:var(--pb-ink-soft)}

/* ==========================================================================
   Comment ça marche — étapes numérotées (soft-organic)
   ========================================================================== */
.pb-steps{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; counter-reset:pbstep}
.pb-step{position:relative; background:#fff; border-radius:var(--pb-radius); padding:32px 26px 28px;
  box-shadow:var(--pb-shadow-sm); transition:transform .35s var(--pb-ease)}
.pb-step:hover{transform:translateY(-6px)}
.pb-step .pb-step-n{counter-increment:pbstep; width:54px; height:54px; border-radius:50% 50% 48% 52%/55% 48% 52% 45%;
  display:grid; place-items:center; font-family:var(--pb-display); font-weight:800; font-size:1.5rem; color:#fff; margin-bottom:16px}
.pb-step .pb-step-n::before{content:counter(pbstep)}
.pb-step:nth-child(1) .pb-step-n{background:var(--pb-yellow); color:var(--pb-ink)}
.pb-step:nth-child(2) .pb-step-n{background:var(--pb-sky)}
.pb-step:nth-child(3) .pb-step-n{background:var(--pb-tomato)}
.pb-step h3{font-size:1.2rem; margin-bottom:6px}
.pb-step p{margin:0; color:var(--pb-ink-soft); font-size:.96rem}
.pb-step .pb-step-ico{position:absolute; top:26px; right:24px; color:var(--pb-wood)}
.pb-step .pb-step-ico svg{width:26px; height:26px}

/* ==========================================================================
   Stats / compteurs (bande sombre)
   ========================================================================== */
.pb-statsband{background:var(--pb-ink); border-radius:var(--pb-radius-lg); padding:clamp(28px,4vw,46px);
  color:#fff; box-shadow:var(--pb-shadow); position:relative; overflow:hidden}
.pb-stats{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; position:relative; z-index:1}
.pb-stat{text-align:center}
.pb-stat .pb-stat-ico{width:50px; height:50px; border-radius:16px; display:grid; place-items:center;
  margin:0 auto 10px; background:rgba(255,255,255,.1); color:var(--pb-yellow)}
.pb-stat .pb-stat-ico svg{width:26px; height:26px}
.pb-stat .pb-stat-n{font-family:var(--pb-display); font-weight:800; font-size:clamp(1.7rem,3vw,2.5rem); color:var(--pb-yellow); line-height:1}
.pb-stat .pb-stat-l{font-weight:700; font-size:.9rem; color:rgba(255,255,255,.82); margin-top:5px}

/* ==========================================================================
   Avis en bulles
   ========================================================================== */
.pb-reviews{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.pb-bubble{background:#fff; border-radius:28px 28px 28px 6px; padding:26px; box-shadow:var(--pb-shadow-sm); position:relative}
.pb-bubble .pb-stars{margin-bottom:10px}
.pb-bubble p{font-size:1.02rem; color:var(--pb-ink)}
.pb-bubble .pb-rev-author{display:flex; align-items:center; gap:12px; margin-top:14px}
.pb-bubble .pb-avatar{width:44px; height:44px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--pb-display); font-weight:700; color:#fff; background:var(--pb-grape)}
.pb-bubble .pb-rev-name{font-family:var(--pb-display); font-weight:700; line-height:1.1}
.pb-bubble .pb-rev-date{font-size:.82rem; color:var(--pb-ink-soft)}

/* ==========================================================================
   Newsletter
   ========================================================================== */
.pb-news{position:relative; overflow:hidden; border-radius:var(--pb-radius-lg);
  background:linear-gradient(135deg,var(--pb-yellow) 0%,var(--pb-tomato) 100%); color:#fff;
  padding:clamp(36px,5vw,64px); text-align:center; box-shadow:var(--pb-shadow)}
.pb-news h2{color:#fff}
.pb-news p{color:rgba(255,255,255,.92); max-width:46ch; margin:0 auto 22px}
.pb-news-form{display:flex; gap:12px; max-width:480px; margin:0 auto; flex-wrap:wrap; justify-content:center}
.pb-news-form input{flex:1; min-width:220px; border:none; border-radius:var(--pb-radius-pill); padding:15px 22px; font-family:var(--pb-body); font-size:1rem}
.pb-news small{display:block; margin-top:14px; color:rgba(255,255,255,.85)}

/* ==========================================================================
   Footer — BENTO (tuiles : marque, liens, avis, paiement, social)
   ========================================================================== */
.pb-footer{background:var(--pb-ink); color:#fff; padding:clamp(40px,6vw,72px) 0 0}
.pb-bento{display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:minmax(0,auto); gap:16px}
.pb-bt{background:rgba(255,255,255,.05); border:1.5px solid rgba(255,255,255,.09);
  border-radius:var(--pb-radius); padding:24px 26px; display:flex; flex-direction:column}
.pb-bt h4{font-family:var(--pb-display); color:var(--pb-yellow); font-size:1rem; margin:0 0 12px}
.pb-bt a{display:block; color:rgba(255,255,255,.78); padding:5px 0; font-size:.95rem; transition:color .2s}
.pb-bt a:hover{color:#fff}
/* tuile marque (grande 2×2) */
.pb-bt--brand{grid-column:span 2; grid-row:span 2; justify-content:space-between; gap:18px;
  background:linear-gradient(150deg,rgba(255,200,61,.16),rgba(255,107,84,.16)); border-color:rgba(255,200,61,.28)}
.pb-bt--brand .pb-foot-word{font-family:var(--pb-display); font-weight:800; font-size:clamp(2rem,4vw,2.5rem); color:#fff; line-height:1}
.pb-bt--brand .pb-foot-word b{color:var(--pb-yellow)}
.pb-bt--brand p{color:rgba(255,255,255,.85); max-width:42ch; margin:12px 0 0}
.pb-foot-club{display:inline-flex; align-items:center; gap:10px; align-self:flex-start;
  background:rgba(0,0,0,.22); border-radius:var(--pb-radius-pill); padding:10px 18px;
  font-family:var(--pb-display); font-weight:700; font-size:.92rem}
.pb-foot-club svg{width:24px; height:24px; color:var(--pb-yellow)}
/* tuile avis */
.pb-bt--avis{background:var(--pb-yellow); color:var(--pb-ink); border-color:transparent;
  justify-content:center; align-items:center; text-align:center}
.pb-bt--avis .pb-foot-rate{font-family:var(--pb-display); font-weight:800; font-size:2.8rem; line-height:1}
.pb-foot-stars{display:inline-flex; gap:2px; color:var(--pb-ink); margin:6px 0}
.pb-bt--avis .pb-bt-sub{font-weight:800; font-size:.86rem}
/* tuile sociale (large) */
.pb-bt--social{grid-column:1 / -1; flex-direction:row; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap}
.pb-bt--social .pb-bt-follow{font-family:var(--pb-display); font-weight:700; color:rgba(255,255,255,.85)}
.pb-social{display:flex; gap:10px; margin:0}
.pb-social a{width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,.1); display:grid; place-items:center; color:#fff; transition:background .2s, transform .25s var(--pb-ease)}
.pb-social a:hover{background:var(--pb-tomato); transform:translateY(-3px)}
.pb-pay{display:flex; gap:8px; flex-wrap:wrap; margin-top:auto}
.pb-pay svg{height:30px; width:auto; border-radius:6px}
.pb-footer-bottom{margin-top:24px; border-top:1px solid rgba(255,255,255,.12); padding:22px 0;
  display:flex; justify-content:space-between; gap:14px 22px; flex-wrap:wrap; font-size:.84rem; color:rgba(255,255,255,.6)}
.pb-footer-bottom a{color:rgba(255,255,255,.7)}
.pb-foot-legal-links{display:flex; gap:18px; flex-wrap:wrap}
.pb-foot-legal-links a:hover{color:#fff}

/* ==========================================================================
   Drawer panier
   ========================================================================== */
.pb-overlay{position:fixed; inset:0; background:rgba(44,42,74,.45); opacity:0; visibility:hidden; transition:.3s; z-index:130}
.pb-overlay.is-open{opacity:1; visibility:visible}
.pb-drawer{position:fixed; top:0; right:0; height:100%; width:min(420px,92vw); background:var(--pb-cream); z-index:140;
  transform:translateX(100%); transition:transform .4s var(--pb-ease); display:flex; flex-direction:column; box-shadow:-20px 0 60px -20px rgba(0,0,0,.4)}
.pb-drawer.is-open{transform:translateX(0)}
.pb-drawer-head{display:flex; align-items:center; justify-content:space-between; padding:22px 24px; border-bottom:2px dashed var(--pb-wood)}
.pb-drawer-head h3{margin:0}
.pb-ship-bar{padding:16px 24px; background:var(--pb-sky-tint)}
.pb-ship-bar .pb-prog{height:10px; background:#fff; border-radius:999px; overflow:hidden; margin-top:8px}
.pb-ship-bar .pb-prog i{display:block; height:100%; background:var(--pb-leaf); border-radius:999px; transition:width .4s}
.pb-ship-bar p{margin:0; font-size:.88rem; font-weight:700}
.pb-drawer-items{flex:1; overflow:auto; padding:16px 24px}
.pb-citem{display:flex; gap:14px; padding:14px 0; border-bottom:1px solid #efe6d4}
.pb-citem img{width:72px; height:72px; border-radius:18px; object-fit:cover; background:var(--pb-cream-2)}
.pb-citem .pb-ci-info{flex:1}
.pb-citem .pb-ci-name{font-family:var(--pb-display); font-weight:700; font-size:.98rem; line-height:1.15}
.pb-qty{display:inline-flex; align-items:center; gap:0; border:2px solid var(--pb-wood); border-radius:999px; margin-top:8px}
.pb-qty button{width:30px; height:30px; font-size:1.1rem; font-weight:700; color:var(--pb-ink); display:grid; place-items:center}
.pb-qty span{min-width:30px; text-align:center; font-weight:700}
.pb-ci-rm{background:none; color:var(--pb-ink-soft); font-size:.82rem; text-decoration:underline; margin-top:6px; display:block}
.pb-drawer-foot{padding:20px 24px; border-top:2px dashed var(--pb-wood); background:#fff}
.pb-drawer-foot .pb-sum{display:flex; justify-content:space-between; font-family:var(--pb-display); font-weight:700; font-size:1.25rem; margin-bottom:14px}
.pb-empty{text-align:center; padding:50px 20px; color:var(--pb-ink-soft)}

/* ---- sticky cart bar (bas, mobile) ---- */
.pb-stickybar{position:fixed; left:12px; right:12px; bottom:12px; z-index:90; background:#fff; border-radius:var(--pb-radius-pill);
  box-shadow:var(--pb-shadow); padding:10px 12px 10px 22px; display:none; align-items:center; justify-content:space-between; gap:12px}
.pb-stickybar .pb-sb-info{font-family:var(--pb-display); font-weight:700}
.pb-stickybar .pb-sb-info small{display:block; font-family:var(--pb-body); font-weight:600; color:var(--pb-ink-soft); font-size:.78rem}

/* ==========================================================================
   PDP — page produit
   ========================================================================== */
.pb-pdp{display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(28px,4vw,56px); align-items:flex-start; position:relative}
.pb-gallery .pb-gal-main{position:relative; border-radius:var(--pb-radius-lg); overflow:hidden; background:var(--pb-cream-2);
  aspect-ratio:1/1; border:6px solid #fff; box-shadow:var(--pb-shadow)}
.pb-gallery .pb-gal-main img{width:100%; height:100%; object-fit:cover}
.pb-thumbs{display:flex; gap:12px; margin-top:14px}
.pb-thumbs button{width:84px; height:84px; border-radius:22px; overflow:hidden; border:3px solid transparent; background:var(--pb-cream-2)}
.pb-thumbs button.is-active{border-color:var(--pb-tomato)}
.pb-thumbs img{width:100%; height:100%; object-fit:cover}
.pb-pdp-info h1{font-size:clamp(2rem,3.6vw,2.8rem)}
.pb-pdp-price{display:flex; align-items:baseline; gap:12px; margin:8px 0 16px}
.pb-pdp-price .pb-now{font-family:var(--pb-display); font-weight:800; font-size:2.2rem}
.pb-pdp-price .pb-was{font-size:1.2rem; text-decoration:line-through; color:var(--pb-ink-soft)}
.pb-pdp-price .pb-save{background:var(--pb-leaf); color:#fff; font-family:var(--pb-display); font-weight:700; font-size:.85rem; padding:5px 12px; border-radius:999px}
.pb-swatches{display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 6px}
.pb-swatch{padding:9px 18px; border-radius:999px; border:2px solid var(--pb-wood); background:#fff; font-weight:700; font-size:.9rem; transition:.2s}
.pb-swatch.is-active{border-color:var(--pb-tomato); background:var(--pb-tomato-tint); color:var(--pb-tomato-deep)}
.pb-pdp-buy{display:flex; gap:12px; align-items:center; margin:18px 0}
.pb-pdp-reassure{display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-top:18px}
.pb-pdp-reassure div{display:flex; gap:10px; align-items:center; font-weight:700; font-size:.9rem}
.pb-pdp-reassure .pb-ico{color:var(--pb-sky-deep)}
.pb-bullets{list-style:none; padding:0; margin:18px 0}
.pb-bullets li{display:flex; gap:12px; align-items:flex-start; padding:7px 0; font-weight:600}
.pb-bullets .pb-ico{color:var(--pb-leaf); flex-shrink:0; margin-top:2px}
.pb-accordion{border-top:2px dashed var(--pb-wood)}
.pb-acc{border-bottom:2px dashed var(--pb-wood)}
.pb-acc-head{width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; padding:18px 0; font-family:var(--pb-display); font-weight:700; font-size:1.1rem}
.pb-acc-body{display:none; padding:0 0 18px; color:var(--pb-ink-soft)}
.pb-acc.is-open .pb-acc-body{display:block}
.pb-acc.is-open .pb-acc-head .pb-chev{transform:rotate(180deg)}
.pb-specs{width:100%; border-collapse:collapse}
.pb-specs td{padding:9px 0; border-bottom:1px solid #efe6d4; font-size:.95rem}
.pb-specs td:first-child{font-weight:700; width:42%}
.pb-stock{display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--pb-tomato-deep); font-size:.9rem}
.pb-stock .pb-dotpulse{width:10px; height:10px; border-radius:50%; background:var(--pb-tomato); animation:pb-pulse 1.4s infinite}
@keyframes pb-pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* distribution étoiles */
.pb-rev-summary{display:grid; grid-template-columns:auto 1fr; gap:30px; align-items:center; background:#fff; border-radius:var(--pb-radius); padding:28px; box-shadow:var(--pb-shadow-sm)}
.pb-rev-big{text-align:center}
.pb-rev-big .pb-rev-num{font-family:var(--pb-display); font-weight:800; font-size:3.4rem; line-height:1}
.pb-rev-dist{display:grid; gap:6px}
.pb-rev-row{display:flex; align-items:center; gap:10px; font-size:.86rem; font-weight:700}
.pb-rev-row .pb-bar{flex:1; height:9px; background:var(--pb-cream-2); border-radius:999px; overflow:hidden}
.pb-rev-row .pb-bar i{display:block; height:100%; background:var(--pb-yellow); border-radius:999px}

/* ==========================================================================
   Shop / filtres
   ========================================================================== */
.pb-shop-head{background:var(--pb-sky-tint); border-radius:var(--pb-radius-lg); padding:clamp(28px,4vw,48px); position:relative; overflow:hidden; margin-bottom:30px}
.pb-filters{display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-bottom:26px}
.pb-chip{font-family:var(--pb-display); font-weight:600; padding:10px 18px; border-radius:999px; background:#fff; box-shadow:var(--pb-shadow-sm); transition:.2s; cursor:pointer; border:2px solid transparent}
.pb-chip.is-active{background:var(--pb-ink); color:#fff}
.pb-chip:hover{transform:translateY(-2px)}
.pb-sortwrap{margin-left:auto; display:flex; align-items:center; gap:8px; font-weight:700}
.pb-sortwrap select{font-family:var(--pb-body); font-weight:700; padding:10px 16px; border-radius:999px; border:2px solid var(--pb-wood); background:#fff}

/* ==========================================================================
   Pages simples (about/contact/legal)
   ========================================================================== */
.pb-prose{max-width:760px; margin:0 auto}
.pb-prose h2{margin-top:1.6em}
.pb-prose ul{padding-left:1.2em}
.pb-page-hero{text-align:center; padding:clamp(40px,6vw,80px) 0 20px}
.pb-form{display:grid; gap:16px; max-width:560px; margin:0 auto}
.pb-form input,.pb-form textarea{border:2px solid var(--pb-wood); border-radius:20px; padding:14px 18px; font-family:var(--pb-body); font-size:1rem; background:#fff}
.pb-form label{font-family:var(--pb-display); font-weight:700; margin-bottom:-8px}
.pb-contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start}
.pb-contact-cards{display:grid; gap:16px}
.pb-contact-card{background:#fff; border-radius:var(--pb-radius); padding:22px; box-shadow:var(--pb-shadow-sm); display:flex; gap:14px; align-items:center}
.pb-contact-card .pb-ico{width:52px; height:52px; border-radius:16px; background:var(--pb-yellow-tint); color:var(--pb-yellow-deep); display:grid; place-items:center; flex-shrink:0}

/* ==========================================================================
   Reveal au scroll (+ filet de sécurité)
   ========================================================================== */
.pb-reveal{opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s var(--pb-ease)}
.pb-reveal.is-in{opacity:1; transform:none}
.pb-revealed .pb-reveal{opacity:1; transform:none} /* filet : si la classe est posée sur body */
@media (prefers-reduced-motion: reduce){
  *{animation:none!important; transition:none!important; scroll-behavior:auto!important}
  .pb-reveal{opacity:1!important; transform:none!important}
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media(max-width:980px){
  .pb-grid{grid-template-columns:repeat(2,1fr)}
  .pb-cats{grid-template-columns:repeat(2,1fr)}
  .pb-benefits{grid-template-columns:repeat(2,1fr)}
  .pb-steps{grid-template-columns:1fr}
  .pb-stats{grid-template-columns:repeat(2,1fr); gap:24px 18px}
  .pb-reviews{grid-template-columns:1fr}
  .pb-hero-grid,.pb-split,.pb-pdp,.pb-contact-grid{grid-template-columns:1fr}
  .pb-split--rev .pb-split-media{order:0}
  .pb-bento{grid-template-columns:repeat(2,1fr)}
  .pb-bt--brand{grid-column:span 2; grid-row:auto}
  .pb-nav{display:none}
  .pb-burger{display:grid}
  .pb-catstrip{display:none}
  .pb-subrow{justify-content:center}
  .pb-hero-media{max-width:440px; margin:0 auto}
  .pb-pdp{position:static}
}
@media(max-width:560px){
  body{font-size:16px}
  .pb-grid,.pb-grid--3,.pb-cats{grid-template-columns:1fr 1fr; gap:14px}
  .pb-benefits{grid-template-columns:1fr 1fr}
  .pb-bento{grid-template-columns:1fr}
  .pb-bt--brand{grid-column:auto}
  .pb-bt--social{flex-direction:column; align-items:flex-start}
  .pb-rev-summary{grid-template-columns:1fr}
  .pb-thumbs button{width:64px; height:64px}
  .pb-stickybar{display:flex}
  .pb-card-title{font-size:1rem}
  .pb-price .pb-now{font-size:1.2rem}
  .pb-lang{display:none}
  body{padding-bottom:80px}
}
