:root{
  --bg:#0f0f10;
  --bg-2:#151517;
  --text:#f3f3f3;
  --muted:#c9c9c9;
  --accent:#d9c2a3;   /* champagne */
  --accent-2:#b79a7b;
  --card:#1c1c1f;
  --stroke:#2a2a2e;
  --radius:14px;
  --shadow:0 10px 30px rgba(0,0,0,.25);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.6}
img{max-width:100%;display:block;border-radius:12px}
a{color:var(--accent)}
.container{width:min(1100px,92%);margin:0 auto}

.site-header{position:sticky;top:0;z-index:50;background:rgba(15,15,16,.8);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--stroke)}
.header-inner{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0}
.brand{display:flex;gap:.7rem;align-items:center;text-decoration:none;color:var(--text)}
.logo{width:42px;height:auto}
.brand-text{font-family:"Playfair Display",serif;font-size:1.1rem;letter-spacing:.06em}

.main-nav ul{display:flex;gap:1rem;list-style:none;margin:0;padding:0}
.main-nav a{text-decoration:none;color:var(--text);padding:.4rem .6rem;border-radius:8px}
.main-nav a:hover{background:var(--stroke)}
.nav-toggle{display:none;background:none;border:1px solid var(--stroke);border-radius:10px;color:var(--text);padding:.4rem .6rem}

.hero{padding:3.5rem 0;background:linear-gradient(180deg, #121214, #0f0f10)}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
.hero-text h1{font-family:"Playfair Display",serif;font-size:clamp(1.8rem,4vw,3rem);margin:.2rem 0}
.cta-group{display:flex;gap:.8rem;margin-top:1rem}
.btn{display:inline-block;padding:.8rem 1rem;border-radius:12px;text-decoration:none;border:1px solid transparent;cursor:pointer;font-weight:600}
.btn-primary{background:var(--accent);color:#1a1a1a}
.btn-primary:hover{background:var(--accent-2)}
.btn-outline{border-color:var(--accent);color:var(--text)}
.btn-outline:hover{background:#1b1b1d}
.btn-ghost{border-color:var(--stroke);color:var(--text);background:transparent}
.section{padding:3rem 0;border-top:1px solid var(--stroke)}
.section.alt{background:var(--bg-2)}
.section-title{font-family:"Playfair Display",serif;font-size:clamp(1.4rem,2.6vw,2rem);margin:.2rem 0 1.2rem}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.card{background:var(--card);padding:1rem;border-radius:var(--radius);border:1px solid var(--stroke);box-shadow:var(--shadow);min-height:120px;display:flex;flex-direction:column;justify-content:space-between}
.card h4{margin:.1rem 0 .6rem}
.price{font-weight:700;color:var(--accent)}
.note{color:var(--muted);margin-top:.6rem}

.booking-form{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow)}
.booking-form .grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
label{display:flex;flex-direction:column;gap:.4rem;font-size:.95rem}
input,select,textarea{width:100%;padding:.75rem;border-radius:12px;border:1px solid var(--stroke);background:#0e0e10;color:var(--text)}
input[type="checkbox"]{width:auto;accent-color:var(--accent)}
.summary{margin-top:1rem;padding:1rem;border:1px dashed var(--stroke);border-radius:12px;background:#121214}
.total{font-weight:700;color:var(--accent)}
.actions{display:flex;gap:.6rem;margin-top:1rem}
.small{color:var(--muted);font-size:.85rem}

.masonry{columns:3 260px;column-gap:1rem}
.masonry img{width:100%;margin:0 0 1rem;border:1px solid var(--stroke)}

.reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.review{background:var(--card);padding:1rem;border-radius:var(--radius);border:1px solid var(--stroke)}
.review blockquote{margin:0 0 .6rem}

.about{display:grid;grid-template-columns:1.1fr .9fr;gap:1.2rem;align-items:center}
.ticks{padding-left:1.1rem}
.ticks li{margin:.3rem 0}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.map-placeholder{display:grid;place-items:center;background:#101012;border:1px dashed var(--stroke);border-radius:12px;min-height:280px}
.hours{list-style:none;padding:0;margin:.6rem 0}
.legal{margin-top:1.5rem;color:var(--muted);text-align:center}

.whatsapp{position:fixed;right:1rem;bottom:1rem;background:#22c55e;color:#101010;padding:.8rem 1rem;border-radius:999px;text-decoration:none;font-weight:700;box-shadow:var(--shadow)}
.sticky-cta{position:fixed;left:50%;transform:translateX(-50%);bottom:1rem;background:var(--accent);color:#111;padding:.7rem 1.1rem;border-radius:999px;text-decoration:none;font-weight:700;border:1px solid #0003}

@media (max-width: 960px){
  .hero-inner{grid-template-columns:1fr}
  .about{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .main-nav ul{display:none}
  .nav-toggle{display:block}
  .main-nav[aria-expanded="true"] ul{display:flex;flex-direction:column;position:absolute;right:.6rem;top:56px;background:#101012;border:1px solid var(--stroke);border-radius:12px;padding:.6rem}
  .main-nav ul li a{padding:.5rem .8rem}
}
/* Section titres */
section {
  padding: 50px 20px;
  margin: 20px auto;
  max-width: 900px;
}

section h2 {
  font-size: 2rem;
  margin-bottom: 20px;
  text-align: center;
}

/* FAQ */
details {
  margin: 10px 0;
  padding: 10px;
  border: 1px solid #d4b483;
  border-radius: 8px;
  background: #080505;
  cursor: pointer;
}

details summary {
  font-weight: bold;
}

/* Blog */
#blog article {
  margin: 20px 0;
  padding: 15px;
  border-left: 4px solid #d4b483;
  background: hsl(0, 11%, 2%);
  border-radius: 8px;
}
/* === MODAL RÉSERVATION (AJOUT) === */
.gh-modal{position:fixed;inset:0;display:none;z-index:1000}
.gh-modal[aria-hidden="false"]{display:block}
.gh-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px)}
.gh-modal__card{
  position:relative;z-index:1;
  width:min(820px,92%);margin:6vh auto;padding:1.2rem 1.2rem 1.4rem;
  background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow);
}
.gh-modal__close{
  position:absolute;right:.6rem;top:.4rem;
  background:transparent;border:1px solid var(--stroke);border-radius:10px;
  color:var(--text);font-size:1.2rem;line-height:1;padding:.2rem .5rem;cursor:pointer;
}
.gh-modal h3{font-family:"Playfair Display",serif;margin:.2rem 0 0.6rem}
.gh-modal h4{margin:1rem 0 .4rem;color:var(--accent)}
.gh-modal__content p{margin:.5rem 0}
.gh-list{margin:.4rem 0 1rem 1.1rem}
.gh-list li{margin:.3rem 0}
.gh-next{margin-top:.8rem}

.gh-links-grid{
  display:grid;gap:.6rem;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  margin:.8rem 0 1rem;
}
.gh-link{
  display:block;text-decoration:none;padding:.8rem 1rem;border-radius:12px;
  background:#121214;border:1px solid var(--stroke);color:var(--text);font-weight:600;
}
.gh-link:hover{border-color:var(--accent);box-shadow:0 0 0 2px rgba(217,194,163,.12) inset}
.gh-step[hidden]{display:none}
/* === MODAL RÉSERVATION (uniformisé) === */
.gh-modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 1000;
  font-family: Poppins, sans-serif;
}
.gh-modal[aria-hidden="false"] { display: block; }

.gh-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.6);
  backdrop-filter: blur(4px);
}

.gh-modal__card {
  position: relative;
  z-index: 1;
  width: min(820px,92%);
  margin: 8vh auto;
  padding: 1.5rem 1.2rem 2rem;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  color: var(--text);
  font-family: Poppins, sans-serif;
}

.gh-modal__close {
  position: absolute;
  right: .6rem;
  top: .6rem;
  background: transparent;
  border: 1px solid var(--stroke);
  border-radius: 10px;
  color: var(--text);
  font-size: 1.2rem;
  line-height: 1;
  padding: .2rem .5rem;
  cursor: pointer;
}

.gh-modal h3 {
  font-size: 1.4rem;
  margin: .2rem 0 1rem;
  color: var(--accent); /* doré */
  font-weight: 600;
}
.gh-modal h4 {
  margin: 1rem 0 .5rem;
  color: var(--accent); /* doré */
  font-weight: 600;
}
.gh-modal__content p {
  margin: .6rem 0;
  font-size: 1rem;
  color: var(--text);
}
.gh-list {
  margin: .4rem 0 1rem 1.2rem;
  padding: 0;
}
.gh-list li {
  margin: .4rem 0;
  color: var(--text);
}

/* Bouton "J’ai compris" — identique au bouton principal */
#prebookAgree {
  margin-top: 1rem;
  display: inline-block;
  padding: .9rem 1.2rem;
  border-radius: 12px;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  font-weight: 600;
  background: var(--accent);  /* doré */
  color: #111;
  transition: background .2s;
}
#prebookAgree:hover {
  background: var(--accent-2);
}
/* Uniformiser les titres de section en Playfair Display blanc */
#faq h2,
#blog h2,
#policy h2,
#about h2 {
  font-family: "Playfair Display", serif !important;
  color: var(--text); /* blanc */
  font-weight: 600;
}
.map-placeholder {
  display: grid;
  place-items: center;
  background: var(--bg-2); /* #151517 */
  border-radius: 12px;
  min-height: 280px;
  border: none; /* supprime le contour en pointillés */
}
/* conteneur plein écran du modal */
.gh-modal[aria-hidden="false"] {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* carte du modal : scroll interne sur mobile */
.gh-modal__card {
  max-height: 85vh;           /* visible sans dépasser l’écran */
  overflow-y: auto;           /* scroll interne */
  -webkit-overflow-scrolling: touch;
}

/* option : désactiver le scroll du body via une classe (plus propre) */
body.modal-open { overflow: hidden; }
/* Masquer les widgets de support */
#intercom-container,
.intercom-lightweight-app,
.crisp-client,
.tawk-min-container,
[id*="zendesk"],
[id*="chat"],
[class*="chat-widget"],
[class*="support-widget"],
.help-widget,
.support-bubble {
  display: none !important;
  visibility: hidden !important;
}

/* Masquer spécifiquement le point d'interrogation bleu */
.help-button,
.support-button,
[aria-label*="help"],
[aria-label*="support"],
.floating-help {
  display: none !important;
}
.gal-img{
  width: 100% !important;
  height: 350px !important;   /* ajuste 300–400 si tu veux */
  object-fit: cover;
  display: block;
  border-radius: 12px;
}
/* fallback si vieux Safari ne gère pas bien la hauteur forcée */
@supports (aspect-ratio: 1){
  .gal-img{ height: auto; aspect-ratio: 4/5; } /* option : ratio 4:5 harmonisé */
}
/* Masquer les éléments PWA sur mobile */
@media (max-width: 768px) {
  .pwa-install-prompt,
  .ios-pwa-prompt,
  [data-pwa],
  .add-to-homescreen,
  .a2hs-prompt {
    display: none !important;
  }
}
.hero-media {
  display: none;
}

}
.btn-link {
  display: inline-block;
  padding: 8px 16px;
  background-color: #d9c2a3;
  color: #111;
  text-decoration: none;
  border-radius: 6px;
  font-weight: 600;
}

.btn-link:hover {
  background-color: #d9c2a3;
}
[data-testid="smsReminderNumber"] + div {
  display: none !important;
}

