/* =========================================================================
   Coiffure Prestige Mascouche — Système de design (prestige, chaleureux, mobile d'abord)
   Palette (DONNEES §7) : violet #7F00E6, rose #CC3366, crème #F2E7DF,
   anthracite #333, prune #3D1A5B, champagne #C9A66B. Contraste AA.
   ========================================================================= */

:root{
  --violet:#7F00E6;
  --violet-deep:#6a00c2;
  --rose:#CC3366;
  --rose-deep:#b02855;
  --cream:#F2E7DF;
  --cream-2:#F8F1EB;
  --ink:#333333;
  --ink-soft:#5a5258;
  --plum:#3D1A5B;
  --plum-2:#2c1142;
  --gold:#C9A66B;
  --gold-soft:#e4d2ad;
  --white:#ffffff;
  --line:rgba(61,26,91,.14);
  --line-soft:rgba(61,26,91,.08);

  --r-card:18px;
  --r-btn:999px;
  --r-input:12px;
  --r-img:18px;

  --shadow-sm:0 2px 10px rgba(61,26,91,.07);
  --shadow:0 14px 40px rgba(61,26,91,.12);
  --shadow-lg:0 26px 70px rgba(61,26,91,.18);

  --container:1180px;
  --gap:clamp(1rem,3vw,2rem);
  --section-y:clamp(3.5rem,8vw,7rem);

  --ff-title:"Playfair Display",Georgia,serif;
  --ff-body:"Montserrat",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--ff-body);
  font-size:1.0625rem;
  line-height:1.7;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--violet);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--rose)}
:focus-visible{outline:3px solid var(--violet);outline-offset:2px;border-radius:4px}

h1,h2,h3,h4{font-family:var(--ff-title);color:var(--plum);line-height:1.12;font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,6vw,3.5rem);letter-spacing:-.01em}
h2{font-size:clamp(1.7rem,4.2vw,2.6rem)}
h3{font-size:clamp(1.25rem,2.6vw,1.6rem)}
p{margin:0 0 1.1em;max-width:68ch}
.lead{font-size:clamp(1.1rem,2.4vw,1.3rem);color:var(--ink);font-weight:500}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1rem,5vw,2.2rem)}
.section{padding-block:var(--section-y)}
.section--cream{background:var(--cream)}
.section--white{background:var(--cream-2)}
.section--plum{background:var(--plum);color:#f3ecf6}
.section--plum h2,.section--plum h3{color:#fff}
.section--plum p{color:#e6dcef}
.eyebrow{font-family:var(--ff-body);font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rose);margin:0 0 .8rem}
.section--plum .eyebrow{color:var(--gold)}
.center{text-align:center}
.measure{max-width:62ch;margin-inline:auto}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--ff-body);font-weight:700;font-size:1rem;line-height:1;
  padding:.95rem 1.5rem;border-radius:var(--r-btn);border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
  text-align:center;white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn--primary{background:var(--violet);color:#fff;box-shadow:0 10px 24px rgba(127,0,230,.28)}
.btn--primary:hover{background:var(--violet-deep);color:#fff;transform:translateY(-2px);box-shadow:0 16px 32px rgba(127,0,230,.34)}
.btn--phone{background:var(--rose);color:#fff;box-shadow:0 10px 24px rgba(204,51,102,.28)}
.btn--phone:hover{background:var(--rose-deep);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--plum);border-color:var(--plum)}
.btn--ghost:hover{background:var(--plum);color:#fff}
.section--plum .btn--ghost{color:#fff;border-color:rgba(255,255,255,.6)}
.section--plum .btn--ghost:hover{background:#fff;color:var(--plum)}
.btn--lg{padding:1.1rem 1.9rem;font-size:1.05rem}
.btn svg{width:1.15em;height:1.15em;flex:none}
.cta-row{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.cta-row--center{justify-content:center}

/* ---------- Bandeau d'annonce (rendez-vous) ---------- */
.announce{
  background:var(--plum);color:#fff;font-size:.92rem;font-weight:500;
  text-align:center;padding:.55rem 1rem;line-height:1.4;
}
.announce a{color:var(--gold-soft);font-weight:700;text-decoration:underline;text-underline-offset:2px}
.announce a:hover{color:#fff}

/* ---------- En-tête ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(248,241,235,.92);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line-soft)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:72px}
.brand{display:flex;align-items:center;gap:.6rem;flex:none}
.brand__mark{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--rose));color:#fff;display:grid;place-items:center;font-family:var(--ff-title);font-weight:700;font-size:1.25rem;box-shadow:var(--shadow-sm)}
.brand__name{font-family:var(--ff-title);font-weight:700;color:var(--plum);font-size:1.18rem;line-height:1.05}
.brand__name span{display:block;font-family:var(--ff-body);font-weight:600;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose)}
.nav{display:none}
.nav__list{display:flex;align-items:center;gap:1.35rem;list-style:none;margin:0;padding:0}
.nav__list a{color:var(--plum);font-weight:600;font-size:.96rem}
.nav__list a:hover,.nav__list .current-menu-item>a{color:var(--violet)}
.header-cta{display:flex;align-items:center;gap:.7rem;flex:none}
.header-phone{display:none}

/* sous-menu */
.menu-item-has-children{position:relative}
.sub-menu{list-style:none;margin:0;padding:.5rem;position:absolute;top:130%;left:0;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(6px);transition:.2s ease}
.menu-item-has-children:hover .sub-menu,.menu-item-has-children:focus-within .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.sub-menu a{display:block;padding:.55rem .7rem;border-radius:8px;font-size:.92rem}
.sub-menu a:hover{background:var(--cream)}

/* hamburger */
.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:#fff;cursor:pointer}
.nav-toggle span{display:block;height:2px;width:22px;margin-inline:auto;background:var(--plum);transition:.25s ease}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* menu mobile */
.mobile-nav{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:var(--cream-2);z-index:60;transform:translateX(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-lg);overflow-y:auto;padding:1.5rem 1.3rem 6rem}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.mobile-nav__close{background:none;border:none;font-size:1.8rem;line-height:1;color:var(--plum);cursor:pointer;width:44px;height:44px}
.mobile-nav ul{list-style:none;margin:0;padding:0}
.mobile-nav>ul>li{border-bottom:1px solid var(--line-soft)}
.mobile-nav a{display:block;padding:.85rem .3rem;color:var(--plum);font-weight:600;font-size:1.05rem}
.mobile-nav .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:transparent;padding:0 0 .5rem .8rem}
.mobile-nav .sub-menu a{font-weight:500;font-size:.98rem;padding:.55rem .3rem}
.nav-backdrop{position:fixed;inset:0;background:rgba(44,17,66,.45);z-index:55;opacity:0;visibility:hidden;transition:.3s ease}
.nav-backdrop.open{opacity:1;visibility:visible}

/* ---------- Barre d'appel fixe mobile ---------- */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:45;display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(61,26,91,.12);padding:.5rem;padding-bottom:max(.5rem,env(safe-area-inset-bottom))}
.callbar a{display:flex;align-items:center;justify-content:center;gap:.45rem;font-weight:700;font-size:.95rem;padding:.7rem;border-radius:var(--r-btn)}
.callbar .cb-phone{background:var(--rose);color:#fff;margin-right:.4rem}
.callbar .cb-book{background:var(--violet);color:#fff}
.callbar svg{width:1.1em;height:1.1em}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--plum)}
.hero__bg{position:absolute;inset:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,17,66,.62),rgba(44,17,66,.78)),radial-gradient(60% 50% at 80% 10%,rgba(127,0,230,.35),transparent 60%)}
.hero__inner{position:relative;z-index:2;padding-block:clamp(3rem,9vw,6rem);min-height:min(86vh,720px);display:flex;flex-direction:column;justify-content:center}
.hero__eyebrow{color:var(--gold);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.8rem;margin-bottom:1rem}
.hero h1{color:#fff;max-width:16ch}
.hero__sub{color:#efe7f5;font-size:clamp(1.05rem,2.4vw,1.3rem);max-width:46ch;margin-bottom:1.6rem;font-weight:500}
.hero .cta-row{margin-bottom:1.1rem}
.hero__note{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#fff;padding:.6rem 1rem;border-radius:var(--r-btn);font-size:.92rem;font-weight:500}
.hero__note strong{color:var(--gold-soft)}

/* ---------- Cartes / grilles ---------- */
.grid{display:grid;gap:var(--gap)}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-card);padding:1.6rem;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card h3{margin-top:.2rem}
.card__price{font-family:var(--ff-title);color:var(--violet);font-weight:700;font-size:1.05rem}
.card__icon{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,rgba(127,0,230,.12),rgba(204,51,102,.12));display:grid;place-items:center;margin-bottom:1rem;color:var(--violet)}
.card__icon svg{width:28px;height:28px}
.card__link{font-weight:700;display:inline-flex;align-items:center;gap:.35rem;margin-top:.4rem}
.card__link::after{content:"\2192";transition:transform .2s ease}
.card:hover .card__link::after{transform:translateX(4px)}

/* service feature split */
.split{display:grid;gap:var(--gap);align-items:center}
.split__media img{border-radius:var(--r-img);box-shadow:var(--shadow)}

/* ---------- Tableau de prix ---------- */
.pricelist{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-card);box-shadow:var(--shadow-sm);overflow:hidden}
.pricelist__head{background:linear-gradient(135deg,var(--plum),var(--plum-2));color:#fff;padding:1rem 1.4rem;font-family:var(--ff-title);font-size:1.2rem;font-weight:700}
.pricelist__row{display:flex;justify-content:space-between;gap:1rem;padding:.85rem 1.4rem;border-top:1px solid var(--line-soft)}
.pricelist__row:nth-child(odd of .pricelist__row){background:rgba(242,231,223,.4)}
.pricelist__name{font-weight:500}
.pricelist__price{font-family:var(--ff-title);font-weight:700;color:var(--violet);white-space:nowrap}
.pricelist__price--consult{color:var(--rose);font-size:.92rem;font-family:var(--ff-body);font-weight:600}
.price-note{font-size:.9rem;color:var(--ink-soft);margin-top:.9rem;font-style:italic}

/* ---------- Bandeau d'avis ---------- */
.reviews__agg{display:flex;flex-direction:column;align-items:center;gap:.3rem;margin-bottom:2rem}
.reviews__stars{color:var(--gold);font-size:1.6rem;letter-spacing:.1em}
.reviews__score{font-family:var(--ff-title);font-size:2.6rem;font-weight:700;color:var(--plum);line-height:1}
.section--plum .reviews__score{color:#fff}
.reviews__meta{font-weight:600;color:var(--ink-soft)}
.section--plum .reviews__meta{color:#e6dcef}
.review-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-card);padding:1.4rem;box-shadow:var(--shadow-sm)}
.review-card__stars{color:var(--gold);letter-spacing:.08em;margin-bottom:.5rem}
.review-card__name{font-family:var(--ff-title);font-weight:700;color:var(--plum);font-size:1.1rem}
.review-card__svc{font-size:.9rem;color:var(--ink-soft)}
.review-card__badge{display:inline-flex;align-items:center;gap:.35rem;margin-top:.7rem;font-size:.82rem;font-weight:600;color:var(--ink-soft)}

/* ---------- Bandeau marques / partenaires ---------- */
.trustband{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(1.4rem,5vw,3.2rem)}
.trustband a,.trustband span{display:inline-flex;align-items:center;gap:.5rem;color:var(--ink-soft);font-weight:600;opacity:.85;transition:opacity .2s ease,color .2s ease}
.trustband a:hover{opacity:1;color:var(--violet)}
.trustband svg,.trustband img{height:30px;width:auto}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin-inline:auto}
.faq__item{background:#fff;border:1px solid var(--line-soft);border-radius:14px;margin-bottom:.8rem;overflow:hidden;box-shadow:var(--shadow-sm)}
.faq__q{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--ff-body);font-weight:700;font-size:1.05rem;color:var(--plum);padding:1.1rem 1.3rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq__q::after{content:"+";font-size:1.5rem;color:var(--violet);transition:transform .25s ease;flex:none}
.faq__q[aria-expanded="true"]::after{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq__a p{padding:0 1.3rem 1.2rem;margin:0;color:var(--ink)}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-size:.85rem;color:var(--ink-soft);padding-top:1.2rem}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;margin:0;padding:0}
.breadcrumb li::after{content:"\203A";margin-left:.4rem;color:var(--gold)}
.breadcrumb li:last-child::after{content:""}
.breadcrumb a{color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--violet)}

/* ---------- Glossaire ---------- */
.glossary-group{margin-bottom:2.6rem}
.glossary-group h2{border-bottom:2px solid var(--gold-soft);padding-bottom:.4rem;margin-bottom:1.2rem}
.glossary-grid{display:grid;gap:1rem;grid-template-columns:1fr}
.term{background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:1.2rem 1.3rem;box-shadow:var(--shadow-sm)}
.term dt{font-family:var(--ff-title);font-weight:700;color:var(--plum);font-size:1.15rem;margin-bottom:.3rem}
.term dd{margin:0;color:var(--ink)}
.term__link{display:inline-block;margin-top:.6rem;font-size:.88rem;font-weight:700}

/* chips de techniques liées */
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:.6rem 0 0}
.chip{display:inline-flex;background:rgba(127,0,230,.08);color:var(--violet);border:1px solid rgba(127,0,230,.18);border-radius:var(--r-btn);padding:.35rem .85rem;font-size:.85rem;font-weight:600}
.chip:hover{background:var(--violet);color:#fff}

/* ---------- Galerie ---------- */
.gallery{display:grid;gap:.9rem;grid-template-columns:repeat(2,1fr)}
.gallery figure{margin:0;border-radius:var(--r-img);overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:4/5;background:var(--cream)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery figure:hover img{transform:scale(1.05)}

/* ---------- Bloc « Nous trouver » ---------- */
.locate{display:grid;gap:var(--gap)}
.locate__map{border-radius:var(--r-img);overflow:hidden;box-shadow:var(--shadow);min-height:320px;border:0}
.locate__map iframe{width:100%;height:100%;min-height:340px;border:0;display:block}
.info-list{list-style:none;margin:0;padding:0}
.info-list li{display:flex;gap:.8rem;padding:.7rem 0;border-bottom:1px solid var(--line-soft)}
.info-list svg{width:22px;height:22px;color:var(--violet);flex:none;margin-top:.15rem}
.hours-table{width:100%;border-collapse:collapse}
.hours-table th,.hours-table td{text-align:left;padding:.5rem .2rem;border-bottom:1px solid var(--line-soft);font-size:.98rem}
.hours-table th{font-weight:600;color:var(--plum)}
.hours-table td{text-align:right;color:var(--ink)}

/* ---------- Formulaire de contact ---------- */
.form-field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.form-field label{font-weight:600;color:var(--plum);font-size:.95rem}
.form-field input,.form-field textarea{font-family:var(--ff-body);font-size:1rem;padding:.8rem 1rem;border:1px solid var(--line);border-radius:var(--r-input);background:#fff;color:var(--ink)}
.form-field input::placeholder,.form-field textarea::placeholder{color:#8b8189}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(127,0,230,.15)}

/* ---------- Articles / blog ---------- */
.post-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-card);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post-card__media{aspect-ratio:16/10;overflow:hidden;background:var(--cream)}
.post-card__media img{width:100%;height:100%;object-fit:cover}
.post-card__body{padding:1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.post-card__body h3{font-size:1.2rem;margin:0}
.post-meta{font-size:.85rem;color:var(--ink-soft)}
.article{max-width:760px;margin-inline:auto}
.article p{font-size:1.08rem}
.article h2{margin-top:1.8rem}
.article img{border-radius:var(--r-img);margin-block:1.4rem}
.article ul,.article ol{padding-left:1.3rem}
.article li{margin-bottom:.5rem}

/* ---------- Pied de page ---------- */
.site-footer{background:var(--plum-2);color:#e6dcef;padding-block:3.5rem 1.5rem}
.site-footer a{color:#e6dcef}
.site-footer a:hover{color:var(--gold-soft)}
.footer-grid{display:grid;gap:2rem;grid-template-columns:1fr}
.footer-col h4{color:#fff;font-family:var(--ff-title);font-size:1.2rem;margin-bottom:.9rem}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:.5rem}
.footer-brand .brand__name{color:#fff}
.footer-social{display:flex;gap:.7rem;margin-top:1rem}
.footer-social a{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:background .2s ease}
.footer-social a:hover{background:var(--violet)}
.footer-social svg{width:20px;height:20px;color:#fff}
.footer-phone{font-family:var(--ff-title);font-size:1.5rem;color:#fff;font-weight:700;display:inline-flex;align-items:center;gap:.5rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.5rem;padding-top:1.5rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center;font-size:.88rem}
.agency-credit{color:var(--violet)!important;font-weight:700}
.agency-credit:hover{color:var(--rose)!important}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .card:hover,.btn:hover,.post-card:hover,.gallery figure:hover img{transform:none!important}
}

/* ---------- Utilitaires ---------- */
.skip-link{position:absolute;left:-999px;top:0;background:var(--violet);color:#fff;padding:.7rem 1.2rem;border-radius:0 0 10px 0;z-index:100}
.skip-link:focus{left:0;color:#fff}
.tag{display:inline-block;background:var(--gold-soft);color:var(--plum);font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;padding:.3rem .7rem;border-radius:var(--r-btn)}
.divider-gold{width:64px;height:3px;background:var(--gold);border-radius:3px;margin:1rem 0}
.center .divider-gold{margin-inline:auto}
.stack-sm>*+*{margin-top:1rem}

/* ---------- Responsive ---------- */
@media (min-width:680px){
  .grid-2{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .split{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr}
  .locate{grid-template-columns:1.1fr 1fr}
  .glossary-grid{grid-template-columns:1fr 1fr}
}
@media (min-width:1024px){
  .nav{display:block}
  .nav-toggle{display:none}
  .header-phone{display:inline-flex}
  .callbar{display:none}
  body{padding-bottom:0!important}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .gallery{grid-template-columns:repeat(4,1fr)}
  .glossary-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1.6fr 1fr 1fr 1.2fr}
}
/* la barre d'appel ne masque pas le contenu en mobile */
@media (max-width:1023px){ body{padding-bottom:72px} }

/* Sécurité anti-débordement des longs mots dans les titres (mobile étroit) */
h1,h2,h3,h4,.hero h1{overflow-wrap:break-word;hyphens:auto}

/* Logo réel (image) dans l'en-tête et le pied */
.brand__logo{height:46px;width:auto;display:block}
.brand__logo--light{height:54px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media (max-width:480px){.brand__logo{height:40px}}

/* ---------- Ruban d'avis défilant ---------- */
.reviews-head{text-align:center;margin-bottom:1.6rem}
.reviews-head__score{font-family:var(--ff-title);font-size:1.8rem;color:var(--plum);font-weight:700;display:inline-flex;align-items:center;gap:.4rem}
.reviews-head__score svg{width:1.5rem;height:1.5rem;color:var(--gold)}
.reviews-head__meta{color:var(--ink-soft);font-weight:600;margin-top:.2rem}
.reviews-head__meta a{font-weight:700}
.ribbon{overflow:hidden;position:relative;padding:.4rem 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.ribbon__track{display:flex;gap:1.2rem;width:max-content;will-change:transform;animation:cp-ribbon 38s linear infinite}
.ribbon:hover .ribbon__track,.ribbon:focus-within .ribbon__track{animation-play-state:paused}
@keyframes cp-ribbon{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rev{flex:0 0 300px;width:300px;background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-card);padding:1.4rem;box-shadow:var(--shadow-sm);margin:0;display:flex;flex-direction:column;gap:.6rem}
.rev__stars{color:var(--gold);letter-spacing:.05em;line-height:1;display:flex;gap:1px}
.rev__stars svg{width:18px;height:18px}
.rev__text{margin:0;color:var(--ink);font-size:1rem;line-height:1.55}
.rev__text--meta{color:var(--ink-soft);font-weight:600}
.rev mark.kw{background:rgba(127,0,230,.12);color:var(--violet);padding:0 .15em;border-radius:3px;font-weight:700}
.rev__by{display:flex;flex-direction:column;gap:.15rem;margin-top:auto}
.rev__name{font-family:var(--ff-title);font-weight:700;color:var(--plum)}
.rev__badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--ink-soft);font-weight:600}
.rev__badge svg{width:14px;height:14px;color:#1a73e8}
@media (prefers-reduced-motion:reduce){
  .ribbon{-webkit-mask-image:none;mask-image:none;overflow-x:auto;scroll-snap-type:x proximity}
  .ribbon__track{animation:none;width:auto}
  .rev{scroll-snap-align:start}
}
