/* ============================================================
   Griffon d'art — Design system (charte validée)
   Fond blanc · menu noir · titres vifs · accents pastel
   Cinzel (titres) · Oswald (menu) · Saira Condensed (labels) · Open Sans (corps)
   ============================================================ */
:root{
  --violet:#68388d;  --violet-p:#e7dcf0;
  --indigo:#3f2cad;  --indigo-p:#dcd8f4;
  --ocre:#cf8118;    --ocre-p:#f6e6c8;
  --vert:#199233;    --vert-p:#cdeccf;
  --rose:#e03c78;    --rose-p:#fbd6e4;
  --noir:#141414;
  --blanc:#ffffff;
  --creme:#fbf8f3;       /* blanc cassé chaud pour rythmer */
  --creme-2:#f4eee4;
  --encre:#222020;       /* corps */
  --gris:#6f6a64;        /* secondaire */
  --ligne:#ece6dc;

  --ff-titre:"Yanone Kaffeesatz","Oswald",sans-serif;
  --ff-menu:"Oswald",sans-serif;
  --ff-label:"Saira Condensed",sans-serif;
  --ff-corps:"Open Sans",-apple-system,sans-serif;

  --maxw:1280px;
  --pad:clamp(18px,4vw,40px);
  --ease:cubic-bezier(.22,1,.36,1);
  --sh-s:0 1px 2px rgba(20,20,20,.05),0 10px 28px rgba(20,20,20,.07);
  --sh-l:0 2px 8px rgba(20,20,20,.07),0 24px 56px rgba(20,20,20,.12);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{margin:0;background:var(--blanc);color:var(--encre);font-family:var(--ff-corps);
  font-size:16.5px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;}
h1,h2{font-family:var(--ff-titre);font-weight:600;margin:0;line-height:1.06;letter-spacing:.004em;text-wrap:balance;}
h3,h4{font-family:var(--ff-label);font-weight:600;margin:0;line-height:1.2;}
p{margin:0;text-wrap:pretty;}
::selection{background:var(--ocre-p);color:var(--noir);}

.gd-wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);}
.gd-section{padding-block:clamp(48px,7vw,92px);}
.gd-section--creme{background:var(--creme);}

/* couleurs de titre par rubrique */
.t-violet{color:var(--violet);} .t-indigo{color:var(--indigo);} .t-ocre{color:var(--ocre);}
.t-vert{color:var(--vert);} .t-rose{color:var(--rose);} .t-noir{color:var(--noir);}

/* ---------- Labels / kickers ---------- */
.gd-kicker{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.22em;font-weight:600;
  font-size:.84rem;color:var(--gris);display:inline-flex;align-items:center;gap:.6em;margin:0 0 .8rem;}
.gd-kicker .bar{width:26px;height:3px;border-radius:2px;background:var(--accent,var(--ocre));}
.gd-h1{font-size:clamp(2.7rem,6.6vw,5rem);}
.gd-h2{font-size:clamp(2.05rem,4vw,3.3rem);}
.gd-lead{font-size:clamp(1.04rem,1.5vw,1.2rem);color:var(--gris);max-width:50ch;}

/* ---------- Surligneur « marqueur » pastel (mots-clés de titres) ---------- */
.mk{position:relative;display:inline;white-space:nowrap;}
.mk>span{position:relative;z-index:1;}
.mk::after{content:"";position:absolute;left:-.14em;right:-.14em;bottom:.04em;height:.42em;z-index:0;
  background:var(--mkc,var(--ocre-p));border-radius:4px 7px 5px 8px;
  clip-path:polygon(0 32%,4% 8%,42% 16%,74% 4%,100% 20%,98% 86%,58% 97%,20% 90%,2% 99%);}

/* ---------- Boutons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6em;font-family:var(--ff-menu);font-weight:500;white-space:nowrap;
  text-transform:uppercase;letter-spacing:.05em;font-size:.94rem;padding:.82em 1.5em;border-radius:6px;
  transition:transform .14s var(--ease),box-shadow .2s,background .2s,color .2s;}
.btn .ar{transition:transform .2s var(--ease);}
.btn:hover .ar{transform:translateX(3px);}
.btn--noir{background:var(--noir);color:#fff;box-shadow:0 8px 20px rgba(20,20,20,.18);}
.btn--noir:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(20,20,20,.26);}
.btn--ocre{background:var(--ocre);color:#fff;box-shadow:0 8px 20px rgba(207,129,24,.28);}
.btn--ocre:hover{transform:translateY(-1px);}
.btn--ghost{border:1.6px solid var(--noir);color:var(--noir);}
.btn--ghost:hover{background:var(--noir);color:#fff;}
.btn--photo{background:rgba(255,255,255,.14);color:#fff;border:1.6px solid rgba(255,255,255,.75);backdrop-filter:blur(4px);}
.btn--photo:hover{background:#fff;color:var(--noir);}
.btn--lg{padding:1em 1.8em;font-size:1rem;}
.tlink{font-family:var(--ff-menu);text-transform:uppercase;letter-spacing:.05em;font-weight:500;
  font-size:.9rem;display:inline-flex;align-items:center;gap:.45em;border-bottom:2px solid var(--accent,var(--ocre));padding-bottom:2px;}
.tlink .ar{transition:transform .2s var(--ease);}
.tlink:hover .ar{transform:translateX(3px);}

/* ---------- Badges ---------- */
.badge{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.06em;font-weight:600;font-size:.72rem;
  padding:.34em .7em;border-radius:100px;display:inline-flex;align-items:center;gap:.4em;background:var(--ocre-p);color:#6e4410;}
.badge--limite{background:var(--rose-p);color:#9c1f4d;}
.badge--unique{background:var(--indigo-p);color:#2b1d83;}
.badge--rupture{background:#eee;color:#888;}

/* ============ EN-TÊTE ============ */
.gd-utility{background:#fff;}
.gd-utility__in{display:flex;align-items:center;gap:clamp(1rem,3vw,2.2rem);padding-block:14px;}
.gd-logo{flex:none;}
.gd-logo img{height:60px;width:auto;}
.gd-fr{display:flex;align-items:center;gap:.6em;font-family:var(--ff-label);font-size:.92rem;color:var(--gris);letter-spacing:.01em;}
.gd-fr .flag{width:24px;height:16px;border-radius:2px;overflow:hidden;display:inline-flex;flex:none;box-shadow:0 0 0 1px rgba(0,0,0,.06);}
.gd-fr .flag i{flex:1;}
.gd-util-mid{display:flex;align-items:center;gap:1.1rem;font-family:var(--ff-label);font-size:.95rem;color:var(--gris);}
.gd-util-mid .lang b{color:var(--noir);}
.gd-lang{position:relative;}
.gd-lang__btn{display:inline-flex;align-items:center;gap:.4em;font-family:var(--ff-label);font-size:.95rem;color:var(--gris);}
.gd-lang__btn b{color:var(--noir);font-weight:600;}
.gd-lang__btn:hover{color:var(--noir);}
.gd-lang__chev{font-size:.7em;}
.gd-lang__menu{position:absolute;top:calc(100% + 8px);left:0;background:rgba(255,255,255,.93);backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);border:1px solid var(--ligne);border-radius:10px;box-shadow:var(--sh-l);padding:.35rem;min-width:178px;z-index:80;display:flex;flex-direction:column;gap:1px;}
.gd-lang__opt{display:flex;align-items:center;gap:.6em;padding:.5em .7em;border-radius:7px;font-family:var(--ff-corps);font-size:.92rem;color:var(--encre);text-align:left;}
.gd-lang__opt span{flex:1;}
.gd-lang__opt b{color:var(--gris);font-family:var(--ff-label);font-size:.78rem;}
.gd-lang__opt:hover{background:var(--creme-2);}
.gd-lang__opt.on{background:var(--violet-p);}
.gd-lang__opt.on b{color:var(--violet);}
.gd-util-mid a:hover,.gd-util-mid button:hover{color:var(--noir);}
.gd-search{margin-left:auto;display:flex;align-items:center;gap:.5rem;}
.gd-search__field{display:flex;align-items:center;background:#fff;border:1.5px solid var(--ligne);border-radius:100px;
  padding:.34em .34em .34em 1.1em;min-width:min(340px,40vw);transition:border-color .18s,box-shadow .18s;}
.gd-search__field:focus-within{border-color:var(--ocre);box-shadow:0 0 0 3px var(--ocre-p);}
.gd-search__field input{border:0;outline:none;flex:1;font-family:var(--ff-corps);font-size:.95rem;background:none;color:var(--encre);min-width:60px;}
.gd-search__clear{color:var(--gris);width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;}
.gd-search__clear:hover{background:var(--creme-2);}
.gd-search__go{width:36px;height:36px;border-radius:50%;background:var(--ocre);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex:none;transition:transform .15s;}
.gd-search__go:hover{transform:scale(1.06);}
.gd-icons{display:flex;align-items:center;gap:.3rem;}
.gd-iconbtn{width:42px;height:42px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--noir);position:relative;transition:background .16s;}
.gd-iconbtn:hover{background:var(--creme-2);}
.gd-iconbtn .cc{position:absolute;top:3px;right:3px;min-width:17px;height:17px;border-radius:100px;background:var(--rose);color:#fff;
  font-family:var(--ff-label);font-size:.66rem;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 .3em;}

/* ---------- Barre de menu NOIRE (pilule) ---------- */
.gd-navbar{position:sticky;top:0;z-index:60;background:#fff;padding:10px 0 14px;}
.gd-navbar.stuck{box-shadow:0 6px 22px rgba(20,20,20,.06);}
.gd-nav{background:var(--noir);border-radius:100px;display:flex;align-items:center;justify-content:center;
  gap:clamp(.05rem,.3vw,.3rem);padding:7px clamp(.4rem,1vw,.8rem);box-shadow:0 10px 26px rgba(20,20,20,.2);}
.gd-navitem{position:relative;}
.gd-navlink{font-family:var(--ff-menu);text-transform:uppercase;letter-spacing:.04em;font-weight:500;font-size:.82rem;
  color:#fff;padding:.6em .82em;border-radius:100px;display:inline-flex;align-items:center;gap:.3em;white-space:nowrap;
  transition:background .2s var(--ease),color .2s;}
.gd-navlink .chev{font-size:.7em;opacity:.7;}
.gd-navitem:hover>.gd-navlink,.gd-navlink.active{background:var(--navc,var(--ocre));color:#fff;}
.gd-navlink.active{box-shadow:0 2px 10px rgba(0,0,0,.25);}

/* méga-menu / dropdown */
.gd-mega{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  background:rgba(231,220,240,.78);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);
  border:1px solid rgba(255,255,255,.5);border-radius:16px;box-shadow:var(--sh-l);padding:1.6rem 1.8rem;
  display:grid;grid-auto-flow:column;gap:2.4rem;opacity:0;visibility:hidden;transition:.2s var(--ease);z-index:70;}
.gd-navitem:hover .gd-mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.gd-mega::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px;}
.gd-megacol{min-width:170px;}
.gd-megacol h4{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;font-weight:700;
  color:var(--violet);margin-bottom:.8rem;}
.gd-megacol a{display:block;font-family:var(--ff-corps);font-size:.92rem;color:var(--encre);padding:.28em 0;transition:color .15s,padding-left .15s;}
.gd-megacol a:hover{color:var(--violet);padding-left:.3em;}
.gd-megacol a.voirtout{color:var(--violet);font-weight:700;margin-top:.3em;}
.gd-drop{position:absolute;top:calc(100% + 14px);right:0;background:rgba(231,220,240,.78);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);border:1px solid rgba(255,255,255,.5);border-radius:14px;box-shadow:var(--sh-l);
  padding:.6rem;min-width:210px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s var(--ease);z-index:70;}
.gd-navitem:hover .gd-drop{opacity:1;visibility:visible;transform:translateY(0);}
.gd-drop::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px;}
.gd-drop a{display:block;font-family:var(--ff-corps);font-size:.92rem;padding:.5em .8em;border-radius:8px;}
.gd-drop a:hover{background:#fff;color:var(--violet);}
.gd-burger{display:none;}

/* ============ HERO plein cadre ============ */
.gd-hero{position:relative;height:clamp(540px,86vh,820px);overflow:hidden;background:#111;}
.gd-hero__slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s var(--ease);}
.gd-hero__slide.on{opacity:1;}
.gd-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);}
.gd-hero__slide.on .gd-hero__bg{animation:kb 7.5s ease-out forwards;}
@keyframes kb{to{transform:scale(1.14);}}
.gd-hero__scrim{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(15,13,12,.34) 0,rgba(15,13,12,0) 24%,rgba(15,13,12,.2) 56%,rgba(15,13,12,.84) 100%),
  linear-gradient(82deg,rgba(15,13,12,.62) 0,rgba(15,13,12,.1) 50%,transparent 74%);}
.gd-hero__in{position:relative;height:100%;display:flex;flex-direction:column;justify-content:flex-end;
  padding-block:clamp(2.2rem,6vw,4.4rem);color:#fff;}
.gd-hero__kicker{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.24em;font-weight:600;
  font-size:.9rem;display:block;margin-bottom:.5rem;color:#fff;}
.gd-hero h1{color:#fff;font-size:clamp(2.8rem,6.6vw,5.6rem);line-height:1.02;margin-bottom:1rem;text-shadow:0 2px 30px rgba(0,0,0,.4);max-width:16ch;}
.gd-hero h1 em{font-style:italic;}
.gd-hero__sub{font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:34ch;margin-bottom:1.7rem;color:rgba(255,255,255,.94);text-shadow:0 1px 16px rgba(0,0,0,.5);}
.gd-hero__cta{display:flex;gap:.8rem;flex-wrap:wrap;}
.gd-hero__ctrl{display:flex;align-items:center;gap:1rem;margin-top:clamp(1.8rem,4vw,3rem);}
.gd-hero__pause,.gd-hero__arrow{border:1.5px solid rgba(255,255,255,.6);color:#fff;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:.15s var(--ease);}
.gd-hero__pause{width:40px;height:40px;} .gd-hero__arrow{width:46px;height:46px;background:rgba(255,255,255,.06);}
.gd-hero__pause:hover{background:rgba(255,255,255,.18);} .gd-hero__arrow:hover{background:#fff;color:var(--noir);}
.gd-hero__dots{display:flex;gap:.5rem;}
.gd-hero__dot{width:34px;height:4px;border-radius:100px;background:rgba(255,255,255,.34);overflow:hidden;position:relative;}
.gd-hero__dot.on{background:rgba(255,255,255,.4);}
.gd-hero__dot .f{position:absolute;inset:0;background:#fff;transform:scaleX(0);transform-origin:left;}
.gd-hero__dot.on .f{animation:fill var(--d,6.5s) linear forwards;}
.gd-hero__dot.pause .f{animation-play-state:paused;}
@keyframes fill{to{transform:scaleX(1);}}
.gd-hero__count{font-family:var(--ff-titre);font-size:1.05rem;letter-spacing:.05em;}
.gd-hero__count span{opacity:.6;font-size:.85em;}
.gd-hero__arrows{margin-left:auto;display:flex;gap:.5rem;}

/* ============ Réassurance ============ */
.gd-assure{border-bottom:1px solid var(--ligne);}
.gd-assure__in{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 2.6rem;padding-block:1.3rem;}
.gd-assure__item{display:flex;align-items:center;gap:.55em;font-family:var(--ff-label);font-size:1rem;color:var(--encre);}
.gd-assure__item .ic{color:var(--ocre);display:inline-flex;}
.gd-assure__item .stars{color:var(--ocre);}
.gd-assure__sep{width:1px;height:24px;background:var(--ligne);}

/* ============ En-têtes de section ============ */
.gd-shead{margin-bottom:clamp(1.8rem,4vw,3rem);}
.gd-shead--c{text-align:center;display:flex;flex-direction:column;align-items:center;}
.gd-shead .gd-lead{margin-top:.8rem;}
.gd-shead--c .gd-lead{margin-left:auto;margin-right:auto;}

/* ============ Cartes catégorie ============ */
.gd-cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;}
.gd-cat{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:.82;box-shadow:var(--sh-s);display:block;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);background:var(--creme-2);}
.gd-cat:hover{transform:translateY(-4px);box-shadow:var(--sh-l);}
.gd-cat__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s var(--ease);}
.gd-cat:hover .gd-cat__img{transform:scale(1.06);}
.gd-cat__tint{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,13,12,0) 36%,rgba(15,13,12,.66) 100%);}
.gd-cat__bar{position:absolute;top:14px;left:14px;width:34px;height:5px;border-radius:100px;background:var(--accent);}
.gd-cat__lab{position:absolute;left:16px;right:16px;bottom:15px;color:#fff;}
.gd-cat__lab h3{color:#fff;font-size:1.2rem;}
.gd-cat__lab span{font-family:var(--ff-label);font-size:.86rem;opacity:.92;}

/* ============ Configurateur ============ */
.cfg-grid{display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(2rem,4vw,3.5rem);align-items:start;}
.cfg-stage{position:relative;background:#fff;border:1px solid var(--ligne);border-radius:20px;padding:clamp(1.4rem,3vw,2.2rem);box-shadow:var(--sh-l);position:sticky;top:96px;}
.cfg-view{position:relative;aspect-ratio:1.12;border-radius:14px;overflow:hidden;background:radial-gradient(circle at 50% 38%,#fff,var(--creme) 78%);display:flex;align-items:center;justify-content:center;}
.cfg-view__fab{position:absolute;inset:0;background-size:cover;background-position:center;}
.cfg-view__shape{position:relative;z-index:2;filter:drop-shadow(0 16px 26px rgba(20,20,20,.22));}
.cfg-models{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-top:1.1rem;}
.cfg-model{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:.85rem;
  padding:.5em 1em;border-radius:100px;border:1.5px solid var(--ligne);background:#fff;transition:.16s var(--ease);}
.cfg-model:hover{border-color:var(--noir);}
.cfg-model.on{border-color:transparent;background:var(--vert);color:#fff;}
.cfg-sizes{display:flex;align-items:center;gap:.7rem;justify-content:center;margin-top:.8rem;flex-wrap:wrap;}
.cfg-sizes__lbl{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;color:var(--gris);}
.cfg-sizes__row{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center;}
.cfg-size{font-family:var(--ff-label);font-weight:600;font-size:.84rem;padding:.4em .85em;border-radius:9px;border:1.5px solid var(--ligne);background:#fff;color:var(--encre);transition:.16s var(--ease);}
.cfg-size:hover{border-color:var(--noir);}
.cfg-size.on{border-color:var(--ocre);background:var(--ocre-p);color:var(--ocre);}
.cfg-panel h3{margin-bottom:.2rem;}
.cfg-filters{display:flex;flex-direction:column;gap:1rem;margin:1.2rem 0;}
.cfg-filtrow{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;}
.cfg-filtrow .lbl{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;color:var(--gris);width:100%;margin-bottom:.1rem;}
.chip{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.04em;font-weight:600;font-size:.82rem;
  padding:.42em .9em;border-radius:100px;border:1.5px solid var(--ligne);background:#fff;display:inline-flex;align-items:center;gap:.45em;transition:.16s var(--ease);}
.chip:hover{border-color:var(--noir);}
.chip.on{border-color:transparent;background:var(--noir);color:#fff;}
.chip .dot{width:12px;height:12px;border-radius:50%;display:inline-block;}
.chip .dot.conic{background:conic-gradient(from 0deg,#e03c78,#cf8118,#199233,#3f2cad,#e03c78);}
.cfg-swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:.55rem;max-height:340px;overflow:auto;padding:.2rem;}
.sw{position:relative;aspect-ratio:1;border-radius:9px;overflow:hidden;background-size:cover;background-position:center;
  cursor:pointer;border:2.5px solid transparent;box-shadow:0 2px 8px rgba(20,20,20,.1);transition:transform .16s var(--ease),border-color .16s;}
.sw:hover{transform:translateY(-2px) scale(1.05);}
.sw.on{border-color:var(--noir);transform:translateY(-2px) scale(1.05);}
.sw.on::after{content:"✓";position:absolute;top:-6px;right:-6px;width:19px;height:19px;background:var(--noir);color:#fff;border-radius:50%;font-size:.66rem;display:flex;align-items:center;justify-content:center;border:2px solid #fff;}
.sw--limite{border-color:var(--rose);}
.sw--rupture{filter:grayscale(.85) opacity(.5);cursor:not-allowed;}
.sw__tag{position:absolute;left:0;right:0;bottom:0;background:var(--rose);color:#fff;font-family:var(--ff-label);font-size:.56rem;text-transform:uppercase;letter-spacing:.05em;text-align:center;padding:1px;}
.cfg-current{display:flex;align-items:center;gap:.8rem;margin:1.1rem 0;padding:.8rem;border:1px solid var(--ligne);border-radius:12px;background:var(--creme);}
.cfg-current img{width:54px;height:54px;border-radius:8px;object-fit:cover;}
.cfg-current b{font-family:var(--ff-label);font-size:1.05rem;}
.cfg-current span{font-size:.85rem;color:var(--gris);}

/* ============ Galerie tissus ============ */
.gal-toolbar{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-bottom:1.4rem;}
.gal-search{display:flex;align-items:center;gap:.5em;border:1.5px solid var(--ligne);border-radius:100px;padding:.4em 1em;background:#fff;}
.gal-search input{border:0;outline:none;font-family:var(--ff-corps);font-size:.95rem;background:none;min-width:160px;}
.gal-count{font-family:var(--ff-label);color:var(--gris);font-size:.95rem;margin-left:auto;}
.gal-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.6rem;}
.gal-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:.7rem;}
.tcard{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:.74;background-size:cover;background-position:center;
  box-shadow:0 3px 12px rgba(20,20,20,.1);cursor:pointer;border:3px solid #fff;transition:transform .18s var(--ease),box-shadow .18s;}
.tcard:hover{transform:translateY(-3px) scale(1.03);z-index:2;box-shadow:var(--sh-l);}
.tcard--limite{border-color:var(--rose);}
.tcard__info{position:absolute;left:0;right:0;bottom:0;padding:.5rem;color:#fff;font-family:var(--ff-label);
  background:linear-gradient(180deg,transparent,rgba(15,13,12,.82));opacity:0;transform:translateY(6px);transition:.2s var(--ease);}
.tcard:hover .tcard__info{opacity:1;transform:translateY(0);}
.tcard__info b{display:block;font-size:.82rem;}
.tcard__info span{font-size:.68rem;opacity:.85;}
.tcard__badge{position:absolute;top:6px;left:6px;font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.04em;
  font-size:.56rem;background:var(--rose);color:#fff;padding:2px 6px;border-radius:100px;}

/* ============ Produits ============ */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;}
.prod{background:#fff;border:1px solid var(--ligne);border-radius:14px;overflow:hidden;box-shadow:var(--sh-s);transition:transform .25s var(--ease),box-shadow .25s var(--ease);}
.prod:hover{transform:translateY(-4px);box-shadow:var(--sh-l);}
.prod__img{position:relative;display:block;aspect-ratio:1;background-size:cover;background-position:center;background-color:var(--creme-2);}
.prod__img .badge{position:absolute;top:10px;left:10px;}
.prod__img .fav{position:absolute;top:8px;right:8px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--noir);display:flex;align-items:center;justify-content:center;transition:.15s;}
.prod__img .fav:hover{background:#fff;color:var(--rose);transform:scale(1.08);}
.prod__b{padding:.9rem 1rem 1.1rem;}
.prod__b h3{font-family:var(--ff-label);font-weight:600;font-size:1.12rem;}
.prod__b .fam{font-family:var(--ff-label);font-size:.8rem;color:var(--gris);text-transform:uppercase;letter-spacing:.05em;}
.prod__b .px{font-family:var(--ff-label);font-weight:700;font-size:1.05rem;margin-top:.3rem;display:block;}

/* ============ Avis ============ */
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}
.avis{background:#fff;border:1px solid var(--ligne);border-radius:14px;padding:1.5rem;box-shadow:var(--sh-s);display:flex;flex-direction:column;gap:.8rem;}
.avis .stars{color:var(--ocre);}
.avis q{font-family:var(--ff-corps);font-style:normal;quotes:"«\00a0" "\00a0»";font-size:1.02rem;line-height:1.55;}
.avis__who{display:flex;align-items:center;gap:.7rem;margin-top:auto;}
.avis__ava{width:42px;height:42px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--ff-titre);}
.avis__who b{font-family:var(--ff-label);font-size:.98rem;}
.avis__who span{font-size:.78rem;color:var(--gris);display:block;}

/* ============ Bandes / médias ============ */
.media-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
.media-frame{border-radius:16px;overflow:hidden;box-shadow:var(--sh-l);aspect-ratio:1.05;background-size:cover;background-position:center;background-color:var(--creme-2);}

/* ============ Étapes (personnalisation) ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;counter-reset:s;}
.step{background:#fff;border:1px solid var(--ligne);border-radius:14px;padding:1.6rem;box-shadow:var(--sh-s);}
.step .n{width:44px;height:44px;border-radius:50%;background:var(--accent,var(--ocre-p));color:#fff;font-family:var(--ff-titre);font-size:1.2rem;display:flex;align-items:center;justify-content:center;margin-bottom:.9rem;}
.step h3{font-size:1.15rem;margin-bottom:.4rem;}
.step p{color:var(--gris);font-size:.96rem;}

/* ============ Formulaires ============ */
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem;}
.field label{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;color:var(--gris);}
.field input,.field textarea,.field select{font-family:var(--ff-corps);font-size:1rem;padding:.8em 1em;border:1.5px solid var(--ligne);border-radius:8px;background:#fff;color:var(--encre);}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ocre);box-shadow:0 0 0 3px var(--ocre-p);}

/* ============ Pied de page ============ */
.gd-foot{background:var(--creme);border-top:1px solid var(--ligne);padding-block:clamp(2.6rem,5vw,4rem) 1.8rem;}
.gd-foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;}
.gd-foot__brand img{height:64px;margin-bottom:.8rem;}
.gd-foot__brand p{color:var(--gris);font-size:.94rem;max-width:32ch;}
.gd-foot__social{display:flex;gap:.6rem;margin-top:1rem;}
.gd-foot__social a{width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--ligne);display:flex;align-items:center;justify-content:center;transition:.16s;}
.gd-foot__social a:hover{background:var(--noir);color:#fff;}
.gd-foot__col h4{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;color:var(--gris);margin-bottom:1rem;}
.gd-foot__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem;}
.gd-foot__col a{font-size:.94rem;}
.gd-foot__col a:hover{color:var(--ocre);}
.gd-foot__bottom{margin-top:2.4rem;padding-top:1.5rem;border-top:1px solid var(--ligne);display:flex;flex-wrap:wrap;
  justify-content:space-between;gap:1rem;font-family:var(--ff-label);font-size:.84rem;color:var(--gris);}
.gd-foot__pay{display:flex;gap:.4rem;align-items:center;}
.gd-foot__pay .pm{height:24px;padding:0 .5em;border:1px solid var(--ligne);border-radius:5px;background:#fff;display:flex;align-items:center;font-family:var(--ff-label);font-weight:700;font-size:.7rem;}

/* ============ Off-canvas mobile ============ */
.gd-scrim{position:fixed;inset:0;background:rgba(15,13,12,.45);z-index:90;opacity:0;visibility:hidden;transition:.25s;}
.gd-scrim.on{opacity:1;visibility:visible;}
.gd-oc{position:fixed;top:0;right:0;bottom:0;width:min(86vw,360px);background:#fff;z-index:95;transform:translateX(100%);
  transition:transform .32s var(--ease);display:flex;flex-direction:column;padding:1.3rem;overflow-y:auto;}
.gd-oc.on{transform:translateX(0);}
.gd-oc__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem;}
.gd-oc nav a{display:block;font-family:var(--ff-menu);text-transform:uppercase;letter-spacing:.06em;font-size:1.05rem;padding:.7em 0;border-bottom:1px solid var(--ligne);}
.gd-oc nav a .mk::after{height:.36em;}

/* ============ Reveal ============ */
.rv{opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease),transform .5s var(--ease);}
.rv.in{opacity:1;transform:none;}
@media(max-width:620px){ .zoomcard{grid-template-columns:1fr !important;} }
@media(max-width:760px){ .news-form{flex-direction:column;} }
@media(max-width:1080px){ .reals-grid,.guide-grid{grid-template-columns:repeat(2,1fr)!important;} }
@media(max-width:520px){ .reals-grid{grid-template-columns:1fr 1fr!important;} .guide-grid{grid-template-columns:1fr!important;} }
.pagehead{padding-block:clamp(2rem,4vw,3.4rem);}
.crumbs{font-family:var(--ff-label);font-size:.84rem;color:var(--gris);margin-bottom:.7rem;display:flex;gap:.5em;flex-wrap:wrap;}
.crumbs a:hover{color:var(--noir);}
.sg-fab{position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:85;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;width:64px;height:64px;border-radius:50%;background:var(--ocre);color:#fff;box-shadow:0 10px 26px rgba(207,129,24,.42);transition:transform .16s var(--ease),box-shadow .2s;}
.sg-fab span{font-family:var(--ff-label);text-transform:uppercase;letter-spacing:.04em;font-size:.6rem;}
.sg-fab:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(207,129,24,.52);}
.sg-modal{position:fixed;inset:0;z-index:120;background:rgba(15,13,12,.55);display:flex;align-items:center;justify-content:center;padding:1.5rem;}
.sg-card{position:relative;background:#fff;border-radius:18px;overflow:hidden;max-width:560px;width:100%;display:grid;grid-template-columns:1fr 1.2fr;box-shadow:var(--sh-l);}
.sg-card__img{background-size:cover;background-position:center;min-height:240px;}
.sg-card__b{padding:1.6rem;}
.sg-close{position:absolute;top:.7rem;right:.7rem;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--noir);}
.sg-table{width:100%;border-collapse:collapse;margin:.8rem 0 1.2rem;}
.sg-table td{padding:.5em 0;border-bottom:1px solid var(--ligne);font-size:.95rem;color:var(--encre);}
.sg-table td:last-child{text-align:right;font-family:var(--ff-label);font-weight:600;color:var(--ocre);}
@media(max-width:560px){.sg-card{grid-template-columns:1fr;}.sg-card__img{min-height:150px;}.sg-fab{width:58px;height:58px;}}

/* ============ Responsive ============ */
@media(max-width:1080px){
  .gd-cat-grid,.prod-grid{grid-template-columns:repeat(2,1fr);}
  .gal-grid{grid-template-columns:repeat(6,1fr);}
  .cfg-grid,.media-split,.steps{grid-template-columns:1fr;}
  .cfg-stage{position:static;}
  .avis-grid{grid-template-columns:1fr;}
}
@media(max-width:960px){
  .gd-nav{display:none;}
  .gd-burger{display:inline-flex;}
  .gd-utility__in{flex-wrap:wrap;}
  .gd-search{order:5;width:100%;margin-left:0;}
  .gd-search__field{min-width:0;flex:1;}
  .gd-util-mid{display:none;}
  .gd-foot__grid{grid-template-columns:1fr 1fr;}
  .gd-foot__brand{grid-column:1/-1;}
}
@media(max-width:620px){
  body{font-size:16px;}
  .gd-cat-grid,.prod-grid{grid-template-columns:1fr 1fr;}
  .gal-grid{grid-template-columns:repeat(4,1fr);}
  .cfg-swatches{grid-template-columns:repeat(5,1fr);}
  .gd-hero__count{display:none;}
  .gd-foot__grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:440px){
  .gal-grid{grid-template-columns:repeat(3,1fr);}
  .gd-cat-grid{grid-template-columns:1fr;}
}
