/* =====================================================================
   MAISON ARIGE — style (version animée + médias)
   ===================================================================== */
:root{
  --cream:#F6F1E9;--sand:#E9DECB;--clay:#C9A98C;
  --ink:#1C1A17;--ink-soft:#4A453E;--arige-green:#0E3B2E;--gold:#B08D57;
  --serif:"Fraunces",Georgia,serif;--sans:"Hanken Grotesk",-apple-system,sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1);--dur:760ms;
  --pad-section:clamp(96px,14vh,200px);--gutter:clamp(24px,6vw,120px);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;overflow-x:clip;}
body{background:var(--cream);color:var(--ink);font-family:var(--sans);font-weight:300;line-height:1.65;overflow-x:clip;}
::selection{background:var(--arige-green);color:var(--cream);}
img{display:block;max-width:100%;}
body::before{content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* curseur */
.cursor{position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid var(--ink);border-radius:50%;pointer-events:none;z-index:10001;transform:translate(-50%,-50%);transition:width .4s var(--ease),height .4s var(--ease),background .4s var(--ease),border-color .4s var(--ease),opacity .3s;mix-blend-mode:difference;opacity:0;}
.cursor.is-active{opacity:1;}
.cursor.is-hover{width:64px;height:64px;background:var(--cream);border-color:transparent;}
@media (hover:none){.cursor{display:none;}}

/* partagés */
.eyebrow{font-size:11px;letter-spacing:.26em;text-transform:uppercase;font-weight:400;color:var(--ink-soft);}
.section-index{display:inline-block;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:400;}
em{font-style:italic;}
.btn-line{display:inline-flex;align-items:center;gap:.7em;font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);background:none;border:none;cursor:pointer;padding-bottom:6px;position:relative;}
.btn-line span{transition:transform var(--dur) var(--ease);}
.btn-line::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease);}
.btn-line:hover::after{transform:scaleX(1);}
.btn-line:hover span{transform:translateX(5px);}
.btn-line--dark{color:var(--ink);}
.btn-solid{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);background:var(--ink);border:1px solid var(--ink);cursor:pointer;padding:18px 32px;width:100%;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);}
.btn-solid:hover{background:var(--arige-green);border-color:var(--gold);}
.link-underline{font-size:13px;letter-spacing:.04em;color:var(--ink);text-decoration:none;position:relative;padding-bottom:3px;}
.link-underline::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease);}
.link-underline:hover::after{transform:scaleX(1);}

/* rideau / chargement du logo */
.curtain{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(125% 105% at 50% 30%,#16553f 0%,#0E3B2E 70%);
  transition:transform 1300ms cubic-bezier(0.65,0,0.35,1),opacity 900ms var(--ease);}
.curtain.is-lifted{transform:translateY(-105%);}

.curtain__inner{display:flex;flex-direction:column;align-items:center;gap:30px;}

.curtain__logobox{position:relative;width:min(64vw,420px);}
/* lueur dorée discrète derrière le logo */
.curtain__logobox::before{content:"";position:absolute;left:50%;top:50%;width:155%;height:155%;
  transform:translate(-50%,-50%) scale(.78);border-radius:50%;pointer-events:none;
  background:radial-gradient(closest-side,rgba(176,141,87,.16),rgba(176,141,87,.04) 55%,transparent 72%);
  filter:blur(7px);opacity:0;animation:loaderGlow 3600ms cubic-bezier(0.4,0,0.2,1) 350ms forwards;}
@keyframes loaderGlow{0%{opacity:0;transform:translate(-50%,-50%) scale(.78);}
  55%{opacity:.6;transform:translate(-50%,-50%) scale(1.03);}
  100%{opacity:.42;transform:translate(-50%,-50%) scale(1);}}

/* le logo : fondu net depuis un léger flou + montée douce */
.curtain__logo{display:block;width:100%;height:auto;letter-spacing:normal;
  filter:drop-shadow(0 16px 50px rgba(0,0,0,.3));
  opacity:0;transform:scale(.95) translateY(12px);
  animation:loaderLogo 2400ms cubic-bezier(0.4,0,0.2,1) 250ms forwards;}
@keyframes loaderLogo{0%{opacity:0;transform:scale(.95) translateY(12px);filter:drop-shadow(0 16px 50px rgba(0,0,0,.3)) blur(8px);}
  65%{opacity:1;}
  100%{opacity:1;transform:scale(1) translateY(0);filter:drop-shadow(0 16px 50px rgba(0,0,0,.3)) blur(0);}}

/* reflet métallique doux qui balaie le logo (masqué à la forme du logo) */
.curtain__shine{position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;opacity:0;
  -webkit-mask:url("../images/logo-gold.png") center/contain no-repeat;
          mask:url("../images/logo-gold.png") center/contain no-repeat;
  background:linear-gradient(105deg,transparent 42%,rgba(231,205,151,.22) 48%,rgba(246,233,202,.42) 50%,rgba(231,205,151,.22) 52%,transparent 58%);
  background-size:300% 100%;background-repeat:no-repeat;background-position:175% 0;
  animation:loaderShine 2600ms cubic-bezier(0.4,0,0.2,1) 1050ms forwards;}
@keyframes loaderShine{0%{background-position:175% 0;opacity:0;}
  18%{opacity:.85;}80%{opacity:.85;}100%{background-position:-75% 0;opacity:0;}}

/* filet doré qui se trace */
.curtain__line{width:0;height:1px;opacity:0;
  background:linear-gradient(90deg,transparent,var(--gold) 30%,#d8bf90 50%,var(--gold) 70%,transparent);
  box-shadow:0 0 8px rgba(176,141,87,.26);
  animation:loaderLine 1700ms cubic-bezier(0.4,0,0.2,1) 1800ms forwards;}
@keyframes loaderLine{to{width:230px;opacity:1;}}

/* header */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.header.is-scrolled{background:rgba(246,241,233,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(28,26,23,.06);}
.nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:26px var(--gutter);transition:padding var(--dur) var(--ease);}
.header.is-scrolled .nav{padding-top:18px;padding-bottom:18px;}
.nav__group{list-style:none;display:flex;gap:36px;}
.nav__group--right{justify-content:flex-end;}
.nav__link{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);text-decoration:none;position:relative;}
.header.hero-dark .nav__link,.header.hero-dark .nav__logo{color:var(--cream);}
.nav__link::after{content:"";position:absolute;left:0;bottom:-5px;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease);}
.nav__link:hover::after{transform:scaleX(1);}
.nav__logo{font-family:var(--serif);font-weight:400;font-size:22px;letter-spacing:.42em;color:var(--ink);text-decoration:none;padding-left:.42em;text-align:center;}
.nav__count{display:inline-block;min-width:16px;text-align:center;color:var(--gold);margin-left:2px;}
.nav__burger{display:none;}
.mobile-menu{position:fixed;inset:0;z-index:999;background:var(--cream);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease);}
.mobile-menu.is-open{opacity:1;pointer-events:auto;}
.mobile-menu__link{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--ink);text-decoration:none;}

/* =====================================================================
   HERO — fond photo frais + orbes
   ===================================================================== */
.hero{position:relative;height:100vh;min-height:660px;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.hero__media{position:absolute;inset:0;z-index:0;overflow:hidden;}
.hero__media img{width:100%;height:120%;object-fit:cover;will-change:transform;animation:kenburns 26s ease-in-out infinite alternate;}
.hero__media video{display:block;width:100%;height:120%;object-fit:cover;will-change:transform;}
@keyframes kenburns{from{transform:scale(1.05) translateY(0);}to{transform:scale(1.2) translateY(-3%);}}
.hero__bg{position:absolute;inset:-15%;z-index:1;mix-blend-mode:soft-light;opacity:.85;
  background:radial-gradient(40% 50% at 18% 26%,rgba(124,107,166,.55),transparent 60%),radial-gradient(42% 52% at 82% 22%,rgba(224,138,43,.5),transparent 60%),radial-gradient(46% 56% at 78% 82%,rgba(201,162,39,.5),transparent 62%),radial-gradient(42% 52% at 16% 80%,rgba(60,140,90,.5),transparent 60%);
  animation:bgDrift 22s ease-in-out infinite alternate;}
@keyframes bgDrift{from{transform:scale(1) translate(0,0);}to{transform:scale(1.12) translate(-2%,-2%);}}
.hero__veil{position:absolute;inset:0;z-index:2;background:radial-gradient(70% 64% at 50% 54%,rgba(8,22,15,.40),rgba(8,22,15,.10) 82%),linear-gradient(180deg,rgba(10,26,18,.34),rgba(10,26,18,.18) 42%,rgba(10,26,18,.50));}
.hero__orbs{position:absolute;inset:0;z-index:3;}
.orb{position:absolute;width:var(--s);height:var(--s);will-change:transform;}
.orb__inner{width:100%;height:100%;border-radius:50%;overflow:hidden;box-shadow:0 30px 60px -20px rgba(0,0,0,.5),inset 0 0 0 5px rgba(246,241,233,.6);animation:float 9s ease-in-out infinite;}
.orb:nth-child(2) .orb__inner{animation-duration:11s;animation-delay:-2s;}
.orb:nth-child(3) .orb__inner{animation-duration:8s;animation-delay:-1s;}
.orb:nth-child(4) .orb__inner{animation-duration:12s;animation-delay:-4s;}
.orb:nth-child(5) .orb__inner{animation-duration:10s;animation-delay:-3s;}
.orb__inner img{width:100%;height:100%;object-fit:cover;}
.orb__tag{position:absolute;left:50%;bottom:-26px;transform:translateX(-50%);white-space:nowrap;font-family:var(--serif);font-style:italic;font-size:14px;color:var(--cream);opacity:.85;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-18px);}}
.hero__content{position:relative;z-index:4;text-align:center;padding:0 var(--gutter);max-width:900px;color:var(--cream);}
.hero__eyebrow{margin-bottom:22px;color:rgba(246,241,233,.85);}
.hero__title{font-family:var(--serif);font-weight:300;font-size:clamp(42px,8vw,108px);line-height:.98;letter-spacing:-.02em;text-shadow:0 2px 30px rgba(0,0,0,.25);}
.hero__title .line{display:block;overflow:hidden;}
.hero__title .line>*{display:inline-block;transform:translateY(110%);}
.hero__title .line>*.in{transform:translateY(0);transition:transform 1100ms var(--ease);}
.hero__sub{font-size:clamp(14px,1.5vw,18px);color:rgba(246,241,233,.9);margin:28px 0 38px;opacity:0;transition:opacity 900ms var(--ease) .6s;}
.hero__sub.in{opacity:1;}
.hero__content .btn-line{color:var(--cream);opacity:0;transition:opacity 900ms var(--ease) .8s;}
.hero__content .btn-line.in{opacity:1;}
.hero__scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);width:1px;height:54px;overflow:hidden;z-index:4;}
.hero__scroll span{display:block;width:1px;height:100%;background:rgba(246,241,233,.6);animation:scrollLine 2.4s var(--ease) infinite;}
@keyframes scrollLine{0%{transform:translateY(-100%);}60%,100%{transform:translateY(100%);}}

/* marquee */
.marquee{background:var(--arige-green);color:var(--cream);padding:22px 0;overflow:hidden;white-space:nowrap;}
.marquee__track{display:inline-flex;align-items:center;gap:28px;animation:marquee 28s linear infinite;}
.marquee__track span{font-family:var(--serif);font-style:italic;font-size:clamp(20px,3vw,34px);font-weight:300;}
.marquee__track .dot{color:var(--gold);font-style:normal;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* =====================================================================
   ZONE NUANCE (Maison -> Citation -> Coffrets) + MAISON moderne
   ===================================================================== */
.flowzone{position:relative;}
.maison{position:relative;background:var(--cream);padding:var(--pad-section) var(--gutter) clamp(80px,11vh,150px);overflow:hidden;}
.maison__inner{position:relative;max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(44px,7vw,120px);align-items:center;}
.maison__ghost{position:absolute;top:-14%;left:40%;font-family:var(--serif);font-weight:300;font-size:34vw;line-height:.7;color:rgba(28,26,23,.045);pointer-events:none;z-index:0;}
.maison__media{position:relative;z-index:1;}
.maison__media.reveal-clip{clip-path:inset(0 0 100% 0);}
.maison__media.reveal-clip.is-visible{clip-path:inset(0 0 0 0);transition:clip-path 1200ms var(--ease);}
.maison__media::before{content:"";position:absolute;left:-14px;top:26px;bottom:26px;width:6px;background:var(--gold);z-index:2;}
.maison__imgwrap{aspect-ratio:4/5;overflow:hidden;border-radius:3px;box-shadow:0 50px 80px -50px rgba(28,26,23,.5);animation:floatY 9s ease-in-out infinite;}
.maison__imgwrap img{width:100%;height:118%;object-fit:cover;will-change:transform;}
@keyframes floatY{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.maison__badge{position:absolute;bottom:16px;left:16px;background:var(--arige-green);color:var(--cream);font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:11px 18px;white-space:nowrap;z-index:3;}
.maison__text{position:relative;z-index:1;}
.maison__title{font-family:var(--serif);font-weight:300;font-size:clamp(34px,5vw,74px);line-height:1.0;margin:22px 0 30px;}
.maison__title .line{display:block;overflow:hidden;}
.maison__title .line>*{display:inline-block;transform:translateY(110%);transition:transform 1000ms var(--ease);}
.maison__title.is-visible .line>*{transform:translateY(0);}
.maison__title.is-visible .line:nth-child(2)>*{transition-delay:.1s;}
.maison__title.is-visible .line:nth-child(3)>*{transition-delay:.2s;}
.maison__body{font-size:clamp(15px,1.5vw,18px);color:var(--ink-soft);max-width:46ch;margin-bottom:28px;}

/* =====================================================================
   COFFRETS (cartes produit : visuel + panneau d'achat)
   ===================================================================== */
.collection{position:relative;overflow:hidden;padding:clamp(70px,10vh,140px) var(--gutter) var(--pad-section);background:radial-gradient(70% 60% at 88% 8%,rgba(176,141,87,.07),transparent 60%),radial-gradient(60% 55% at 6% 92%,rgba(14,59,46,.06),transparent 60%),var(--cream);}
.collection::before{content:"Rituels";position:absolute;top:46%;left:50%;transform:translate(-50%,-50%) rotate(-4deg);font-family:var(--serif);font-style:italic;font-weight:300;font-size:30vw;line-height:.8;color:rgba(28,26,23,.055);white-space:nowrap;pointer-events:none;z-index:0;}
.collection__head{position:relative;z-index:1;max-width:1200px;margin:0 auto 48px;}
.collection__lead{margin-top:18px;max-width:46ch;font-size:clamp(15px,1.4vw,17px);color:var(--ink-soft);}
.collection__title{font-family:var(--serif);font-weight:300;font-size:clamp(28px,4.4vw,56px);line-height:1.08;margin-top:18px;}
.packs{position:relative;z-index:1;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:clamp(22px,2.6vw,34px);}
.pcard{display:grid;grid-template-columns:1fr 1.08fr;height:400px;background:#FBF7EF;border:1px solid rgba(28,26,23,.07);border-radius:5px;overflow:hidden;box-shadow:0 30px 60px -45px rgba(28,26,23,.35);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);}
.pcard:hover{box-shadow:0 44px 80px -45px rgba(28,26,23,.45);transform:translateY(-3px);}
.pcard--rev{grid-template-columns:1.08fr 1fr;}
.pcard--rev .pcard__media{order:2;}
.pcard--rev .pcard__panel{order:1;}
.pcard__media{position:relative;overflow:hidden;min-height:300px;}
.pcard__media img{width:100%;height:100%;object-fit:cover;will-change:transform;transition:transform 1300ms var(--ease);}
.pcard:hover .pcard__media img{transform:scale(1.06);}
.pcard__flag{position:absolute;top:16px;left:16px;z-index:2;background:var(--gold);color:#1c1a17;font-size:9px;letter-spacing:.2em;text-transform:uppercase;padding:8px 13px;}
.pcard__panel{display:flex;flex-direction:column;justify-content:center;gap:13px;padding:clamp(30px,4vw,62px);}
.pcard--feature .pcard__panel{background:linear-gradient(180deg,#FBF7EF,#F3EAD9);}
.pcard__chip{align-self:flex-start;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);padding:6px 12px;border-radius:40px;}
.pcard__name{font-family:var(--serif);font-weight:400;font-size:clamp(26px,2.8vw,38px);line-height:1.04;color:var(--ink);}
.pcard__desc{font-size:15px;line-height:1.65;color:var(--ink-soft);max-width:40ch;}
.pcard__foot{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:8px;padding-top:20px;border-top:1px solid rgba(28,26,23,.12);}
.pcard__from{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:3px;}
.pcard__price{font-family:var(--serif);font-size:clamp(22px,2.2vw,30px);color:var(--ink);}
.pcard__btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--sans);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cream);background:var(--arige-green);border:none;padding:15px 22px;border-radius:40px;cursor:pointer;transition:background var(--dur) var(--ease);}
.pcard__btn span{transition:transform var(--dur) var(--ease);}
.pcard__btn:hover{background:var(--accent);}
.pcard__btn:hover span{transform:translateX(4px);}

/* =====================================================================
   VIDEO
   ===================================================================== */
.videosec{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden;}
.videosec__bg{position:absolute;inset:0;width:100%;height:118%;object-fit:cover;will-change:transform;z-index:0;}
.videosec__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(110deg,rgba(8,22,16,.78),rgba(8,22,16,.34) 70%,rgba(8,22,16,.2));}
.videosec__content{position:relative;z-index:2;color:var(--cream);padding:0 var(--gutter);max-width:640px;margin-left:clamp(0px,4vw,80px);}
.videosec__index{color:var(--gold);}
.videosec__title{font-family:var(--serif);font-weight:300;font-size:clamp(34px,5.2vw,76px);line-height:1.02;margin:18px 0 22px;}
.videosec__body{font-size:clamp(14px,1.4vw,17px);line-height:1.75;color:rgba(246,241,233,.86);max-width:46ch;}

/* =====================================================================
   SENTEURS — horizontal enrichi
   ===================================================================== */
.hscroll{position:relative;background:var(--ink);}
.hscroll__sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;}
.hscroll__ghost{position:absolute;z-index:0;right:4vw;top:50%;transform:translateY(-50%);font-family:var(--serif);font-weight:300;font-size:46vh;line-height:.8;color:rgba(246,241,233,.05);pointer-events:none;user-select:none;}
.hscroll__track{position:relative;z-index:1;display:flex;height:100%;align-items:center;will-change:transform;padding:0 6vw;gap:5vw;}
.hpanel{flex:0 0 auto;width:min(78vw,1040px);height:74vh;display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(28px,4vw,64px);align-items:center;}
.hpanel__media{height:100%;border-radius:4px;overflow:hidden;position:relative;}
.hpanel__media::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 55%,color-mix(in srgb,var(--accent) 45%,transparent));}
.hpanel__media::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);z-index:2;}
.hpanel__media img{width:100%;height:100%;object-fit:cover;}
.hpanel__body{color:var(--cream);}
.hpanel__num{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(40px,5vw,72px);line-height:1;color:var(--accent);display:block;margin-bottom:18px;}
.hpanel__name{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3.4vw,48px);line-height:1.05;margin-bottom:12px;}
.hpanel__tag{font-family:var(--serif);font-style:italic;font-size:clamp(17px,1.8vw,22px);color:var(--accent);margin-bottom:20px;}
.hpanel__text{font-size:clamp(14px,1.4vw,16px);line-height:1.75;color:rgba(246,241,233,.78);max-width:42ch;}
.hpanel--intro,.hpanel--outro{display:flex;flex-direction:column;justify-content:center;width:min(60vw,640px);color:var(--cream);}
.hpanel--intro .section-index{color:var(--gold);}
.hpanel__heading{font-family:var(--serif);font-weight:300;font-size:clamp(34px,5vw,68px);line-height:1.05;margin:18px 0 22px;}
.hpanel__lead{color:rgba(246,241,233,.7);font-size:16px;max-width:34ch;}
.hpanel__hint{margin-top:42px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);animation:hintMove 1.8s var(--ease) infinite;}
@keyframes hintMove{0%,100%{transform:translateX(0);}50%{transform:translateX(10px);}}
.hpanel--outro{align-items:flex-start;}
.hpanel__lead2{font-family:var(--serif);font-size:clamp(20px,2.4vw,30px);line-height:1.45;color:var(--cream);margin-bottom:32px;}
.hpanel__lead2 em{color:var(--gold);}
.hscroll__progress{position:absolute;left:6vw;right:6vw;bottom:42px;height:1px;background:rgba(246,241,233,.18);z-index:2;}
.hscroll__progress span{position:absolute;left:0;top:0;height:100%;width:0;background:var(--gold);}

/* statement */
.statement{position:relative;background:var(--arige-green);color:var(--cream);padding:clamp(120px,20vh,240px) var(--gutter);text-align:center;overflow:hidden;}
.statement__bg{position:absolute;inset:-15%;z-index:0;opacity:.5;background:radial-gradient(50% 60% at 30% 20%,rgba(176,141,87,.4),transparent 60%),radial-gradient(50% 60% at 80% 90%,rgba(60,140,90,.5),transparent 60%);}
.statement__quote{position:relative;z-index:1;max-width:820px;margin:0 auto;}
.statement__quote em{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(26px,4vw,52px);line-height:1.2;display:block;}
.statement__quote cite{display:block;margin-top:32px;font-style:normal;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);}

/* newsletter */
.newsletter{padding:var(--pad-section) var(--gutter);}
.newsletter__card{position:relative;max-width:800px;margin:0 auto;text-align:center;overflow:hidden;border-radius:9px;
  padding:clamp(50px,7vw,92px) clamp(26px,6vw,76px);color:var(--cream);
  background:radial-gradient(125% 135% at 50% -10%,#175840 0%,#0E3B2E 58%);
  box-shadow:0 55px 100px -55px rgba(14,59,46,.75);}
.newsletter__card::before{content:"";position:absolute;inset:14px;border:1px solid rgba(176,141,87,.42);border-radius:5px;pointer-events:none;}
.newsletter__card::after{content:"";position:absolute;left:50%;top:-28%;width:72%;height:72%;transform:translateX(-50%);pointer-events:none;
  background:radial-gradient(closest-side,rgba(176,141,87,.22),transparent 72%);}
.newsletter__index{position:relative;display:inline-block;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.newsletter__title{position:relative;font-family:var(--serif);font-weight:300;font-size:clamp(30px,4.4vw,58px);line-height:1.05;color:var(--cream);}
.newsletter__title em{font-style:italic;}
.newsletter__ornament{position:relative;display:block;width:104px;height:10px;margin:22px auto 26px;}
.newsletter__ornament::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;transform:translateY(-50%);
  background:linear-gradient(90deg,transparent,var(--gold) 24%,#e7cd97 50%,var(--gold) 76%,transparent);}
.newsletter__ornament::after{content:"";position:absolute;top:50%;left:50%;width:7px;height:7px;transform:translate(-50%,-50%) rotate(45deg);
  background:#e7cd97;box-shadow:0 0 9px rgba(176,141,87,.65);}
.newsletter__body{position:relative;color:rgba(246,241,233,.82);margin:0 auto 36px;max-width:470px;font-size:clamp(14px,1.4vw,16px);line-height:1.7;}
.newsletter__form{position:relative;display:flex;flex-direction:column;gap:12px;max-width:470px;margin:0 auto;}
.nlf__row{display:flex;gap:12px;}
.nlf__field{flex:1;min-width:0;width:100%;background:rgba(246,241,233,.06);border:1px solid rgba(176,141,87,.4);border-radius:999px;
  color:var(--cream);font-family:var(--sans);font-weight:300;font-size:15px;padding:14px 24px;outline:none;
  transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease);}
.nlf__field::placeholder{color:rgba(246,241,233,.5);}
.nlf__field:focus{border-color:var(--gold);background:rgba(246,241,233,.1);}
.nlf__btn{margin-top:6px;display:inline-flex;align-items:center;justify-content:center;gap:.6em;cursor:pointer;border:none;border-radius:999px;
  padding:15px 28px;font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#10271d;
  background:linear-gradient(135deg,#e7cd97,#b08d57 58%,#9a7b46);
  box-shadow:0 8px 20px -8px rgba(176,141,87,.7);transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.nlf__btn span{transition:transform var(--dur) var(--ease);}
.nlf__btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px -8px rgba(176,141,87,.85);}
.nlf__btn:hover span{transform:translateX(4px);}
.newsletter__note{position:relative;margin-top:18px;font-size:11px;letter-spacing:.12em;color:rgba(246,241,233,.45);}
@media (max-width:520px){
  .nlf__row{flex-direction:column;}
}

/* footer */
.footer{background:var(--arige-green);color:rgba(246,241,233,.78);padding:clamp(70px,9vh,120px) var(--gutter) 40px;}
.footer__grid{max-width:1500px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:64px;border-bottom:1px solid rgba(176,141,87,.25);}
.footer__logo{font-family:var(--serif);font-size:24px;letter-spacing:.4em;color:var(--gold);display:block;margin-bottom:18px;padding-left:.4em;}
.footer__brand p{font-size:14px;max-width:30ch;}
.footer__col{display:flex;flex-direction:column;gap:12px;}
.footer__head{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;}
.footer__col a{font-size:14px;color:rgba(246,241,233,.78);text-decoration:none;transition:color var(--dur) var(--ease);width:fit-content;}
.footer__col a:hover{color:var(--cream);}
.footer__base{max-width:1500px;margin:28px auto 0;display:flex;justify-content:space-between;font-size:11px;letter-spacing:.08em;color:rgba(246,241,233,.5);}

/* drawer */
.drawer-overlay{position:fixed;inset:0;z-index:1100;background:rgba(11,28,21,.35);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease);}
.drawer-overlay.is-open{opacity:1;pointer-events:auto;}
.drawer{position:fixed;top:0;right:0;z-index:1101;width:min(420px,92vw);height:100%;background:var(--cream);transform:translateX(100%);transition:transform var(--dur) var(--ease);display:flex;flex-direction:column;}
.drawer.is-open{transform:translateX(0);}
.drawer__head{display:flex;justify-content:space-between;align-items:center;padding:32px;border-bottom:1px solid rgba(28,26,23,.1);}
.drawer__title{font-family:var(--serif);font-style:italic;font-size:22px;}
.drawer__close{background:none;border:none;cursor:pointer;font-size:26px;line-height:1;color:var(--ink);}
.drawer__body{flex:1;padding:32px;overflow-y:auto;}
.drawer__empty{color:var(--ink-soft);font-style:italic;font-family:var(--serif);}
.drawer__line{display:flex;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid rgba(28,26,23,.08);font-size:14px;}
.drawer__line span:last-child{color:var(--ink-soft);white-space:nowrap;}
.drawer__foot{padding:28px 32px;border-top:1px solid rgba(28,26,23,.1);}
.drawer__total{display:flex;justify-content:space-between;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px;}

/* reveals */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 900ms var(--ease),transform 900ms var(--ease);}
.reveal.is-visible{opacity:1;transform:translateY(0);}
@keyframes countPop{0%{transform:scale(1);}40%{transform:scale(1.5);}100%{transform:scale(1);}}
.nav__count.pop{animation:countPop 500ms var(--ease);}

/* responsive */
@media (max-width:900px){
  .nav{grid-template-columns:auto 1fr auto;}
  .nav__group--left,.nav__group--right .nav__link:not(.nav__cart){display:none;}
  .nav__group--right{gap:18px;}
  .nav__logo{font-size:19px;}
  .nav__burger{display:flex;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;padding:4px;}
  .nav__burger span{width:22px;height:1px;background:var(--ink);display:block;}
  .header.hero-dark .nav__burger span{background:var(--cream);}
  .orb{transform:scale(.58)!important;}
  .orb:nth-child(3){display:none;}
  .orb__tag{display:none;}
  .maison__inner{grid-template-columns:1fr;gap:30px;}
  .maison__ghost{display:none;}
  .maison__media::before{display:none;}
  .pcard{grid-template-columns:1fr;height:auto;}
  .pcard--rev{grid-template-columns:1fr;}
  .pcard--rev .pcard__media,.pcard--rev .pcard__panel{order:0;}
  .pcard__media{min-height:0;aspect-ratio:4/3;}
  .pcard__desc{max-width:none;}
  .collection::before{font-size:64vw;top:30%;}
  .videosec{min-height:70vh;}
  .videosec__content{margin-left:0;}
  /* horizontal -> swipe natif */
  .hscroll{height:auto!important;}
  .hscroll__sticky{position:static;height:auto;display:block;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:14vh 0;}
  .hscroll__ghost{display:none;}
  .hscroll__track{transform:none!important;padding:0 6vw;gap:6vw;}
  .hpanel{scroll-snap-align:center;width:86vw;height:auto;grid-template-columns:1fr;gap:24px;}
  .hpanel__media{height:54vh;}
  .hpanel--intro,.hpanel--outro{width:86vw;height:auto;}
  .hscroll__progress{display:none;}
  .footer__grid{grid-template-columns:1fr 1fr;gap:36px;}
  .footer__base{flex-direction:column;gap:8px;text-align:center;}
}
@media (max-width:520px){.footer__grid{grid-template-columns:1fr;}}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important;}
  .reveal{opacity:1;transform:none;}
  .hero__title .line>*,.maison__title .line>*{transform:none;}
  .hero__sub,.hero__content .btn-line{opacity:1;}
}

/* =====================================================================
   RECONSTRUCTION — Curseur · Particules · Loader · Diagnostic · Menu
   (Bloc ajouté : surcharge la cascade via l'ordre)
   ===================================================================== */

/* ---- Curseur (anneau + point + libellé) + barre de progression ---- */
.cursor{display:flex;align-items:center;justify-content:center;}
.cursor__label{font-family:var(--sans);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);opacity:0;white-space:nowrap;transition:opacity .3s var(--ease);}
.cursor.is-label{width:96px;height:96px;background:var(--gold);border-color:transparent;mix-blend-mode:normal;}
.cursor.is-label .cursor__label{opacity:1;}
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:100%;background:linear-gradient(90deg,var(--gold),#E8CD96);transform:scaleX(0);transform-origin:left center;z-index:10002;pointer-events:none;}
.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;border-radius:50%;background:var(--gold);pointer-events:none;z-index:10001;transform:translate(-50%,-50%);opacity:0;transition:opacity .3s var(--ease);}
.cursor-dot.is-active{opacity:1;}
@media (hover:none){.cursor-dot{display:none;}}

/* ---- Particules + reflet doré du titre ---- */
.hero__particles{position:absolute;inset:0;z-index:3;pointer-events:none;overflow:hidden;will-change:transform;}
.particle{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(232,205,150,.9),rgba(232,205,150,0) 70%);will-change:transform;animation:pfloat ease-in-out infinite;}
@keyframes pfloat{0%{transform:translate(0,0);}50%{transform:translate(12px,-34px);}100%{transform:translate(0,0);}}
.hero__title .line span{color:#F7F2EA;text-shadow:0 2px 30px rgba(0,0,0,.34);background:linear-gradient(105deg,#F7F2EA 0%,#F7F2EA 43%,#F0DCAE 50%,#F7F2EA 57%,#F7F2EA 100%);background-size:240% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:titleShimmer 7.5s ease-in-out infinite;}
@keyframes titleShimmer{0%{background-position:130% 0;}55%{background-position:-30% 0;}100%{background-position:130% 0;}}

/* ---- Coffrets : relief 3D + zoom image + parallaxe ---- */
.pcard{transition:box-shadow var(--dur) var(--ease),transform .3s var(--ease);transform-style:preserve-3d;}
.pcard:hover{box-shadow:0 54px 90px -40px rgba(0,0,0,.6);}
.pcard__media{transition:transform 1300ms var(--ease);}
.pcard:hover .pcard__media{transform:scale(1.05);}
.pcard__media img{height:118%;transition:none;}
.pcard:hover .pcard__media img{transform:none;}

/* ---- Boutons magnétiques ---- */
.btn-line{transition:transform .35s var(--ease);}
.pcard__btn{transition:background var(--dur) var(--ease),transform .35s var(--ease);}
.btn-solid{transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform .35s var(--ease);}

/* ---- Loader : chargement du logo (styles définis plus haut) ---- */

/* ---- Menu : pastille verte "Mon Diagnostic" + burger -> croix ---- */
.nav__feature{background:var(--arige-green);color:var(--cream)!important;border:1px solid var(--arige-green);border-radius:40px;padding:8px 15px;white-space:nowrap;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);}
.nav__feature::after{display:none!important;}
.nav__feature:hover{background:#0a2c21;color:var(--cream)!important;}
.header.hero-dark .nav__feature{color:var(--cream)!important;border-color:var(--arige-green);}
.mobile-menu__link--feature{color:var(--arige-green);}
.nav__burger span{transition:transform .3s var(--ease),background .3s var(--ease);}
.nav__burger.is-x span{background:var(--ink)!important;}
.nav__burger.is-x span:nth-child(1){transform:translateY(3.5px) rotate(45deg);}
.nav__burger.is-x span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg);}

/* =====================================================================
   DIAGNOSTIC DE PEAU
   ===================================================================== */
.diag{position:relative;background:var(--arige-green);color:var(--cream);padding:var(--pad-section) var(--gutter);overflow:hidden;}
.diag__halo{position:absolute;width:60vw;height:60vw;top:-20vw;right:-15vw;background:radial-gradient(circle,rgba(176,141,87,.22),transparent 65%);pointer-events:none;}
.diag__inner{position:relative;z-index:1;max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:start;}
.diag .section-index{color:var(--gold);}
.diag__title{font-family:var(--serif);font-weight:300;font-size:clamp(30px,4vw,52px);line-height:1.06;margin:18px 0 22px;}
.diag__title em{font-style:italic;}
.diag__lead{font-size:16px;line-height:1.75;color:rgba(245,240,232,.82);max-width:42ch;}
.diag__how{list-style:none;margin:34px 0 0;padding:0;display:grid;gap:18px;}
.diag__how li{display:flex;gap:16px;align-items:flex-start;font-size:14px;line-height:1.5;color:rgba(245,240,232,.78);}
.diag__how-n{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:20px;min-width:30px;}
.diag__how strong{color:var(--cream);font-weight:500;}

/* Panneau interactif */
.diag__panel{background:#FBF7F0;color:var(--ink);border-radius:18px;padding:38px 34px;min-height:440px;box-shadow:0 50px 90px -40px rgba(0,0,0,.55);}
.dg-screen{animation:dgIn .5s var(--ease) both;}
@keyframes dgIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.dg-kicker{font-family:var(--sans);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:0 0 8px;}
.dg-h{font-family:var(--serif);font-weight:400;font-size:clamp(22px,2.6vw,30px);line-height:1.12;margin:0 0 12px;}
.dg-sub{font-size:14.5px;line-height:1.65;color:var(--ink-soft);margin:0 0 24px;max-width:46ch;}
.dg-fine{font-size:11.5px;color:var(--ink-soft);opacity:.8;margin:16px 0 0;}
.dg-cta{display:inline-flex;align-items:center;gap:8px;background:var(--arige-green);color:var(--cream);border:none;border-radius:40px;padding:14px 26px;font-family:var(--sans);font-size:13.5px;letter-spacing:.03em;cursor:pointer;transition:background .3s var(--ease),transform .3s var(--ease);}
.dg-cta:hover{background:#0a2c21;transform:translateY(-2px);}
.dg-cta--gold{background:var(--gold);color:#2a1f08;}
.dg-cta--gold:hover{background:#9c7b48;}
.dg-back{background:none;border:none;color:var(--ink-soft);font-family:var(--sans);font-size:13px;cursor:pointer;padding:0;margin:0 0 18px;transition:color .2s;}
.dg-back:hover{color:var(--ink);}

/* Profils */
.dg-profiles{display:grid;gap:12px;margin:0 0 22px;}
.dg-profile{display:flex;align-items:stretch;border:1px solid rgba(20,40,30,.14);border-radius:13px;overflow:hidden;transition:border-color .2s,box-shadow .2s;}
.dg-profile:hover{border-color:var(--gold);box-shadow:0 10px 30px -18px rgba(0,0,0,.4);}
.dg-profile__main{flex:1;display:flex;flex-direction:column;gap:3px;padding:15px 17px;cursor:pointer;}
.dg-profile__name{font-family:var(--serif);font-size:18px;}
.dg-profile__rel{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);}
.dg-profile__res{font-size:12.5px;color:var(--ink-soft);margin-top:2px;}
.dg-del{width:46px;border:none;background:rgba(20,40,30,.05);color:var(--ink-soft);font-size:20px;cursor:pointer;transition:background .2s,color .2s;}
.dg-del:hover{background:#c0392b;color:#fff;}

/* Formulaire */
.dg-form{display:grid;gap:18px;}
.dg-field{display:grid;gap:7px;}
.dg-field>span{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);}
.dg-field input{font-family:var(--sans);font-size:15px;padding:13px 15px;border:1px solid rgba(20,40,30,.2);border-radius:11px;background:#fff;color:var(--ink);outline:none;transition:border-color .2s;}
.dg-field input:focus{border-color:var(--gold);}
.dg-chips{display:flex;flex-wrap:wrap;gap:8px;}
.dg-chip{font-family:var(--sans);font-size:13px;padding:9px 15px;border:1px solid rgba(20,40,30,.2);border-radius:30px;background:#fff;color:var(--ink);cursor:pointer;transition:all .2s var(--ease);}
.dg-chip.is-on{background:var(--arige-green);color:var(--cream);border-color:var(--arige-green);}
.dg-err{color:#c0392b;font-size:12.5px;min-height:14px;margin:0;}

/* Quiz */
.dg-progress{height:3px;background:rgba(20,40,30,.1);border-radius:3px;overflow:hidden;margin:0 0 22px;}
.dg-progress span{display:block;height:100%;background:var(--gold);transition:width .4s var(--ease);}
.dg-quiz__head{display:flex;align-items:center;gap:14px;margin:0 0 10px;}
.dg-quiz__head .dg-back{margin:0;font-size:18px;}
.dg-step{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);}
.dg-q{font-family:var(--serif);font-weight:400;font-size:clamp(20px,2.5vw,27px);line-height:1.15;margin:0 0 22px;}
.dg-options{display:grid;gap:10px;}
.dg-opt{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;font-family:var(--sans);font-size:15px;padding:15px 18px;border:1px solid rgba(20,40,30,.18);border-radius:13px;background:#fff;color:var(--ink);cursor:pointer;transition:all .2s var(--ease);}
.dg-opt:hover,.dg-opt.is-on{border-color:var(--arige-green);background:rgba(14,59,46,.05);transform:translateX(4px);}
.dg-opt__tick{color:var(--gold);opacity:0;transition:opacity .2s;}
.dg-opt:hover .dg-opt__tick,.dg-opt.is-on .dg-opt__tick{opacity:1;}

/* Résultat */
.dg-route{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:6px 0 22px;}
.dg-route__card{border:1px solid rgba(20,40,30,.12);border-radius:14px;overflow:hidden;background:#fff;}
.dg-route__img{height:120px;overflow:hidden;}
.dg-route__img img{width:100%;height:100%;object-fit:cover;}
.dg-route__body{padding:14px 15px;}
.dg-route__moment{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);}
.dg-route__body h4{font-family:var(--serif);font-weight:400;font-size:18px;margin:5px 0 2px;}
.dg-route__tag{font-style:italic;font-size:12.5px;color:var(--ink-soft);margin:0 0 7px;}
.dg-route__why{font-size:12.5px;line-height:1.5;color:var(--ink-soft);margin:0;}
.dg-blocklbl{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin:0 0 10px;}
.dg-freq{display:flex;align-items:center;gap:16px;background:rgba(14,59,46,.05);border-radius:14px;padding:16px 18px;margin:0 0 18px;}
.dg-freq__n{font-family:var(--serif);font-size:38px;line-height:1;color:var(--arige-green);}
.dg-freq__txt{display:flex;flex-direction:column;gap:3px;}
.dg-freq__txt strong{font-size:13px;letter-spacing:.02em;text-transform:uppercase;color:var(--ink);font-weight:500;}
.dg-freq__txt span{font-size:12.5px;line-height:1.5;color:var(--ink-soft);}
.dg-tips{margin:0 0 18px;}
.dg-tips ul{list-style:none;margin:0;padding:0;display:grid;gap:9px;}
.dg-tips li{position:relative;padding-left:20px;font-size:13px;line-height:1.55;color:var(--ink-soft);}
.dg-tips li::before{content:"";position:absolute;left:2px;top:7px;width:6px;height:6px;border-radius:50%;background:var(--gold);}
.dg-note{font-size:13px;line-height:1.55;background:rgba(176,141,87,.12);border-radius:11px;padding:13px 15px;margin:0 0 18px;}
.dg-rec{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--arige-green);color:var(--cream);border-radius:14px;padding:18px 20px;margin:0 0 16px;}
.dg-rec__txt{display:flex;flex-direction:column;gap:3px;}
.dg-rec__lbl{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);}
.dg-rec__name{font-family:var(--serif);font-size:17px;}
.dg-rec__price{font-size:13px;color:rgba(245,240,232,.8);}
.dg-up{font-size:13px;color:var(--ink-soft);margin:0 0 18px;}
.dg-up a{color:var(--arige-green);text-decoration:underline;text-underline-offset:3px;}
.dg-reminders{border-top:1px solid rgba(20,40,30,.12);padding-top:18px;margin:0 0 16px;}
.dg-rem__txt{font-size:13px;line-height:1.55;color:var(--ink-soft);margin:0 0 12px;}
.dg-rem__btns{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 8px;}
.dg-ghostbtn{font-family:var(--sans);font-size:12.5px;padding:10px 16px;border:1px solid rgba(20,40,30,.2);border-radius:30px;background:#fff;color:var(--ink);cursor:pointer;transition:all .2s var(--ease);}
.dg-ghostbtn:hover{border-color:var(--gold);color:var(--arige-green);}
.dg-actions{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 0;}

@media (max-width:900px){
  .diag__inner{grid-template-columns:1fr;gap:38px;}
  .diag__panel{padding:30px 22px;}
  .dg-route{grid-template-columns:1fr;}
}

/* =====================================================================
   AJUST. — Section Coffrets en vert + photos de packs visibles en entier
   ===================================================================== */
.collection{background:radial-gradient(80% 70% at 85% 6%,rgba(176,141,87,.16),transparent 60%),var(--arige-green);}
.collection .section-index{color:var(--gold);}
.collection__title{color:var(--cream);}
.collection__lead{color:rgba(245,240,232,.82);}

/* Cartes : photo complète (contain), fond crème pour les marges */
.pcard__media{background:#FBF7EF;}
.pcard__media img{object-fit:contain;height:100%;transition:none;transform:none;}
.pcard:hover .pcard__media{transform:none;}
.pcard:hover .pcard__media img{transform:none;}
@media (max-width:900px){
  .pcard__media{aspect-ratio:16/10;}
}

/* =====================================================================
   TUNNEL DE COMMANDE — composition senteurs · livraison · confirmation
   ===================================================================== */
/* état épuisé sur la carte */
.pcard--soldout{opacity:.72;}
.pcard--soldout .pcard__media img{filter:grayscale(.35) brightness(.92);}
.pcard__flag--out{background:#7a2e2e;color:#f6efe9;}
.pcard__btn--soldout{display:inline-flex;align-items:center;gap:.6em;font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:rgba(28,26,23,.5);background:rgba(28,26,23,.06);border:1px solid rgba(28,26,23,.12);border-radius:999px;padding:13px 24px;cursor:not-allowed;}

/* boutons partagés du tunnel */
.btn-gold{display:inline-flex;align-items:center;justify-content:center;gap:.6em;cursor:pointer;border:none;border-radius:999px;
  padding:14px 28px;font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#10271d;
  background:linear-gradient(135deg,#e7cd97,#b08d57 58%,#9a7b46);box-shadow:0 8px 20px -8px rgba(176,141,87,.7);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),opacity var(--dur) var(--ease);}
.btn-gold span{transition:transform var(--dur) var(--ease);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 28px -8px rgba(176,141,87,.85);}
.btn-gold:hover span{transform:translateX(4px);}
.btn-gold:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;}
.btn-ghost{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);padding:12px 6px;transition:color var(--dur) var(--ease);}
.btn-ghost:hover{color:var(--ink);}

/* overlay + dialogue */
.tunnel{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;pointer-events:none;transition:opacity 360ms var(--ease);}
.tunnel.is-open{opacity:1;pointer-events:auto;}
.tunnel__overlay{position:absolute;inset:0;background:rgba(11,28,21,.55);backdrop-filter:blur(4px);}
.tunnel__dialog{position:relative;width:min(720px,100%);max-height:92vh;overflow-y:auto;background:var(--cream);border-radius:12px;
  box-shadow:0 60px 120px -50px rgba(11,28,21,.7);padding:clamp(26px,4vw,46px);
  transform:translateY(18px) scale(.98);transition:transform 420ms var(--ease);}
.tunnel.is-open .tunnel__dialog{transform:translateY(0) scale(1);}
.tunnel__close{position:absolute;top:16px;right:18px;background:none;border:none;font-size:30px;line-height:1;color:var(--ink-soft);cursor:pointer;z-index:2;transition:color var(--dur) var(--ease);}
.tunnel__close:hover{color:var(--ink);}

/* indicateur d'étapes */
.tunnel__steps{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:26px;}
.tunnel__step{display:inline-flex;align-items:center;gap:.5em;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:rgba(28,26,23,.4);}
.tunnel__step b{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:rgba(28,26,23,.1);font-size:11px;font-weight:600;color:rgba(28,26,23,.5);}
.tunnel__step.is-active{color:var(--arige-green);}
.tunnel__step.is-active b{background:var(--arige-green);color:var(--cream);}
.tunnel__step.is-done b{background:var(--gold);color:#10271d;}

/* panneaux */
.tunnel__panel{display:none;}
.tunnel__panel.is-active{display:block;animation:tnFade 420ms var(--ease);}
@keyframes tnFade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.tunnel__head{text-align:center;margin-bottom:22px;}
.tunnel__pack{display:inline-block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;}
.tunnel__title{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3.4vw,38px);line-height:1.1;color:var(--ink);}
.tunnel__sub{color:var(--ink-soft);font-size:14px;margin-top:8px;}
.tunnel__sub strong{color:var(--arige-green);}

/* grille des senteurs */
.scent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px;}
.scent{position:relative;border:1px solid rgba(28,26,23,.1);border-radius:9px;overflow:hidden;background:#fff;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.scent.is-on{border-color:var(--gold);box-shadow:0 0 0 2px rgba(176,141,87,.35);}
.scent__img{position:relative;aspect-ratio:4/3;overflow:hidden;}
.scent__img img{width:100%;height:100%;object-fit:cover;}
.scent__badge{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:var(--gold);color:#10271d;font-size:12px;font-weight:600;display:none;align-items:center;justify-content:center;}
.scent.is-on .scent__badge{display:flex;}
.scent__name{display:block;font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink);text-align:center;padding:10px 8px 4px;line-height:1.2;min-height:42px;}
.scent__qty{display:flex;align-items:center;justify-content:center;gap:14px;padding:6px 0 12px;}
.scent__btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(28,26,23,.2);background:none;color:var(--ink);font-size:16px;line-height:1;cursor:pointer;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);}
.scent__btn:hover{background:var(--arige-green);border-color:var(--arige-green);color:var(--cream);}
.scent__n{min-width:16px;text-align:center;font-size:15px;font-weight:500;color:var(--ink);}

/* barre d'action */
.tunnel__bar{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid rgba(28,26,23,.1);padding-top:18px;position:sticky;bottom:0;background:var(--cream);}
.tunnel__counter{font-size:13px;letter-spacing:.04em;color:var(--ink-soft);}
.tunnel__counter strong{color:var(--arige-green);font-size:16px;}

/* formulaire */
.tform{display:flex;flex-direction:column;gap:12px;margin-bottom:22px;}
.tform__row{display:flex;gap:12px;}
.tform__field{flex:1;min-width:0;width:100%;background:#fff;border:1px solid rgba(28,26,23,.16);border-radius:10px;color:var(--ink);font-family:var(--sans);font-weight:300;font-size:15px;padding:14px 18px;outline:none;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.tform__field::placeholder{color:rgba(28,26,23,.4);}
.tform__field:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,141,87,.15);}
.tform__field.is-empty{border-color:#b4574f;}
.tform__err{color:#b4574f;font-size:13px;margin:-8px 0 14px;}

/* paiement */
.paywrap{margin-bottom:8px;}
.paywrap__label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px;}
.payopts{display:flex;gap:12px;}
.payopt{flex:1;text-align:left;cursor:pointer;background:#fff;border:1px solid rgba(28,26,23,.16);border-radius:10px;padding:16px 18px;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease);}
.payopt__t{display:block;font-size:14px;font-weight:500;color:var(--ink);}
.payopt__d{display:block;font-size:12px;color:var(--ink-soft);margin-top:3px;}
.payopt.is-active{border-color:var(--arige-green);background:rgba(14,59,46,.04);box-shadow:0 0 0 2px rgba(14,59,46,.18);}

/* confirmation */
.tn-done{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;padding:14px 0;}
.tn-done__seal{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;color:#10271d;background:radial-gradient(circle at 38% 32%,#d8ba7e,#b08d57 60%,#8a6a3d);box-shadow:0 10px 24px -8px rgba(176,141,87,.7);}
.tn-summary{width:100%;text-align:left;background:#fff;border:1px solid rgba(28,26,23,.1);border-radius:10px;padding:18px 20px;font-size:14px;color:var(--ink-soft);line-height:1.7;}
.tn-summary b{color:var(--ink);}
.tn-summary .tn-line{display:flex;justify-content:space-between;gap:12px;}
.tn-summary .tn-total{border-top:1px solid rgba(28,26,23,.1);margin-top:10px;padding-top:10px;font-size:15px;color:var(--ink);}

@media (max-width:560px){
  .scent-grid{grid-template-columns:repeat(2,1fr);}
  .tform__row{flex-direction:column;}
  .payopts{flex-direction:column;}
  .tunnel__step{font-size:10px;}
}


/* Bouton confirmation WhatsApp (commande) */
#tnWhats{background:#25D366 !important;color:#fff !important;text-decoration:none !important;border:none !important;box-shadow:0 8px 20px -8px rgba(37,211,102,.7) !important;}
#tnWhats:hover{background:#1ebe5d !important;box-shadow:0 14px 28px -8px rgba(37,211,102,.85) !important;}
#tnWhats span{color:#fff !important;}
