:root{
  --bg:#fff;
  --text:#111827;
  --muted:#6b7280;
  --border:#e5e7eb;
  --chip:#f3f4f6;
  --primary:#ff385c;
  --shadow:0 10px 30px rgba(17,24,39,.08);
  --radius:16px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--text);background:var(--bg);line-height:1.5}
img{display:block;max-width:100%}
button{font:inherit}
a{color:inherit;text-decoration:none}

.container{max-width:1120px;margin:0 auto;padding:0 16px}
.noScroll{overflow:hidden}

.skip{
  position:absolute;left:-999px;top:10px;
  background:#111827;color:#fff;padding:8px 12px;border-radius:12px;z-index:999;
}
.skip:focus{left:10px}

/* Topbar */
.topbar{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--border)}
.topbar__inner{display:flex;align-items:center;gap:14px;padding:12px 0}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.brand__logo{width:130px;height:130px;border-radius:12px;object-fit:cover;border:1px solid var(--border)}
.brand__title{font-weight:800; font-size:1.75rem}
.brand__subtitle{color:var(--muted);font-size:.9rem}
.topbar__nav{margin-left:auto;display:flex;gap:14px;flex-wrap:wrap}
.topbar__nav a{color:#374151;font-size:.95rem}
.topbar__nav a:hover{text-decoration:underline}
.topbar__actions{display:flex;gap:10px;align-items:center}

/* Buttons */
.btn{border:1px solid var(--border);background:#fff;border-radius:999px;padding:10px 14px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn--primary{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:800}
.btn--primary:hover{filter:brightness(.96)}
.btn--outline{background:#fff;border-color:var(--border);font-weight:700}
.btn--outline:hover{background:#f8fafc}
.btn--ghost{border-color:transparent;background:#fff;font-weight:800}
.btn--ghost:hover{background:#f8fafc}
.btn--full{width:100%}

.btn--chip{background:rgba(17,24,39,.78);border-color:transparent;color:#fff;padding:10px 12px}
.btn--chip:hover{background:rgba(17,24,39,.88)}
.btn--chip2{background:var(--chip);border-color:transparent;color:#111827;font-weight:800;padding:10px 12px}
.btn--chip2:hover{filter:brightness(.98)}
.btn--chip2.isActive{outline:2px solid rgba(17,24,39,.15)}

/* Hero */
.hero{padding:18px 0}
.heroGrid{position:relative;display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:10px}
.heroGrid__big{grid-column:1/2;grid-row:1/3}
.heroGrid__big img,.heroGrid__small img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius)}
.heroGrid__more{position:absolute;right:14px;bottom:14px}

/* Réduction des photos de présentation */
.heroGrid{
  max-height: 360px;
  overflow: hidden;
}

.heroGrid img{
  max-height: 360px;
  object-fit: cover;
}

@media (max-width: 768px){
  .heroGrid{
    max-height: 240px;
  }
  .heroGrid img{
    max-height: 240px;
  }
}

/* Layout */
.layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:40px;padding:10px 0 40px}
.left .block{padding:0}
.h1{font-size:1.45rem;margin:0 0 8px}
.h2{font-size:1.15rem;margin:0 0 10px}
.meta{display:flex;gap:10px;flex-wrap:wrap;color:#374151;font-size:.95rem}
.ratingRow{display:flex;align-items:center;gap:8px;margin-top:10px}
.badge{background:#111827;color:#fff;border-radius:999px;padding:4px 10px;font-weight:800;font-size:.9rem}
.muted{color:var(--muted)}
.small{font-size:.92rem}
.tiny{font-size:.82rem}
.center{text-align:center}
hr.sep{border:0;border-top:1px solid var(--border);margin:22px 0}
.bullets{margin:10px 0 0;padding-left:18px}
.bullets li{margin:6px 0}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.card{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 1px 0 rgba(0,0,0,.02);padding:0;cursor:pointer}
.card img{height:140px;width:100%;object-fit:cover}
.card__body{padding:10px 12px}
.card__title{font-weight:800}
.card__text{color:var(--muted);font-size:.9rem}

/* Amenities */
.amenities{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.amenity{border:1px solid var(--border);border-radius:14px;padding:10px 12px;background:#fff}
.more{margin-top:12px}
.more summary{cursor:pointer;font-weight:800}
.miniGallery{margin-top:12px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.mini{border:0;background:transparent;padding:0;cursor:pointer}
.mini img{width:100%;height:78px;object-fit:cover;border-radius:14px;border:1px solid var(--border)}

/* Gallery */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0 12px}
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.gallery__item{border:0;background:transparent;padding:0;cursor:pointer}
.gallery__item img{width:100%;height:150px;object-fit:cover;border-radius:16px;border:1px solid var(--border)}

/* Booking card */
.right{position:relative}
.bookCard{position:sticky;top:86px;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:16px;background:#fff}
.bookCard__head{display:grid;gap:4px}
.bookCard__title{font-weight:900;font-size:1.05rem}
.bookCard__body{display:grid;gap:10px;margin-top:12px}
.bookCard__divider{height:1px;background:var(--border);margin:14px 0}
.noteTitle{font-weight:900;margin-bottom:6px}

/* Footer */
.footer{margin:28px 0 10px}

/* Image buttons + Lightbox */
.imgBtn{border:0;background:transparent;padding:0;cursor:zoom-in}
.lightbox{position:fixed;inset:0;display:none;z-index:100}
.lightbox.isOpen{display:block}
.lightbox__backdrop{position:absolute;inset:0;background:rgba(17,24,39,.7)}
.lightbox__dialog{
  position:relative;max-width:min(980px,92vw);margin:6vh auto 0;background:#fff;border-radius:18px;overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.35)
}
.lightbox__dialog img{width:100%;max-height:72vh;object-fit:contain;background:#0b1220}
.lightbox__caption{padding:10px 14px;color:#334155}
.lightbox__close{
  position:absolute;top:10px;right:10px;width:40px;height:40px;border-radius:999px;border:1px solid rgba(255,255,255,.35);
  background:rgba(17,24,39,.5);color:#fff;cursor:pointer
}

/* Beds24 modal */
.modal{position:fixed;inset:0;display:none;z-index:200}
.modal.isOpen{display:block}
.modal__backdrop{position:absolute;inset:0;background:rgba(17,24,39,.7)}
.modal__dialog{
  position:relative;width:min(1100px,96vw);height:min(900px,92vh);margin:4vh auto 0;background:#fff;border-radius:18px;
  overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.35);display:grid;grid-template-rows:auto 1fr;
}
.modal__topbar{
  display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid var(--border);background:#fff
}
.modal__title{font-weight:900}
.modal__link{font-weight:800;color:#2563eb}
.modal__link:hover{text-decoration:underline}
.modal__close{
  width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:#fff;cursor:pointer
}
#beds24Frame{width:100%;height:100%;border:0}

/* Reservation page */
.page{padding:18px 0 40px}
.pageCard{border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);background:#fff;overflow:hidden}
.pageCard__head{padding:14px 14px 0}
.iframeWrap{height:min(1100px,80vh);margin-top:12px}
.iframeWrap iframe{width:100%;height:100%;border:0}

/* Responsive */
@media (max-width: 980px){
  .layout{grid-template-columns:1fr;gap:18px}
  .bookCard{position:relative;top:auto}
  .heroGrid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .heroGrid__big{grid-column:1/3;grid-row:auto}
}
@media (max-width: 560px){
  .cards{grid-template-columns:1fr}
  .amenities{grid-template-columns:1fr}
  .miniGallery{grid-template-columns:repeat(3,1fr)}
  .topbar__nav{display:none}
}


/* Promo block */
.promo{
  margin-top: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fff;
  display: grid;
  gap: 10px;
}
.promo__line{ margin: 0; }

/* Content modal */
.modal__dialog--content{
  width: min(900px, 96vw);
  height: min(860px, 92vh);
}
.modal__content{
  padding: 14px;
  overflow: auto;
}
.modal__content h3{
  margin: 16px 0 8px;
  font-size: 1.05rem;
}
.modal__content h4{
  margin: 14px 0 6px;
  font-size: 1rem;
}
.modal__content ul{
  margin: 8px 0 0;
  padding-left: 18px;
}
.modal__content li{ margin: 6px 0; }
.leadline{ margin-top: 0; }
.callout{
  margin: 12px 0;
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--chip);
}
