@import url("https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&display=swap");
/* =====================================================================
   LA CLEF — Microbrasserie artisanale premium
   Feuille de style principale
   Palette : Noir profond / Or métallisé / Jaune ambré / Blanc cassé
   Esthétique : whisky premium × brasserie artisanale × horlogerie suisse
   ===================================================================== */

/* ---------------------------------------------------------------------
   1. Variables globales (design tokens)
   --------------------------------------------------------------------- */
:root {
  /* Couleurs — identité « Alpin » (ardoise & glacier du Valais) par défaut.
     Les thèmes Sombre/Claire restent sélectionnables par le client (override JS). */
  --noir: #1B2A2E;            /* granite de nuit : fond principal */
  --noir-2: #223841;          /* surfaces légèrement relevées */
  --noir-3: #2b434c;          /* cartes / panneaux */
  --or: #A6C2C4;              /* glacier : filets, accents, liens (remplace l'or) */
  --or-clair: #C9D6D6;        /* survols clairs */
  --ambre: #7FA0A2;          /* glacier profond : CTA, points forts */
  --blanc-casse: #ECF1F1;     /* neige : texte principal */
  --gris-texte: #8CA4A6;      /* glacier sourd : texte secondaire */
  --gris-bord: #34474e;       /* ardoise froide : bordures discrètes */

  /* Typographie — Bodoni Moda (display, fort contraste) + Archivo (UI/texte) */
  --serif: "Bodoni Moda", Didot, "Times New Roman", serif;
  --sans: "Archivo", "Helvetica Neue", Arial, sans-serif;

  /* Mesures */
  --max-width: 1280px;
  --gutter: clamp(1rem, 4vw, 3rem);
  --radius: 2px;             /* coins quasi nets, esprit luxe */
  --transition: 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);

  /* Ombres */
  --ombre-carte: 0 10px 40px rgba(0, 0, 0, 0.55);
  --ombre-or: 0 8px 30px rgba(166, 194, 196, 0.18);
}

/* ---------------------------------------------------------------------
   2. Reset léger
   --------------------------------------------------------------------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--noir);
  color: var(--blanc-casse);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.65;
  font-weight: 300;
  letter-spacing: 0.2px;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; margin: 0; padding: 0; }
button { font-family: inherit; cursor: pointer; }

h1, h2, h3, h4 {
  font-family: var(--serif);
  font-weight: 500;
  line-height: 1.15;
  margin: 0 0 0.5em;
  letter-spacing: 0.5px;
}

/* ---------------------------------------------------------------------
   3. Utilitaires de mise en page
   --------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.section { padding-block: clamp(3.5rem, 8vw, 7rem); }

.eyebrow {
  display: inline-block;
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--or);
  margin-bottom: 1rem;
}

.section-title {
  font-size: clamp(2rem, 4vw, 3.25rem);
  margin-bottom: 0.3em;
}

.section-head { text-align: center; margin-bottom: clamp(2rem, 5vw, 3.5rem); }

/* Filet doré décoratif */
.filet {
  width: 64px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--or), transparent);
  margin: 1.2rem auto;
}
.filet.left { margin-inline: 0; background: linear-gradient(90deg, var(--or), transparent); }

.text-or { color: var(--or); }
.text-ambre { color: var(--ambre); }
.text-mute { color: var(--gris-texte); }

/* ---------------------------------------------------------------------
   4. Boutons premium (noir & or)
   --------------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding: 0.95rem 2.1rem;
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border: 1px solid var(--or);
  border-radius: var(--radius);
  background: transparent;
  color: var(--or);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}
.btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, var(--or), var(--ambre));
  transform: translateY(101%);
  transition: var(--transition);
  z-index: -1;
}
.btn:hover { color: var(--noir); border-color: var(--ambre); }
.btn:hover::before { transform: translateY(0); }

.btn-fill {
  background: linear-gradient(120deg, var(--or), var(--ambre));
  color: var(--noir);
  border-color: transparent;
}
.btn-fill::before { background: var(--noir); }
.btn-fill:hover { color: var(--or); }

.btn-block { width: 100%; }
.btn-sm { padding: 0.65rem 1.3rem; font-size: 0.7rem; }

/* ---------------------------------------------------------------------
   5. Top bar (langue, devise, contact)
   --------------------------------------------------------------------- */
.topbar {
  background: var(--noir);
  border-bottom: 1px solid var(--gris-bord);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  color: var(--gris-texte);
}
.topbar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 38px;
}
.topbar a:hover { color: var(--or); }

/* ---------------------------------------------------------------------
   6. Header principal
   --------------------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: color-mix(in srgb, var(--noir) 92%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--gris-bord);
  transition: var(--transition);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  min-height: 84px;
}
.brand { display: flex; align-items: center; gap: 0.85rem; }
.brand .logo-mark { width: 38px; height: 38px; }
.brand-name {
  font-family: var(--serif);
  font-size: 1.6rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--blanc-casse);
  line-height: 1;
}
.brand-name b { color: var(--or); font-weight: 500; }
.brand-sub {
  display: block;
  font-family: var(--sans);
  font-size: 0.56rem;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--gris-texte);
  margin-top: 4px;
}

/* Navigation */
.main-nav ul { display: flex; gap: 2.4rem; }
.main-nav a {
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--blanc-casse);
  padding-block: 0.4rem;
  position: relative;
}
.main-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 1px;
  background: var(--or);
  transition: var(--transition);
}
.main-nav a:hover { color: var(--or); }
.main-nav a:hover::after,
.main-nav a.active::after { width: 100%; }

.header-actions { display: flex; align-items: center; gap: 1.5rem; }
.icon-btn {
  background: transparent;
  border: none;
  color: var(--blanc-casse);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  transition: var(--transition);
}
.icon-btn:hover { color: var(--or); }
.icon-btn svg { width: 22px; height: 22px; }
.cart-count {
  background: var(--or);
  color: var(--noir);
  font-size: 0.62rem;
  font-weight: 700;
  border-radius: 50%;
  min-width: 18px;
  height: 18px;
  display: inline-grid;
  place-items: center;
  margin-left: 2px;
}

/* Burger mobile */
.burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: transparent;
  border: none;
  padding: 6px;
}
.burger span {
  width: 24px;
  height: 2px;
  background: var(--blanc-casse);
  transition: var(--transition);
}

/* ---------------------------------------------------------------------
   7. Hero (accueil)
   --------------------------------------------------------------------- */
.hero {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: center;
  text-align: center;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(166, 194, 196, 0.12), transparent 60%),
    linear-gradient(180deg, var(--noir), var(--noir));
  overflow: hidden;
}
.hero::after {
  /* léger grain ambré bas de page */
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 40%;
  background: linear-gradient(180deg, transparent, rgba(245, 184, 0, 0.05));
  pointer-events: none;
}
.hero-content { position: relative; z-index: 2; max-width: 760px; margin-inline: auto; }
.hero h1 {
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  margin-bottom: 0.3em;
}
.hero h1 span { color: var(--or); }
.hero p {
  color: var(--gris-texte);
  font-size: clamp(1rem, 2vw, 1.2rem);
  max-width: 540px;
  margin: 0 auto 2.2rem;
}
.hero-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* Houblon décoratif flottant */
.hero-deco {
  position: absolute;
  opacity: 0.07;
  color: var(--or);
  z-index: 1;
}
.hero-deco.one { top: 12%; left: 6%; width: 120px; }
.hero-deco.two { bottom: 14%; right: 7%; width: 160px; }

/* ---------------------------------------------------------------------
   8. Bandeau d'arguments (trust bar)
   --------------------------------------------------------------------- */
.trust {
  border-block: 1px solid var(--gris-bord);
  background: var(--noir-2);
}
.trust .container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  padding-block: 2.2rem;
}
.trust-item { display: flex; align-items: center; gap: 0.9rem; }
.trust-item svg { width: 30px; height: 30px; color: var(--or); flex-shrink: 0; }
.trust-item img.trust-img { width: 38px; height: 38px; object-fit: cover; border-radius: 7px; flex-shrink: 0; }
.trust-item h4 { font-size: 0.95rem; margin: 0; font-family: var(--sans); font-weight: 600; letter-spacing: 0.04em; }
.trust-item p { margin: 0; font-size: 0.76rem; color: var(--gris-texte); }

/* ===== Espace client — tableau de bord modulaire ===== */
.account-shell { display: grid; grid-template-columns: 250px 1fr; gap: 1.5rem; max-width: 1100px; margin: 0 auto; align-items: start; }
.account-side { background: var(--noir-2); border: 1px solid var(--gris-bord); border-radius: 16px; padding: 1.1rem; position: sticky; top: 1rem; }
.account-id { display: flex; align-items: center; gap: .7rem; padding-bottom: 1rem; border-bottom: 1px solid var(--gris-bord); margin-bottom: .7rem; }
.account-avatar { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg, var(--or), #5e7a7c); color: var(--noir); font-weight: 700; font-family: var(--serif); display: flex; align-items: center; justify-content: center; font-size: 1.15rem; flex-shrink: 0; }
.account-id-txt { min-width: 0; }
.account-id-name { font-weight: 600; font-size: .92rem; }
.account-id-mail { font-size: .72rem; color: var(--gris-texte); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.account-nav { display: flex; flex-direction: column; gap: 2px; }
.acc-nav-item { display: block; width: 100%; text-align: left; background: none; border: 0; color: var(--gris-texte); font: 500 .86rem/1.2 var(--sans); padding: .62rem .7rem; border-radius: 9px; cursor: pointer; transition: background .15s, color .15s; }
.acc-nav-item:hover { background: rgba(128,128,128,.14); color: var(--blanc-casse); }
.acc-nav-item.on { background: rgba(166,194,196,.12); color: var(--or); }
.acc-logout { margin-top: .8rem; padding-top: .8rem; border-top: 1px solid var(--gris-bord); border-radius: 0; color: #c98b86; }
.account-main { min-height: 320px; }
.acc-head { margin-bottom: 1.3rem; }
.acc-eyebrow2 { font: 600 .66rem/1 var(--mono); letter-spacing: .22em; text-transform: uppercase; color: var(--or); }
.acc-h2 { font-family: var(--serif); font-size: 1.9rem; margin: .3rem 0 .2rem; }
.acc-status { display: flex; align-items: center; gap: .45rem; font-size: .8rem; color: var(--gris-texte); margin: 0; }
.acc-dot { width: 8px; height: 8px; border-radius: 50%; background: #4caf72; box-shadow: 0 0 0 3px rgba(76,175,114,.18); }
.acc-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.acc-stat { background: var(--noir-2); border: 1px solid var(--gris-bord); border-radius: 14px; padding: 1.1rem 1.2rem; }
.acc-stat-v { font-family: var(--serif); font-size: 1.7rem; color: var(--or); line-height: 1; }
.acc-stat-l { font-size: .76rem; color: var(--gris-texte); margin-top: .4rem; text-transform: uppercase; letter-spacing: .06em; }
.acc-block { background: var(--noir-2); border: 1px solid var(--gris-bord); border-radius: 14px; padding: 1.3rem; margin-bottom: 1.2rem; }
.acc-block h3 { margin: 0 0 .9rem; font-family: var(--serif); font-size: 1.2rem; }
.acc-addr-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.acc-addr { border: 1px solid var(--gris-bord); border-radius: 12px; padding: 1rem; }
.acc-addr-type { font: 600 .66rem/1 var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--or); margin-bottom: .5rem; }
.acc-addr-body { font-size: .85rem; line-height: 1.5; }
.acc-msg { font-size: .82rem; }
.acc-msg.ok { color: #4caf72; }
.acc-msg.err { color: #c98b86; }
.acc-soon { display: flex; flex-direction: column; align-items: center; gap: .8rem; text-align: center; color: var(--gris-texte); padding: 2.5rem 1.3rem; }
.acc-soon svg { width: 42px; height: 42px; color: var(--or); opacity: .7; }
@media (max-width: 760px){ .account-shell { grid-template-columns: 1fr; } .account-side { position: static; } .account-nav { flex-direction: row; flex-wrap: wrap; } .acc-nav-item { width: auto; } }
/* Espace client — Phase 1 (commandes détail, adresses CRUD, fidélité) */
.btn-mini { background: none; border: 1px solid var(--gris-bord); color: var(--gris-texte); font: 500 .72rem var(--sans); padding: .35rem .6rem; border-radius: 7px; cursor: pointer; transition: border-color .15s, color .15s; }
.btn-mini:hover { border-color: var(--or); color: var(--or); }
.btn-mini.danger:hover { border-color: #c98b86; color: #c98b86; }
.acc-addr.is-default { border-color: var(--or); }
.acc-addr-act { display: flex; gap: .4rem; flex-wrap: wrap; margin-top: .8rem; }
.acc-modal-bg { position: fixed; inset: 0; z-index: 9000; background: rgba(0,0,0,.65); display: flex; align-items: center; justify-content: center; padding: 1rem; }
.acc-modal { background: var(--noir-2); border: 1px solid var(--gris-bord); border-radius: 16px; padding: 1.5rem; max-width: 520px; width: 100%; max-height: 88vh; overflow: auto; }
.acc-modal h3 { font-family: var(--serif); font-size: 1.3rem; margin: 0 0 1rem; }
.acc-modal-act { display: flex; gap: .6rem; justify-content: flex-end; margin-top: 1rem; }
.acc-totals { margin-top: 1.2rem; border-top: 1px solid var(--gris-bord); padding-top: 1rem; }
.acc-totals > div { display: flex; justify-content: space-between; font-size: .88rem; padding: .25rem 0; color: var(--gris-texte); }
.acc-total-grand { font-size: 1.05rem; color: var(--blanc-casse); border-top: 1px solid var(--gris-bord); margin-top: .4rem; padding-top: .6rem; }
.acc-total-grand b { color: var(--or); }
.acc-timeline { list-style: none; padding: 0; margin: 0; }
.acc-timeline li { display: flex; gap: .8rem; padding: .5rem 0; font-size: .86rem; }
.acc-tl-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--or); margin-top: .35rem; flex-shrink: 0; box-shadow: 0 0 0 3px rgba(166,194,196,.15); }
.acc-tier { display: flex; align-items: center; gap: 1.4rem; flex-wrap: wrap; }
.acc-tier-badge { font-family: var(--serif); font-size: 1.1rem; letter-spacing: .04em; color: var(--noir); background: linear-gradient(135deg, var(--or), #5e7a7c); padding: .9rem 1.4rem; border-radius: 12px; font-weight: 700; }
.acc-tier-info { flex: 1; min-width: 200px; }
.acc-progress { height: 8px; border-radius: 999px; background: rgba(128,128,128,.2); overflow: hidden; }
.acc-progress span { display: block; height: 100%; background: linear-gradient(90deg, var(--or), var(--or-clair)); }
.acc-tiers { display: flex; gap: .6rem; flex-wrap: wrap; }
.acc-tierpill { border: 1px solid var(--gris-bord); border-radius: 10px; padding: .6rem .9rem; display: flex; flex-direction: column; gap: .2rem; font-size: .82rem; }
.acc-tierpill.on { border-color: var(--or); color: var(--or); }
.acc-tierpill span { font-size: .68rem; color: var(--gris-texte); }
/* Espace client — Phase 2 (wishlist, coupons, parrainage, produits) */
.acc-prod-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 1rem; }
.acc-prod { position: relative; }
.acc-prod-link { display: block; color: inherit; text-decoration: none; }
.acc-prod-img { aspect-ratio: 1; border-radius: 12px; background: var(--noir-3) center/cover no-repeat; border: 1px solid var(--gris-bord); }
.acc-prod-name { font-size: .82rem; margin-top: .5rem; line-height: 1.3; }
.acc-prod-price { font-size: .82rem; font-weight: 600; margin-top: .15rem; }
.acc-prod-x { position: absolute; top: 6px; right: 6px; width: 26px; height: 26px; border-radius: 50%; border: 0; background: rgba(0,0,0,.6); color: #fff; cursor: pointer; font-size: .8rem; line-height: 1; }
.acc-prod-x:hover { background: #c98b86; }
.acc-coupons { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 1rem; }
.acc-coupon { border: 1px dashed var(--or); border-radius: 12px; padding: 1rem; text-align: center; background: rgba(166,194,196,.05); }
.acc-coupon.gift { border-style: solid; }
.acc-coupon-val { font-family: var(--serif); font-size: 1.5rem; color: var(--or); }
.acc-coupon-code { font-family: var(--mono); font-size: .8rem; letter-spacing: .1em; margin-top: .3rem; }
.acc-reflink { display: flex; gap: .6rem; margin-top: 1rem; }
.acc-reflink input { flex: 1; min-width: 0; background: var(--noir); border: 1px solid var(--gris-bord); border-radius: 9px; padding: .6rem .8rem; color: var(--gris-texte); font-size: .82rem; }
.btn-wish { background: none; border: 1px solid var(--gris-bord); color: var(--or); font-size: 1.2rem; line-height: 1; padding: 0 .9rem; border-radius: 10px; cursor: pointer; }
.btn-wish:hover, .btn-wish.on { border-color: var(--or); background: rgba(166,194,196,.1); }
/* Espace client — Phase 3 (retours, support, notifications, sécurité, RGPD) */
.acc-photo-prev { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .6rem; }
.acc-photo-t { width: 60px; height: 60px; object-fit: cover; border-radius: 8px; border: 1px solid var(--gris-bord); }
.acc-ticket { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: .8rem; border: 1px solid var(--gris-bord); border-radius: 10px; margin-bottom: .6rem; cursor: pointer; }
.acc-ticket:hover { border-color: var(--or); }
.acc-tag { font: 600 .66rem var(--mono); letter-spacing: .08em; text-transform: uppercase; padding: .25rem .6rem; border-radius: 999px; border: 1px solid var(--gris-bord); color: var(--gris-texte); white-space: nowrap; }
.acc-tag.on { border-color: var(--or); color: var(--or); }
.acc-thread { display: flex; flex-direction: column; gap: .7rem; }
.acc-msgbubble { max-width: 80%; padding: .7rem .9rem; border-radius: 12px; font-size: .88rem; line-height: 1.5; }
.acc-msgbubble.me { align-self: flex-end; background: rgba(166,194,196,.12); border: 1px solid rgba(166,194,196,.3); }
.acc-msgbubble.staff { align-self: flex-start; background: rgba(255,255,255,.05); border: 1px solid var(--gris-bord); }
.acc-notif { padding: .9rem; border-left: 3px solid transparent; border-bottom: 1px solid var(--gris-bord); }
.acc-notif.unread { border-left-color: var(--or); background: rgba(166,194,196,.04); }
.acc-notif-t { font-weight: 600; font-size: .9rem; }
.acc-sess-list { display: flex; flex-direction: column; gap: .5rem; }
.acc-sess { padding: .7rem .9rem; border: 1px solid var(--gris-bord); border-radius: 10px; font-size: .86rem; }
.acc-switch { display: flex; align-items: center; gap: .6rem; font-size: .88rem; padding: .4rem 0; cursor: pointer; }
.acc-switch input { width: auto; }

/* ---------------------------------------------------------------------
   9. Grille produits & cartes
   --------------------------------------------------------------------- */
.product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: clamp(1.2rem, 3vw, 2.2rem);
}
.product-card {
  background: var(--noir-3);
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  transition: var(--transition);
  display: flex;
  flex-direction: column;
}
.product-card:hover {
  border-color: var(--or);
  transform: translateY(-6px);
  box-shadow: var(--ombre-or);
}
.product-media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: linear-gradient(160deg, var(--noir-3), var(--noir));
}
.product-media img,
.product-media svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.product-card:hover .product-media img,
.product-card:hover .product-media svg { transform: scale(1.06); }

.badge {
  position: absolute;
  top: 12px;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.3rem 0.7rem;
  border-radius: var(--radius);
}
.badge.new { left: 12px; background: var(--or); color: var(--noir); }
.badge.out { right: 12px; background: #2a2a2a; color: var(--gris-texte); border: 1px solid var(--gris-bord); }

.quick-view {
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translate(-50%, 140%);
  transition: var(--transition);
  white-space: nowrap;
}
.product-card:hover .quick-view { transform: translate(-50%, 0); }

.product-body { padding: 1.3rem; text-align: center; display: flex; flex-direction: column; gap: 0.4rem; flex: 1; }
.product-cat { font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--or); }
.product-title { font-size: 1.18rem; margin: 0; }
.product-title a:hover { color: var(--or); }
.product-price { font-family: var(--serif); font-size: 1.3rem; color: var(--blanc-casse); margin-top: auto; }
.product-price small { font-size: 0.7rem; color: var(--gris-texte); }

.center-cta { text-align: center; margin-top: clamp(2rem, 5vw, 3.5rem); }

/* ---------------------------------------------------------------------
   10. Bandeau de marque (split)
   --------------------------------------------------------------------- */
.brand-band { background: var(--noir-2); border-block: 1px solid var(--gris-bord); }
.brand-band .container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.brand-band .visual {
  aspect-ratio: 4 / 3;
  border: 1px solid var(--or);
  border-radius: var(--radius);
  background: linear-gradient(160deg, var(--noir-3), var(--noir));
  display: grid;
  place-items: center;
  position: relative;
}
.brand-band .visual svg { width: 45%; color: var(--or); opacity: 0.85; }
.brand-band .visual::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(166, 194, 196, 0.3);
  border-radius: var(--radius);
}
.brand-band h2 { font-size: clamp(2rem, 4vw, 3rem); }
.brand-band p { color: var(--gris-texte); margin-bottom: 1.4rem; }

/* ---------------------------------------------------------------------
   11. Newsletter
   --------------------------------------------------------------------- */
.newsletter {
  text-align: center;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(166, 194, 196, 0.1), transparent 60%),
    var(--noir);
  border-top: 1px solid var(--gris-bord);
}
.newsletter h2 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
.newsletter p { color: var(--gris-texte); max-width: 480px; margin: 0 auto 2rem; }
.news-form {
  display: flex;
  max-width: 480px;
  margin-inline: auto;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.news-form input {
  flex: 1;
  min-width: 220px;
  padding: 0.95rem 1.2rem;
  background: var(--noir-3);
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  color: var(--blanc-casse);
  font: inherit;
}
.news-form input:focus { outline: none; border-color: var(--or); }

/* ---------------------------------------------------------------------
   12. Footer
   --------------------------------------------------------------------- */
.site-footer {
  background: var(--noir);
  border-top: 1px solid var(--gris-bord);
  padding-top: clamp(3rem, 6vw, 5rem);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  padding-bottom: 3rem;
}
.footer-col h4 {
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--or);
  margin-bottom: 1.2rem;
}
.footer-col li { margin-bottom: 0.65rem; }
.footer-col a { font-size: 0.85rem; color: var(--gris-texte); }
.footer-col a:hover { color: var(--or); }
.footer-about p { font-size: 0.85rem; color: var(--gris-texte); margin: 1rem 0; max-width: 320px; }
.footer-social { display: flex; gap: 0.8rem; }
.footer-social a {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border: 1px solid var(--gris-bord);
  border-radius: 50%;
  transition: var(--transition);
}
.footer-social a:hover { border-color: var(--or); color: var(--or); }
.footer-social svg { width: 16px; height: 16px; }
.footer-bottom {
  border-top: 1px solid var(--gris-bord);
  padding-block: 1.6rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.6rem;
  font-size: 0.74rem;
  color: var(--gris-texte);
}

/* ---------------------------------------------------------------------
   13. Fil d'Ariane & en-tête de page
   --------------------------------------------------------------------- */
.page-head {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(166, 194, 196, 0.08), transparent 65%),
    var(--noir-2);
  border-bottom: 1px solid var(--gris-bord);
  text-align: center;
  padding-block: clamp(2.5rem, 6vw, 4.5rem);
}
.page-head h1 { font-size: clamp(2.2rem, 5vw, 3.5rem); }
.breadcrumb {
  display: flex;
  gap: 0.5rem;
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: var(--gris-texte);
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.breadcrumb.center { justify-content: center; }
.breadcrumb a:hover { color: var(--or); }
.breadcrumb .sep { color: var(--or); }

/* ---------------------------------------------------------------------
   14. Boutique : filtres
   --------------------------------------------------------------------- */
.shop-layout { display: grid; grid-template-columns: 250px 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.shop-aside {
  position: sticky;
  top: 110px;
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  padding: 1.6rem;
  background: var(--noir-2);
}
.filter-group { margin-bottom: 1.8rem; }
.filter-group h4 {
  font-family: var(--sans);
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--or);
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--gris-bord);
  padding-bottom: 0.6rem;
}
.filter-chip {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.85rem;
  color: var(--gris-texte);
  padding: 0.35rem 0;
  cursor: pointer;
  transition: var(--transition);
  background: none;
  border: none;
  width: 100%;
  text-align: left;
}
.filter-chip:hover,
.filter-chip.active { color: var(--or); }
.filter-chip .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gris-bord); transition: var(--transition); }
.filter-chip.active .dot,
.filter-chip:hover .dot { background: var(--or); }

.shop-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.8rem;
  flex-wrap: wrap;
  gap: 1rem;
}
.shop-toolbar .count { font-size: 0.82rem; color: var(--gris-texte); }
.shop-toolbar select {
  background: var(--noir-3);
  color: var(--blanc-casse);
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  padding: 0.6rem 1rem;
  font: inherit;
  font-size: 0.82rem;
}

/* ---------------------------------------------------------------------
   15. Fiche produit
   --------------------------------------------------------------------- */
.product-detail { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }

/* Galerie */
.gallery-main {
  aspect-ratio: 1;
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  overflow: hidden;
  background: linear-gradient(160deg, var(--noir-3), var(--noir));
  position: relative;
}
.gallery-main img,
.gallery-main svg { width: 100%; height: 100%; object-fit: cover; }
.gallery-thumbs { display: flex; gap: 0.8rem; margin-top: 0.9rem; }
.gallery-thumbs button {
  width: 72px; height: 72px;
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--noir-2);
  padding: 0;
  transition: var(--transition);
}
.gallery-thumbs button.active,
.gallery-thumbs button:hover { border-color: var(--or); }
.gallery-thumbs img, .gallery-thumbs svg { width: 100%; height: 100%; object-fit: cover; }

/* Infos produit */
.pd-cat { font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--or); }
.pd-title { font-size: clamp(2rem, 4vw, 3rem); margin: 0.4rem 0; }
.pd-price { font-family: var(--serif); font-size: 2.2rem; color: var(--or); margin: 0.4rem 0; }
.pd-price small { font-size: 0.8rem; color: var(--gris-texte); font-family: var(--sans); }
.pd-tax { font-size: 0.72rem; color: var(--gris-texte); letter-spacing: 0.1em; }
.pd-desc { color: var(--gris-texte); margin: 1.4rem 0; }
.pd-rating { display: flex; align-items: center; gap: 0.5rem; color: var(--or); font-size: 0.85rem; margin-bottom: 0.4rem; }
.pd-divider { height: 1px; background: var(--gris-bord); margin: 1.6rem 0; }

/* Bloc personnalisation */
.perso-block {
  border: 1px solid var(--gris-bord);
  border-left: 2px solid var(--or);
  border-radius: var(--radius);
  padding: 1.4rem;
  background: var(--noir-2);
  margin-bottom: 1.6rem;
}
.perso-block .perso-head { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.4rem; }
.perso-block .perso-head svg { width: 20px; height: 20px; color: var(--or); }
.perso-block h3 { font-family: var(--sans); font-size: 0.95rem; letter-spacing: 0.06em; margin: 0; }
.perso-note { font-size: 0.74rem; color: var(--gris-texte); margin-bottom: 1rem; }
.field { margin-bottom: 1rem; }
.field label { display: block; font-size: 0.76rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--blanc-casse); margin-bottom: 0.5rem; }
.field textarea,
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field input[type="password"] {
  width: 100%;
  padding: 0.85rem 1rem;
  background: var(--noir);
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  color: var(--blanc-casse);
  font: inherit;
  resize: vertical;
}
.field textarea:focus,
.field input:focus { outline: none; border-color: var(--or); }
.char-count { font-size: 0.7rem; color: var(--gris-texte); text-align: right; margin-top: 0.3rem; }

/* Upload fichier custom */
.file-upload {
  display: flex;
  align-items: center;
  gap: 1rem;
  border: 1px dashed var(--gris-bord);
  border-radius: var(--radius);
  padding: 0.9rem 1rem;
  background: var(--noir);
  transition: var(--transition);
}
.file-upload:hover { border-color: var(--or); }
.file-upload label.btn { flex-shrink: 0; cursor: pointer; }
.file-name { font-size: 0.78rem; color: var(--gris-texte); }
.file-formats { font-size: 0.68rem; color: var(--gris-texte); margin-top: 0.4rem; }
.file-preview { margin-top: 0.8rem; }
.file-preview img { width: 80px; height: 80px; object-fit: cover; border: 1px solid var(--or); border-radius: var(--radius); }

/* Variantes (couleur / matériau) */
.variant-group { margin-bottom: 1.4rem; }
.variant-group > span.lbl { display: block; font-size: 0.76rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--blanc-casse); margin-bottom: 0.7rem; }
.variant-options { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.variant-opt {
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  background: var(--noir);
  color: var(--gris-texte);
  padding: 0.6rem 1.1rem;
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  transition: var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.variant-opt small { color: var(--or); font-size: 0.7rem; }
.variant-opt:hover { border-color: var(--or-clair); color: var(--blanc-casse); }
.variant-opt.active { border-color: var(--or); color: var(--noir); background: linear-gradient(120deg, var(--or), var(--ambre)); }
.variant-opt.active small { color: var(--noir); }

/* Pastille couleur */
.swatch { width: 18px; height: 18px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.25); }

/* Quantité */
.qty-row { display: flex; align-items: center; gap: 1.2rem; margin-bottom: 1.4rem; flex-wrap: wrap; }
.qty-control {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--gris-bord);
  border-radius: var(--radius);
  overflow: hidden;
}
.qty-control button {
  width: 44px; height: 46px;
  background: var(--noir);
  border: none;
  color: var(--or);
  font-size: 1.2rem;
  transition: var(--transition);
}
.qty-control button:hover { background: var(--or); color: var(--noir); }
.qty-control input {
  width: 54px;
  height: 46px;
  text-align: center;
  background: var(--noir);
  border: none;
  border-inline: 1px solid var(--gris-bord);
  color: var(--blanc-casse);
  font: inherit;
}

.pd-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.4rem; }
.pd-actions .btn { flex: 1; min-width: 200px; }

.stock-line { display: flex; align-items: center; gap: 0.6rem; font-size: 0.82rem; margin-bottom: 1.4rem; }
.stock-dot { width: 9px; height: 9px; border-radius: 50%; }
.stock-dot.in { background: #5fbf72; box-shadow: 0 0 8px #5fbf72; }
.stock-dot.out { background: #b85c5c; }

.share-row { display: flex; align-items: center; gap: 0.9rem; font-size: 0.78rem; color: var(--gris-texte); }
.share-row a { width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid var(--gris-bord); border-radius: 50%; transition: var(--transition); }
.share-row a:hover { border-color: var(--or); color: var(--or); }
.share-row svg { width: 15px; height: 15px; }

/* Onglets description */
.tabs { margin-top: clamp(3rem, 6vw, 5rem); }
.tab-nav { display: flex; gap: 2rem; border-bottom: 1px solid var(--gris-bord); margin-bottom: 2rem; flex-wrap: wrap; }
.tab-nav button {
  background: none;
  border: none;
  color: var(--gris-texte);
  font-size: 0.85rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding-bottom: 1rem;
  position: relative;
  transition: var(--transition);
}
.tab-nav button::after {
  content: ""; position: absolute; left: 0; bottom: -1px; width: 0; height: 2px; background: var(--or); transition: var(--transition);
}
.tab-nav button.active { color: var(--or); }
.tab-nav button.active::after { width: 100%; }
.tab-panel { display: none; color: var(--gris-texte); max-width: 820px; line-height: 1.9; }
.tab-panel.active { display: block; animation: fadeUp 0.5s ease; }
.tab-panel h3 { color: var(--blanc-casse); margin-top: 1.5rem; }
.tab-panel ul.feature-list { margin: 1rem 0; }
.tab-panel ul.feature-list li { padding-left: 1.6rem; position: relative; margin-bottom: 0.6rem; }
.tab-panel ul.feature-list li::before { content: "✦"; position: absolute; left: 0; color: var(--or); }
.specs-table { width: 100%; border-collapse: collapse; }
.specs-table td { padding: 0.85rem 0; border-bottom: 1px solid var(--gris-bord); font-size: 0.88rem; }
.specs-table td:first-child { color: var(--or); width: 40%; letter-spacing: 0.04em; }

/* ---------------------------------------------------------------------
   16. Panier
   --------------------------------------------------------------------- */
.cart-layout { display: grid; grid-template-columns: 1fr 360px; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.cart-items { border: 1px solid var(--gris-bord); border-radius: var(--radius); overflow: hidden; }
.cart-item {
  display: grid;
  grid-template-columns: 96px 1fr auto;
  gap: 1.2rem;
  padding: 1.3rem;
  border-bottom: 1px solid var(--gris-bord);
  align-items: center;
}
.cart-item:last-child { border-bottom: none; }
.cart-item .thumb { width: 96px; height: 96px; border: 1px solid var(--gris-bord); border-radius: var(--radius); overflow: hidden; background: var(--noir-2); }
.cart-item .thumb img, .cart-item .thumb svg { width: 100%; height: 100%; object-fit: cover; }
.cart-item h4 { font-family: var(--serif); font-size: 1.15rem; margin: 0 0 0.2rem; }
.cart-item .meta { font-size: 0.74rem; color: var(--gris-texte); }
.cart-item .line-price { font-family: var(--serif); font-size: 1.2rem; color: var(--or); text-align: right; }
.cart-item .remove { background: none; border: none; color: var(--gris-texte); font-size: 0.72rem; letter-spacing: 0.06em; margin-top: 0.5rem; transition: var(--transition); }
.cart-item .remove:hover { color: #b85c5c; }

.cart-summary {
  border: 1px solid var(--or);
  border-radius: var(--radius);
  padding: 1.8rem;
  background: var(--noir-2);
  position: sticky;
  top: 110px;
}
.cart-summary h3 { font-family: var(--sans); font-size: 0.85rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--or); margin-bottom: 1.4rem; }
.summary-line { display: flex; justify-content: space-between; padding: 0.6rem 0; font-size: 0.9rem; color: var(--gris-texte); }
.summary-line.total { border-top: 1px solid var(--gris-bord); margin-top: 0.6rem; padding-top: 1.2rem; color: var(--blanc-casse); font-size: 1.1rem; }
.summary-line.total b { font-family: var(--serif); color: var(--or); font-size: 1.5rem; }
.promo-row { display: flex; gap: 0.5rem; margin: 1.2rem 0; }
.promo-row input { flex: 1; padding: 0.7rem; background: var(--noir); border: 1px solid var(--gris-bord); border-radius: var(--radius); color: var(--blanc-casse); font: inherit; font-size: 0.82rem; }

/* ---------------------------------------------------------------------
   17. Commande (checkout) — étapes
   --------------------------------------------------------------------- */
.steps { display: flex; justify-content: center; gap: 0; margin-bottom: 3rem; flex-wrap: wrap; }
.step { display: flex; align-items: center; gap: 0.7rem; color: var(--gris-texte); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; }
.step .num { width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--gris-bord); display: grid; place-items: center; font-size: 0.8rem; }
.step.active { color: var(--or); }
.step.active .num { border-color: var(--or); background: var(--or); color: var(--noir); }
.step.done .num { border-color: var(--or); color: var(--or); }
.step-bar { width: 50px; height: 1px; background: var(--gris-bord); margin-inline: 1rem; }

.checkout-layout { display: grid; grid-template-columns: 1fr 360px; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.form-card { border: 1px solid var(--gris-bord); border-radius: var(--radius); padding: 1.8rem; background: var(--noir-2); margin-bottom: 1.5rem; }
.form-card h3 { font-family: var(--sans); font-size: 0.95rem; letter-spacing: 0.08em; margin-bottom: 1.4rem; display: flex; align-items: center; gap: 0.6rem; }
.form-card h3 svg { width: 20px; height: 20px; color: var(--or); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-grid .full { grid-column: 1 / -1; }
.pay-method { display: flex; align-items: center; gap: 0.9rem; border: 1px solid var(--gris-bord); border-radius: var(--radius); padding: 1rem; margin-bottom: 0.8rem; cursor: pointer; transition: var(--transition); }
.pay-method:hover, .pay-method.active { border-color: var(--or); }
.pay-method .radio { width: 18px; height: 18px; border-radius: 50%; border: 1px solid var(--or); display: grid; place-items: center; flex-shrink: 0; }
.pay-method.active .radio::after { content: ""; width: 9px; height: 9px; border-radius: 50%; background: var(--or); }

/* ---------------------------------------------------------------------
   18. Compte client
   --------------------------------------------------------------------- */
.account-layout { display: grid; grid-template-columns: 260px 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.account-nav { border: 1px solid var(--gris-bord); border-radius: var(--radius); padding: 1.4rem; background: var(--noir-2); position: sticky; top: 110px; }
.account-nav .user { display: flex; align-items: center; gap: 0.9rem; padding-bottom: 1.2rem; margin-bottom: 1.2rem; border-bottom: 1px solid var(--gris-bord); }
.account-nav .avatar { width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(120deg, var(--or), var(--ambre)); display: grid; place-items: center; color: var(--noir); font-family: var(--serif); font-size: 1.3rem; font-weight: 600; }
.account-nav a { display: flex; align-items: center; gap: 0.8rem; padding: 0.75rem 0.6rem; border-radius: var(--radius); font-size: 0.85rem; color: var(--gris-texte); transition: var(--transition); }
.account-nav a svg { width: 18px; height: 18px; }
.account-nav a:hover, .account-nav a.active { color: var(--or); background: var(--noir); }

.account-card { border: 1px solid var(--gris-bord); border-radius: var(--radius); padding: 1.8rem; background: var(--noir-2); margin-bottom: 1.5rem; }
.account-card h3 { font-family: var(--sans); font-size: 1rem; letter-spacing: 0.06em; margin-bottom: 1.4rem; }
.order-row { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 1rem; align-items: center; padding: 1rem 0; border-bottom: 1px solid var(--gris-bord); font-size: 0.85rem; }
.order-row:last-child { border-bottom: none; }
.order-row .ref { color: var(--or); font-weight: 600; }
.status-tag { font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.3rem 0.7rem; border-radius: var(--radius); }
.status-tag.delivered { background: rgba(95,191,114,0.15); color: #7fcf90; border: 1px solid rgba(95,191,114,0.4); }
.status-tag.progress { background: rgba(245,184,0,0.12); color: var(--ambre); border: 1px solid rgba(245,184,0,0.4); }

/* Connexion (auth) */
.auth-wrap { max-width: 440px; margin-inline: auto; }
.auth-card { border: 1px solid var(--gris-bord); border-radius: var(--radius); padding: 2.2rem; background: var(--noir-2); }
.auth-tabs { display: flex; margin-bottom: 1.8rem; border: 1px solid var(--gris-bord); border-radius: var(--radius); overflow: hidden; }
.auth-tabs button { flex: 1; background: var(--noir); border: none; color: var(--gris-texte); padding: 0.85rem; font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; transition: var(--transition); }
.auth-tabs button.active { background: linear-gradient(120deg, var(--or), var(--ambre)); color: var(--noir); }

/* ---------------------------------------------------------------------
   19. Aperçu rapide (modale)
   --------------------------------------------------------------------- */
.modal-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,0.82);
  backdrop-filter: blur(4px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}
.modal-overlay.open { display: flex; animation: fadeIn 0.3s ease; }
.modal {
  background: var(--noir-3);
  border: 1px solid var(--or);
  border-radius: var(--radius);
  max-width: 820px;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
  position: relative;
  max-height: 90vh;
}
.modal-close { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border-radius: 50%; background: rgba(0,0,0,0.5); border: 1px solid var(--gris-bord); color: var(--blanc-casse); z-index: 2; transition: var(--transition); }
.modal-close:hover { border-color: var(--or); color: var(--or); }
.modal .modal-media { background: linear-gradient(160deg, var(--noir-3), var(--noir)); display: grid; place-items: center; }
.modal .modal-media svg, .modal .modal-media img { width: 70%; }
.modal .modal-body { padding: 2rem; overflow-y: auto; }

/* ---------------------------------------------------------------------
   20. Animations
   --------------------------------------------------------------------- */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

/* Révélation au scroll (piloté par JS) */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
}

/* ---------------------------------------------------------------------
   21. Responsive
   --------------------------------------------------------------------- */
@media (max-width: 1024px) {
  .brand-band .container { grid-template-columns: 1fr; }
  .brand-band .visual { max-width: 460px; }
  .shop-layout { grid-template-columns: 1fr; }
  .shop-aside { position: static; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 860px) {
  .main-nav, .header-actions .label-hide { display: none; }
  .burger { display: flex; }
  .product-detail { grid-template-columns: 1fr; }
  .cart-layout, .checkout-layout { grid-template-columns: 1fr; }
  .cart-summary, .account-nav { position: static; }
  .account-layout { grid-template-columns: 1fr; }
  .trust .container { grid-template-columns: 1fr 1fr; }
  .modal { grid-template-columns: 1fr; }
  .modal .modal-media { min-height: 200px; }

  /* Menu mobile déployé */
  .main-nav.open {
    display: block;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--noir-2);
    border-bottom: 1px solid var(--gris-bord);
    padding: 1.5rem var(--gutter);
  }
  .main-nav.open ul { flex-direction: column; gap: 0; }
  .main-nav.open li { border-bottom: 1px solid var(--gris-bord); }
  .main-nav.open a { display: block; padding: 1rem 0; }
  .burger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .burger.active span:nth-child(2) { opacity: 0; }
  .burger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}

@media (max-width: 560px) {
  .topbar-left { display: none; }
  .footer-grid { grid-template-columns: 1fr; }
  .trust .container { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .order-row { grid-template-columns: 1fr 1fr; }
  .hero { min-height: 80vh; }
}

/* =====================================================================
   DIRECTION ARTISTIQUE v2 — signature « Clef », ambre-liquide, typo data,
   + polish (focus-visible, :active, easing fort). 100% additif.
   ===================================================================== */
:root{
  --ambre-fonce:#5e7a7c;
  --parchemin:#dfe7e7; --parchemin-2:#cdd9d9; --encre:#1b2a2e;
  --liquide:linear-gradient(180deg,var(--or-clair) 0%,var(--or) 50%,var(--ambre) 100%);
  --mono:"Archivo","Helvetica Neue",Arial,sans-serif;
  --ease-out:cubic-bezier(.23,1,.32,1);
  --transition:.22s var(--ease-out);          /* plus vif + courbe plus forte */
}

/* Accessibilité : focus visible doré (manquait totalement) */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,
select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible,
.filter-chip:focus-visible,.quick-view:focus-visible{
  outline:none;box-shadow:0 0 0 3px rgba(166,194,196,.4);border-radius:var(--radius);
}

/* Boutons : feedback au clic + transitions ciblées (pas "all") */
.btn{transition:transform 180ms var(--ease-out),background 180ms var(--ease-out),color 180ms var(--ease-out),border-color 180ms var(--ease-out);}
.btn:active{transform:scale(.97);}

/* CTA principal : ambre-liquide (signature, utilisé une fois) */
.btn-fill{background:var(--liquide);border-color:transparent;color:var(--noir);}
@media (hover:hover) and (pointer:fine){
  .btn-fill:hover{transform:translateY(-1px);filter:brightness(1.05);}
}

/* Typo « fiche de brassage » : monospace pour les données chiffrées */
.product-price,.pd-price,.pd-tax,.cart-total,.order-total{font-family:var(--mono);letter-spacing:-.01em;}
.data-mono{font-family:var(--mono);}

/* Séparateur signé d'une clef */
.key-divider{display:flex;align-items:center;gap:1rem;color:var(--or);margin:2.4rem 0;}
.key-divider::before,.key-divider::after{content:"";flex:1;height:1px;background:var(--gris-bord);}
.key-divider svg{width:22px;height:22px;flex:none;}

/* Carte « étiquette » parchemin + cachet d'édition (prête, à poser sur les fiches) */
.label-card{position:relative;background:linear-gradient(160deg,var(--parchemin),var(--parchemin-2));
  color:var(--encre);border-radius:3px;padding:2.2rem 2rem 1.6rem;
  box-shadow:0 24px 60px rgba(0,0,0,.55),inset 0 0 0 1px rgba(42,33,24,.16);}
.label-card::after{content:"";position:absolute;inset:10px;border:1px solid rgba(42,33,24,.32);border-radius:2px;pointer-events:none;}
.label-card .lc-name{font-family:var(--serif);font-weight:700;font-size:2.8rem;line-height:.92;text-align:center;text-transform:uppercase;letter-spacing:1px;margin:.6rem 0 .2rem;}
.label-card .lc-sub{text-align:center;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:#5a4a31;}
.label-card .lc-spec{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem;margin:1.2rem 0;border-top:1px solid rgba(42,33,24,.25);border-bottom:1px solid rgba(42,33,24,.25);padding:.7rem 0;}
.label-card .lc-spec div{text-align:center;font-family:var(--mono);}
.label-card .lc-spec b{display:block;font-size:1.05rem;font-weight:700;}
.label-card .lc-spec span{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:#7a6647;}
.edition-seal{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:11px;color:var(--encre);}
.edition-seal svg{width:26px;height:26px;color:var(--ambre-fonce);flex:none;}
.edition-seal b{font-size:14px;}

/* =====================================================================
   ALPIN — accueil restructuré (éditorial, minéral, vaste espace)
   ===================================================================== */
.al-hero{position:relative;min-height:82vh;display:flex;align-items:flex-end;overflow:hidden;
  background:radial-gradient(130% 90% at 64% -10%, #5b7d85 0%, #355058 30%, #21343b 58%, var(--noir) 82%);
  background-size:cover;background-position:center;}
.al-hero-veil{position:absolute;inset:0;pointer-events:none;background:
  repeating-linear-gradient(96deg, rgba(255,255,255,.022) 0 2px, transparent 2px 26px),
  linear-gradient(180deg, rgba(20,30,34,.32) 0%, transparent 28%, rgba(20,30,34,.86) 100%);}
.al-hero-bottle{position:absolute;right:9%;bottom:0;height:74%;color:#C9D6D6;opacity:.9;}
.al-hero-bottle rect{stroke:var(--or);}
.al-hero-bottle-wrap{display:contents;}
.al-hero .al-hero-bottle-img{opacity:1;object-fit:contain;object-position:bottom right;width:auto;pointer-events:none;}
.al-hero-inner{position:relative;padding-bottom:clamp(2.4rem,7vh,5rem);max-width:640px;}
.al-kick{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--or);margin-bottom:1.4rem;}
.al-hero-title{font-family:var(--serif);font-weight:400;font-size:clamp(2.8rem,8vw,5.5rem);line-height:.98;letter-spacing:-.01em;color:var(--blanc-casse);margin:0 0 1.8rem;text-wrap:balance;}
.al-hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;}

.al-manifesto{padding:clamp(4rem,11vh,7.5rem) var(--gutter);text-align:center;}
.al-manifesto-line{font-family:var(--serif);font-weight:400;font-size:clamp(1.4rem,3.4vw,2.1rem);line-height:1.4;color:var(--blanc-casse);max-width:30ch;margin:0 auto;text-wrap:balance;}

.al-edition{padding:0 0 clamp(3.5rem,9vh,6.5rem);}
.al-edition-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(1.6rem,5vw,4rem);}
.al-edition-media{aspect-ratio:4/3;border-radius:2px;position:relative;overflow:hidden;background:linear-gradient(160deg,#33474e,#1d2f35);background-size:cover;background-position:center;}
.al-edition-media::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(112deg, rgba(0,0,0,.16) 0 3px, transparent 3px 11px);}
.al-photo-note{position:absolute;left:1.1rem;bottom:.9rem;z-index:1;font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#EDE7D7;text-shadow:0 1px 4px rgba(0,0,0,.55);font-style:italic;}
.al-num{font-family:var(--serif);font-weight:500;font-size:clamp(4rem,11vw,7rem);line-height:.78;color:#365a62;}
.al-edition-name{font-family:var(--serif);font-weight:400;font-size:clamp(1.6rem,4vw,2.1rem);color:var(--blanc-casse);margin:.4rem 0 1rem;}
.al-specs{display:flex;gap:1.5rem;flex-wrap:wrap;font-family:var(--sans);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--or);margin-bottom:1.4rem;}
.al-edition-text{font-size:.92rem;line-height:1.75;color:var(--gris-texte);max-width:34ch;margin:0 0 1.6rem;}

.al-slate{position:relative;padding:clamp(4rem,10vh,6.5rem) var(--gutter);background:linear-gradient(150deg,#22363c,#16242a);border-top:1px solid var(--gris-bord);overflow:hidden;}
.al-slate::before{content:"";position:absolute;inset:0;pointer-events:none;background:
  repeating-linear-gradient(122deg, rgba(0,0,0,.22) 0 2px, transparent 2px 9px),
  repeating-linear-gradient(38deg, rgba(255,255,255,.02) 0 1px, transparent 1px 14px);}
.al-slate-inner{position:relative;max-width:460px;margin-inline:auto 0;}
.al-slate-title{font-family:var(--serif);font-weight:400;font-size:clamp(1.7rem,4.5vw,2.4rem);line-height:1.12;color:var(--blanc-casse);margin:0 0 1rem;text-wrap:balance;}
.al-slate-text{font-size:.92rem;line-height:1.75;color:var(--gris-texte);max-width:36ch;margin:0 0 1.6rem;}

/* Fiche produit — Alpin (millésime) */
.al-pd-kick{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--or);margin-bottom:1rem;}
.product-detail .pd-title{font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:-.01em;}
.product-detail .pd-price{font-family:var(--serif)!important;letter-spacing:0;}
.product-detail .gallery-main{aspect-ratio:4/5;background:linear-gradient(160deg,#33474e,#1d2f35);border:1px solid var(--gris-bord);border-radius:2px;}
.al-spec{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--gris-bord);margin:1.7rem 0;}
.al-spec-cell{padding:.85rem 0;border-bottom:1px solid var(--gris-bord);}
.al-spec-cell:nth-child(even){padding-left:1.2rem;border-left:1px solid var(--gris-bord);}
.al-spec-k{display:block;font-family:var(--sans);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris-texte);margin-bottom:.3rem;}
.al-spec-cell b{font-family:var(--serif);font-weight:400;font-size:1.4rem;color:var(--blanc-casse);}

/* Tuer l'eyebrow (tell IA, présent sur chaque section) — on garde .al-kick délibéré */
.eyebrow{display:none!important;}
.section-title{font-family:var(--serif);font-weight:400;}
/* Emblème « clé » doré -> neutralisé en froid */
.logo-mark,.brand-band .visual img{filter:grayscale(1) brightness(1.55) contrast(.9);}

@media (max-width:780px){
  .al-edition-grid{grid-template-columns:1fr;}
  .al-hero-bottle{height:50%;right:4%;opacity:.65;}
  .al-hero{min-height:74vh;}
}
@media (prefers-reduced-motion:reduce){ .reveal{opacity:1!important;transform:none!important;} }

/* =====================================================================
   ALPIN — motion signature + finitions cartes produit
   (animations sûres : l'état final est visible même si l'animation ne joue pas)
   ===================================================================== */
/* Entrée chorégraphiée du hero (kicker -> titre -> actions -> bouteille).
   État au repos = VISIBLE ; l'entrée vient de @starting-style -> si les transitions
   ne jouent pas (onglet en arrière-plan, rendu headless), tout reste visible (jamais blanc). */
.al-hero-inner > *{transition:opacity .85s var(--ease-out), transform .85s var(--ease-out);}
.al-hero-inner .al-kick{transition-delay:.1s}
.al-hero-inner .al-hero-title{transition-delay:.24s}
.al-hero-inner .al-hero-actions{transition-delay:.42s}
.al-hero-bottle{transition:opacity 1.5s var(--ease-out) .35s, transform 1.5s var(--ease-out) .35s;}
@starting-style{
  .al-hero-inner > *{opacity:0;transform:translateY(22px);}
  .al-hero-bottle{opacity:0;transform:translateY(46px);}
}

/* Reveal au défilement : courbe plus ferme + léger décalage dans les grilles */
.reveal{transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);}
.product-grid .product-card:nth-child(2){transition-delay:.07s}
.product-grid .product-card:nth-child(3){transition-delay:.14s}
.product-grid .product-card:nth-child(4){transition-delay:.21s}
.product-grid .product-card:nth-child(5){transition-delay:.28s}

/* Cartes produit — finition Alpin : survol sobre, image qui respire, titres/prix Bodoni */
.product-card{transition:transform .5s var(--ease-out);}
.product-media{overflow:hidden;background:linear-gradient(160deg,#33474e,#1d2f35);}
.product-media img,.product-media svg{transition:transform .9s var(--ease-out);}
.product-card:hover{transform:translateY(-4px);}
.product-card:hover .product-media img,.product-card:hover .product-media svg{transform:scale(1.05);}
.product-title{font-family:var(--serif);font-weight:400;}
.product-title a{font-family:var(--serif);}
.product-price{font-family:var(--serif)!important;}

@media (prefers-reduced-motion:reduce){
  .al-hero-inner > *,.al-hero-bottle{transition:none!important;}
  .product-card{transition:none;}
  .product-card:hover{transform:none;}
  .product-card:hover .product-media img,.product-card:hover .product-media svg{transform:none;}
}

/* =====================================================================
   ALPIN — savoir-faire + newsletter en éditorial + états vides (polish)
   ===================================================================== */
.brand-band{padding:clamp(4rem,10vh,7rem) var(--gutter);border-top:1px solid var(--gris-bord);}
.brand-band > .container{display:grid;grid-template-columns:.85fr 1.45fr;gap:clamp(2rem,6vw,5rem);align-items:center;}
.brand-band .visual{display:flex;justify-content:center;}
.brand-band .visual img{width:clamp(110px,16vw,170px);height:auto;}
.brand-band h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.8rem,4vw,2.7rem);line-height:1.1;color:var(--blanc-casse);margin:0 0 1.3rem;text-wrap:balance;}
.brand-band p{color:var(--gris-texte);line-height:1.8;max-width:56ch;margin:0 0 1rem;}
.brand-band .text-or{color:var(--or)!important;font-family:var(--serif);font-size:1.3rem;font-style:italic;margin:1.3rem 0 1.6rem;}

.newsletter{padding:clamp(4rem,11vh,7.5rem) var(--gutter);text-align:center;border-top:1px solid var(--gris-bord);background:linear-gradient(150deg,var(--noir-2),var(--noir));position:relative;overflow:hidden;}
.newsletter::before{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(122deg, rgba(0,0,0,.18) 0 2px, transparent 2px 10px);}
.newsletter > .container{position:relative;max-width:580px;}
.newsletter h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.8rem,4.5vw,2.8rem);line-height:1.12;color:var(--blanc-casse);margin:0 0 1rem;text-wrap:balance;}
.newsletter p{color:var(--gris-texte);line-height:1.7;max-width:46ch;margin:0 auto 2.2rem;}
.news-form{display:flex;gap:.7rem;max-width:450px;margin:0 auto;flex-wrap:wrap;}
.news-form input{flex:1;min-width:200px;background:transparent;border:1px solid var(--gris-bord);border-radius:1px;padding:.95rem 1.1rem;color:var(--blanc-casse);font-family:var(--sans);font-size:.9rem;transition:border-color .25s var(--ease-out);}
.news-form input::placeholder{color:var(--gris-texte);}
.news-form input:focus{outline:none;border-color:var(--or);}

/* États vides éditoriaux (vitrine) */
.empty{text-align:center;color:var(--gris-texte);padding:clamp(2.5rem,8vh,5rem) 1rem;font-family:var(--serif);font-size:1.25rem;line-height:1.6;}
.empty a{color:var(--or);}

@media(max-width:780px){
  .brand-band > .container{grid-template-columns:1fr;text-align:center;}
  .brand-band p{margin-inline:auto;}
}


/* ===== Accessibilite quick-wins (audit 2026-06-26) ===== */
.skip-link{position:absolute;left:.5rem;top:-3.5rem;z-index:1000;background:var(--or);color:var(--noir);padding:.65rem 1.1rem;border-radius:0 0 4px 4px;font-family:var(--sans);font-weight:600;font-size:.9rem;letter-spacing:.02em;text-decoration:none;transition:top .2s ease;}
.skip-link:focus{top:0;outline:2px solid var(--blanc-casse);outline-offset:2px;}
.icon-btn{min-width:44px;min-height:44px;justify-content:center;}
.site-footer a{display:inline-block;padding-block:.25rem;}

/* ===== Mini-panier premium (toast + drawer) — audit 2026-06-26 ===== */
.cart-backdrop{position:fixed;inset:0;z-index:1100;background:rgba(8,14,16,.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s;}
.cart-backdrop.open{opacity:1;visibility:visible;}
.mini-cart{position:fixed;top:0;right:0;z-index:1110;height:100vh;height:100dvh;width:min(420px,92vw);background:var(--noir-2);border-left:1px solid var(--gris-bord);box-shadow:-22px 0 60px rgba(0,0,0,.5);display:flex;flex-direction:column;transform:translateX(101%);transition:transform .36s cubic-bezier(.32,.72,0,1);will-change:transform;}
.mini-cart.open{transform:none;}
.mini-cart-head{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.4rem;border-bottom:1px solid var(--gris-bord);}
.mini-cart-head h3{font-family:var(--serif);font-weight:400;font-size:1.3rem;color:var(--blanc-casse);margin:0;letter-spacing:.01em;}
.mini-cart-close{background:none;border:none;color:var(--gris-texte);cursor:pointer;width:44px;height:44px;display:grid;place-items:center;border-radius:50%;transition:color .2s,background .2s;}
.mini-cart-close:hover{color:var(--blanc-casse);background:rgba(255,255,255,.05);}
.mini-cart-body{flex:1;overflow-y:auto;padding:.4rem 1.4rem;}
.mc-line{display:grid;grid-template-columns:54px 1fr auto;gap:.9rem;padding:1rem 0;border-bottom:1px solid var(--gris-bord);align-items:start;}
.mc-line .mc-thumb{width:54px;height:54px;border-radius:2px;background:var(--noir-3);border:1px solid var(--gris-bord);display:grid;place-items:center;color:var(--gris-texte);}
.mc-line .mc-thumb svg{width:24px;height:24px;}
.mc-line h4{font-family:var(--sans);font-size:.92rem;font-weight:500;color:var(--blanc-casse);margin:0 0 .2rem;line-height:1.3;}
.mc-line .mc-meta{font-size:.76rem;color:var(--gris-texte);margin:0 0 .5rem;line-height:1.35;}
.mc-qty{display:inline-flex;align-items:center;border:1px solid var(--gris-bord);border-radius:2px;}
.mc-qty button{background:none;border:none;color:var(--blanc-casse);width:30px;height:30px;cursor:pointer;font-size:1rem;line-height:1;transition:color .2s;}
.mc-qty button:hover:not(:disabled){color:var(--or);}
.mc-qty button:disabled{opacity:.35;cursor:default;}
.mc-qty span{min-width:30px;text-align:center;font-size:.85rem;font-family:var(--mono,monospace);}
.mc-line .mc-price{font-family:var(--mono,monospace);font-size:.9rem;color:var(--blanc-casse);text-align:right;white-space:nowrap;margin:0;}
.mc-line .mc-rm{background:none;border:none;color:var(--gris-texte);font-size:.72rem;cursor:pointer;margin-top:.6rem;padding:0;text-align:right;display:block;width:100%;transition:color .2s;}
.mc-line .mc-rm:hover{color:#c98b86;}
.mini-cart-empty{text-align:center;color:var(--gris-texte);font-family:var(--serif);font-size:1.2rem;padding:3rem 1rem;}
.mini-cart-foot{padding:1.2rem 1.4rem;border-top:1px solid var(--gris-bord);background:var(--noir-3);}
.mc-subtotal{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem;}
.mc-subtotal .lbl{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gris-texte);}
.mc-subtotal .val{font-family:var(--serif);font-size:1.5rem;color:var(--or);}
.mini-cart-foot .btn{width:100%;}
.mc-continue{display:block;width:100%;text-align:center;background:none;border:none;color:var(--gris-texte);font-family:var(--sans);font-size:.82rem;margin-top:.75rem;cursor:pointer;padding:.45rem;transition:color .2s;}
.mc-continue:hover{color:var(--blanc-casse);}
.btn.is-loading{opacity:.72;cursor:progress;}
/* toasts */
.toast-wrap{position:fixed;top:1rem;right:1rem;z-index:1200;display:flex;flex-direction:column;gap:.6rem;pointer-events:none;max-width:min(360px,92vw);}
.toast{display:flex;align-items:center;gap:.75rem;background:var(--noir-2);border:1px solid var(--gris-bord);border-radius:2px;padding:.85rem 1.05rem;box-shadow:0 14px 40px rgba(0,0,0,.45);color:var(--blanc-casse);font-family:var(--sans);font-size:.88rem;line-height:1.35;pointer-events:auto;opacity:0;transform:translateX(20px);transition:opacity .3s ease,transform .3s cubic-bezier(.32,.72,0,1);}
.toast.show{opacity:1;transform:none;}
.toast .ti{flex-shrink:0;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:rgba(166,194,196,.16);color:var(--or);}
.toast.err .ti{background:rgba(201,139,134,.16);color:#c98b86;}
@media (max-width:560px){
  .toast-wrap{top:auto;bottom:1rem;left:1rem;right:1rem;max-width:none;}
  .toast{transform:translateY(22px);}
  .toast.show{transform:none;}
}
@media (prefers-reduced-motion:reduce){
  .mini-cart{transition:none;}
  .cart-backdrop,.toast{transition:opacity .15s ease;}
  .toast{transform:none;}
}


/* ============================================================
   AUDIT THEME « CLAIRE » (clair) — lisibilite WCAG AA — 2026-06-28
   Surfaces volontairement sombres dans TOUS les themes (heros photo,
   visuels avec voile). Le texte y reste clair meme en theme clair.
   ============================================================ */
.al-hero .al-hero-title { color: #F5F1E8; text-shadow: 0 2px 18px rgba(0,0,0,.45); }
.al-hero .al-kick { color: #C9D6D6; }
/* Sections dont l'admin a pose une photo de fond (voile sombre via cms.js). */
.cms-on-photo h1, .cms-on-photo h2, .cms-on-photo h3,
.cms-on-photo .al-hero-title, .cms-on-photo .loc-h2 { color: #F5F1E8 !important; }
.cms-on-photo p, .cms-on-photo .loc-lead, .cms-on-photo .loc-hero-sub,
.cms-on-photo .loc-card-note, .cms-on-photo li, .cms-on-photo small { color: rgba(245,241,232,.84) !important; }
.cms-on-photo .al-kick { color: #C9D6D6 !important; }
/* Boutons « contour » poses sur une surface sombre : texte/contour clairs. */
.al-hero-actions .btn:not(.btn-fill),
.cms-on-photo .btn:not(.btn-fill) { color: #F5F1E8; border-color: rgba(245,241,232,.5); }
.al-hero-actions .btn:not(.btn-fill):hover,
.cms-on-photo .btn:not(.btn-fill):hover { color: var(--noir); }

/* Couleurs sémantiques (succès / erreur / danger) — versions foncées AA pour le thème clair. */
[data-theme="claire"] .acc-msg.ok,
[data-theme="claire"] .loc-form-msg.ok { color: #157347; }
[data-theme="claire"] .acc-msg.err,
[data-theme="claire"] .acc-err,
[data-theme="claire"] .acc-logout,
[data-theme="claire"] .loc-form-msg.err { color: #b3261e; }
[data-theme="claire"] .btn-mini.danger:hover { border-color: #b3261e; color: #b3261e; }
