/* ========== THEME ========== */
:root{
  --bg:#070b16; --bg-2:#0c1427;
  --gold:#d4af37; --gold-2:#f1d67a;
  --text:#e9eef7; --muted:#9fb0cf;
  --card:#0b1120cc; --glass:rgba(12,20,39,.35);
  --stroke:#19223a; --ring:#d4af3733;
  --shadow:0 20px 50px rgba(3,8,20,.45);

  /* spacing & radius */
  --px: clamp(14px, 2.5vw, 24px);
  --radius: 14px;
}

/* ========== GLOBAL ========== */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 10% -10%, #102043 0%, transparent 70%),
    radial-gradient(800px 500px at 110% 10%, #0b1b3f 0%, transparent 60%),
    var(--bg);
  overflow-x:hidden;
  -webkit-tap-highlight-color: transparent;
}

/* Utility */
.accent{color:var(--gold)}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.9rem 1.2rem; border-radius:12px; text-decoration:none; font-weight:600;
  letter-spacing:.2px; transition:.25s; cursor:pointer; user-select:none;
}
.btn.primary{background:linear-gradient(135deg,var(--gold),var(--gold-2)); color:#0b0d16; box-shadow:0 12px 30px var(--ring)}
.btn.primary:active{transform:translateY(1px)}
.btn.ghost{border:1px solid var(--gold); color:var(--gold); background:transparent}
.btn.small{padding:.55rem .9rem; font-size:.92rem}

/* ========== HEADER / NAV ========== */
.site-header{
  position:sticky; top:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:12px var(--px);
  background:linear-gradient(180deg,#060912f2,#060912aa);
  border-bottom:1px solid #0e1832; backdrop-filter:saturate(1.2) blur(8px);
}
.brand{display:flex; align-items:center; gap:.5rem; text-decoration:none; color:var(--text); font-weight:700; letter-spacing:.2px; font-size:clamp(1rem, 2.2vw, 1.2rem)}
.logo-mark{color:var(--gold)}

.nav{display:flex; align-items:center; gap:.6rem}
.nav ul{display:flex; gap:.4rem; list-style:none; margin:0; padding:0}
.nav a{color:var(--text); text-decoration:none; padding:.7rem .8rem; border-radius:10px}
.nav a:active{background:var(--glass)}
.hide-sm{display:none}

/* Burger */
.burger{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border:1px solid var(--stroke);
  border-radius:12px; background:#08101f; cursor:pointer; position:relative;
}
.burger span{position:absolute; left:10px; right:10px; height:2px; background:var(--text); transition:.25s}
.burger span:nth-child(1){top:13px}
.burger span:nth-child(2){top:20px}
.burger span:nth-child(3){top:27px}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Drawer mobile */
#nav-links{
  position:fixed; inset:64px var(--px) auto var(--px);
  display:flex; flex-direction:column; gap:.4rem;
  background:#0a1327; border:1px solid #14203f; border-radius:16px;
  padding:10px; transform:translateY(-12px); opacity:0; pointer-events:none; transition:.22s;
}
#nav-links.open{transform:none; opacity:1; pointer-events:auto}

/* ≥ 1024px: nav inline */
@media (min-width:1024px){
  .burger{display:none}
  .hide-sm{display:inline-flex}
  #nav-links{position:static; background:transparent; border:none; padding:0; flex-direction:row; transform:none; opacity:1; pointer-events:auto}
}

/* ========== HERO ========== */
.hero{position:relative; min-height:72vh; display:grid; align-items:center}
.hero-media{position:absolute; inset:0; overflow:hidden; isolation:isolate}
.hero-media img{width:100%; height:100%; object-fit:cover; filter:contrast(1.05) saturate(1.05) brightness(.72)}
.hero-media .gradient{position:absolute; inset:0; background:
  radial-gradient(680px 360px at 12% 84%, rgba(0,0,0,.0) 0, #060912 60%),
  radial-gradient(820px 460px at 100% 10%, #051029 0, rgba(5,16,41,0) 60%)}
.hero-content{position:relative; padding:8vw var(--px); max-width:1150px}
.hero h1{font-size:clamp(2rem, 6vw, 3.4rem); margin:0 0 .35rem; line-height:1.06}
.hero p{margin:0 0 1rem; color:var(--muted); font-weight:300; font-size:clamp(.98rem, 2.8vw, 1.1rem)}
.cta-row{display:flex; gap:.7rem; flex-wrap:wrap}

/* Carousel hero (touch-friendly) */
.carousel{margin-top:22px; position:relative}
.carousel .track{
  display:grid; grid-auto-flow:column; gap:14px; overflow:auto;
  scroll-snap-type:x mandatory; padding:6px; border-radius:14px;
  -webkit-overflow-scrolling: touch;
}
.slide{scroll-snap-align:center; position:relative; width:min(86vw, 420px); border-radius:16px; overflow:hidden; border:1px solid #152444; background:#0a1226}
.slide img{width:100%; height:clamp(180px, 40vw, 240px); object-fit:cover}
.slide figcaption{position:absolute; left:10px; bottom:10px; background:rgba(7,11,22,.65); padding:.28rem .55rem; border:1px solid #223057; border-radius:8px; font-size:.85rem}
.carousel button{position:absolute; top:50%; transform:translateY(-50%); width:46px; height:46px; border-radius:12px; border:1px solid #cfcfcf3d; background:#ffffff2a; color:#fff; backdrop-filter:blur(6px); cursor:pointer; display:none}
@media (min-width:768px){ .carousel button{display:block} }

/* ========== SECTIONS / GRID ========== */
.section{padding:40px var(--px)}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:.8rem; flex-wrap:wrap}
.section h2{font-size:clamp(1.4rem, 3.4vw, 2.2rem); margin:0}
.filters{display:flex; gap:.6rem; flex-wrap:wrap}
.filters input,.filters select{
  background:#0b1326; color:var(--text); border:1px solid var(--stroke);
  border-radius:12px; padding:.8rem 1rem; outline:none; min-width:200px
}

/* Cards */
.grid{margin-top:18px; display:grid; gap:16px; grid-template-columns:1fr}
.card{
  background:linear-gradient(180deg, #0b1120, #0b1120e6);
  border:1px solid #172446; border-radius:16px; overflow:hidden;
  box-shadow:var(--shadow); transition:.2s;
}
.card:active{transform:translateY(1px)}
.card .media{position:relative}
.card .media img{width:100%; height:180px; object-fit:cover; display:block}
.badge{position:absolute; left:10px; top:10px; background:#0a1327cc; border:1px solid #1e2b4b; padding:.32rem .5rem; border-radius:8px; font-size:.78rem}
.card .body{padding:12px}
.card h3{margin:0 0 6px; font-size:1.02rem; color:#f6f8ff}
.meta{display:flex; gap:10px; color:var(--muted); font-size:.9rem}
.price{display:flex; gap:8px; align-items:center; margin:8px 0 0; flex-wrap:wrap}
.price .pill{border:1px solid #223057; background:#0a1327; color:#ced7ee; padding:.35rem .55rem; border-radius:999px; font-size:.85rem}
.card .actions{display:grid; grid-template-columns:1fr 1fr; gap:8px; padding:12px}

/* ≥ 768px : 2-3 colonnes */
@media (min-width:768px){
  .grid{grid-template-columns:repeat(2, 1fr); gap:20px}
  .card .media img{height:200px}
}
@media (min-width:1100px){
  .grid{grid-template-columns:repeat(3, 1fr)}
}

/* Note */
.note{color:#8ea3ca; margin-top:8px; font-size:.92rem}

/* ========== ABOUT / CONTACT ========== */
.about{display:grid; grid-template-columns:1fr; gap:16px}
.about-card{background:var(--card); border:1px solid var(--stroke); border-radius:16px; padding:18px}
.ticks{list-style:none; padding:0; margin:10px 0 0}
.ticks li{margin:.2rem 0; color:#cfe0ff}
.about-photo img{width:100%; height:100%; border-radius:16px; object-fit:cover; border:1px solid var(--stroke)}

@media (min-width:900px){
  .about{grid-template-columns:1.1fr .9fr; gap:24px}
}

.contact-grid{display:grid; grid-template-columns:1fr; gap:16px; align-items:start}
#contact-form label{display:block; font-size:.9rem; color:#bcd0f4}
#contact-form input,#contact-form textarea{
  width:100%; background:#0a1327; color:var(--text); border:1px solid var(--stroke);
  border-radius:12px; padding:.9rem 1rem; margin:.35rem 0 1rem; outline:none
}
.form-ok{color:#7be3a1}

@media (min-width:900px){
  .contact-grid{grid-template-columns:.8fr 1.2fr; gap:20px}
}

/* ========== FOOTER ========== */
.footer{padding:22px var(--px); border-top:1px solid #0e1832; color:#93a6c9; text-align:center; font-size:.95rem}

/* ========== DIALOGS (BOOKING & GALLERY) ========== */
dialog{border:none; border-radius:16px; padding:0; background:#0b1120; color:var(--text)}
dialog::backdrop{background:rgba(3,6,14,.7); backdrop-filter:blur(2px)}

/* Booking */
.booking{width:100%; max-width:720px}
.booking header{display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid #14203f}
.icon.close{background:none; border:1px solid #29375c; color:#a7b7db; border-radius:10px; padding:.25rem .5rem; cursor:pointer}
.bk-body{display:grid; grid-template-columns:1fr; gap:12px; padding:14px}
.bk-car{display:flex; gap:12px}
.bk-car img{width:128px; height:92px; border-radius:10px; object-fit:cover; border:1px solid #1a2749}
.bk-form label{display:block; font-size:.9rem; color:#bcd0f4; margin-bottom:.6rem}
.bk-form input,.bk-form select{width:100%; background:#0a1327; color:#fff; border:1px solid #1a2749; border-radius:10px; padding:.7rem .8rem; margin-top:.35rem; margin-bottom:.6rem}

/* Gallery */
#gallery{width:100%; max-width:980px}
.gal-header{display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-bottom:1px solid #14203f}
.gal-view{position:relative; display:grid; place-items:center; aspect-ratio:16/9; background:#050a18}
#gal-img{max-width:100%; max-height:70vh; object-fit:contain}
.gal-nav{position:absolute; top:50%; transform:translateY(-50%); width:52px; height:52px; border-radius:12px; border:1px solid #2a3a5e; background:#ffffff1f; color:#fff; cursor:pointer; backdrop-filter:blur(6px); display:none}
@media (min-width:768px){ .gal-nav{display:block} }
.gal-thumbs{display:flex; gap:10px; overflow:auto; padding:10px; border-top:1px solid #14203f; background:#0a1327}
.gal-thumbs button{border:1px solid #223057; background:#0a1327; border-radius:10px; padding:0}
.gal-thumbs img{width:90px; height:68px; object-fit:cover; display:block; border-radius:10px; opacity:.85}
.gal-thumbs .active img{outline:2px solid var(--gold); opacity:1}

/* Dialog plein écran en mobile */
@media (max-width:600px){
  dialog{width:100vw; height:100dvh; max-width:none; border-radius:0}
  .booking, #gallery{height:100%}
  .gal-view{aspect-ratio:auto; height:calc(100% - 160px)}
}

/* ========== FLOATING CTA ==========
   Respect du safe-area iOS et évite le chevauchement clavier */
.floating-cta{
  position:fixed; right:calc(12px + env(safe-area-inset-right));
  bottom:calc(12px + env(safe-area-inset-bottom));
  z-index:55;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));
  color:#0b0d16; text-decoration:none; font-weight:700;
  padding:.85rem 1.1rem; border-radius:999px; border:1px solid #e8d79c;
  box-shadow:0 18px 40px var(--ring)
}

/* ========== DESKTOP POLISH ========== */
@media (min-width:1100px){
  .hero{min-height:92vh}
  .hero-content{max-width:1150px}
  .card:hover{transform:translateY(-4px); box-shadow:0 24px 60px rgba(0,0,0,.5)}
  .card .media img{height:220px}
}
/* ===== FIX iPhone horizontal scroll (carousel) ===== */

/* 1) Le document ne s'étire jamais en largeur */
html { overflow-x: hidden; }
body { overflow-x: clip; } /* meilleur que hidden sur iOS 17+ */

/* 2) Le container du carousel clippe tout ce qui dépasse */
.hero .carousel { overflow: clip; } /* fallback auto -> hidden */
@supports not (overflow: clip) {
  .hero .carousel { overflow: hidden; }
}

/* 3) Le track ne peut pas créer de largeur > 100% */
.hero .carousel .track{
  display: flex;                 /* plus sûr que grid sur iOS */
  gap: 18px;
  padding-inline: 6px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain; /* empêche de “tirer” la page */
  max-width: 100%;
}

/* 4) Les flèches restent DANS le cadre (plus de valeurs négatives) */
.hero .carousel .car-prev { left: 8px; }
.hero .carousel .car-next { right: 8px; }

/* 5) Les slides ne dépassent jamais visuellement */
.hero .carousel .slide{
  width: clamp(260px, 86vw, 420px);
  contain: layout paint; /* évite les arrondis qui débordent */
}
.hero .carousel .slide img{ display:block; max-width:100%; }

/* Optionnel: cacher la scrollbar horizontale du track */
.hero .carousel .track::-webkit-scrollbar{ display:none; }
@media (max-width: 600px){
  .card, .hero .carousel .slide { box-shadow: none; }
}
/* ====== HERO FADE GALLERY (no horizontal overflow) ====== */
.hero-gallery{
  position:relative; margin-top:22px; border-radius:16px;
  border:1px solid #152444; background:#0a1226; overflow:hidden; /* évite tout débordement */
}
.hg-viewport{position:relative; width:100%; height:clamp(180px, 40vw, 360px)}
.hg-slide{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transition:opacity .6s ease; will-change:opacity;
}
.hg-slide.is-active{opacity:1}

/* Dots */
.hg-dots{position:absolute; left:12px; bottom:12px; display:flex; gap:8px; z-index:2}
.hg-dots .dot{
  width:10px; height:10px; border-radius:999px;
  border:1px solid var(--gold); background:transparent; opacity:.6;
}
.hg-dots .dot.is-active{background:var(--gold); opacity:1}

/* Arrows (masquées en mobile, visibles tablette+) */
.hg-ctrl button{
  position:absolute; top:50%; transform:translateY(-50%);
  width:52px; height:52px; border-radius:12px;
  border:1px solid #ffffff2e; background:#ffffff22; color:#fff;
  backdrop-filter:blur(6px); cursor:pointer; display:none;
}
.hg-prev{left:10px} .hg-next{right:10px}
@media (min-width:768px){ .hg-ctrl button{display:block} }

/* Sécurité anti-scroll latéral global (iPhone) */
html{overflow-x:hidden}
body{overflow-x:clip}
body::before { content: none !important; }

html { overflow-x: hidden; }
body {
  overflow-x: clip;
  background:
    radial-gradient(40% 70% at 85% 15%, rgba(212,175,55,.12) 0%, rgba(212,175,55,0) 55%),
    radial-gradient(70% 60% at 10% 90%, rgba(30,75,190,.2) 0%, rgba(30,75,190,0) 60%),
    linear-gradient(180deg, #070b16 0%, #0a1430 100%);
  color: #e9eef7;
}
body::before { content: none !important; }
.hero-media img { display: none; }     /* masque l’image de fond du hero */
/* ====== CENTERING PATCH ====== */
:root { --container: 1150px; }

/* Crée des gouttières fluides pour que le contenu soit centré sans wrapper */
.site-header,
.section,
.footer {
  /* centre le "contenu" visuellement tout en gardant le fond en pleine largeur */
  padding-inline: max(var(--px), calc((100vw - var(--container)) / 2));
}

/* Le bloc texte du hero : on le centre réellement */
.hero-content{
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 0; /* on évite un double padding car .hero a déjà du padding */
}

/* Les sous-blocs des sections restent bien alignés au conteneur */
.section-head,
#car-grid,
.note,
.about,
.contact-grid {
  max-width: var(--container);
  margin-inline: auto;
}

/* Optionnel : le header conserve son layout mais “s’aligne” au conteneur */
.site-header{
  /* on garde tes styles existants + cette ligne de centrage déjà ci-dessus */
  box-sizing: border-box; /* pour que le padding n’élargisse pas le sticky */
}
/* ===== ABOUT full-bleed en bas ===== */

/* On retire le padding latéral de la section pour permettre le plein écran */
.section.about{ padding-inline: 0; }

/* Ordre: la carte en premier, la photo en bas */
.about{ display:grid; grid-template-columns: 1fr; }
.about-card{ order:1; max-width: 1150px; margin-inline:auto; padding: clamp(16px, 2.5vw, 28px); }
.about-photo{ order:2; grid-column: 1 / -1; }

/* Full-bleed : la photo occupe toute la largeur du viewport */
.about-photo img{
  display:block;
  width: 100vw;
  max-width: 100vw;
  height: clamp(260px, 42vw, 560px);
  object-fit: cover;
  /* marge négative centrée pour déborder au-delà du flux */
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);

  /* On enlève le look “carte” pour un vrai plein écran */
  border: 0;
  border-radius: 0;
}

/* Desktop : on garde l'idée “carte + image dessous” (pas de 2 colonnes) */
@media (min-width: 900px){
  .about{ grid-template-columns: 1fr; }
}
.brand img {
  height: 42px;
  border-radius: 8px;
  display: block;
}
.logo-img {
  height: 100px;
  width: auto;
  border-radius: 12px;
}
