
:root{
  --bg:#f5f1ea;
  --bg-soft:#fbf8f3;
  --ink:#181512;
  --muted:#6e655d;
  --line:rgba(24,21,18,.12);
  --panel-dark:#211d1a;
  --color-border:#e0dbd5;
  --color-warm:#e4dcd4;
  --max:1260px;
  --radius:24px;
  --shadow:0 18px 50px rgba(14, 11, 8, .08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scrollbar-gutter:stable}
body{margin:0;color:var(--ink);background:var(--bg);font-family:"Inter",Arial,sans-serif;line-height:1.6}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1rem}
h1,h2,h3{margin:0 0 1rem;line-height:1.05;font-family:"Cormorant Garamond",serif;font-weight:600}
h1{font-size:clamp(3rem,7vw,6rem)}
h2{font-size:clamp(2.1rem,4vw,3.6rem)}
h3{font-size:clamp(1.35rem,2.2vw,2rem)}
.container{width:min(calc(100% - 2rem), var(--max));margin-inline:auto}
.narrow{width:min(calc(100% - 2rem), 860px);margin-inline:auto}
.skip-link{position:absolute;left:-9999px;top:auto}
.br-mobile{display:none}
.skip-link:focus{left:1rem;top:1rem;z-index:9999;background:#fff;padding:.75rem 1rem;border-radius:12px}
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(245,241,234,.72);border-bottom:1px solid var(--line);padding-bottom:10px}
.header-inner{width:min(calc(100% - 2rem), var(--max));margin-inline:auto;min-height:88px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}
.nav{display:flex;align-items:center;gap:1.25rem}
.nav-left{justify-content:flex-end}
.nav-right{justify-content:flex-start}
.nav a{font-size:.94rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.header-center{display:flex;align-items:center;justify-content:center;align-self:stretch}
.logo-block{position:relative;display:flex;align-items:center;justify-content:center;height:100%}
.site-logo{display:flex;align-items:center;justify-content:center;text-align:center}
.site-logo img{display:block;width:min(240px,42vw);height:auto}
.header-book-cta{position:absolute;bottom:-10px;left:0;width:100%;text-align:center;font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-style:italic;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#fff;text-decoration:none;border:3px solid #c9a84c;padding:.28rem 0;background:#000;transition:background .2s ease,color .2s ease;white-space:nowrap;box-sizing:border-box}
.header-book-cta:hover{background:#c9a84c;color:#000}
.menu-toggle{display:none;appearance:none;border:0;background:transparent;padding:0;width:42px;height:42px;cursor:pointer}
.menu-toggle span{display:block;height:2px;background:var(--ink);margin:7px 0;border-radius:999px}
.mobile-nav{display:none;grid-column:1/-1;padding:0 0 1rem;gap:.75rem}
.mobile-nav a{padding:.35rem 0;text-transform:uppercase;letter-spacing:.06em;font-size:.92rem}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:.8rem 1.25rem;border-radius:999px;border:1px solid transparent;font-weight:600;transition:.25s ease}
.btn:hover{transform:translateY(-1px)}
.btn-small{min-height:40px;padding:.55rem 1rem;font-size:.92rem;white-space:nowrap}
.btn-outline{border-color:var(--line);background:rgba(255,255,255,.55)}
.booking-link{background:#161310;border-color:#c9a84c;border-width:2px;color:#fff;white-space:nowrap}
.booking-link:hover{background:#c9a84c;border-color:#c9a84c;color:#000;transform:translateY(-1px)}
.eyebrow{margin-bottom:1rem;font-size:.82rem;text-transform:uppercase;letter-spacing:.22em;color:rgba(255,255,255,.82)}
.eyebrow.dark{color:var(--muted)}
.text-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;border-bottom:1px solid currentColor;padding-bottom:.15rem}

.hero-split{padding:1.5rem 0 0}
.hero-split-inner{width:min(calc(100% - 2rem), 1380px);margin-inline:auto;display:grid;grid-template-columns:minmax(320px, 520px) minmax(0, 1fr);align-items:stretch;min-height:calc(100svh - 116px)}
.hero-copy-panel{background:var(--bg-soft);padding:clamp(2rem, 5vw, 5rem);display:flex;flex-direction:column;justify-content:center}
.hero-panel-copy{max-width:34rem;color:#302924;font-size:1.05rem}
.hero-actions.dark{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-top:1.25rem}
.hero-fixed-media{position:relative;overflow:hidden;min-height:calc(100svh - 116px);background:#171411}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease}
.hero-slide.is-active{opacity:1;z-index:1}
.hero-slide video,.hero-slide img,.hero-placeholder{width:100%;height:100%;object-fit:cover}
.hero-placeholder{min-height:72svh;background-size:cover;background-position:center;transform:scale(1.02)}
.hero-placeholder-1{background-image:linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.42)),radial-gradient(circle at 20% 20%, rgba(212,187,150,.46), transparent 32%),linear-gradient(135deg, #d8c4aa 0%, #8a705f 38%, #241b16 100%)}
.hero-placeholder-2{background-image:linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.4)),radial-gradient(circle at 70% 20%, rgba(240,220,193,.28), transparent 24%),linear-gradient(135deg, #1e1714 10%, #645246 48%, #d7c9b7 100%)}
.hero-placeholder-3{background-image:linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.38)),radial-gradient(circle at 75% 35%, rgba(255,230,200,.18), transparent 22%),linear-gradient(135deg, #94806a 0%, #4c3d33 42%, #181412 100%)}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(20,16,14,.32);color:#fff;font-size:2rem;line-height:1;cursor:pointer}
.hero-arrow.prev{left:1rem}
.hero-arrow.next{right:1rem}
.hero-dots{position:absolute;left:50%;bottom:1.25rem;transform:translateX(-50%);z-index:4;display:flex;gap:.55rem}
.hero-dot{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.34);cursor:pointer}
.hero-dot.is-active{background:#fff}
.intro-band{padding:2.2rem 0 1rem}
.intro-band p{font-size:clamp(1.18rem,2vw,1.55rem);text-align:center;color:#302924}
.split-section{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;padding:4rem 0}
.visual-arched{border-radius:220px 220px 28px 28px;overflow:hidden;min-height:560px;box-shadow:var(--shadow)}
.editorial-block{width:100%;height:100%;border-radius:var(--radius);background-size:cover;background-position:center}
.editorial-warm{background-image:linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.18)),url('/assets/img/editorial-salon.webp')}
.editorial-neutral{background-image:linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.08)),linear-gradient(140deg, #efe9e1 0%, #c7beb3 45%, #908274 100%)}
.editorial-dark{background-image:linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.12)),linear-gradient(140deg, #3b3028 0%, #221c18 55%, #120f0d 100%)}
.editorial-soft{background-image:linear-gradient(180deg, rgba(255,255,255,.05), rgba(0,0,0,.08)),linear-gradient(140deg, #e8ddcf 0%, #bca996 45%, #8f7460 100%)}

.page-hero{padding:5rem 0 3rem}
.page-hero-soft{background:linear-gradient(180deg, rgba(255,255,255,.32), rgba(255,255,255,0))}
.page-hero-dark{background:linear-gradient(180deg, #191613 0%, #26211d 100%);color:#fff}
.editorial-two-col{display:grid;grid-template-columns:1fr 1fr;gap:3rem;padding:3rem 0 4rem}
.editorial-stack{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:end}
.editorial-stack .tall{min-height:520px}
.editorial-stack .short{min-height:340px}
.service-listing{padding:1.5rem 0 4rem}
.service-row{display:grid;grid-template-columns:.7fr 1.3fr;gap:2rem;padding:1.5rem 0;border-bottom:1px solid var(--line)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:220px;gap:1rem;padding:2rem 0 5rem}
.gallery-item{border-radius:22px;box-shadow:var(--shadow);background-size:cover;background-position:center}
.gallery-item.tall{grid-row:span 2}
.gallery-item.wide{grid-column:span 2}
.contact-grid,.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:2rem 0 5rem}
.team-grid{grid-template-columns:repeat(3,1fr)}
.contact-card,.team-card{background:rgba(255,255,255,.75);border:1px solid var(--line);border-radius:24px;padding:1.5rem;box-shadow:var(--shadow)}
.contact-card-map{padding:0;overflow:hidden;display:flex;flex-direction:column;}
.contact-card-map .contact-card-info{padding:1.5rem;}
.contact-map{height:280px;flex-shrink:0;}
.contact-map iframe{display:block;width:100%;height:100%;border:0;}
.team-photo{height:340px;border-radius:18px;margin-bottom:1rem;background-size:cover;background-position:center top}
.team-mono{width:44px;height:44px;border-radius:50%;background:linear-gradient(160deg,#2a221a 0%,#1e1814 50%,#141210 100%);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;flex-shrink:0}
.team-mono-letter{font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:600;font-size:1.5rem;color:rgba(240,230,211,.78);line-height:1;user-select:none;letter-spacing:-.01em;pointer-events:none}
.team-mono--gold{background:linear-gradient(160deg,#2e2010 0%,#201608 50%,#150f04 100%)}
.team-mono--gold .team-mono-letter{color:rgba(212,169,106,.95)}
.team-role{text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;color:var(--muted)}
.contact-actions{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;margin-top:1rem}

.reservation-luxe{padding:1rem 0 4rem;background:radial-gradient(circle at top, rgba(255,255,255,.45), transparent 35%),linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,0));scroll-margin-top:6rem}
.reservation-luxe-inner{display:flex;flex-direction:column;justify-content:center}
.reservation-luxe-head{max-width:760px;margin:0 auto 2rem;text-align:center}
.reservation-intro{max-width:640px;margin:0 auto;color:var(--muted);font-size:1.05rem}
.reservation-stage{display:flex;justify-content:center}
.reservation-frame-shell{position:relative;width:min(100%, 1120px);min-height:440px;border-radius:0 32px 32px 32px;overflow:hidden;background:linear-gradient(180deg, rgba(255,255,255,.58), rgba(255,255,255,.82));border:1px solid var(--line);box-shadow:0 24px 80px rgba(14, 11, 8, .12);}
.reservation-frame-shell::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 15%, rgba(220,198,170,.22), transparent 26%),radial-gradient(circle at 78% 18%, rgba(120,94,75,.12), transparent 24%);pointer-events:none;z-index:1}
/* Masque le bandeau "English / Propulsé par GOrendezvous" en bas de l'iframe */
.reservation-frame-shell::after{content:"";position:absolute;bottom:0;left:0;right:0;height:19px;background:#fff;pointer-events:none;z-index:3;border-radius:0 0 32px 32px}
.booking-frame{position:relative;z-index:2;display:block;width:100%;height:540px;margin-top:-12px;min-height:unset;border:0;background:#fff;transition:height .3s ease}
.reservation-support{text-align:center;margin-top:1.5rem;color:var(--muted)}

.site-footer{background:#161310;color:#efe8de;padding:3rem 0 1rem}
.footer-grid{display:grid;grid-template-columns:1.4fr .7fr .7fr .7fr 1.2fr;gap:2rem}
.footer-brand{font-family:"Cormorant Garamond",serif;font-size:2rem;letter-spacing:.18em;margin-bottom:1rem}
.footer-links{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2rem;padding-top:1rem;color:rgba(255,255,255,.72);font-size:.92rem}
.footer-newsletter-sub{font-size:.88rem;opacity:.72;margin:.4rem 0 1rem;line-height:1.5}
.footer-newsletter-form{display:flex;flex-direction:column;gap:.5rem}
.footer-newsletter-form input{display:block;width:100%;background:#2a2421;border:1px solid rgba(255,255,255,.28);border-radius:6px;padding:.65rem .9rem;color:#efe8de;font-size:.88rem;font-family:inherit;outline:none;transition:border-color .2s}
.footer-newsletter-form input::placeholder{color:rgba(239,232,222,.45)}
.footer-newsletter-form input:focus{border-color:rgba(255,255,255,.55)}
.footer-newsletter-form button{display:block;width:100%;background:#2a2421;border:1px solid rgba(255,255,255,.28);border-radius:6px;padding:.65rem .9rem;color:#efe8de;font-size:.88rem;font-family:inherit;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:background .2s,border-color .2s;text-align:center}
.footer-newsletter-form button:hover{background:#3a3229;border-color:rgba(255,255,255,.5)}


/* ══════════════════════════════════════════════════════════════
   PATCH — Hero avec image de fond (ajout à la fin de style.css)

   Usage :
   <section class="page-hero page-hero-img"
            style="--hero-bg: url('/assets/img/NOM.jpg')">
   ══════════════════════════════════════════════════════════════ */

.page-hero-img {
  position: relative;
  background-image: var(--hero-bg, none);
  background-size: cover;
  background-position: center center;   /* ni haut ni bas — milieu exact */
  background-repeat: no-repeat;
  background-color: var(--panel-dark);
}

/* Voile sombre pour lisibilité */
.page-hero-img::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(24, 21, 18, .52) 0%,
    rgba(24, 21, 18, .30) 50%,
    rgba(24, 21, 18, .62) 100%
  );
  pointer-events: none;
}

/* Tout le contenu passe au-dessus du voile */
.page-hero-img > * {
  position: relative;
  z-index: 1;
}

/* Typographie sur image */
.page-hero-img h1,
.page-hero-img h2,
.page-hero-img p         { color: #fff; }
.page-hero-img .eyebrow,
.page-hero-img .eyebrow.dark { color: rgba(255, 255, 255, .72); }
.page-hero-img .text-link    { color: #fff; border-color: rgba(255,255,255,.5); }
.page-hero-img .text-link:hover { border-color: #fff; }
.page-hero-img .btn-outline  { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.38); color: #fff; }
.page-hero-img .btn-outline:hover { background: rgba(255,255,255,.22); }

@media (max-width:1100px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:920px){
  .site-header{padding-bottom:0}
  .desktop-nav{display:none}
  .menu-toggle{display:block}
  .mobile-nav.is-open{display:grid}
  .header-inner{grid-template-columns:42px 1fr 42px}
  .header-center{justify-self:center}
  .site-logo{justify-self:center}
  .header-book-cta{display:none}
  .hero-split-inner,.split-section,.editorial-two-col,.service-row,.contact-grid{grid-template-columns:1fr}
  .hero-copy-panel{padding:2rem 1.25rem}
  .hero-fixed-media{min-height:56svh}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .reservation-frame-shell{min-height:480px}
  .booking-frame{height:580px}
}
@media (max-width:640px){
  .br-mobile{display:block}
  .hero-fixed-media{min-height:50svh}
  .hero-actions.dark{flex-direction:column;align-items:stretch}
  .btn{width:100%}
  .gallery-grid,.team-grid{grid-template-columns:1fr}
  .gallery-item.wide{grid-column:auto}
  .site-logo img{width:min(170px,48vw)}
  .reservation-luxe-head{text-align:left}
  .reservation-intro{margin:0}
  .reservation-frame-shell{min-height:520px;border-radius:24px}
  .booking-frame{height:620px}
}


/* ══════════════════════════════════════════════════════
   CONSEILS — Articles
══════════════════════════════════════════════════════ */
.article-body {
  max-width: 680px;
  margin: 0 auto;
  padding-top: 4rem;
  padding-bottom: 3rem;
}
.article-body .article-intro {
  font-size: 1.15rem;
  line-height: 1.7;
  opacity: .85;
  margin-bottom: 2.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--color-border, #e0dbd5);
}
.article-body h2 {
  font-size: 1.25rem;
  font-weight: 500;
  margin: 2.2rem 0 .7rem;
}
.article-body p {
  line-height: 1.75;
  margin-bottom: 1rem;
}
.article-cta {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-border, #e0dbd5);
  text-align: center;
}
.article-cta p {
  margin-bottom: 1.2rem;
  font-size: .95rem;
  opacity: .75;
}

/* ══════════════════════════════════════════════════════
   SALON — Citation d'accueil
══════════════════════════════════════════════════════ */
.salon-quote {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1.5;
  margin: 1.2rem auto 1.6rem;
  max-width: 34ch;
  border: none;
  padding: 0;
  color: inherit;
}

/* ══════════════════════════════════════════════════════
   AVIS — Page témoignages
══════════════════════════════════════════════════════ */
.avis-featured {
  background: var(--panel-dark);
  color: #f5f1ea;
  padding: 5.5rem 0;
}
.avis-featured-stars {
  color: #c9a97a;
  font-size: 1.2rem;
  letter-spacing: .1em;
  margin: 0 0 1.5rem;
}
.avis-featured-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.75rem, 3.8vw, 3rem);
  font-style: italic;
  font-weight: 500;
  line-height: 1.38;
  max-width: 48rem;
  margin: 0 auto 2rem;
  border: none;
  padding: 0;
  color: #f5f1ea;
}
.avis-featured-name {
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .22em;
  color: rgba(245,241,234,.48);
  margin: 0;
}
.avis-all { padding: 4.5rem 0 5rem; }
.avis-all-head { text-align: center; margin-bottom: 2.5rem; }
.avis-all-head h2 { margin-bottom: .3rem; font-size: clamp(1.6rem,3vw,2.4rem); }
.avis-all-head p  { color: var(--muted); font-size: .9rem; }
.avis-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: .8rem;
}
.avis-card {
  background: rgba(255,255,255,.82);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 1.1rem 1.2rem 1rem;
  display: flex;
  flex-direction: column;
  gap: .45rem;
  box-shadow: 0 2px 10px rgba(14,11,8,.05);
  transition: box-shadow .22s ease, transform .22s ease;
}
.avis-card:hover { box-shadow: 0 8px 28px rgba(14,11,8,.1); transform: translateY(-2px); }
.avis-card-stars { color: #c9a97a; font-size: .85rem; letter-spacing: .06em; margin: 0; }
.avis-card-text  { font-size: .875rem; line-height: 1.64; color: #302924; font-style: italic; flex: 1; margin: 0; }
.avis-card-name  { font-size: .74rem; text-transform: uppercase; letter-spacing: .18em; color: var(--muted); margin: 0; padding-top: .4rem; border-top: 1px solid var(--line); }

/* ══════════════════════════════════════════════════════
   ACCUEIL — Section témoignages
══════════════════════════════════════════════════════ */
.home-avis { padding: 4rem 0 4.5rem; background: var(--bg-soft); }
.home-avis-head { text-align: center; margin-bottom: 2.25rem; }
.home-avis-head h2 { font-size: clamp(1.5rem,3vw,2.2rem); margin-bottom: .3rem; }
.home-avis-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1rem;
  margin-bottom: 2rem;
}
.home-avis-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 1.4rem 1.5rem 1.25rem;
  box-shadow: var(--shadow);
}
.home-avis-stars { color: #c9a97a; font-size: .88rem; letter-spacing: .06em; margin: 0 0 .6rem; }
.home-avis-quote { font-family: 'Cormorant Garamond',serif; font-size: 1.18rem; font-style: italic; font-weight: 500; line-height: 1.46; color: var(--ink); margin: 0 0 .7rem; }
.home-avis-name  { font-size: .76rem; text-transform: uppercase; letter-spacing: .18em; color: var(--muted); margin: 0; }
.home-avis-cta   { text-align: center; }

/* ══════════════════════════════════════════════════════
   i18n — Bascule de langue (un seul mot visible)
══════════════════════════════════════════════════════ */
.lang-toggle {
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: .3rem .55rem;
  margin-left: .25rem;
  transition: color .18s, background .18s, border-color .18s;
  white-space: nowrap;
  flex-shrink: 0;
}
.lang-toggle:hover {
  color: var(--ink);
  background: rgba(24,21,18,.07);
  border-color: rgba(24,21,18,.22);
}

/* Dans le menu mobile : petite marge en haut */
.mobile-nav .lang-toggle {
  align-self: flex-start;
  margin: .5rem 0 0;
}

@media (max-width: 920px) {
  .avis-grid        { grid-template-columns: repeat(2,1fr); }
  .home-avis-grid   { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px) {
  .avis-grid, .home-avis-grid { grid-template-columns: 1fr; }
  .avis-featured    { padding: 3.5rem 0; }
  .home-avis-grid   { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════
   AVIS — Carrousel (variants : compact + featured-dark)
══════════════════════════════════════════════════════ */
.avis-carousel-section {
  padding: 1.6rem 0 1.25rem;
  background: var(--bg-soft);
  border-bottom: 1px solid var(--line);
}

.avis-carousel {
  position: relative;
  width: min(100%, 740px);
  margin: 0 auto;
}

.avis-carousel-viewport {
  position: relative;
  overflow: hidden;
  height: 130px;
}

.avis-carousel-track {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
  height: 100%;
}

.avis-carousel-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .55s ease;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: .5rem 3rem;
}
.avis-carousel-slide.is-active {
  opacity: 1;
  pointer-events: auto;
}

.avis-carousel-stars {
  color: #c9a97a;
  font-size: .82rem;
  letter-spacing: .1em;
  margin: 0 0 .55rem;
}

.avis-carousel-quote {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: clamp(.98rem, 1.6vw, 1.2rem);
  font-weight: 500;
  line-height: 1.5;
  color: var(--ink);
  margin: 0 0 .55rem;
  max-width: 38rem;
  border: none;
  padding: 0;
  quotes: none;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.avis-carousel-name {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--muted);
  margin: 0;
}

.avis-carousel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.65);
  color: var(--ink);
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  transition: background .2s, border-color .2s;
}
.avis-carousel-arrow:hover { background: #fff; border-color: rgba(24,21,18,.28); }
.avis-carousel-prev { left: -.5rem; }
.avis-carousel-next { right: -.5rem; }


.avis-carousel-cta {
  margin-top: 1.1rem;
  text-align: center;
}

/* ── Variant "featured-dark" pour la page Avis ─────── */

/* Le dark carousel a une hauteur naturelle — pas de fixed height */
.avis-carousel--dark .avis-carousel-viewport {
  height: auto;
  min-height: 180px;
}
.avis-carousel--dark .avis-carousel-track {
  height: auto;
}
/* Le slide actif repasse en position: relative pour pousser le conteneur */
.avis-carousel--dark .avis-carousel-slide.is-active {
  position: relative;
}
/* Pas de line-clamp sur les grandes citations — elles s'affichent en entier */
.avis-carousel--dark .avis-carousel-quote {
  font-size: clamp(1.5rem, 3.6vw, 2.6rem);
  color: #f5f1ea;
  max-width: 48rem;
  display: block;
  -webkit-line-clamp: unset;
  overflow: visible;
}
.avis-carousel--dark .avis-carousel-name {
  color: rgba(245,241,234,.55);
}
.avis-carousel--dark .avis-carousel-stars {
  color: #c9a97a;
  font-size: 1.2rem;
}
.avis-carousel--dark .avis-carousel-arrow {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.22);
  color: #f5f1ea;
}
.avis-carousel--dark .avis-carousel-arrow:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.4);
}

/* ── CTA Réserver entre featured et grille (avis.php) ── */
.avis-featured-cta {
  text-align: center;
  padding: 2.5rem 1rem 0;
}

@media (max-width: 640px) {
  .avis-carousel-arrow { display: none; }
  .avis-carousel-slide { padding: 1rem .5rem; }
}
@media (prefers-reduced-motion: reduce) {
  .avis-carousel-slide,
  .avis-carousel-dot { transition: none; }
}

/* ── Newsletter (Brevo) ───────────────────────────────────────────────── */
.newsletter-form { margin-top: .75rem; width: 100%; }

.newsletter-row {
  display: flex;
  flex-direction: row;
  gap: .5rem;
  width: 100%;
}

.newsletter-input {
  flex: 1;
  min-width: 0;
  box-sizing: border-box;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 6px;
  padding: .65rem .85rem;
  color: #efe8de;
  font-size: .85rem;
  font-family: inherit;
  outline: none;
  transition: border-color .2s, background .2s;
}
.newsletter-input::placeholder { color: rgba(239,232,222,.45); }
.newsletter-input:focus {
  border-color: rgba(201,168,76,.6);
  background: rgba(255,255,255,.09);
}

.newsletter-submit {
  flex-shrink: 0;
  box-sizing: border-box;
  background: #c9a84c;
  border: none;
  border-radius: 6px;
  padding: .65rem 1rem;
  color: #1a1612;
  font-size: .78rem;
  font-family: inherit;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  transition: background .2s, opacity .2s;
}
.newsletter-submit:hover { background: #d6b65a; }
.newsletter-submit:disabled {
  opacity: .55;
  cursor: wait;
}

/* Honeypot — invisible mais accessible aux bots */
.newsletter-hp {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Message de retour */
.newsletter-status {
  margin: .6rem 0 0;
  min-height: 1.2em;
  font-size: .8rem;
  line-height: 1.4;
  color: rgba(239,232,222,.7);
}
.newsletter-status[data-type="success"] { color: #c9a84c; }
.newsletter-status[data-type="error"]   { color: #e89a8a; }

/* Helper accessibilité (label caché visuellement) */
.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

@media (max-width: 480px) {
  .newsletter-row { flex-direction: column; }
  .newsletter-submit { width: 100%; }
}

/* ── H1 d'article (titre visible, gère court ou long titre) ─────────── */
.article-h1 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.5rem, 3.2vw, 2.4rem);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: -.005em;
  max-width: 30ch;
  margin: 0 auto;
}

/* ── Newsletter CTA inline (articles + conseils) ────────────────────── */
.newsletter-cta {
  padding: 4.5rem 1rem 5rem;
  background: rgba(201, 168, 76, 0.06);
  border-top: 1px solid rgba(201, 168, 76, 0.18);
  text-align: center;
}
.newsletter-cta .eyebrow {
  margin: 0 0 .9rem;
  letter-spacing: .14em;
  display: inline-block;
}
.newsletter-cta-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.8rem, 3.2vw, 2.6rem);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -.005em;
  margin: 0 auto 1rem;
  max-width: 22ch;
}
.newsletter-cta-text {
  max-width: 56ch;
  margin: 0 auto 1.8rem;
  line-height: 1.7;
  opacity: .8;
  font-size: .96rem;
}

/* Variante du formulaire pour la CTA (fond clair, contraste différent) */
.newsletter-form--cta {
  max-width: 480px;
  margin: 0 auto;
  text-align: left;
}
.newsletter-form--cta .newsletter-input {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, .15);
  color: #1a1612;
  font-size: .9rem;
  padding: .75rem 1rem;
}
.newsletter-form--cta .newsletter-input::placeholder {
  color: rgba(26, 22, 18, 0.45);
}
.newsletter-form--cta .newsletter-input:focus {
  border-color: #c9a84c;
  background: #fff;
  outline: none;
  box-shadow: 0 0 0 3px rgba(201, 168, 76, 0.18);
}
.newsletter-form--cta .newsletter-submit {
  background: #161310;
  color: #fff;
  border: 2px solid #161310;
  padding: .73rem 1.4rem;
  font-size: .8rem;
  transition: background .2s, color .2s, border-color .2s;
}
.newsletter-form--cta .newsletter-submit:hover {
  background: #c9a84c;
  border-color: #c9a84c;
  color: #161310;
}
.newsletter-form--cta .newsletter-status {
  text-align: center;
  color: rgba(26, 22, 18, 0.7);
  margin-top: .8rem;
}
.newsletter-form--cta .newsletter-status[data-type="success"] {
  color: #6c8f3a;
}
.newsletter-form--cta .newsletter-status[data-type="error"] {
  color: #b85a3f;
}

@media (max-width: 640px) {
  .newsletter-cta { padding: 3.5rem 1rem 4rem; }
}

/* ── Articles connexes (auto, fin d'article) ─────────────────────────── */
.related-articles {
  padding: 4rem 1rem 5rem;
  background: rgba(201, 168, 76, 0.04);
  border-top: 1px solid rgba(201, 168, 76, 0.15);
}
.related-articles .eyebrow {
  margin: 0;
  letter-spacing: .14em;
}
.related-articles-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -.005em;
  margin: .6rem 0 2.5rem;
  max-width: 26ch;
}

.related-articles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}

.related-article-card { height: 100%; }

.related-article-link {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  height: 100%;
  transition: opacity .2s, transform .2s;
}
.related-article-link:hover {
  opacity: .85;
  transform: translateY(-2px);
}

.related-article-visual {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: 4px;
  background-color: var(--color-warm, #e4dcd4);
  background-size: cover;
  background-position: center;
  overflow: hidden;
  margin-bottom: 1rem;
}
.related-article-cat {
  position: absolute;
  bottom: .65rem;
  left: .65rem;
  font-size: .65rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, .9);
  color: #1a1a1a;
  padding: .22rem .55rem;
  border-radius: 2px;
}

.related-article-body {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.related-article-titre {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.05rem, 1.8vw, 1.25rem);
  font-weight: 400;
  line-height: 1.3;
  margin: 0 0 .8rem;
  letter-spacing: -.005em;
}
.related-article-body .text-link {
  margin-top: auto;
  font-size: .82rem;
  border-bottom: none;
  padding-bottom: 0;
}

@media (max-width: 880px) {
  .related-articles-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .related-articles { padding: 3rem 1rem 3.5rem; }
}

/* ── Highlights accueil (3 colonnes : adresses, dimanche, tarifs) ────────── */
.home-highlights {
  padding: 4.5rem 0;
  background: #fbf8f2;
  border-top: 1px solid rgba(0, 0, 0, .05);
  border-bottom: 1px solid rgba(0, 0, 0, .05);
}

.home-highlights-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem;
  align-items: start;
}

.home-highlight {
  display: flex;
  flex-direction: column;
  gap: .55rem;
}

.home-highlight .eyebrow {
  margin: 0;
  letter-spacing: .14em;
  font-size: .72rem;
}

.home-highlight h3 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.3rem, 2vw, 1.55rem);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: -.005em;
  margin: .15rem 0 .25rem;
  max-width: 22ch;
}

.home-highlight p {
  margin: 0;
  font-size: .92rem;
  line-height: 1.6;
  opacity: .78;
}

.home-highlight .text-link {
  margin-top: .4rem;
  font-size: .82rem;
}

@media (max-width: 880px) {
  .home-highlights-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
