/* ==========================================================================
   SALONS DU MARIAGE — Feuille de styles unique (thème WordPress sur mesure)
   Direction artistique A2 « Maison · grotesque »
   --------------------------------------------------------------------------
   SOMMAIRE
   01. Design tokens (:root)         07. Boutons
   02. Reset & base                  08. Badges & états temporels
   03. Layout (.container, .grid)    09. Carte salon (.salon-card)
   04. Typographie utilitaire        10. Formulaires (.form)
   05. En-tête / navigation          11. Filtres (sidebar + drawer)
   06. Pied de page                  12. Composants de page + responsive
   --------------------------------------------------------------------------
   BREAKPOINTS (mobile-first) :
     — base   : < 768px   (mobile)
     — sm     : ≥ 768px   (tablette portrait)      @media (min-width:768px)
     — md     : ≥ 1024px  (tablette paysage / petit desktop)  (min-width:1024px)
     — lg     : ≥ 1280px  (desktop large)          @media (min-width:1280px)
   POLICES : 2 familles — Schibsted Grotesk (titres+texte), JetBrains Mono
   (labels). PT Serif est réservé au logo. À auto-héberger en production
   (font-display: swap déjà posé sur les <link> des gabarits).
   ========================================================================== */

/* ========== 01. DESIGN TOKENS ========================================== */
:root{
  /* — Neutres chauds — */
  --paper:#F7F2E9;          /* fond de page (albâtre chaud) */
  --surface:#FFFFFF;        /* cartes, panneaux */
  --surface-2:#FCF8F1;      /* surface alternée / champs */
  --ink:#1F1A16;            /* texte principal */
  --ink-soft:#6B6157;       /* texte secondaire */
  --ink-faint:#9A9085;      /* légendes, placeholders */
  --line:#E7DCCB;           /* filets / bordures */
  --line-strong:#D8C9B2;    /* bordures appuyées */

  /* — Marque / primaire (terracotta #D96931) — */
  --brand:#D96931;
  --brand-700:#B3491E;      /* survol / pressé */
  --brand-50:#FBEAE0;       /* fond teinté */
  --walnut:#946A3F;         /* secondaire — noyer (eyebrows, méta) */
  --walnut-50:#F1E7DA;

  /* — États système — */
  --success:#3E7A53;  --success-bg:#E7F0E8;  --success-line:#CBE0CF;
  --warning:#9C6B1C;  --warning-bg:#F6ECD7;  --warning-line:#E8D6AE;
  --error:#A2362B;    --error-bg:#F6E2DD;    --error-line:#E6BFB8;
  --info:#2F5E8C;     --info-bg:#E5EDF5;     --info-line:#C2D5E8;

  /* — Typographie — */
  --font-sans:"Schibsted Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --font-logo:"PT Serif","Tinos",Georgia,"Times New Roman",serif;

  /* — Échelle d'espacement (base 4px) — */
  --sp-1:4px;  --sp-2:8px;  --sp-3:12px; --sp-4:16px; --sp-5:20px;
  --sp-6:24px; --sp-8:32px; --sp-10:40px; --sp-12:48px; --sp-16:64px;
  --sp-20:80px; --sp-24:96px;

  /* — Rayons — */
  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:22px; --r-pill:999px;

  /* — Ombres — */
  --sh-1:0 1px 2px rgba(31,26,22,.05);
  --sh-2:0 8px 28px -12px rgba(31,26,22,.22);
  --sh-3:0 24px 60px -28px rgba(31,26,22,.32);

  /* — Contenu — */
  --container:1200px;
  --container-narrow:760px;   /* lecture article */
  --header-h:76px;
  --transition:.18s ease;
}

/* ========== 02. RESET & BASE ========================================== */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}
body{
  font-family:var(--font-sans);
  font-size:16px;line-height:1.6;
  color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,picture,svg,video{display:block;max-width:100%}
img{height:auto}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit;color:inherit}
button{background:none;border:none;cursor:pointer}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.1;letter-spacing:-.02em;text-wrap:balance}
p{text-wrap:pretty}
:focus-visible{outline:none;box-shadow:0 0 0 3px var(--brand-50),0 0 0 5px var(--brand);border-radius:var(--r-sm)}
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--brand);color:#fff;padding:12px 18px;border-radius:0 0 var(--r-sm) 0;font-weight:600}
.skip-link:focus{left:0}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ========== 03. LAYOUT ================================================ */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}
@media (min-width:768px){.container{padding:0 32px}}
.section{padding:56px 0}
@media (min-width:1024px){.section{padding:80px 0}}
.section--tight{padding:40px 0}
.section--alt{background:var(--surface-2)}
.stack>*+*{margin-top:var(--sp-4)}
.grid{display:grid;gap:24px}
.grid--2{grid-template-columns:1fr}
.grid--3{grid-template-columns:1fr}
.grid--4{grid-template-columns:1fr}
.grid--cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
@media (min-width:768px){
  .grid--2{grid-template-columns:repeat(2,1fr)}
  .grid--3{grid-template-columns:repeat(2,1fr)}
  .grid--4{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:1024px){
  .grid--3{grid-template-columns:repeat(3,1fr)}
  .grid--4{grid-template-columns:repeat(4,1fr)}
}

/* En-tête de section éditorial */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:32px}
.section-head__eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand);display:flex;align-items:center;gap:10px;margin-bottom:12px}
.section-head__eyebrow::before{content:"";width:26px;height:2px;background:var(--brand)}
.section-head__title{font-size:clamp(28px,4vw,40px)}
.section-head__sub{color:var(--ink-soft);font-size:15.5px;max-width:48ch;margin-top:8px}
.section-head__link{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--ink);display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.section-head__link:hover{color:var(--brand)}
.section-head__link svg{width:15px;height:15px}

/* ========== 04. TYPOGRAPHIE UTILITAIRE ================================ */
.t-eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brand)}
.t-mono{font-family:var(--font-mono)}
.t-lede{font-size:clamp(17px,2vw,20px);line-height:1.5;color:var(--ink-soft)}
.t-small{font-size:13px;color:var(--ink-soft)}
.t-muted{color:var(--ink-faint)}
.display{font-size:clamp(40px,7vw,76px);font-weight:800;letter-spacing:-.04em;line-height:.95}
.display em{font-style:normal;color:var(--brand)}

/* ========== 05. EN-TÊTE / NAVIGATION ================================== */
.site-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
.site-header__bar{display:flex;align-items:center;gap:20px;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:10px;flex:none}
.brand__logo{height:38px;width:auto}
.site-nav{display:none}
@media (min-width:1024px){
  .site-nav{display:flex;align-items:center;gap:4px;margin-left:8px}
}
.site-nav__link{font-size:15px;font-weight:500;color:var(--ink);padding:9px 14px;border-radius:var(--r-pill);display:inline-flex;align-items:center;gap:6px;transition:var(--transition)}
.site-nav__link:hover{background:var(--surface);color:var(--brand)}
.site-nav__link[aria-current="page"]{color:var(--brand);font-weight:600}
.site-nav__link svg{width:15px;height:15px}
.site-header__actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.header-cta{display:none}
@media (min-width:768px){.header-cta{display:inline-flex}}

/* Burger */
.burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;align-items:center;border-radius:var(--r-sm)}
@media (min-width:1024px){.burger{display:none}}
.burger__line{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:var(--transition)}
.burger[aria-expanded="true"] .burger__line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] .burger__line:nth-child(2){opacity:0}
.burger[aria-expanded="true"] .burger__line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Menu mobile (drawer plein écran) */
.mobile-menu{position:fixed;inset:0;z-index:99;background:var(--paper);padding:calc(var(--header-h) + 16px) 24px 32px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .26s ease;visibility:hidden;overflow-y:auto}
.mobile-menu[data-open="true"]{transform:translateX(0);visibility:visible}
@media (min-width:1024px){.mobile-menu{display:none}}
.mobile-menu__link{font-size:20px;font-weight:600;padding:14px 6px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.mobile-menu__link svg{width:18px;height:18px;color:var(--brand)}
.mobile-menu__cta{margin-top:20px}

/* ========== 06. PIED DE PAGE ========================================== */
.site-footer{background:var(--ink);color:#E7DCCB;padding:56px 0 32px;margin-top:64px}
.site-footer a{color:#E7DCCB}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1fr;gap:40px}
@media (min-width:768px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr}}
@media (min-width:1024px){.footer-grid{grid-template-columns:1.6fr 1fr 1fr 1.2fr}}
.footer-brand__logo{height:40px;margin-bottom:16px}
.footer-brand p{color:#B8AC98;font-size:14px;max-width:34ch}
.footer-col__title{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#9A8E78;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:11px}
.footer-col a{font-size:14.5px;color:#D6CAB4;transition:var(--transition)}
.footer-newsletter__field{display:flex;gap:8px;margin-top:14px}
.footer-newsletter input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-sm);padding:11px 13px;color:#fff;font-size:14px}
.footer-newsletter input::placeholder{color:#9A8E78}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{width:38px;height:38px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.footer-social a:hover{background:var(--brand);border-color:var(--brand)}
.footer-social svg{width:18px;height:18px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:44px;padding-top:24px;display:flex;flex-wrap:wrap;gap:8px 24px;align-items:center;justify-content:space-between;font-size:13px;color:#9A8E78}
.footer-bottom__legal{display:flex;flex-wrap:wrap;gap:8px 18px}

/* ========== 07. BOUTONS =============================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-sans);font-weight:600;font-size:15px;line-height:1;text-align:center;white-space:nowrap;border:1.5px solid transparent;border-radius:var(--r-pill);padding:13px 24px;cursor:pointer;transition:var(--transition);min-height:44px}
.btn svg{width:17px;height:17px;flex:none}
.btn--primary{background:var(--brand);color:#fff}
.btn--primary:hover{background:var(--brand-700);box-shadow:var(--sh-2);transform:translateY(-1px)}
.btn--secondary{background:transparent;color:var(--brand);border-color:var(--line-strong)}
.btn--secondary:hover{border-color:var(--brand);background:var(--brand-50)}
.btn--ghost{background:transparent;color:var(--ink);padding-left:12px;padding-right:12px}
.btn--ghost:hover{color:var(--brand)}
.btn--on-dark{background:#fff;color:var(--ink)}
.btn--on-dark:hover{background:var(--brand);color:#fff}
.btn--sm{padding:9px 16px;font-size:13.5px;min-height:38px}
.btn--lg{padding:16px 30px;font-size:16.5px;min-height:52px}
.btn--block{width:100%}
.btn[disabled],.btn[aria-disabled="true"]{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none;pointer-events:none}

/* ========== 08. BADGES & ÉTATS TEMPORELS ============================== */
.badge{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:12px;letter-spacing:.01em;line-height:1;padding:5px 11px;border-radius:var(--r-pill);white-space:nowrap}
.badge svg{width:13px;height:13px;flex:none}
.badge--upcoming{background:var(--success-bg);color:var(--success)}      /* 🟢 à venir */
.badge--now{background:var(--brand);color:#fff}                          /* 🟡 en cours */
.badge--past{background:#ECE6DC;color:var(--ink-faint)}                  /* ⚫ passé */
.badge--featured{background:var(--walnut-50);color:var(--walnut);border:1px solid #E4D2AE} /* ⭐ à la une / Diamant */
.badge--price{background:var(--surface);color:var(--ink-soft);border:1px solid var(--line)}
.badge--neutral{background:var(--surface-2);color:var(--ink-soft);border:1px solid var(--line)}
.badge--mono{font-family:var(--font-mono);font-weight:500;font-size:11px;letter-spacing:.04em;text-transform:uppercase}

/* Pastille statut (espace pro) */
.status{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600}
.status::before{content:"";width:8px;height:8px;border-radius:50%}
.status--published::before{background:var(--success)}
.status--pending::before{background:var(--warning)}
.status--past::before{background:var(--ink-faint)}

/* ========== 09. CARTE SALON (.salon-card) ============================= */
.salon-card{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-1);transition:var(--transition)}
.salon-card:hover{box-shadow:var(--sh-3);transform:translateY(-3px)}
.salon-card__media{position:relative;aspect-ratio:16/9;background:#EDE6D9;overflow:hidden}
.salon-card__img{width:100%;height:100%;object-fit:cover}
.salon-card__badge{position:absolute;top:12px;left:12px;z-index:2}
.salon-card__fav{position:absolute;top:12px;right:12px;z-index:2;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--brand);box-shadow:var(--sh-1);transition:var(--transition)}
.salon-card__fav:hover{background:#fff;transform:scale(1.06)}
.salon-card__fav svg{width:18px;height:18px}
.salon-card__fav[aria-pressed="true"] svg{fill:var(--brand)}
.salon-card__pastbar{display:flex;align-items:center;justify-content:center;gap:8px;background:#ECE6DC;color:var(--ink-soft);font-size:12px;font-weight:600;text-align:center;padding:9px 12px}
.salon-card__pastbar svg{width:14px;height:14px;flex:none}
.salon-card__body{display:flex;flex-direction:column;flex:1;padding:18px}
.salon-card__city{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-weight:500;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--walnut)}
.salon-card__city svg{width:13px;height:13px}
.salon-card__feat-tag{margin-left:auto}
.salon-card__title{font-size:20px;font-weight:700;letter-spacing:-.015em;line-height:1.2;margin:10px 0 13px}
.salon-card__title a{transition:var(--transition)}
.salon-card__title a:hover{color:var(--brand)}
.salon-card__meta{display:flex;flex-direction:column;gap:8px;font-size:13.5px;color:var(--ink-soft)}
.salon-card__meta-item{display:flex;align-items:center;gap:9px}
.salon-card__meta-item svg{width:15px;height:15px;color:var(--walnut);flex:none}
.salon-card__date{font-weight:600;color:var(--ink)}
.salon-card__foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px;padding-top:15px;border-top:1px solid var(--line)}
.salon-card__price{font-size:13px;font-weight:600;color:var(--ink)}
.salon-card__price small{font-weight:500;color:var(--ink-faint)}
/* — Modificateurs — */
.salon-card--featured{border-color:#E4D2AE;box-shadow:0 0 0 1px #E4D2AE,var(--sh-2)}
.salon-card--past{opacity:.94}
.salon-card--past .salon-card__img{filter:grayscale(.85) brightness(1.02)}
.salon-card--past .salon-card__title{color:var(--ink-soft)}
.salon-card--noimg .salon-card__media{display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,#EDE6D9,#EDE6D9 10px,#F2EDE2 10px,#F2EDE2 20px)}
.salon-card--noimg .salon-card__media::after{content:"Visuel à venir";font-family:var(--font-mono);font-size:12px;color:var(--ink-faint)}
.salon-card--row{flex-direction:row}
@media (max-width:560px){.salon-card--row{flex-direction:column}}
.salon-card--row .salon-card__media{aspect-ratio:auto;width:40%;min-height:100%}
@media (max-width:560px){.salon-card--row .salon-card__media{width:100%;aspect-ratio:16/9}}
.salon-card--row .salon-card__body{flex:1}

/* ========== 10. FORMULAIRES (.form) =================================== */
/* Style générique applicable par classes à n'importe quel markup (JetFormBuilder). */
.form{display:flex;flex-direction:column;gap:18px}
.form__row{display:grid;gap:18px}
@media (min-width:768px){.form__row--2{grid-template-columns:1fr 1fr}}
.field{display:flex;flex-direction:column;gap:7px}
.field__label{font-size:13px;font-weight:600;color:var(--ink)}
.field__req{color:var(--brand)}
.field__hint{font-size:12.5px;color:var(--ink-faint);display:flex;align-items:center;gap:6px}
.field__hint svg{width:14px;height:14px;flex:none}
.input,.select,.textarea{width:100%;font-size:15px;background:var(--surface-2);border:1.5px solid var(--line-strong);border-radius:var(--r-sm);padding:12px 14px;transition:var(--transition);min-height:46px}
.textarea{min-height:120px;resize:vertical;line-height:1.5}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B6157' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.input::placeholder,.textarea::placeholder{color:var(--ink-faint)}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand);background:var(--surface);box-shadow:0 0 0 3px var(--brand-50)}
.field--error .input,.field--error .select,.field--error .textarea{border-color:var(--error);background:var(--error-bg)}
.field--error .field__hint{color:var(--error)}
.field--success .input{border-color:var(--success);background:var(--success-bg)}
/* Choix (radio / checkbox) */
.choice{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--ink-soft);cursor:pointer}
.choice input{margin-top:2px;width:18px;height:18px;accent-color:var(--brand);flex:none}
.choice-group{display:flex;flex-direction:column;gap:11px}
/* Segmenté (toggle 2-3 options) */
.segmented{display:inline-flex;border:1.5px solid var(--line-strong);border-radius:var(--r-pill);overflow:hidden;background:var(--surface)}
.segmented__btn{font-size:13.5px;font-weight:600;padding:10px 20px;color:var(--ink-soft);transition:var(--transition);min-height:42px}
.segmented__btn[aria-pressed="true"]{background:var(--brand);color:#fff}
/* Messages de formulaire */
.form-message{display:flex;align-items:flex-start;gap:10px;padding:13px 16px;border-radius:var(--r-sm);font-size:14px;border:1px solid}
.form-message svg{width:18px;height:18px;flex:none;margin-top:1px}
.form-message--success{background:var(--success-bg);color:var(--success);border-color:var(--success-line)}
.form-message--error{background:var(--error-bg);color:var(--error);border-color:var(--error-line)}
.form-message--info{background:var(--info-bg);color:var(--info);border-color:var(--info-line)}

/* Étapes (multi-step) */
.steps{display:flex;align-items:center;gap:0;margin-bottom:28px;flex-wrap:wrap}
.steps__item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink-faint)}
.steps__num{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-strong);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:13px;font-weight:600;flex:none}
.steps__item--active{color:var(--ink);font-weight:600}
.steps__item--active .steps__num{background:var(--brand);border-color:var(--brand);color:#fff}
.steps__item--done .steps__num{background:var(--success);border-color:var(--success);color:#fff}
.steps__sep{flex:1;min-width:24px;height:1.5px;background:var(--line-strong);margin:0 12px}

/* ========== 11. FILTRES (sidebar + drawer) =========================== */
.filters{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px}
.filters__group+.filters__group{margin-top:20px;padding-top:20px;border-top:1px solid var(--line)}
.filters__legend{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px}
.filters__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.filters__title{font-size:18px;font-weight:700}
.filters__clear{font-size:13px;color:var(--brand);font-weight:600}
.filter-chip{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;padding:8px 14px;border:1.5px solid var(--line);border-radius:var(--r-pill);background:var(--surface);color:var(--ink-soft);transition:var(--transition)}
.filter-chip:hover{border-color:var(--line-strong)}
.filter-chip--active{background:var(--brand-50);border-color:var(--brand);color:var(--brand-700)}
.filter-chips{display:flex;flex-wrap:wrap;gap:8px}
.active-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.active-filter{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;background:var(--brand-50);color:var(--brand-700);border:1px solid #F0D3C2;border-radius:var(--r-pill);padding:6px 8px 6px 13px}
.active-filter button{display:flex;width:18px;height:18px;align-items:center;justify-content:center;border-radius:50%;color:var(--brand-700)}
.active-filter button:hover{background:#F0D3C2}
.active-filter svg{width:13px;height:13px}

/* Barre d'outils liste (tri + nb résultats + bouton filtres mobile) */
.list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.list-toolbar__count{font-size:14.5px;color:var(--ink-soft)}
.list-toolbar__count b{color:var(--ink)}
.filters-toggle{display:inline-flex}
@media (min-width:1024px){.filters-toggle{display:none}}

/* Layout annuaire : sidebar + grille */
.directory{display:grid;grid-template-columns:1fr;gap:32px}
@media (min-width:1024px){.directory{grid-template-columns:300px 1fr;align-items:start}}
.directory__aside{display:none}
@media (min-width:1024px){.directory__aside{display:block;position:sticky;top:calc(var(--header-h) + 20px)}}

/* Drawer filtres (mobile) */
.drawer{position:fixed;inset:0;z-index:120;visibility:hidden}
.drawer[data-open="true"]{visibility:visible}
.drawer__backdrop{position:absolute;inset:0;background:rgba(31,26,22,.45);opacity:0;transition:opacity .25s}
.drawer[data-open="true"] .drawer__backdrop{opacity:1}
.drawer__panel{position:absolute;top:0;left:0;bottom:0;width:min(92%,380px);background:var(--paper);transform:translateX(-100%);transition:transform .26s ease;display:flex;flex-direction:column}
.drawer[data-open="true"] .drawer__panel{transform:translateX(0)}
.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.drawer__title{font-size:18px;font-weight:700}
.drawer__close{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.drawer__close:hover{background:var(--surface)}
.drawer__body{flex:1;overflow-y:auto;padding:20px}
.drawer__foot{padding:16px 20px;border-top:1px solid var(--line);display:flex;gap:10px}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:48px;flex-wrap:wrap}
.pagination__link{min-width:44px;height:44px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--line);border-radius:var(--r-sm);font-size:15px;font-weight:600;color:var(--ink);transition:var(--transition)}
.pagination__link:hover{border-color:var(--brand);color:var(--brand)}
.pagination__link[aria-current="page"]{background:var(--brand);border-color:var(--brand);color:#fff}
.pagination__link[aria-disabled="true"]{opacity:.4;pointer-events:none}
.pagination__ellipsis{padding:0 6px;color:var(--ink-faint)}

/* ========== 12. COMPOSANTS DE PAGE =================================== */
/* Fil d'Ariane */
.breadcrumb{padding:18px 0}
.breadcrumb__list{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;color:var(--ink-faint)}
.breadcrumb__sep{color:var(--line-strong)}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb [aria-current="page"]{color:var(--ink-soft)}

/* Barre de recherche (hero) */
.searchbar{display:flex;flex-direction:column;gap:8px;background:var(--surface);border-radius:var(--r-lg);padding:10px;box-shadow:var(--sh-3)}
@media (min-width:768px){.searchbar{flex-direction:row;border-radius:var(--r-pill);align-items:center}}
.searchbar__field{flex:1;display:flex;align-items:center;gap:10px;padding:8px 16px}
.searchbar__field svg{width:18px;height:18px;color:var(--walnut);flex:none}
.searchbar__field input,.searchbar__field select{border:none;background:none;width:100%;font-size:15px;min-height:36px;padding:0}
.searchbar__field input:focus,.searchbar__field select:focus{outline:none;box-shadow:none}
.searchbar__field+.searchbar__field{border-top:1px solid var(--line)}
@media (min-width:768px){.searchbar__field+.searchbar__field{border-top:none;border-left:1px solid var(--line)}}
.searchbar .btn{flex:none}

/* Bandeau de réassurance */
.assurance{display:grid;grid-template-columns:1fr;gap:20px}
@media (min-width:768px){.assurance{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1024px){.assurance{grid-template-columns:repeat(4,1fr)}}
.assurance__item{display:flex;gap:14px;align-items:flex-start}
.assurance__icon{width:44px;height:44px;border-radius:var(--r-md);background:var(--brand-50);color:var(--brand);display:flex;align-items:center;justify-content:center;flex:none}
.assurance__icon svg{width:22px;height:22px}
.assurance__title{font-size:15.5px;font-weight:700;margin-bottom:4px}
.assurance__text{font-size:13.5px;color:var(--ink-soft);line-height:1.5}

/* Accordéon (FAQ) */
.accordion{border-top:1px solid var(--line)}
.accordion__item{border-bottom:1px solid var(--line)}
.accordion__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 4px;font-size:17px;font-weight:600;text-align:left;color:var(--ink)}
.accordion__trigger:hover{color:var(--brand)}
.accordion__icon{flex:none;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--line-strong);display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.accordion__icon svg{width:14px;height:14px;transition:transform var(--transition)}
.accordion__trigger[aria-expanded="true"] .accordion__icon{background:var(--brand);border-color:var(--brand);color:#fff}
.accordion__trigger[aria-expanded="true"] .accordion__icon svg{transform:rotate(180deg)}
.accordion__panel{overflow:hidden;max-height:0;transition:max-height .3s ease}
.accordion__panel-inner{padding:0 4px 22px;color:var(--ink-soft);font-size:15px;line-height:1.6;max-width:68ch}
/* Sans JS : tout ouvert (dégradation propre) */
.no-js .accordion__panel{max-height:none}

/* Carte info / encadré */
.callout{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--brand);border-radius:var(--r-md);padding:20px 22px}
.callout--tip{background:var(--brand-50);border-color:#F0D3C2;border-left-color:var(--brand)}
.callout__title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:9px;margin-bottom:8px}
.callout__title svg{width:18px;height:18px;color:var(--brand)}
.callout p{font-size:14.5px;color:var(--ink-soft);line-height:1.55}

/* Bloc d'info clé (fiche salon) */
.keyfacts{display:grid;grid-template-columns:1fr;gap:2px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
@media (min-width:600px){.keyfacts{grid-template-columns:1fr 1fr}}
.keyfact{background:var(--surface);padding:18px 20px;display:flex;gap:13px;align-items:flex-start}
.keyfact__icon{width:38px;height:38px;border-radius:var(--r-sm);background:var(--brand-50);color:var(--brand);display:flex;align-items:center;justify-content:center;flex:none}
.keyfact__icon svg{width:19px;height:19px}
.keyfact__label{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:3px}
.keyfact__value{font-size:15.5px;font-weight:600}
.keyfact__value a{color:var(--brand)}

/* Avis / notes */
.rating{display:inline-flex;align-items:center;gap:8px}
.rating__stars{display:inline-flex;gap:2px;color:var(--brand)}
.rating__stars svg{width:18px;height:18px}
.rating__score{font-weight:700;font-size:16px}
.rating__count{font-size:13px;color:var(--ink-faint)}
.review{padding:22px 0;border-top:1px solid var(--line)}
.review__head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.review__avatar{width:42px;height:42px;border-radius:50%;background:var(--walnut-50);color:var(--walnut);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex:none}
.review__name{font-weight:600;font-size:14.5px}
.review__date{font-size:12.5px;color:var(--ink-faint)}
.review__stars{display:inline-flex;gap:1px;color:var(--brand);margin-left:auto}
.review__stars svg{width:15px;height:15px}
.review__text{font-size:14.5px;color:var(--ink-soft);line-height:1.6}

/* Mini-carte Leaflet (placeholder + conteneur) */
.map-mini{aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);background:#E7ECE4}
.map-full{height:calc(100vh - var(--header-h));min-height:480px}
.map-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,#E7ECE4,#E7ECE4 12px,#EDF1EA 12px,#EDF1EA 24px);color:var(--ink-faint);font-family:var(--font-mono);font-size:12px;text-align:center;padding:20px}

/* Article — confort de lecture */
.prose{max-width:var(--container-narrow);margin:0 auto;font-size:17px;line-height:1.72;color:#2A241E}
.prose>*+*{margin-top:1.3em}
.prose h2{font-size:clamp(24px,3.4vw,32px);margin-top:1.8em}
.prose h3{font-size:clamp(20px,2.6vw,24px);margin-top:1.5em}
.prose p{text-wrap:pretty}
.prose a{color:var(--brand);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
.prose ul,.prose ol{padding-left:1.3em;display:flex;flex-direction:column;gap:.5em}
.prose ul li{list-style:disc}
.prose ol li{list-style:decimal}
.prose blockquote{border-left:3px solid var(--brand);padding:4px 0 4px 22px;font-size:21px;line-height:1.45;color:var(--ink);font-weight:500}
.prose figure img{border-radius:var(--r-lg);width:100%}
.prose figcaption{font-size:13px;color:var(--ink-faint);margin-top:8px;text-align:center}

/* Table des matières (sommaire article) */
.toc{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:20px 22px}
.toc__title{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px}
.toc ol{display:flex;flex-direction:column;gap:9px;counter-reset:toc}
.toc a{font-size:14.5px;color:var(--ink-soft);display:flex;gap:10px}
.toc a::before{counter-increment:toc;content:counter(toc,decimal-leading-zero);font-family:var(--font-mono);font-size:12px;color:var(--brand)}
.toc a:hover{color:var(--brand)}

/* Bloc auteur (E-E-A-T) */
.author-box{display:flex;gap:18px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px}
.author-box__avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;flex:none;background:var(--walnut-50)}
.author-box__name{font-size:17px;font-weight:700}
.author-box__role{font-family:var(--font-mono);font-size:12px;color:var(--brand);text-transform:uppercase;letter-spacing:.04em;margin:3px 0 8px}
.author-box__bio{font-size:14px;color:var(--ink-soft);line-height:1.55}

/* Trombinoscope équipe */
.team-member{text-align:center}
.team-member__photo{aspect-ratio:1;border-radius:var(--r-lg);object-fit:cover;width:100%;background:var(--walnut-50);margin-bottom:14px}
.team-member__name{font-size:18px;font-weight:700}
.team-member__role{font-family:var(--font-mono);font-size:12px;color:var(--brand);text-transform:uppercase;letter-spacing:.04em;margin-top:4px}

/* Pricing (formules Coton / Diamant) */
.pricing{display:grid;grid-template-columns:1fr;gap:24px}
@media (min-width:768px){.pricing{grid-template-columns:1fr 1fr}}
.plan{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:32px 28px;position:relative}
.plan--featured{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand),var(--sh-2)}
.plan__flag{position:absolute;top:-13px;left:28px;background:var(--brand);color:#fff;font-size:12px;font-weight:600;padding:5px 13px;border-radius:var(--r-pill);display:inline-flex;align-items:center;gap:6px}
.plan__flag svg{width:13px;height:13px}
.plan__name{font-family:var(--font-mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--walnut)}
.plan__price{font-size:46px;font-weight:800;letter-spacing:-.03em;margin:14px 0 4px}
.plan__price small{font-size:16px;font-weight:500;color:var(--ink-faint)}
.plan__desc{font-size:14.5px;color:var(--ink-soft);margin-bottom:22px}
.plan__features{display:flex;flex-direction:column;gap:13px;margin-bottom:28px;flex:1}
.plan__feature{display:flex;gap:11px;font-size:14.5px;align-items:flex-start}
.plan__feature svg{width:18px;height:18px;color:var(--success);flex:none;margin-top:1px}
.plan__feature--off{color:var(--ink-faint)}
.plan__feature--off svg{color:var(--ink-faint)}

/* Tableau de bord pro */
.dash-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.dash-table th{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);text-align:left;padding:14px 18px;background:var(--surface-2);border-bottom:1px solid var(--line);font-weight:600}
.dash-table td{padding:16px 18px;border-bottom:1px solid var(--line);font-size:14.5px;vertical-align:middle}
.dash-table tr:last-child td{border-bottom:none}
.dash-table__title{font-weight:600}
.dash-table__meta{font-size:12.5px;color:var(--ink-faint)}
.dash-card{display:none}
@media (max-width:767px){
  .dash-table{display:none}
  .dash-card{display:flex;flex-direction:column;gap:14px}
  .dash-card__item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:16px}
}

/* État vide / 404 */
.empty-state{text-align:center;max-width:460px;margin:0 auto;padding:48px 20px}
.empty-state__icon{width:72px;height:72px;border-radius:50%;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;color:var(--walnut)}
.empty-state__icon svg{width:34px;height:34px}
.empty-state__title{font-size:24px;margin-bottom:10px}
.empty-state__text{color:var(--ink-soft);margin-bottom:24px}
.error-code{font-size:clamp(80px,18vw,160px);font-weight:800;letter-spacing:-.05em;color:var(--brand);line-height:.9}

/* Bloc B2B (CTA référencement) */
.cta-band{background:var(--ink);color:#F2EDE4;border-radius:var(--r-xl);padding:44px 32px;display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
@media (min-width:900px){.cta-band{grid-template-columns:1.5fr 1fr;padding:56px 48px}}
.cta-band__title{font-size:clamp(26px,3.6vw,38px);color:#fff}
.cta-band__text{color:#C9BCA6;margin-top:12px;font-size:16px;max-width:46ch}
.cta-band__actions{display:flex;gap:12px;flex-wrap:wrap}
@media (min-width:900px){.cta-band__actions{justify-content:flex-end}}

/* Hero accueil */
.hero{position:relative;border-radius:var(--r-xl);overflow:hidden;background:linear-gradient(115deg,#2B1A12 0%,#5A2E18 52%,#94401F 100%);color:#F7F2E9}
.hero__media{position:absolute;inset:0;opacity:.30;object-fit:cover;width:100%;height:100%}
.hero__inner{position:relative;padding:48px 28px}
@media (min-width:768px){.hero__inner{padding:72px 56px}}
@media (min-width:1024px){.hero__inner{padding:92px 72px;max-width:820px}}
.hero__eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#E4C99B;margin-bottom:18px}
.hero__title{font-size:clamp(38px,6.5vw,72px);font-weight:800;letter-spacing:-.035em;line-height:.96}
.hero__title em{font-style:normal;color:#E4C99B}
.hero__text{font-size:clamp(16px,2vw,19px);color:#EBE1D2;max-width:46ch;margin-top:18px}
.hero__search{margin-top:30px}
.hero__stats{display:flex;gap:28px;flex-wrap:wrap;margin-top:30px}
.hero__stat b{display:block;font-size:26px;font-weight:800;letter-spacing:-.02em}
.hero__stat span{font-size:12.5px;color:#D6C7AE;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}

/* Utilitaires divers */
.divider{height:1px;background:var(--line);border:none;margin:0}
.tag-list{display:flex;flex-wrap:wrap;gap:8px}
.social-links{display:flex;gap:10px}
.social-links a{width:40px;height:40px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:var(--transition)}
.social-links a:hover{border-color:var(--brand);color:var(--brand)}
.social-links svg{width:18px;height:18px}
.center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.flow>*+*{margin-top:var(--sp-4)}

/* Calendrier — groupes par mois */
.cal-month+.cal-month{margin-top:36px}
.cal-month__label{display:flex;align-items:baseline;gap:10px;font-size:14px;font-family:var(--font-mono);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);padding-bottom:8px;border-bottom:2px solid var(--ink);margin-bottom:6px}
.cal-month__year{color:var(--brand)}

/* Cartes de synthèse (espace pro) */
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px}
.stat-card__label{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint)}
.stat-card__value{font-size:38px;font-weight:800;letter-spacing:-.02em;margin-top:8px}

/* Page membre (profil individuel) */
.member-profile{display:grid;grid-template-columns:1fr;gap:32px}
@media (min-width:768px){.member-profile{grid-template-columns:280px 1fr;align-items:start}}
.member-articles{display:flex;flex-direction:column;gap:0}

/* Carte plein écran (Leaflet) */
.map-layout{display:grid;grid-template-columns:1fr;height:calc(100vh - var(--header-h))}
@media (min-width:1024px){.map-layout{grid-template-columns:380px 1fr}}
.map-layout__list{overflow-y:auto;border-right:1px solid var(--line);background:var(--paper);display:none}
@media (min-width:1024px){.map-layout__list{display:block}}
.map-layout__head{position:sticky;top:0;background:var(--paper);border-bottom:1px solid var(--line);padding:18px 20px;z-index:2}
.map-layout__count{font-size:14px;color:var(--ink-soft)}
.map-layout__count b{color:var(--ink)}
.map-layout__items{padding:12px}
.map-item{display:flex;gap:12px;padding:12px;border-radius:var(--r-md);cursor:pointer;transition:var(--transition)}
.map-item:hover,.map-item--active{background:var(--surface)}
.map-item__thumb{width:72px;height:54px;border-radius:var(--r-sm);object-fit:cover;flex:none;background:#EDE6D9}
.map-item__city{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--walnut)}
.map-item__title{font-size:14.5px;font-weight:700;letter-spacing:-.01em;margin:3px 0 5px;line-height:1.2}
.map-item__date{font-size:12.5px;color:var(--ink-soft)}
.map-canvas{position:relative;background:#E7ECE4}
.map-mobile-toggle{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:5}
@media (min-width:1024px){.map-mobile-toggle{display:none}}
/* Marqueur Leaflet stylé (à appliquer via L.divIcon className="sdm-marker") */
.sdm-marker{background:var(--brand);color:#fff;font-weight:700;font-size:12px;border:2px solid #fff;border-radius:50% 50% 50% 0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transform:rotate(-45deg);box-shadow:var(--sh-2)}
.sdm-marker span{transform:rotate(45deg)}
.sdm-marker--featured{background:var(--walnut)}
.sdm-marker--cluster{background:var(--ink);border-radius:50%;width:38px;height:38px;transform:none}
.sdm-marker--cluster span{transform:none}

/* Ligne agenda (accueil + calendrier compact) */
.agenda-row{display:flex;align-items:center;gap:18px;padding:18px 4px;border-bottom:1px solid var(--line);transition:var(--transition)}
.agenda-row:hover{background:var(--surface);padding-left:14px;padding-right:14px;border-radius:var(--r-md)}
.agenda-row__date{flex:none;width:64px;text-align:center;font-family:var(--font-mono);font-size:13px;color:var(--ink-soft);line-height:1.1}
.agenda-row__date b{display:block;font-family:var(--font-sans);font-size:26px;font-weight:800;color:var(--ink);letter-spacing:-.02em}
.agenda-row__main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.agenda-row__title{font-size:16.5px;font-weight:700;letter-spacing:-.01em}
.agenda-row__loc{font-size:13px;color:var(--ink-soft)}
.agenda-row .badge{flex:none}
.agenda-row__chev{width:20px;height:20px;color:var(--ink-faint);flex:none}
@media (max-width:560px){
  .agenda-row{flex-wrap:wrap;gap:12px}
  .agenda-row__chev{display:none}
  .agenda-row .badge{order:3}
}

/* Carte article (post-card) */
.post-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:var(--transition)}
.post-card:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.post-card__media{aspect-ratio:16/9;overflow:hidden;background:#EDE6D9}
.post-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.post-card:hover .post-card__media img{transform:scale(1.04)}
.post-card__body{padding:18px;display:flex;flex-direction:column;flex:1}
.post-card__cat{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--brand)}
.post-card__title{font-size:18px;font-weight:700;letter-spacing:-.015em;line-height:1.25;margin:9px 0 10px}
.post-card__title a:hover{color:var(--brand)}
.post-card__excerpt{font-size:14px;color:var(--ink-soft);line-height:1.55;flex:1}
.post-card__meta{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);margin-top:14px}
.post-card--featured{grid-column:1/-1}
@media (min-width:768px){.post-card--featured{flex-direction:row}.post-card--featured .post-card__media{width:52%;aspect-ratio:auto}.post-card--featured .post-card__body{padding:32px;justify-content:center}.post-card--featured .post-card__title{font-size:clamp(24px,3vw,32px)}.post-card--featured .post-card__excerpt{font-size:15.5px;flex:none;margin-top:6px}}

/* ===== Fiche salon ===== */
.salon-cover{position:relative;aspect-ratio:16/9;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);background:#EDE6D9}
.salon-cover__img{width:100%;height:100%;object-fit:cover}
.salon-cover__badge{position:absolute;top:16px;left:16px;z-index:2}
.salon-cover__actions{position:absolute;top:16px;right:16px;z-index:2;display:flex;gap:8px}
.salon-cover__action{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:var(--sh-1);transition:var(--transition)}
.salon-cover__action:hover{background:#fff}
.salon-cover__action svg{width:19px;height:19px}
.salon-cover__action[aria-pressed="true"]{color:var(--brand)}
.salon-cover__action[aria-pressed="true"] svg{fill:var(--brand)}
.salon-cover__banner{position:absolute;left:0;right:0;bottom:0;z-index:2;background:rgba(31,26,22,.86);color:#E7DCCB;font-size:13.5px;font-weight:600;padding:12px 18px;display:flex;align-items:center;gap:9px}
.salon-cover__banner svg{width:16px;height:16px;flex:none;color:#E4C99B}
.salon-cover--past .salon-cover__img{filter:grayscale(.85)}

.salon-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap;margin:26px 0 8px}
.salon-head__city{display:flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--walnut);margin-bottom:12px}
.salon-head__city svg{width:14px;height:14px}
.salon-head h1{font-size:clamp(28px,4.6vw,46px)}
.salon-head__tagline{font-size:clamp(16px,2vw,19px);color:var(--ink-soft);margin-top:10px;max-width:50ch}

.salon-layout{display:grid;grid-template-columns:1fr;gap:36px;margin-top:36px}
@media (min-width:1024px){.salon-layout{grid-template-columns:1fr 360px;align-items:start}}
.salon-main>*+*{margin-top:40px}
.salon-block__title{font-size:24px;margin-bottom:18px}
.salon-aside{display:flex;flex-direction:column;gap:18px}
@media (min-width:1024px){.salon-aside{position:sticky;top:calc(var(--header-h) + 20px)}}

.booking-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh-1)}
.booking-card__date{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600}
.booking-card__date svg{width:18px;height:18px;color:var(--brand);flex:none}
.booking-card__price{font-size:30px;font-weight:800;letter-spacing:-.02em;margin:16px 0 2px}
.booking-card__price small{font-size:14px;font-weight:500;color:var(--ink-faint)}
.booking-card__price-note{font-size:13px;color:var(--ink-soft);margin-bottom:18px}
.booking-card__links{display:flex;flex-direction:column;gap:10px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.booking-card__link{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink);font-weight:500}
.booking-card__link svg{width:17px;height:17px;color:var(--walnut);flex:none}
.booking-card__link:hover{color:var(--brand)}

/* Planche de variantes (démo intégration) */
.variant-strip{display:grid;grid-template-columns:1fr;gap:20px}
@media (min-width:900px){.variant-strip{grid-template-columns:repeat(3,1fr)}}
.variant-strip__item{background:var(--surface);border:1px dashed var(--line-strong);border-radius:var(--r-lg);padding:16px}
.variant-strip__label{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.variant-strip__label code{color:var(--brand)}

/* Liens ville (pages curatées) */
.salon-card__city-link,.salon-head__city-link{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:color .15s,border-color .15s}
.salon-card__city-link:hover,.salon-card__city-link:focus-visible,.salon-head__city-link:hover,.salon-head__city-link:focus-visible{color:var(--brand);border-bottom-color:currentColor}
