/* =============================================================
   ÉQUIVALENCE — Feuille de style principale
   Direction : luxe sobre, parfumerie, moderne, éditorial.
   ============================================================= */

:root{
  /* Couleurs — conservées, juste nommées proprement */
  --bg:#ffffff;
  --surface:#fafaf7;           /* blanc cassé très léger pour sections alternées */
  --surface-soft:#f5f4ef;
  --text:#0f172a;
  --text-strong:#0b0b0c;
  --muted:#6b7280;
  --muted-2:#9ca3af;
  --border:#e5e7eb;
  --border-soft:#ececec;
  --line:#d8d4cb;              /* filet éditorial discret */
  --black:#111827;

  /* Accent discret (déjà utilisé avant en feat-dot) */
  --gold:#c6a15c;
  --gold-soft:#d8bc86;

  /* Vignettes & fonds atmosphère */
  --gray-45: rgba(189,189,189,.45);
  --gray-light-45: rgba(238,238,238,.45);
  --haze: rgba(15,23,42,.04);

  /* Footer */
  --footer-bg:#0f172a;
  --footer-text:#d1d5db;
  --footer-muted:#9ca3af;
  --footer-border:rgba(255,255,255,.10);

  /* Ombres très douces (luxe = peu d'ombre) */
  --shadow:0 1px 2px rgba(15,23,42,.04);
  --shadow-lift:0 10px 40px -18px rgba(15,23,42,.25);

  /* Radius (sobre, peu arrondi sur boutons) */
  --r-xs:2px;
  --r-sm:4px;
  --r-md:8px;
  --r-lg:14px;

  /* Typo */
  --serif:"Book Antiqua","Palatino Linotype",Palatino,"URW Palladio L",P052,"Cormorant Garamond",Georgia,serif;
  --sans:"Helvetica Neue","Inter",-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;

  /* Eyebrow / libellés éditoriaux */
  --tracking-wide:.28em;
  --tracking-ultra:.42em;

  /* Transitions */
  --ease:cubic-bezier(.22,.61,.36,1);
  --t-fast:.25s var(--ease);
  --t-mid:.45s var(--ease);
}

*{box-sizing:border-box}
html,body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--serif);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit}

::selection{background:#0f172a;color:#fff}

/* ==================== LAYOUT ==================== */
.container{max-width:1240px;margin:0 auto;padding:0 32px}

/* Section générique : padding généreux, pas d'ombre par défaut */
.section{padding:96px 0;position:relative}
.section--tight{padding:64px 0}
.section--alt{background:var(--surface)}

.section-head{max-width:720px;margin:0 auto 56px;text-align:center}
.section-title{
  font-family:var(--serif);
  font-size:clamp(32px,4.6vw,52px);
  font-weight:400;
  letter-spacing:-.01em;
  line-height:1.1;
  margin:0 0 14px;
  color:var(--text-strong);
}
.section-subtitle{
  color:var(--muted);
  margin:0 auto;
  max-width:56ch;
  font-size:15px;
  font-style:italic;
}

/* Eyebrow : petit libellé en haut de section ou dans un hero */
.eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:11px;
  font-weight:600;
  letter-spacing:var(--tracking-ultra);
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:18px;
  position:relative;
  padding-left:44px;
}
.eyebrow::before{
  content:"";position:absolute;left:0;top:50%;width:32px;height:1px;background:var(--gold);transform:translateY(-50%);
}

/* Filet fin de séparation éditoriale */
.hr-fine{border:0;height:1px;background:var(--border);margin:48px auto;max-width:120px}
.hr-gold{border:0;height:1px;background:var(--gold);margin:0 auto 28px;width:48px}

/* ==================== HERO ==================== */
.hero{padding:96px 0 80px;position:relative}
.hero .grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:88px;
  align-items:center;
}
.title-xl{
  font-family:var(--serif);
  font-size:clamp(48px,7vw,96px);
  line-height:.98;
  font-weight:300;
  letter-spacing:-.025em;
  color:var(--text-strong);
  margin:0;
}
.title-xl .muted{
  color:var(--muted-2);
  font-weight:300;
  font-style:italic;
}
.subtitle{
  margin-top:18px;
  color:var(--muted);
  font-family:var(--sans);
  font-size:12px;
  font-weight:600;
  letter-spacing:var(--tracking-ultra);
  text-transform:uppercase;
}
.lead{
  margin-top:28px;
  color:#4b5563;
  max-width:52ch;
  font-size:17px;
  line-height:1.7;
}
.actions{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}

/* ==================== BOUTONS ==================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:16px 32px;
  border:1px solid var(--text-strong);
  border-radius:var(--r-xs);
  text-decoration:none;
  font-family:var(--sans);
  font-size:12px;
  font-weight:600;
  letter-spacing:var(--tracking-wide);
  text-transform:uppercase;
  color:var(--text-strong);
  background:transparent;
  cursor:pointer;
  position:relative;
  transition:background var(--t-fast), color var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.btn:hover{background:var(--text-strong);color:#fff}
.btn-primary{background:var(--text-strong);color:#fff}
.btn-primary:hover{background:#000;color:#fff}
.btn-soft{
  background:transparent;
  color:var(--text-strong);
  border-color:var(--border);
}
.btn-soft:hover{background:var(--surface);color:var(--text-strong);border-color:var(--text-strong)}
.btn-ghost{
  background:transparent;color:var(--text-strong);border-color:transparent;padding:14px 8px;
}
.btn-ghost::after{
  content:"";display:block;position:absolute;left:8px;right:8px;bottom:8px;height:1px;background:currentColor;transform-origin:left;transition:transform var(--t-mid);
}
.btn-ghost:hover{background:transparent;color:var(--text-strong)}
.btn-ghost:hover::after{transform:scaleX(.6)}

.btn-sm{padding:10px 20px;font-size:11px}
.btn-lg{padding:18px 38px;font-size:13px}
.btn-block{width:100%}

/* Anciennes "pills" : on garde la classe pour compat, mais on enlève l'effet pill criard */
.pill{
  display:inline-block;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:var(--tracking-ultra);
  text-transform:uppercase;
  color:var(--muted);
  background:transparent;
  border:1px solid var(--border);
  padding:6px 12px;
  border-radius:999px;
  font-weight:600;
}

/* ==================== CARTE HERO PRODUIT ==================== */
.card{
  background:#fff;
  border:1px solid var(--border-soft);
  border-radius:var(--r-sm);
  padding:32px;
  transition:border-color var(--t-mid), transform var(--t-mid);
}
.card:hover{border-color:var(--text-strong);transform:translateY(-2px)}
.card .thumb{
  background:var(--surface);
  aspect-ratio:3/4;
  border-radius:2px;
  display:grid;place-items:center;
  overflow:hidden;
}
.card h3{
  margin:18px 0 4px;
  font-size:22px;
  font-weight:400;
  letter-spacing:-.01em;
}
.card p{margin:6px 0;color:var(--muted);font-size:14px;line-height:1.55}
.card .price{
  margin-top:14px;
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:var(--tracking-wide);
  text-transform:uppercase;
  color:var(--text-strong);
  font-weight:600;
}
.card .pill{margin-top:16px}

/* Décor flacon vestigial (conservé pour compat index) */
.flacon{width:64px;height:88px;border-radius:4px;background:#8b4513;position:relative}
.flacon:before{content:"";position:absolute;top:8px;right:8px;width:26px;height:10px;border-radius:2px;background:#b76722}

/* ==================== GRILLES PRODUITS ==================== */
.cards-3{display:grid;gap:40px;grid-template-columns:repeat(3,1fr);margin-top:48px}
.cards-2{display:grid;gap:40px;grid-template-columns:repeat(2,1fr)}
.cards-4{display:grid;gap:32px;grid-template-columns:repeat(4,1fr)}

/* Carte produit — look catalogue haute parfumerie */
.pcard{
  background:transparent;
  border:0;
  border-radius:0;
  overflow:visible;
  position:relative;
  transition:transform var(--t-mid);
}
.pcard:hover{transform:translateY(-4px)}
.pcard-badge{
  position:absolute;
  top:14px;left:14px;
  z-index:3;
  background:rgba(255,255,255,.92);
  color:var(--text-strong);
  font-family:var(--sans);
  font-weight:600;
  font-size:10px;
  letter-spacing:var(--tracking-wide);
  text-transform:uppercase;
  padding:6px 10px;
  border-radius:2px;
  border:1px solid var(--border);
}
.pcard-badge--out{background:rgba(15,23,42,.85);color:#fff;border-color:transparent}

.pcard-thumb{
  aspect-ratio:3/4;
  background:var(--surface);
  display:grid;place-items:center;
  position:relative;
  overflow:hidden;
  border-radius:2px;
}
.pcard-thumb img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  transition:transform 1.2s var(--ease), filter var(--t-mid);
}
.pcard:hover .pcard-thumb img{transform:scale(1.04)}

.pcard-body{padding:18px 2px 0;text-align:left}
.pcard-title{
  margin:6px 0 4px;
  font-size:18px;
  font-weight:400;
  letter-spacing:-.005em;
  color:var(--text-strong);
}
.pcard-sub{color:var(--muted);font-size:13px;line-height:1.55}
.pcard-sub--preline{
  white-space:pre-line;             /* préserve les sauts de ligne (\n) */
  display:-webkit-box;
  -webkit-line-clamp:4;             /* max 4 lignes en aperçu carte */
  -webkit-box-orient:vertical;
  line-clamp:4;
  overflow:hidden;
}
.pcard-type{
  display:inline-block;margin:2px 0 6px;
  font-family:var(--sans);font-size:9.5px;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);
  padding:2px 8px;border:1px solid var(--gold);border-radius:999px;
  line-height:1.4;
}
.pcard-price{
  margin-top:10px;
  display:flex;gap:10px;align-items:baseline;
  font-family:var(--sans);
}
.pcard-price strong{
  font-size:14px;
  letter-spacing:.04em;
  color:var(--text-strong);
  font-weight:600;
}
.pcard-price s{color:var(--muted-2);font-size:13px}
.pcard-btn{
  margin-top:14px;
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--text-strong);
  padding:10px 0;
  text-decoration:none;
  font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:var(--tracking-wide);text-transform:uppercase;
  border-bottom:1px solid var(--text-strong);
}
.pcard-btn:hover{color:var(--gold);border-color:var(--gold)}

.product-link{display:block;text-decoration:none;color:inherit}
.product-link:focus-visible{outline:2px solid var(--text-strong);outline-offset:4px}

.center{text-align:center}
.mt-28{margin-top:40px}
.mt-48{margin-top:48px}

/* ==================== NOTRE UNIVERS ==================== */
.univers-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center;
}
.univers-title{
  font-family:var(--serif);
  font-size:clamp(32px,4.4vw,48px);
  font-weight:300;
  letter-spacing:-.01em;
  line-height:1.1;
  margin:0 0 18px;
  color:var(--text-strong);
}
.univers-lead{color:#374151;margin:0 0 18px;max-width:56ch;font-size:17px;line-height:1.7}
.univers-text{color:var(--muted);margin:0 0 24px;max-width:56ch;font-size:15px;line-height:1.7}
.univers-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:4px 24px;margin-top:24px;
  border-top:1px solid var(--border);padding-top:20px;
}
.univers-list ul{margin:0;padding:0;list-style:none}
.univers-list li{
  margin:10px 0;
  font-family:var(--sans);font-size:12px;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text);font-weight:500;
  position:relative;padding-left:22px;
}
.univers-list li::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:10px;height:1px;background:var(--gold);
}

.univers-card{
  background:var(--surface);
  color:var(--text);
  border-radius:var(--r-sm);
  padding:56px 40px;
  border:1px solid var(--border-soft);
  position:relative;
}
.univers-card::before{
  content:"";position:absolute;top:24px;left:50%;transform:translateX(-50%);width:28px;height:1px;background:var(--gold);
}
.bottles{display:flex;gap:14px;justify-content:center;margin:20px 0 22px}
.bottles span{width:28px;height:40px;border-radius:2px;background:linear-gradient(180deg,#b08a57,#8b6a3d)}
.univers-card-title{
  text-align:center;margin:8px 0 10px;
  font-size:26px;font-weight:400;letter-spacing:-.01em;color:var(--text-strong);
}
.univers-card-sub{
  text-align:center;color:var(--muted);
  margin:0 auto 32px;max-width:42ch;
  font-size:15px;line-height:1.65;font-style:italic;
}
.univers-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;text-align:center;
  border-top:1px solid var(--border);padding-top:28px;
}
.univers-stats strong{
  display:block;
  font-size:30px;font-weight:300;color:var(--text-strong);letter-spacing:-.02em;margin-bottom:4px;
}
.univers-stats span{
  display:block;color:var(--muted);
  font-family:var(--sans);font-size:10px;letter-spacing:var(--tracking-ultra);text-transform:uppercase;
}

/* ==================== SECTIONS PLEIN ÉCRAN ==================== */
.section-full{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  box-sizing:border-box;
}
.section-full > *{width:100%}
@media (max-width: 720px){
  /* Sur mobile on relâche le 100vh : le contenu peut être plus grand que l'écran sans casser */
  .section-full{min-height:auto}
}

/* ==================== CATÉGORIES OLFACTIVES ==================== */
.category-wrap{display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin-top:32px}
.category{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  padding:28px 18px;
  text-align:center;
  transition:border-color var(--t-mid), transform var(--t-mid);
}
.category:hover{border-color:var(--text-strong);transform:translateY(-3px)}
.category-icon{font-size:22px;color:var(--gold)}
.category-name{
  font-weight:500;margin-top:14px;font-size:15px;
  font-family:var(--sans);letter-spacing:var(--tracking-wide);text-transform:uppercase;
}
.category-desc{color:var(--muted);font-size:13px;margin-top:8px;line-height:1.5}

/* ==================== CARTES COLLECTION (variantes) ==================== */
.pcard--soft{background:#fff;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}
.pcard-banner{
  height:160px;border-radius:2px;background:var(--surface);
  display:flex;align-items:center;justify-content:center;margin:18px 18px 0;
}
.flacon-hero{
  width:64px;height:86px;background:linear-gradient(#8b4513,#6d3a0f);border-radius:4px;position:relative;
}
.flacon-hero__top{
  position:absolute;top:6px;left:50%;transform:translateX(-50%);width:28px;height:8px;background:#b76722;border-radius:2px;
}
.pcard-features{display:grid;gap:10px;margin:14px 0}
.feat{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:13px}
.feat-dot{width:6px;height:6px;border-radius:999px;background:var(--gold)}

/* ==================== PAGINATION ==================== */
.pagination{display:flex;gap:4px;justify-content:center;margin-top:48px;font-family:var(--sans)}
.pagination .page{
  padding:10px 14px;
  border:1px solid var(--border);
  border-radius:var(--r-xs);
  background:#fff;
  text-decoration:none;
  color:var(--text);
  font-size:12px;letter-spacing:.08em;
  min-width:40px;text-align:center;
  transition:all var(--t-fast);
}
.pagination .page:hover{border-color:var(--text-strong)}
.pagination .page.is-active{background:var(--text-strong);color:#fff;border-color:var(--text-strong)}

/* ==================== CTA BANNIÈRE ==================== */
.cta-banner{
  background:var(--text-strong);
  color:#fff;
  border-radius:var(--r-sm);
  padding:72px 40px;
  text-align:center;
  position:relative;
}
.cta-banner::before{
  content:"";display:block;width:32px;height:1px;background:var(--gold);margin:0 auto 24px;
}
.cta-banner h2{
  margin:0 0 14px;
  font-family:var(--serif);font-size:clamp(28px,3.4vw,40px);font-weight:300;letter-spacing:-.01em;
}
.cta-banner p{color:#d1d5db;margin:0 0 28px;font-size:16px}
.cta-banner .btn{border-color:#fff;color:#fff;background:transparent}
.cta-banner .btn:hover{background:#fff;color:var(--text-strong)}

/* ==================== FORMULAIRES (design system) ==================== */
.form-grid{display:grid;gap:18px}
.field{display:block}
.field label,
.form-label{
  display:block;
  font-family:var(--sans);
  font-size:11px;
  font-weight:600;
  letter-spacing:var(--tracking-wide);
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:8px;
}
.form-input,
.form-select,
.form-textarea,
input.form-control,
select.form-control,
textarea.form-control{
  width:100%;
  padding:14px 14px;
  border:1px solid var(--border);
  border-radius:var(--r-xs);
  background:#fff;
  font-family:var(--serif);
  font-size:15px;
  color:var(--text);
  outline:none;
  transition:border-color var(--t-fast);
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus,
input.form-control:focus,
select.form-control:focus,
textarea.form-control:focus{border-color:var(--text-strong)}
.form-textarea{min-height:140px;resize:vertical}
.form-help{font-size:12px;color:var(--muted);margin-top:6px;font-style:italic}

.form-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  padding:40px;
}

/* ==================== ÉTATS / MESSAGES ==================== */
.notice{
  padding:14px 16px;
  border-radius:var(--r-xs);
  font-size:14px;
  margin:0 0 20px;
  border:1px solid var(--border);
}
.notice-ok{background:#f6f7f2;border-color:#d9dcc8;color:#4d5a1d}
.notice-error{background:#fbf4f4;border-color:#ecd2d2;color:#8a1f1f}
.notice-info{background:var(--surface);border-color:var(--border);color:var(--text)}

/* ==================== UTILITAIRES ==================== */
.text-center{text-align:center}
.text-muted{color:var(--muted)}
.text-gold{color:var(--gold)}
.u-eyebrow{
  font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:var(--tracking-ultra);
  text-transform:uppercase;color:var(--muted);
}
.u-serif{font-family:var(--serif)}
.u-sans{font-family:var(--sans)}
.stack-sm>*+*{margin-top:8px}
.stack-md>*+*{margin-top:18px}
.stack-lg>*+*{margin-top:32px}

/* ==================== BREAKPOINTS PRIMAIRES (laissés légers; responsive.css fait le reste) ==================== */
@media (max-width:1100px){
  .cards-3{grid-template-columns:repeat(3,1fr);gap:28px}
  .cards-4{grid-template-columns:repeat(3,1fr)}
  .univers-grid{gap:48px}
}
@media (max-width:900px){
  .hero .grid{grid-template-columns:1fr;gap:40px}
  .section{padding:64px 0}
  .section-head{margin-bottom:36px}
  .cards-3,.cards-4{grid-template-columns:repeat(2,1fr);gap:22px}
  .univers-grid{grid-template-columns:1fr;gap:40px}
  .container{padding:0 20px}
}
