/* ============================================================
   SELHAM PARFUMS — Design System
   Univers : noir profond, doré, brun, sable, blanc cassé
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Jost:wght@300;400;500;600&display=swap');

:root{
  /* Couleurs */
  --noir:        #0B0805;
  --noir-2:      #110C07;
  --noir-3:      #181109;
  --brun:        #271A0E;
  --brun-soft:   #3A2917;
  --or:          #C7A25A;
  --or-light:    #E6CD93;
  --or-deep:     #9E7C3C;
  --sable:       #D7C3A0;
  --blanc:       #F5EFE3;
  --blanc-soft:  #ECE3D2;
  --creme:       #EFE7D7;
  --gris-doux:   #E7DECF;

  --txt-clair:   rgba(245,239,227,.74);
  --txt-clair-2: rgba(245,239,227,.50);
  --txt-sombre:  #36281A;
  --txt-sombre-2:#6B5A45;

  --ligne:       rgba(199,162,90,.28);
  --ligne-soft:  rgba(245,239,227,.10);

  /* Type */
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', -apple-system, sans-serif;

  /* Mesure */
  --max:  1280px;
  --pad:  clamp(20px, 5vw, 64px);
  --radius: 2px;

  --shadow-soft: 0 24px 60px -28px rgba(0,0,0,.7);
  --shadow-card: 0 30px 70px -40px rgba(0,0,0,.85);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family: var(--sans);
  background: var(--noir);
  color: var(--blanc);
  font-weight: 300;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background: var(--or); color: var(--noir); }

/* ---------- Typographie ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:400; line-height:1.08; letter-spacing:.005em; }
.eyebrow{
  font-family:var(--sans);
  font-size:.72rem; font-weight:500;
  letter-spacing:.34em; text-transform:uppercase;
  color: var(--or);
  display:inline-flex; align-items:center; gap:.8em;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--or); opacity:.6; }
.eyebrow.center::after{ content:""; width:34px; height:1px; background:var(--or); opacity:.6; }
.eyebrow.center{ justify-content:center; }

.display{
  font-size: clamp(2.6rem, 6.2vw, 5.4rem);
  font-weight:300; line-height:1.04;
  letter-spacing:-.01em;
}
.section-title{ font-size: clamp(2rem, 4.4vw, 3.4rem); font-weight:300; }
.lede{ font-size: clamp(1rem,1.25vw,1.15rem); color:var(--txt-clair); font-weight:300; max-width:54ch; }

.serif-italic{ font-style:italic; }
.gold{ color:var(--or); }

/* ---------- Layout ---------- */
.wrap{ max-width:var(--max); margin:0 auto; padding-inline:var(--pad); }
.section{ padding-block: clamp(72px, 11vw, 140px); position:relative; }
.section--tight{ padding-block: clamp(56px, 8vw, 96px); }
.center{ text-align:center; }
.divider{ height:1px; background:var(--ligne-soft); border:0; }

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--sans); font-size:.8rem; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase;
  padding: 1.05em 2em; border-radius:var(--radius);
  transition: all .35s cubic-bezier(.2,.7,.2,1);
  position:relative; white-space:nowrap; line-height:1;
}
.btn svg{ width:1.15em; height:1.15em; flex:0 0 auto; }

.btn--wa{
  background: linear-gradient(180deg,var(--or-light),var(--or));
  color: var(--noir);
  box-shadow: 0 14px 30px -14px rgba(199,162,90,.6);
}
.btn--wa:hover{ filter:brightness(1.06); transform:translateY(-2px); box-shadow:0 20px 40px -16px rgba(199,162,90,.75); }

.btn--ghost{
  border:1px solid var(--ligne);
  color: var(--blanc);
  background:transparent;
}
.btn--ghost:hover{ border-color:var(--or); color:var(--or-light); background:rgba(199,162,90,.06); }

.btn--dark{ background:var(--noir); color:var(--blanc); }
.btn--dark:hover{ background:var(--brun); }

.btn--block{ width:100%; }
.btn--sm{ padding:.85em 1.4em; font-size:.72rem; }

.link-gold{
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--or);
  display:inline-flex; align-items:center; gap:.6em; font-weight:500;
  transition:gap .3s ease;
}
.link-gold:hover{ gap:1em; color:var(--or-light); }
.link-gold svg{ width:1.1em; height:1.1em; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition: background .4s ease, border-color .4s ease, padding .4s ease;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background: rgba(11,8,5,.86);
  backdrop-filter: blur(16px);
  border-bottom-color: var(--ligne-soft);
}
.header-inner{
  max-width:var(--max); margin:0 auto; padding: 22px var(--pad);
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  transition:padding .4s ease;
}
.scrolled .header-inner{ padding-block:14px; }

.brand{ display:flex; flex-direction:column; line-height:1; gap:.28em; }
.brand .name{ font-family:var(--serif); font-size:1.5rem; font-weight:500; letter-spacing:.22em; }
.brand .sub{ font-size:.56rem; letter-spacing:.5em; text-transform:uppercase; color:var(--or); padding-left:.1em; }
.brand-logo{ height:60px; width:auto; align-self:flex-start; transition:height .4s ease; }
.scrolled .brand-logo{ height:48px; }
.footer .brand-logo{ height:92px; }

.nav{ display:flex; align-items:center; gap:clamp(20px,2.4vw,36px); }
.nav a{
  font-size:.78rem; letter-spacing:.13em; text-transform:uppercase; font-weight:400; white-space:nowrap;
  color:var(--txt-clair); position:relative; padding:.4em 0; transition:color .3s;
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0; background:var(--or); transition:width .35s ease;
}
.nav a:hover, .nav a.active{ color:var(--blanc); }
.nav a:hover::after, .nav a.active::after{ width:100%; }

.header-cta{ display:flex; align-items:center; gap:16px; }
.burger{
  display:none; width:42px; height:42px; align-items:center; justify-content:center;
  border:1px solid var(--ligne); border-radius:var(--radius);
}
.burger span{ display:block; width:18px; height:1.5px; background:var(--blanc); position:relative; transition:.3s; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:18px; height:1.5px; background:var(--blanc); transition:.3s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }
.burger.open span{ background:transparent; }
.burger.open span::before{ top:0; transform:rotate(45deg); }
.burger.open span::after{ top:0; transform:rotate(-45deg); }

/* Mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:99; background:var(--noir-2);
  display:flex; flex-direction:column; justify-content:center; gap:8px;
  padding: 0 var(--pad);
  transform:translateX(100%); transition:transform .5s cubic-bezier(.7,0,.2,1);
  visibility:hidden;
}
.mobile-menu.open{ transform:translateX(0); visibility:visible; }
.mobile-menu a{
  font-family:var(--serif); font-size:2.4rem; font-weight:300; color:var(--blanc);
  padding:.25em 0; border-bottom:1px solid var(--ligne-soft); transition:color .3s, padding-left .3s;
}
.mobile-menu a:hover{ color:var(--or); padding-left:.4em; }
.mobile-menu .btn{ margin-top:32px; align-self:flex-start; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; object-position:center 38%; }
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(7,5,3,.97) 0%, rgba(7,5,3,.95) 44%, rgba(7,5,3,.82) 62%, rgba(7,5,3,.55) 85%, rgba(7,5,3,.66) 100%),
    linear-gradient(180deg, rgba(7,5,3,.66) 0%, rgba(7,5,3,.4) 24%, rgba(7,5,3,.56) 58%, rgba(7,5,3,.95) 100%),
    radial-gradient(130% 100% at 72% 42%, transparent 42%, rgba(7,5,3,.6) 100%),
    linear-gradient(rgba(7,5,3,.2), rgba(7,5,3,.2));
}
.hero-inner{ position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding-inline:var(--pad); width:100%; padding-top:90px; }
.hero-content{ max-width:600px; text-shadow:0 2px 30px rgba(7,5,3,.7); }
.hero h1{ margin:.32em 0 .5em; }
.hero .lede{ margin-bottom:2.4em; color:rgba(245,239,227,.9); max-width:36ch; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:16px; }
.hero-scroll{
  position:absolute; bottom:34px; right:var(--pad); z-index:2;
  font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--txt-clair-2);
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.hero-scroll .line{ width:1px; height:42px; background:linear-gradient(var(--or),transparent); }
@media (max-width:1024px), (max-height:720px){ .hero-scroll{ display:none; } }

/* ============================================================
   VALEURS
   ============================================================ */
.values{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--ligne-soft); }
.value{
  padding: clamp(28px,3.4vw,46px) clamp(22px,2.6vw,34px);
  border-right:1px solid var(--ligne-soft);
  display:flex; flex-direction:column; gap:16px;
}
.value:last-child{ border-right:0; }
.value .vnum{ font-family:var(--serif); font-style:italic; font-size:1.1rem; color:var(--or); }
.value .vicon{ width:34px; height:34px; color:var(--or); }
.value h3{ font-size:1.5rem; font-weight:400; }
.value p{ font-size:.92rem; color:var(--txt-clair); }

/* ============================================================
   CARTE PRODUIT
   ============================================================ */
.product-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,34px); }
.product-grid.cols-4{ grid-template-columns:repeat(4,1fr); }

.card{
  position:relative; background:linear-gradient(180deg,var(--noir-3),var(--noir-2));
  border:1px solid var(--ligne-soft); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column;
  transition:border-color .45s ease, transform .45s ease;
}
.card:hover{ border-color:var(--ligne); transform:translateY(-4px); }
.card-media{
  position:relative; aspect-ratio:4/5; overflow:hidden;
  background:radial-gradient(120% 90% at 50% 20%, #2a1d10, var(--noir));
}
.card-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1s cubic-bezier(.2,.7,.2,1); }
.card:hover .card-media img{ transform:scale(1.06); }
.card-media .badge{
  position:absolute; top:14px; left:14px; z-index:2;
  font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; font-weight:500;
  color:var(--blanc); background:rgba(11,8,5,.6); backdrop-filter:blur(6px);
  border:1px solid var(--ligne); padding:.5em .9em; border-radius:100px;
}
.card-fav{
  position:absolute; top:12px; right:12px; z-index:2; width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--ligne-soft); border-radius:100px; background:rgba(11,8,5,.5);
  backdrop-filter:blur(6px); color:var(--blanc); transition:.3s;
}
.card-fav:hover{ color:var(--or); border-color:var(--or); }
.card-fav.active{ color:var(--or); }
.card-fav.active svg{ fill:var(--or); }

.card-body{ padding:22px 22px 24px; display:flex; flex-direction:column; gap:6px; flex:1; }
.card-type{ font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--or); font-weight:500; }
.card-name{ font-family:var(--serif); font-size:1.65rem; font-weight:400; line-height:1.1; }
.card-fam{ font-size:.78rem; color:var(--txt-clair-2); letter-spacing:.04em; }
.card-desc{ font-size:.9rem; color:var(--txt-clair); margin-top:2px; }
.card-foot{ margin-top:auto; padding-top:18px; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.card-price{ font-family:var(--serif); font-size:1.5rem; color:var(--blanc); }
.card-price small{ font-size:.7rem; font-family:var(--sans); letter-spacing:.12em; color:var(--txt-clair-2); margin-left:.3em; }
.card-actions{ display:flex; gap:10px; margin-top:16px; }
.card-actions .btn{ flex:1; }

/* --- États : promotion & épuisé --- */
.badge--promo{
  left:auto; right:14px;
  background:linear-gradient(180deg,var(--or-light),var(--or));
  color:var(--noir); border-color:transparent; font-weight:600;
}
.card .badge--promo{ top:auto; bottom:14px; }
.tag-epuise{
  position:absolute; z-index:3; left:50%; top:50%; transform:translate(-50%,-50%);
  font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; font-weight:600;
  color:var(--blanc); background:rgba(11,8,5,.72); backdrop-filter:blur(4px);
  border:1px solid var(--ligne); padding:.7em 1.4em; border-radius:100px;
}
.card.is-epuise .card-media img{ filter:grayscale(.55) brightness(.62); }
.price-old{ color:var(--txt-clair-2); font-size:.72em; margin-right:.35em; text-decoration:line-through; }

/* ============================================================
   SECTIONS CLAIRES (À propos)
   ============================================================ */
.section--light{ background:var(--creme); color:var(--txt-sombre); }
.section--light .lede{ color:var(--txt-sombre-2); }
.section--light .eyebrow{ color:var(--or-deep); }
.section--light .eyebrow::before,.section--light .eyebrow.center::after{ background:var(--or-deep); }
.section--light h2{ color:var(--txt-sombre); }
.section--sand{ background:var(--sand-grad, linear-gradient(180deg,var(--noir),var(--noir-3))); }

.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,80px); align-items:center; }
.split-media{ position:relative; aspect-ratio:4/5; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft); }
.split-media img{ width:100%; height:100%; object-fit:cover; }
.split-media .frame{ position:absolute; inset:14px; border:1px solid rgba(245,239,227,.25); pointer-events:none; z-index:2; }
.stat-row{ display:flex; gap:40px; margin-top:34px; }
.stat .num{ font-family:var(--serif); font-size:2.6rem; color:var(--or-deep); line-height:1; }
.section--sand .stat .num{ color:var(--or); }
.stat .lbl{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--txt-sombre-2); margin-top:8px; }
.section--sand .stat .lbl{ color:var(--txt-clair-2); }

/* ============================================================
   FAMILLES OLFACTIVES
   ============================================================ */
.fam-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--ligne-soft); border:1px solid var(--ligne-soft); }
.fam{
  background:var(--noir-2); padding:clamp(30px,3.4vw,44px); position:relative; overflow:hidden;
  transition:background .5s ease; min-height:240px; display:flex; flex-direction:column;
}
.fam:hover{ background:var(--noir-3); }
.fam .fam-no{ font-family:var(--serif); font-style:italic; color:var(--or); font-size:1.1rem; }
.fam h3{ font-size:2rem; font-weight:300; margin-top:auto; }
.fam p{ font-size:.9rem; color:var(--txt-clair); margin-top:12px; }
.fam .fam-glyph{ position:absolute; top:24px; right:24px; width:40px; height:40px; color:var(--or); opacity:.55; }

/* ============================================================
   TÉMOIGNAGES
   ============================================================ */
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,30px); }
.testi{
  border:1px solid var(--ligne-soft); border-radius:var(--radius); padding:clamp(28px,3vw,40px);
  display:flex; flex-direction:column; gap:20px; background:linear-gradient(180deg,var(--noir-2),var(--noir));
}
.testi .quote-mark{ font-family:var(--serif); font-size:3.4rem; line-height:.6; color:var(--or); height:.5em; }
.testi p{ font-family:var(--serif); font-size:1.45rem; font-weight:300; line-height:1.35; font-style:italic; color:var(--blanc-soft); }
.testi .stars{ display:flex; gap:3px; color:var(--or); }
.testi .stars svg{ width:15px; height:15px; }
.testi .who{ margin-top:auto; display:flex; align-items:center; gap:12px; }
.testi .ava{ width:42px; height:42px; border-radius:100px; background:linear-gradient(135deg,var(--brun-soft),var(--brun)); display:flex; align-items:center; justify-content:center; font-family:var(--serif); color:var(--or); font-size:1.1rem; border:1px solid var(--ligne); }
.testi .who .nm{ font-size:.92rem; color:var(--blanc); letter-spacing:.02em; }
.testi .who .loc{ font-size:.74rem; color:var(--txt-clair-2); }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{ border-top:1px solid var(--ligne-soft); }
.faq-item{ border-bottom:1px solid var(--ligne-soft); }
.faq-q{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:28px 4px; text-align:left;
}
.faq-q span{ font-family:var(--serif); font-size:clamp(1.2rem,2vw,1.6rem); font-weight:400; transition:color .3s; }
.faq-item:hover .faq-q span{ color:var(--or-light); }
.faq-icon{ flex:0 0 auto; width:26px; height:26px; position:relative; }
.faq-icon::before,.faq-icon::after{ content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:var(--or); transition:.35s; }
.faq-icon::before{ width:14px; height:1.5px; }
.faq-icon::after{ width:1.5px; height:14px; }
.faq-item.open .faq-icon::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .45s cubic-bezier(.2,.7,.2,1); }
.faq-a p{ padding:0 4px 28px; color:var(--txt-clair); font-size:1rem; max-width:70ch; }

/* ============================================================
   CONTACT / CTA
   ============================================================ */
.cta{ position:relative; overflow:hidden; }
.cta-bg{ position:absolute; inset:0; z-index:0; }
.cta-bg img{ width:100%; height:100%; object-fit:cover; }
.cta-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(11,8,5,.82),rgba(11,8,5,.92)); }
.cta-inner{ position:relative; z-index:2; text-align:center; display:flex; flex-direction:column; align-items:center; gap:22px; }
.cta-inner h2{ font-size:clamp(2.2rem,5vw,4rem); font-weight:300; }
.contact-meta{ display:flex; flex-wrap:wrap; gap:14px 40px; justify-content:center; margin-top:8px; }
.contact-meta a, .contact-meta span{ display:inline-flex; align-items:center; gap:10px; font-size:.92rem; letter-spacing:.06em; color:var(--txt-clair); transition:color .3s; }
.contact-meta a:hover{ color:var(--or); }
.contact-meta svg{ width:18px; height:18px; color:var(--or); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--noir-2); border-top:1px solid var(--ligne-soft); }
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-block:clamp(56px,7vw,84px); }
.footer .brand .name{ font-size:1.7rem; }
.footer-about{ color:var(--txt-clair); font-size:.92rem; max-width:34ch; margin-top:20px; }
.footer-col h4{ font-family:var(--sans); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--or); font-weight:500; margin-bottom:18px; }
.footer-col a, .footer-col p{ display:block; font-size:.92rem; color:var(--txt-clair); padding:7px 0; transition:color .3s; }
.footer-col a:hover{ color:var(--blanc); }
.footer-bottom{ border-top:1px solid var(--ligne-soft); padding-block:24px; display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; align-items:center; }
.footer-bottom p{ font-size:.78rem; color:var(--txt-clair-2); letter-spacing:.04em; }
.footer-bottom .made{ display:flex; align-items:center; gap:8px; }

/* ============================================================
   CATALOGUE
   ============================================================ */
.page-head{ padding-top:clamp(140px,16vw,200px); padding-bottom:clamp(40px,5vw,64px); text-align:center; position:relative; }
.page-head .crumbs{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--txt-clair-2); margin-bottom:24px; }
.page-head .crumbs a:hover{ color:var(--or); }
.page-head h1{ font-size:clamp(2.6rem,6vw,5rem); font-weight:300; }
.page-head .lede{ margin:22px auto 0; }

.catalog-toolbar{ display:flex; flex-direction:column; gap:24px; padding-bottom:36px; }
.search-box{ position:relative; max-width:520px; margin:0 auto; width:100%; }
.search-box input{
  width:100%; background:var(--noir-2); border:1px solid var(--ligne-soft); border-radius:100px;
  padding:16px 22px 16px 52px; color:var(--blanc); font-family:var(--sans); font-size:.95rem; font-weight:300;
  letter-spacing:.02em; transition:border-color .3s;
}
.search-box input::placeholder{ color:var(--txt-clair-2); }
.search-box input:focus{ outline:none; border-color:var(--or); }
.search-box svg{ position:absolute; left:20px; top:50%; transform:translateY(-50%); width:18px; height:18px; color:var(--or); }

.filters{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.filters .flabel{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--txt-clair-2); align-self:center; margin-right:6px; }
.chip{
  font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; font-weight:400;
  padding:.7em 1.3em; border:1px solid var(--ligne-soft); border-radius:100px; color:var(--txt-clair);
  transition:.3s;
}
.chip:hover{ border-color:var(--or); color:var(--blanc); }
.chip.active{ background:var(--or); color:var(--noir); border-color:var(--or); font-weight:500; }

.catalog-meta{ display:flex; justify-content:space-between; align-items:center; padding:18px 0 30px; border-top:1px solid var(--ligne-soft); }
.catalog-meta .count{ font-size:.84rem; color:var(--txt-clair); letter-spacing:.04em; }
.catalog-meta .count b{ color:var(--or); font-weight:500; }
.empty-state{ text-align:center; padding:80px 0; color:var(--txt-clair-2); font-family:var(--serif); font-size:1.6rem; font-style:italic; display:none; }

/* ============================================================
   FICHE PRODUIT
   ============================================================ */
.pdp{ padding-top:clamp(120px,14vw,170px); }
.pdp-grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(40px,5vw,80px); align-items:start; }
.pdp-gallery{ position:sticky; top:100px; }
.pdp-main{ aspect-ratio:4/5; border-radius:var(--radius); overflow:hidden; position:relative; box-shadow:var(--shadow-card); background:radial-gradient(120% 90% at 50% 20%, #2a1d10, var(--noir)); }
.pdp-main img{ width:100%; height:100%; object-fit:cover; }
.pdp-main .frame{ position:absolute; inset:16px; border:1px solid rgba(245,239,227,.2); z-index:2; pointer-events:none; }
.pdp-thumbs{ display:flex; gap:14px; margin-top:14px; }
.pdp-thumb{ flex:1; aspect-ratio:1; border-radius:var(--radius); overflow:hidden; border:1px solid var(--ligne-soft); opacity:.6; transition:.3s; cursor:pointer; }
.pdp-thumb img{ width:100%; height:100%; object-fit:cover; }
.pdp-thumb.active, .pdp-thumb:hover{ opacity:1; border-color:var(--or); }

.pdp-info .crumbs{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--txt-clair-2); margin-bottom:22px; }
.pdp-info .crumbs a:hover{ color:var(--or); }
.pdp-type{ color:var(--or); }
.pdp-info h1{ font-size:clamp(2.4rem,4.4vw,3.6rem); font-weight:300; margin:.18em 0 .3em; }
.pdp-rating{ display:flex; align-items:center; gap:12px; margin-bottom:24px; }
.pdp-rating .stars{ display:flex; gap:3px; color:var(--or); } .pdp-rating .stars svg{ width:16px; height:16px; }
.pdp-rating span{ font-size:.82rem; color:var(--txt-clair-2); letter-spacing:.04em; }
.pdp-price{ font-family:var(--serif); font-size:2.6rem; color:var(--blanc); margin-bottom:8px; }
.pdp-price small{ font-family:var(--sans); font-size:.8rem; letter-spacing:.1em; color:var(--txt-clair-2); }
.pdp-price .price-old{ color:var(--txt-clair-2); font-size:.55em; text-decoration:line-through; margin-right:.2em; }
.promo-flag{ font-family:var(--sans); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; font-weight:600; vertical-align:middle; color:var(--noir); background:linear-gradient(180deg,var(--or-light),var(--or)); padding:.45em .8em; border-radius:100px; margin-left:.4em; }
.pdp-avail{ font-size:.82rem; letter-spacing:.04em; margin-bottom:6px; }
.pdp-avail.in{ color:#7BB37B; }
.pdp-avail.out{ color:var(--or-light); }
.pdp-desc{ color:var(--txt-clair); font-size:1.02rem; margin:20px 0 28px; max-width:52ch; }

.pdp-specs{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--ligne-soft); border:1px solid var(--ligne-soft); margin:28px 0; }
.spec{ background:var(--noir); padding:20px 22px; }
.spec .k{ font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--txt-clair-2); }
.spec .v{ font-family:var(--serif); font-size:1.3rem; margin-top:6px; color:var(--blanc); }

.notes-row{ display:flex; flex-wrap:wrap; gap:10px; margin:18px 0 30px; }
.note-pill{ font-size:.78rem; letter-spacing:.06em; padding:.6em 1.1em; border:1px solid var(--ligne); border-radius:100px; color:var(--sable); }
.note-pill b{ color:var(--or); font-weight:500; font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; margin-right:.5em; }

.pdp-cta{ display:flex; flex-direction:column; gap:14px; margin-top:30px; }
.pdp-cta .row{ display:flex; gap:14px; }
.pdp-cta .row .btn{ flex:1; }
.pdp-reassure{ display:flex; flex-wrap:wrap; gap:20px; margin-top:22px; }
.pdp-reassure div{ display:flex; align-items:center; gap:9px; font-size:.82rem; color:var(--txt-clair); }
.pdp-reassure svg{ width:17px; height:17px; color:var(--or); }
.card-fav-btn.active{ color:var(--or-light); border-color:var(--or); }
.card-fav-btn.active svg{ fill:rgba(199,162,90,.25); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav, .header-cta .btn{ display:none; }
  .burger{ display:flex; }
  .values{ grid-template-columns:repeat(2,1fr); }
  .value:nth-child(2){ border-right:0; }
  .value:nth-child(1),.value:nth-child(2){ border-bottom:1px solid var(--ligne-soft); }
  .product-grid, .product-grid.cols-4{ grid-template-columns:repeat(2,1fr); }
  .fam-grid{ grid-template-columns:repeat(2,1fr); }
  .testi-grid{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; }
  .split-media{ max-width:520px; }
  .pdp-grid{ grid-template-columns:1fr; }
  .pdp-gallery{ position:static; max-width:560px; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:32px; }
  .footer .footer-brand{ grid-column:1/-1; }
}
@media (max-width:620px){
  .values{ grid-template-columns:1fr; }
  .value{ border-right:0 !important; border-bottom:1px solid var(--ligne-soft); }
  .product-grid, .product-grid.cols-4{ grid-template-columns:1fr; }
  .fam-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; }
  .pdp-specs{ grid-template-columns:1fr; }
  .stat-row{ gap:28px; }
  .hero-actions .btn{ flex:1; }
  .card-actions{ flex-direction:column; }
}

/* ============================================================
   SÉLECTEUR DE LANGUE
   ============================================================ */
.lang-switch{ display:flex; align-items:center; border:1px solid var(--ligne); border-radius:100px; overflow:hidden; flex:0 0 auto; }
.lang-switch button{
  padding:.55em .95em; font-size:.72rem; letter-spacing:.08em; font-weight:500;
  color:var(--txt-clair-2); transition:background .25s, color .25s; line-height:1;
}
.lang-switch button.active{ background:var(--or); color:var(--noir); }
.lang-switch button:not(.active):hover{ color:var(--blanc); }
.mobile-menu .lang-switch{ align-self:flex-start; margin-top:24px; }
.mobile-menu .lang-switch button{ font-size:.9rem; padding:.7em 1.2em; }

/* ============================================================
   ARABE / RTL
   ============================================================ */
body.rtl{ --serif:'El Messiri', Georgia, serif; --sans:'Tajawal', sans-serif; }
body.rtl{ font-family:var(--sans); }
/* l'arabe ne se prête pas au letter-spacing ni aux majuscules */
body.rtl .eyebrow, body.rtl .nav a, body.rtl .btn, body.rtl .chip, body.rtl .card-type,
body.rtl .badge, body.rtl .tag-epuise, body.rtl .flabel, body.rtl .footer-col h4,
body.rtl .stat .lbl, body.rtl .spec .k, body.rtl .note-pill b, body.rtl .pdp-type,
body.rtl .pdp-info .crumbs, body.rtl .page-head .crumbs, body.rtl .link-gold,
body.rtl .promo-flag, body.rtl .badge--promo, body.rtl .hero-scroll, body.rtl .pdp-avail,
body.rtl .footer-bottom p, body.rtl .made{ letter-spacing:0; text-transform:none; }
body.rtl{ font-weight:400; }

/* flèches & éléments directionnels */
body.rtl .link-gold svg{ transform:scaleX(-1); }
/* on n'inverse PAS l'image (le logo des flacons resterait à l'envers) :
   on inverse seulement le dégradé pour assombrir le côté du texte (droite) */
body.rtl .hero-bg::after{
  background:
    linear-gradient(270deg, rgba(7,5,3,.97) 0%, rgba(7,5,3,.95) 44%, rgba(7,5,3,.82) 62%, rgba(7,5,3,.55) 85%, rgba(7,5,3,.66) 100%),
    linear-gradient(180deg, rgba(7,5,3,.66) 0%, rgba(7,5,3,.4) 24%, rgba(7,5,3,.56) 58%, rgba(7,5,3,.95) 100%),
    radial-gradient(130% 100% at 28% 42%, transparent 42%, rgba(7,5,3,.6) 100%),
    linear-gradient(rgba(7,5,3,.2), rgba(7,5,3,.2));
}
body.rtl .eyebrow::before{ margin-left:0; }

/* badges & favoris (miroir) */
body.rtl .card-media .badge{ left:auto; right:14px; }
body.rtl .card .badge--promo{ right:auto; left:14px; }
body.rtl .card-fav{ right:auto; left:12px; }

/* bordures de la grille valeurs */
body.rtl .value{ border-right:0; border-left:1px solid var(--ligne-soft); }
body.rtl .value:last-child{ border-left:0; }

/* nav : soulignement à droite */
body.rtl .nav a::after{ left:auto; right:0; }

/* hero scroll à gauche en RTL */
body.rtl .hero-scroll{ right:auto; left:var(--pad); }

/* l'arabe a besoin d'un interligne un peu plus aéré */
body.rtl .testi p, body.rtl .lede, body.rtl .faq-a p{ line-height:1.7; }
@media (max-width:1024px){
  body.rtl .value{ border-left:0; }
  body.rtl .value:nth-child(1),body.rtl .value:nth-child(2){ border-bottom:1px solid var(--ligne-soft); }
}

