/* =========================================================
   ZEVLO — MiniCam Retro Zevlo™  •  Page de vente
   Palette : Noir (#000) / Rose clair (#F9E8E8) / Blanc
   Type    : Archivo (display) + Figtree (corps)
========================================================= */

:root{
  --ink:#0a0a0a;
  --ink-soft:#3a3a3a;
  --muted:#6b6b6b;
  --paper:#ffffff;
  --rose:#f9e8e8;
  --rose-2:#fdf3f3;
  --rose-grad-a:#fbeaea;
  --rose-grad-b:#f6dede;
  --line:#ececec;
  --line-2:#e2dada;
  --red:#e23b3b;
  --green:#1f9d55;
  --gold:#f5b301;
  --pad:20px;               /* marge latérale mobile (uniforme) */
  --maxw:1180px;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 8px 30px rgba(0,0,0,.08);
  --shadow-sm:0 2px 10px rgba(0,0,0,.06);
}

*{box-sizing:border-box;}
html,body{
  margin:0;padding:0;
  overflow-x:clip;            /* aucun scroll horizontal, sans casser position:sticky */
  width:100%;
  background:var(--paper);
  color:var(--ink);
  font-family:"Figtree",system-ui,-apple-system,sans-serif;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,video{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

h1,h2,h3,.display{
  font-family:"Archivo",system-ui,sans-serif;
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.05;
  margin:0;
  text-wrap:balance;
}

.container{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

.section{padding:64px 0;}
.section--rose{background:var(--rose);}
.section-title{
  font-size:clamp(28px,4.4vw,46px);
  text-align:center;
  margin-bottom:14px;
}
.section-intro{
  text-align:center;max-width:680px;margin:0 auto 44px;
  color:var(--ink-soft);font-size:17px;text-wrap:pretty;
}

/* Placeholder médias (image grise rayée) */
.ph{
  position:relative;overflow:hidden;background:#c9c9c9;
  background-image:repeating-linear-gradient(45deg,
    rgba(255,255,255,.18) 0 14px, rgba(0,0,0,.04) 14px 28px);
}
.ph img,.ph video{width:100%;height:100%;object-fit:cover;}

/* ============ STARS ============ */
.stars{color:var(--gold);letter-spacing:1px;font-size:14px;display:inline-flex;}

/* =========================================================
   1 — BANDEAU SUPÉRIEUR STICKY
========================================================= */
.topbar{
  position:sticky;top:0;z-index:90;
  background:var(--ink);color:#fff;
  height:38px;display:flex;align-items:center;justify-content:center;
  overflow:hidden;font-size:13.5px;font-weight:600;letter-spacing:.02em;
}
.topbar__track{position:relative;width:100%;height:100%;}
.topbar__msg{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(100%);
  transition:opacity .5s ease, transform .5s ease;
  padding:0 16px;text-align:center;
}
.topbar__msg.is-active{opacity:1;transform:translateY(0);}
.topbar__msg.is-leave{opacity:0;transform:translateY(-100%);}

/* =========================================================
   2 — HEADER / NAV
========================================================= */
.header{
  position:relative;z-index:80;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
}
.logo{
  font-family:"Archivo",sans-serif;font-weight:900;
  font-size:26px;letter-spacing:.06em;color:var(--ink);
}
.nav{display:flex;gap:34px;align-items:center;}
.nav a{font-weight:600;font-size:15px;color:var(--ink-soft);transition:color .2s;}
.nav a:hover{color:var(--ink);}
.header__cart{display:none;font-size:22px;}

/* icône panier + badge */
.nav-cart{position:relative;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);padding:4px;line-height:0;}
.nav-cart:hover{opacity:.7;}
.nav-cart__badge{
  position:absolute;top:-5px;right:-7px;min-width:18px;height:18px;padding:0 4px;
  background:var(--red);color:#fff;border-radius:999px;
  font-family:"Archivo",sans-serif;font-weight:800;font-size:11px;line-height:18px;text-align:center;
}

/* =========================================================
   PANIER (tiroir)
========================================================= */
.cart-overlay{
  position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.45);
  opacity:0;transition:opacity .3s ease;
}
.cart-overlay.is-open{opacity:1;}
.cart-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:210;
  width:min(420px,100%);background:#fff;
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  box-shadow:-10px 0 40px rgba(0,0,0,.16);
}
.cart-drawer.is-open{transform:translateX(0);}
.cart-drawer__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 22px 16px;
}
.cart-drawer__title{font-family:"Archivo",sans-serif;font-weight:800;font-size:24px;}
.cart-close{font-size:20px;color:var(--ink);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.cart-close:hover{background:var(--line);}
.cart-reviews{
  background:var(--ink);color:#fff;text-align:center;
  padding:9px 16px;font-size:13px;font-weight:600;
}
.cart-reviews .stars{color:var(--gold);}
.cart-reviews strong{font-weight:800;}

.cart-body{flex:1;overflow-y:auto;padding:10px 22px;}

/* état vide */
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:100%;gap:22px;padding:40px 10px;}
.cart-empty__emoji{
  width:130px;height:130px;border-radius:50%;background:var(--rose);
  display:flex;align-items:center;justify-content:center;font-size:60px;
}
.cart-empty__title{font-family:"Archivo",sans-serif;font-weight:800;font-size:26px;}
.cart-empty__btn{
  background:var(--red);color:#fff;border-radius:12px;
  font-family:"Archivo",sans-serif;font-weight:800;font-size:15px;
  padding:14px 30px;transition:transform .12s,filter .2s;
}
.cart-empty__btn:hover{transform:translateY(-1px);filter:brightness(1.05);}

/* items */
.cart-item{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid var(--line);}
.cart-item__thumb{width:74px;height:74px;border-radius:10px;overflow:hidden;background:#f0eded;flex:none;}
.cart-item__thumb img{width:100%;height:100%;object-fit:cover;}
.cart-item__main{flex:1;min-width:0;display:flex;flex-direction:column;gap:7px;}
.cart-item__top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.cart-item__name{font-weight:700;font-size:14.5px;line-height:1.25;}
.cart-item__del{color:var(--muted);line-height:0;padding:2px;transition:color .2s;}
.cart-item__del:hover{color:var(--red);}
.cart-item__color{font-size:13px;color:var(--muted);}
.cart-item__row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:2px;}
.cart-qty{display:inline-flex;align-items:center;border:1.5px solid var(--line-2);border-radius:10px;overflow:hidden;}
.cart-qty button{width:34px;height:34px;font-size:17px;font-weight:700;color:var(--ink);}
.cart-qty button:hover{background:var(--line);}
.cart-qty span{min-width:30px;text-align:center;font-weight:700;font-size:14px;}
.cart-item__price{font-family:"Archivo",sans-serif;font-weight:800;font-size:15px;}
.cart-item__old{color:var(--muted);font-weight:600;font-size:12.5px;text-decoration:line-through;margin-left:3px;}

/* pied */
.cart-foot{border-top:1px solid var(--line);padding:18px 22px calc(18px + env(safe-area-inset-bottom));}
.cart-subtotal{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:14px;}
.cart-subtotal span{white-space:nowrap;}
.cart-subtotal span:first-child{font-family:"Archivo",sans-serif;font-weight:800;font-size:18px;}
.cart-subtotal span:last-child{font-family:"Archivo",sans-serif;font-weight:800;font-size:20px;}
.cart-subtotal__old{color:var(--muted);font-weight:600;font-size:14px;text-decoration:line-through;margin-left:4px;}
.cart-checkout{
  width:100%;background:var(--ink);color:#fff;border-radius:12px;
  font-family:"Archivo",sans-serif;font-weight:800;font-size:17px;letter-spacing:.02em;
  min-height:54px;display:flex;align-items:center;justify-content:center;
  transition:transform .12s,background .25s;
}
.cart-checkout:hover{transform:translateY(-1px);background:#000;}
.cart-pay{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:14px;}
.cart-pay img{height:22px;width:auto;}

/* =========================================================
   3 — HERO / BLOC PRODUIT
========================================================= */
.hero{padding:34px 0 56px;}
.hero__grid{
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:54px;align-items:start;
}

/* ---- Carrousel produit ---- */
.gallery{position:relative;min-width:0;}
@media(min-width:981px){
  /* le carrousel reste affiché (sticky) pendant qu'on scrolle l'offre */
  .gallery{position:sticky;top:54px;align-self:start;}
}
.gallery__stage{
  position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:1/1;background:#c9c9c9;
}
.gallery__track{display:flex;height:100%;will-change:transform;}
.gallery__slide{min-width:100%;height:100%;}
.gallery__slide .ph{width:100%;height:100%;}
.gallery__slide .cap{
  position:absolute;left:14px;bottom:14px;
  background:rgba(0,0,0,.62);color:#fff;font-family:monospace;
  font-size:12px;padding:5px 9px;border-radius:6px;letter-spacing:.02em;
}
.gallery__arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.92);box-shadow:var(--shadow-sm);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  color:var(--ink);transition:transform .15s,background .2s;
}
.gallery__arrow:hover{background:#fff;transform:translateY(-50%) scale(1.06);}
.gallery__arrow--prev{left:12px;}
.gallery__arrow--next{right:12px;}
.thumbs{
  display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:12px;
}
.thumb{
  aspect-ratio:1/1;border-radius:10px;overflow:hidden;
  border:2px solid transparent;background:#d2d2d2;padding:0;
  transition:border-color .2s,transform .15s;
}
.thumb:hover{transform:translateY(-2px);}
.thumb.is-active{border-color:var(--ink);}

/* ---- Bloc offre ---- */
.offer{display:flex;flex-direction:column;gap:16px;}
.rating-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13.5px;color:var(--ink-soft);}
.rating-row strong{color:var(--ink);white-space:nowrap;}
.trustpilot{display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:13px;color:#00b67a;}
.trustpilot .tp-star{color:#00b67a;}

.offer__title{font-size:clamp(26px,3.2vw,36px);line-height:1.08;}

.price-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.price{font-family:"Archivo",sans-serif;font-weight:800;font-size:32px;}
.price-old{color:var(--muted);text-decoration:line-through;font-size:19px;font-weight:600;}
.badge{
  font-weight:800;font-size:12.5px;padding:4px 10px;border-radius:999px;
  letter-spacing:.02em;
}
.badge--off{background:var(--ink);color:#fff;}
.badge--viral{background:var(--red);color:#fff;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;}

.offer-banner{
  background:var(--rose);color:var(--ink);border-radius:var(--radius-sm);
  padding:12px 16px;font-weight:700;font-size:15px;
}
.urgency-banner{
  background:var(--red);color:#fff;border-radius:var(--radius-sm);
  padding:11px 16px;font-weight:800;font-size:14px;letter-spacing:.02em;text-align:center;
}
.offer__desc{color:var(--ink-soft);font-size:15.5px;font-weight:700;text-wrap:pretty;}

/* sélecteur couleur */
.field-label{font-weight:700;font-size:13.5px;margin-bottom:8px;display:block;}
.swatches{display:flex;gap:10px;flex-wrap:wrap;}
.swatch{
  display:flex;align-items:center;gap:8px;border:1.5px solid var(--line-2);
  border-radius:999px;padding:7px 14px;font-weight:600;font-size:13.5px;
  background:#fff;transition:border-color .2s,box-shadow .2s;
}
.swatch .dot{width:15px;height:15px;border-radius:50%;border:1px solid rgba(0,0,0,.15);}
.swatch.is-active{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink);}
.dot--rouge{background:#e23b3b;}
.dot--jaune{background:#f5c518;}
.dot--blanc{background:#f4f4f4;}
.dot--bleu{background:#3b6fe2;}

.assurance{display:flex;flex-direction:column;gap:10px;}
.assurance li{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14.5px;list-style:none;}
.assurance ul{margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.assurance .ic{font-size:18px;}

/* quantité + CTA */
.buy-row{display:flex;gap:12px;align-items:stretch;}
.qty{
  display:inline-flex;align-self:flex-start;align-items:center;border:1.5px solid var(--line-2);
  border-radius:12px;overflow:hidden;
}
.qty button{width:44px;font-size:20px;font-weight:700;color:var(--ink);}
.qty input{
  width:42px;text-align:center;border:none;font-size:16px;font-weight:700;
  font-family:inherit;-moz-appearance:textfield;
}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}

.btn-cta{
  width:100%;background:var(--ink);color:#fff;border-radius:12px;
  font-family:"Archivo",sans-serif;font-weight:800;font-size:17px;letter-spacing:.03em;
  padding:0 24px;min-height:56px;display:flex;align-items:center;justify-content:center;
  transition:transform .12s ease, background .25s ease;
}
.btn-cta:hover{transform:translateY(-1px);background:#000;}
.btn-cta.is-clicked{transform:scale(.97);background:var(--green);}

.pay-logos{display:flex;align-items:center;justify-content:center;gap:10px;}
.pay-logos img{height:21px;width:auto;}

/* accordéons */
.acc{border-top:1px solid var(--line);}
.acc__item{border-bottom:1px solid var(--line);}
.acc__head{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;
  text-align:left;padding:16px 2px;font-weight:700;font-size:15px;color:var(--ink);
}
.acc__icon{font-size:22px;font-weight:400;transition:transform .25s;flex:none;}
.acc__item.is-open .acc__icon{transform:rotate(45deg);}
.acc__body{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.acc__body p{margin:0 2px 18px;color:var(--ink-soft);font-size:14.5px;text-wrap:pretty;}

/* mini-témoignages */
.mini-revs{display:flex;flex-direction:column;gap:10px;margin-top:6px;}
.mini-rev{
  background:var(--rose);border-radius:12px;padding:13px 16px;
}
.mini-rev__top{display:flex;align-items:center;gap:9px;margin-bottom:5px;}
.mini-rev__av{width:26px;height:26px;border-radius:50%;background:#b98a6a;flex:none;object-fit:cover;}
.mini-rev__name{font-weight:800;font-size:13.5px;}
.mini-rev__time{color:var(--muted);font-size:12px;font-weight:500;}
.mini-rev__txt{font-size:14px;font-weight:600;}

/* =========================================================
   4 — SUBLIMEZ VOS SOUVENIRS
========================================================= */
.feature-split{
  display:grid;grid-template-columns:1fr minmax(280px,420px) 1fr;
  grid-template-rows:auto auto;
  gap:36px 40px;align-items:center;
}
.feature-item{display:flex;flex-direction:column;gap:8px;}
.feature-item .ic{font-size:24px;}
.feature-item h3{font-size:19px;}
.feature-item p{margin:0;color:var(--ink-soft);font-size:14.5px;text-wrap:pretty;}
.feature-media{border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;}
/* placement desktop : colonne gauche (alignée à droite) | image | colonne droite */
.fi-tl{grid-column:1;grid-row:1;align-items:flex-end;text-align:right;}
.fi-bl{grid-column:1;grid-row:2;align-items:flex-end;text-align:right;}
.fi-media{grid-column:2;grid-row:1 / span 2;align-self:stretch;}
.fi-tr{grid-column:3;grid-row:1;}
.fi-br{grid-column:3;grid-row:2;}

/* =========================================================
   5 — TON GUIDE EXPRESS
========================================================= */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.guide-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
}
.guide-card__media{aspect-ratio:4/3;position:relative;}
.guide-card__badge{
  position:absolute;left:12px;bottom:12px;color:#fff;
}
.guide-card__badge .rec{
  background:var(--red);color:#fff;font-family:"Archivo",sans-serif;font-weight:800;
  font-size:13px;padding:3px 9px;border-radius:5px;display:inline-block;
}
.guide-card__badge .sub{display:block;font-size:11px;margin-top:5px;max-width:200px;line-height:1.3;text-shadow:0 1px 4px rgba(0,0,0,.5);}
.guide-card__body{padding:20px 22px 26px;}
.guide-card__body h3{font-size:20px;margin-bottom:10px;}
.guide-card__body p{margin:0;color:var(--ink-soft);font-size:14px;text-wrap:pretty;}
.dots.guide-dots{display:none;}

/* =========================================================
   6 — CAPTURE LA MAGIE
========================================================= */
.magic{background:linear-gradient(180deg,#fef8f8 0%,#f7dee0 100%);}
.magic__grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.magic__media{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;}
.magic__title{font-size:clamp(28px,3.6vw,42px);margin-bottom:18px;}
.magic__body{color:var(--ink-soft);font-size:16px;margin-bottom:24px;text-wrap:pretty;}
.btn-dark{
  background:var(--ink);color:#fff;border-radius:12px;
  font-family:"Archivo",sans-serif;font-weight:800;font-size:16px;letter-spacing:.02em;
  padding:16px 30px;min-height:56px;display:inline-flex;align-items:center;justify-content:center;
  transition:transform .12s,background .25s;width:100%;
}
.btn-dark:hover{transform:translateY(-1px);background:#000;}
.btn-dark.is-clicked{transform:scale(.97);background:var(--green);}
.micro{font-size:12.5px;color:var(--muted);text-align:center;margin-top:10px;}

/* =========================================================
   7 — TA NOUVELLE OBSESSION
========================================================= */
.obsession__grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.obsession__title{font-size:clamp(28px,3.6vw,42px);margin-bottom:24px;}
.obs-item{
  display:flex;gap:14px;padding:16px 18px;border:1px solid var(--line);
  border-radius:12px;margin-bottom:14px;align-items:flex-start;
}
.obs-item .ic{font-size:22px;flex:none;}
.obs-item h3{font-size:16px;margin-bottom:4px;}
.obs-item p{margin:0;color:var(--ink-soft);font-size:13.5px;text-wrap:pretty;}
.obsession__media{border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;}
.obs-rating{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:12px;font-weight:700;font-size:14px;}

/* =========================================================
   8 — NOS FANS SONT ACCROS
========================================================= */
.fans__reassure{
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  margin-bottom:8px;font-size:13.5px;color:var(--ink-soft);
}
.avatars{display:flex;}
.avatars span,.avatars img{
  width:30px;height:30px;border-radius:50%;border:2px solid #fff;background:#b98a6a;
  margin-left:-9px;object-fit:cover;
}
.avatars span:first-child,.avatars img:first-child{margin-left:0;}
.fans__reassure strong{color:var(--ink);}

.revs{position:relative;margin-top:30px;}
.revs__track{
  display:grid;grid-auto-flow:column;grid-auto-columns:calc((100% - 3*18px)/4);
  gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.revs__track::-webkit-scrollbar{display:none;}
.rev-card{
  scroll-snap-align:start;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
}
.rev-card__media{aspect-ratio:4/3;}
.rev-card__body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:10px;flex:1;}
.rev-card__txt{font-size:14px;color:var(--ink-soft);text-wrap:pretty;flex:1;}
.rev-card__foot{display:flex;align-items:center;justify-content:space-between;}
.rev-card__name{font-weight:800;font-size:13.5px;}
.rev-verified{font-size:11px;color:var(--green);font-weight:700;}
.dots{display:flex;gap:8px;justify-content:center;margin-top:22px;}
.dot-nav{width:9px;height:9px;border-radius:50%;background:#d0d0d0;transition:background .2s,width .2s;}
.dot-nav.is-active{background:var(--ink);width:24px;border-radius:5px;}
.fans__cta{display:flex;justify-content:center;margin-top:26px;}
.btn-pill{
  background:var(--ink);color:#fff;border-radius:999px;font-family:"Archivo",sans-serif;
  font-weight:800;font-size:15px;padding:14px 40px;transition:transform .12s,background .25s;
}
.btn-pill:hover{transform:translateY(-1px);background:#000;}

/* =========================================================
   9 — FAQ
========================================================= */
.faq__head{text-align:center;margin-bottom:38px;}
.faq__head h2{font-size:clamp(26px,3.4vw,40px);margin-bottom:12px;}
.faq__head p{color:var(--ink-soft);max-width:680px;margin:0 auto;}
.faq__grid{display:grid;grid-template-columns:1fr 1fr;gap:0 48px;}
.faq__foot{text-align:center;margin-top:40px;}
.faq__foot h3{font-size:22px;margin-bottom:8px;}
.faq__foot a{font-weight:700;border-bottom:2px solid var(--ink);}

/* =========================================================
   10 — BANDEAU FEATURES
========================================================= */
.feat-band{background:linear-gradient(180deg,#fdf1f1 0%,#f3d5d7 100%);}
.feat-band__foot{margin-top:0;margin-bottom:44px;}
.feat-band__foot h3{font-size:clamp(24px,3vw,34px);margin-bottom:12px;}
.feat-band__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
.feat-card{display:flex;flex-direction:column;gap:8px;}
.feat-card .ic{font-size:26px;}
.feat-card h3{font-size:18px;}
.feat-card p{margin:0;color:var(--ink-soft);font-size:13.5px;text-wrap:pretty;}

/* =========================================================
   11 — FOOTER
========================================================= */
.footer{background:#faf7f5;padding:60px 0 120px;}
.footer__grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:start;}
.footer__logo{font-family:Georgia,"Times New Roman",serif;font-size:34px;font-weight:700;letter-spacing:.01em;margin-bottom:14px;}
.footer__tag{color:var(--ink-soft);font-size:15px;max-width:380px;margin-bottom:18px;text-wrap:pretty;}
.footer__contact{font-size:14px;color:var(--ink-soft);line-height:1.9;}
.footer__links{
  display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;font-size:14px;
}
.footer__links a{color:var(--ink-soft);transition:color .2s;}
.footer__links a:hover{color:var(--ink);}

/* =========================================================
   STICKY ADD TO CART (mobile)
========================================================= */
.sticky-cart{
  position:fixed;left:0;right:0;bottom:0;z-index:100;
  background:#fff;color:var(--ink);
  display:flex;align-items:center;gap:14px;
  padding:12px var(--pad);
  padding-bottom:calc(12px + env(safe-area-inset-bottom));
  min-height:64px;
  transform:translateY(120%);transition:transform .3s ease;
  border-top:1px solid var(--line);
  box-shadow:0 -6px 20px rgba(0,0,0,.10);
}
.sticky-cart.is-visible{transform:translateY(0);}
.sticky-cart__thumb{width:42px;height:42px;border-radius:8px;background:#c9c9c9;flex:none;}
.sticky-cart__info{flex:1;min-width:0;}
.sticky-cart__name{font-weight:700;font-size:13px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sticky-cart__price{font-family:"Archivo",sans-serif;font-weight:800;font-size:15px;}
.sticky-cart__btn{
  background:var(--ink);color:#fff;border-radius:10px;
  font-family:"Archivo",sans-serif;font-weight:800;font-size:13.5px;letter-spacing:.02em;
  padding:0 18px;height:44px;display:flex;align-items:center;white-space:nowrap;
}

/* =========================================================
   RESPONSIVE — TABLETTE
========================================================= */
@media(max-width:980px){
  .hero__grid{grid-template-columns:minmax(0,1fr);gap:32px;}
  .feature-split{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto auto auto;
    gap:28px 22px;align-items:start;
  }
  .fi-tl{grid-column:1;grid-row:1;align-items:flex-start;text-align:left;}
  .fi-tr{grid-column:2;grid-row:1;}
  .fi-media{grid-column:1 / span 2;grid-row:2;aspect-ratio:16/10;max-height:420px;width:100%;}
  .fi-bl{grid-column:1;grid-row:3;align-items:flex-start;text-align:left;}
  .fi-br{grid-column:2;grid-row:3;}
  .guide-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto;}
  .magic__grid,.obsession__grid{grid-template-columns:1fr;gap:28px;}
  .obsession__media{order:-1;}
  .magic__media{aspect-ratio:4/3;}
  .feat-band__grid{grid-template-columns:1fr 1fr;gap:26px 24px;}
  .faq__grid{grid-template-columns:1fr;gap:0;}
  .footer__grid{grid-template-columns:1fr;gap:30px;}
  .revs__track{grid-auto-columns:calc((100% - 18px)/1.15);}
}

/* =========================================================
   RESPONSIVE — MOBILE
========================================================= */
@media(max-width:640px){
  :root{--pad:18px;}
  .section{padding:46px 0;}
  .nav{display:flex;gap:18px;}
  .nav a{font-size:14px;}
  .header__inner{justify-content:space-between;}
  .header__cart{display:none;}
  .logo{font-size:23px;}
  .hero{padding:24px 0 40px;}
  .thumbs{
    display:grid;grid-template-columns:none;
    grid-auto-flow:column;grid-auto-columns:62px;gap:8px;min-width:0;
    overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .thumbs::-webkit-scrollbar{display:none;}

  /* Ton Guide Express → carrousel horizontal avec petit aperçu de la carte suivante */
  .guide-grid{
    display:grid;grid-template-columns:none;
    grid-auto-flow:column;grid-auto-columns:91%;
    gap:14px;max-width:none;margin:0;
    padding:4px 0 12px;
    overflow-x:auto;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;scrollbar-width:none;
    scroll-padding-left:0;
  }
  .guide-grid::-webkit-scrollbar{display:none;}
  .guide-card{scroll-snap-align:start;}
  .dots.guide-dots{display:flex;}
  .buy-row{flex-wrap:nowrap;}
  .feat-band__grid{gap:24px 20px;}
  .footer{padding:48px 0 130px;}
  .footer__links{grid-template-columns:1fr 1fr;}
  .sticky-cart{display:flex;}
  .gallery__arrow{display:none;}   /* mobile = swipe natif */
}

@media(min-width:641px){
  /* sticky add-to-cart visible aussi sur desktop */
  .sticky-cart{padding-left:max(var(--pad),calc((100vw - var(--maxw))/2));padding-right:max(var(--pad),calc((100vw - var(--maxw))/2));}
}

/* réduction d'animation */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important;}
}
