:root{--black:#080808;--cream:#f4eee6;--gold:#c8a46b;--red:#b5121b;--muted:#b8aea3;--line:rgba(200,164,107,.35);--card:rgba(255,255,255,.06)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:#090909;color:var(--cream);font-family:Inter,sans-serif}a{text-decoration:none;color:inherit}.site-header{position:fixed;top:0;width:100%;z-index:50;padding:18px 5vw;transition:.3s}.site-header.scrolled{background:rgba(0,0,0,.86);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);padding:10px 5vw}.navbar{display:flex;align-items:center;justify-content:space-between;gap:22px}.brand-logo{width:220px;max-width:45vw}.nav-links{display:flex;gap:24px;text-transform:uppercase;letter-spacing:1.8px;font-size:12px}.mobile-menu-btn{display:none;background:#111;color:var(--cream);border:1px solid var(--line);border-radius:999px;padding:8px 13px}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:14px 24px;text-transform:uppercase;letter-spacing:1.5px;font-size:13px;font-weight:800}.btn-primary{background:linear-gradient(135deg,var(--gold),#a45c40);color:#080808}.btn-secondary{border:1px solid var(--gold);color:var(--cream);background:rgba(0,0,0,.25)}.hero{min-height:100vh;background:url('assets/hero-vistrot-sports.webp') center/cover no-repeat;position:relative;display:flex;align-items:center;padding:150px 7vw 90px}.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,.62),rgba(0,0,0,.22)),radial-gradient(circle at 20% 45%,rgba(181,18,27,.28),transparent 38%)}.hero-content{position:relative;z-index:2;max-width:800px}.hero-logo{width:min(680px,92vw);margin-bottom:26px;filter:drop-shadow(0 18px 25px #000)}.eyebrow{color:var(--gold);text-transform:uppercase;letter-spacing:4px;font-size:13px;font-weight:800;margin-bottom:18px}h1,h2,h3{font-family:'Cormorant Garamond',serif}h1{font-size:clamp(46px,7vw,96px);line-height:.95;margin-bottom:24px}h2{font-size:clamp(40px,5vw,76px);line-height:1;margin-bottom:22px}.hero-text,.section p{font-size:18px;line-height:1.8;color:#e5d8c8}.hero-buttons,.contact-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}.hero-card{position:absolute;right:7vw;bottom:8vh;z-index:2;width:230px;border:1px solid var(--gold);border-radius:24px;background:rgba(0,0,0,.52);padding:26px;box-shadow:0 25px 70px #000}.hero-card strong{display:block;color:var(--gold);font-size:42px;font-family:'Cormorant Garamond',serif}.hero-card span{color:#fff;line-height:1.6}.intro-strip{padding:34px 8vw;text-align:center;background:#141414;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-family:'Cormorant Garamond',serif;font-size:clamp(24px,3vw,36px);color:var(--gold)}.section{padding:100px 7vw}.zones-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px}.zones-grid article,.contact-card{background:var(--card);border:1px solid var(--line);border-radius:28px;padding:30px}.zones-grid h3,.contact-card h3{font-size:34px;color:var(--gold);margin-bottom:12px}.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.photo-card{min-height:430px;border-radius:30px;border:1px solid var(--line);background:url('assets/hero-vistrot-sports.webp') center/cover no-repeat;box-shadow:0 30px 90px rgba(0,0,0,.5)}.text-link{color:var(--gold);font-weight:800}.menu-section{text-align:center;background:#111}.section-lead{max-width:780px;margin:0 auto 38px}.menu-img{width:min(100%,1055px);border-radius:28px;border:1px solid var(--line);box-shadow:0 30px 90px rgba(0,0,0,.55)}.contact-section{background:#141414;display:grid;grid-template-columns:1.2fr .8fr;gap:40px}.footer{display:flex;justify-content:space-between;gap:20px;padding:30px 7vw;border-top:1px solid var(--line);color:var(--muted)}@media(max-width:980px){.nav-links{display:none;position:absolute;top:74px;right:5vw;background:rgba(0,0,0,.95);border:1px solid var(--line);border-radius:18px;padding:20px;flex-direction:column}.nav-links.open{display:flex}.mobile-menu-btn{display:block}.nav-actions{display:none}.hero-card{position:relative;right:auto;bottom:auto;margin-top:30px}.hero{display:block}.zones-grid,.split,.contact-section{grid-template-columns:1fr}.section{padding:76px 6vw}.footer{flex-direction:column}.brand-logo{width:180px}}
/* SECTION OÙ NOUS TROUVER */
.location-section {
  background:
    radial-gradient(circle at 20% 0%, rgba(200,164,107,.14), transparent 34%),
    radial-gradient(circle at 80% 10%, rgba(181,18,27,.12), transparent 32%),
    #0d0d0d;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.location-head {
  text-align: center;
  max-width: 920px;
  margin: 0 auto 46px;
}

.location-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr);
  gap: 34px;
  align-items: stretch;
}

.location-map-card,
.location-info-card {
  border: 1px solid var(--line);
  border-radius: 30px;
  overflow: hidden;
  background: rgba(255,255,255,.055);
  box-shadow: 0 30px 90px rgba(0,0,0,.45);
}

.location-map-card img,
.location-map-card iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 430px;
  object-fit: cover;
  border: 0;
}

.location-info-card {
  padding: 38px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.location-info-card h3 {
  color: var(--gold);
  font-size: 42px;
  margin-bottom: 16px;
}

.location-info-card p,
.contact-phone {
  color: #e5d8c8;
  font-size: 18px;
  line-height: 1.8;
}

.contact-lines {
  display: grid;
  gap: 14px;
  margin-top: 24px;
}

.contact-lines a {
  display: flex;
  align-items: center;
  min-height: 54px;
  padding: 13px 20px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.28);
  color: var(--cream);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: .25s ease;
}

.contact-lines a:hover {
  border-color: var(--gold);
  color: var(--gold);
  transform: translateY(-2px);
}

.contact-phone a {
  color: var(--gold);
  font-weight: 800;
}

.location-google-card {
  min-height: 430px;
}

.location-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.location-actions .btn {
  width: 100%;
}

.copy-map-btn {
  cursor: pointer;
  font-family: inherit;
}

.location-note {
  min-height: 24px;
  margin-top: 18px;
  color: var(--gold) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}


@media (max-width: 980px) {
  .location-grid {
    grid-template-columns: 1fr;
  }

  .location-map-card img,
  .location-map-card iframe {
    min-height: 320px;
  }
}

/* === Correctifs Vistrot Sports — classes utilisées par /sports/index.html === */
.hero-badge {
  position: absolute;
  right: 7vw;
  bottom: 8vh;
  z-index: 2;
  width: 190px;
  height: 190px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--gold);
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  background: rgba(0,0,0,.34);
  backdrop-filter: blur(8px);
  box-shadow: 0 25px 70px rgba(0,0,0,.45);
}

.hero-badge span,
.hero-badge strong { display: block; }

.hero-badge strong {
  font-family: 'Cormorant Garamond', serif;
  color: var(--cream);
  font-size: 28px;
  line-height: 1;
  margin-top: 6px;
  text-transform: none;
  letter-spacing: .5px;
}

.section-image {
  min-height: 520px;
  border-radius: 30px;
  border: 1px solid var(--line);
  background-size: cover;
  background-position: center;
  box-shadow: 0 30px 90px rgba(0,0,0,.5);
}

.image-ambiance {
  background-image: url('assets/ambiance-vistrot-sports.png');
}

.image-salon {
  background-image: url('assets/vistrot-sports-salon.png');
}

.cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  margin-top: 36px;
}

.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 30px;
  backdrop-filter: blur(12px);
  transition: .3s ease;
}

.card:hover {
  transform: translateY(-6px);
  border-color: var(--gold);
}

.card h3 {
  font-size: 34px;
  color: var(--gold);
  margin-bottom: 12px;
}

.feature-dark {
  background:
    radial-gradient(circle at 78% 20%, rgba(181,18,27,.14), transparent 34%),
    #101010;
}

@media(max-width:980px){
  .hero-badge{
    position: relative;
    right: auto;
    bottom: auto;
    margin-top: 34px;
    width: 160px;
    height: 160px;
  }
  .hero{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;}
  .cards{grid-template-columns:1fr;}
  .section-image{min-height:340px;}
}


/* POPUP RÉSERVATION BIENTÔT DISPONIBLE */
body.modal-open {
  overflow: hidden;
}

.reservation-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 22px;
}

.reservation-modal.open {
  display: flex;
}

.reservation-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(8px);
}

.reservation-modal-dialog {
  position: relative;
  z-index: 1;
  width: min(620px, 100%);
  border: 1px solid var(--line);
  border-radius: 32px;
  padding: 42px;
  background:
    radial-gradient(circle at 20% 0%, rgba(200,164,107,.18), transparent 34%),
    radial-gradient(circle at 86% 20%, rgba(181,18,27,.16), transparent 36%),
    #101010;
  box-shadow: 0 30px 100px rgba(0,0,0,.72);
  text-align: center;
}

.reservation-modal-close {
  position: absolute;
  top: 16px;
  right: 18px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.35);
  color: var(--cream);
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
}

.reservation-modal-dialog h2 {
  font-size: clamp(34px, 5vw, 58px);
  line-height: 1;
  margin-bottom: 20px;
}

.reservation-modal-dialog p {
  color: #e5d8c8;
  font-size: 18px;
  line-height: 1.75;
}

.reservation-modal-actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 30px;
}

.reservation-modal-actions .btn {
  border: 0;
  cursor: pointer;
  font-family: inherit;
}

@media(max-width:640px) {
  .reservation-modal {
    padding: 14px;
  }

  .reservation-modal-dialog {
    padding: 34px 20px 24px;
    border-radius: 24px;
  }

  .reservation-modal-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .reservation-modal-actions .btn {
    width: 100%;
  }
}
