:root{
  --bg:#07130f;
  --panel:rgba(255,255,255,.06);
  --border:rgba(255,255,255,.12);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.72);
  --muted2:rgba(255,255,255,.62);
  --gold:#d7b46a;
  --gold2:rgba(215,180,106,.18);
  --green:#1f6f3d;
  --radius:18px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  background:radial-gradient(900px 500px at 20% 0%, rgba(215,180,106,.18), transparent 60%),
             radial-gradient(900px 600px at 80% 20%, rgba(31,111,61,.25), transparent 62%),
             var(--bg);
  color:var(--text);
}
img{max-width:100%;display:block}
a{color:inherit}

.container{max-width:1100px;margin:0 auto;padding:0 16px}
.section{padding:22px 0}

.muted{color:var(--muted)}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(7,19,15,.82);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08)}
.navRow{display:flex;align-items:center;gap:12px;padding:12px 0}
.brand{display:flex;flex-direction:column;text-decoration:none;line-height:1.05}
.brand b{font-size:15px}
.brand span{font-size:12px;color:var(--muted2)}
.navLinks{display:flex;gap:14px;flex:1;justify-content:center}
.navLinks a{text-decoration:none;color:rgba(255,255,255,.78);font-size:14px;padding:8px 10px;border-radius:12px}
.navLinks a:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.92)}
.actions{display:flex;gap:10px}

@media(max-width:920px){
  .navLinks{display:none}
}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  color:var(--text);text-decoration:none;font-weight:600;font-size:14px;
  cursor:pointer;
}
.btn:hover{background:rgba(255,255,255,.10)}
.btn.gold{background:var(--gold2);border-color:rgba(215,180,106,.35)}
.btn.gold:hover{background:rgba(215,180,106,.24)}
.btn.green{background:rgba(31,111,61,.18);border-color:rgba(31,111,61,.35)}
.btn.green:hover{background:rgba(31,111,61,.26)}

/* HERO */
.hero{margin-top:18px;border:1px solid var(--border);border-radius:calc(var(--radius) + 10px);overflow:hidden;background:
  linear-gradient(0deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.35) 55%, rgba(0,0,0,.10) 100%),
  url("/vitrine/hero.webp") center/cover no-repeat;
  box-shadow:0 18px 55px rgba(0,0,0,.48);
}
.heroInner{padding:24px}
.heroTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.heroActions{display:flex;gap:10px;flex-wrap:wrap}
.heroLead{margin:12px 0 0;color:rgba(255,255,255,.80);max-width:760px;line-height:1.55}
.heroMeta{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.72);font-size:14px;margin-top:8px}
.stars{color:rgba(215,180,106,.95);letter-spacing:1px}
.dot{opacity:.6}
.heroBadges{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.badge{font-size:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);padding:6px 10px;border-radius:999px;color:rgba(255,255,255,.82)}

.bookingBar{margin-top:16px;display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:10px;
  background:rgba(7,19,15,.55);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:12px;backdrop-filter:blur(10px)}
.bookingField{display:flex;flex-direction:column;gap:6px}
.bookingField label{font-size:12px;color:rgba(255,255,255,.72)}
.bookingField input,.bookingField select{height:38px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);color:rgba(255,255,255,.92);padding:0 10px;outline:none}
.bookingField input:focus,.bookingField select:focus{border-color:rgba(215,180,106,.45)}
@media(max-width:920px){
  .bookingBar{grid-template-columns:1fr;}
}

/* CARDS & GRIDS */
.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:920px){
  .grid2,.grid3{grid-template-columns:1fr}
}

.sectionHead{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}
.sectionHead h2{margin:0}
.sectionHead p{margin:6px 0 0;color:var(--muted)}

/* PROMO */
.promo{display:grid;grid-template-columns:1.1fr .9fr;gap:14px;align-items:stretch}
.promoTitle{margin:0 0 8px;font-size:22px}
.promo img{width:100%;height:320px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border)}
.promoCtas{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
@media(max-width:920px){.promo{grid-template-columns:1fr}.promo img{height:240px}}

/* Mini hero for inner pages */
.pageHero{margin-top:18px;border:1px solid var(--border);border-radius:calc(var(--radius) + 10px);overflow:hidden;background:
  linear-gradient(0deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.36) 50%, rgba(0,0,0,.10) 100%),
  url("/vitrine/hero.webp") center/cover no-repeat;box-shadow:0 18px 55px rgba(0,0,0,.48)}
.pageHeroInner{padding:22px;min-height:180px;display:flex;align-items:flex-end}
.pageHero h1{margin:0;font-size:30px}
.pageHero p{margin:8px 0 0;color:rgba(255,255,255,.72);max-width:760px}

.pageTitle{margin:22px 0 8px;font-size:30px}
.pageIntro{margin:0 0 16px;color:var(--muted);max-width:780px}

.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0}
.kpi{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:14px}
.kpi b{display:block}
.kpi span{display:block;margin-top:6px;color:var(--muted);font-size:14px}
@media(max-width:920px){.kpis{grid-template-columns:1fr 1fr}}

.listCards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:920px){.listCards{grid-template-columns:1fr}}
.iconCard{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:16px}
.iconRow{display:flex;gap:10px;align-items:flex-start}
.iconDot{width:36px;height:36px;border-radius:12px;border:1px solid rgba(215,180,106,.35);background:rgba(215,180,106,.10);display:flex;align-items:center;justify-content:center;font-weight:700;color:rgba(215,180,106,.95)}
.iconCard h3{margin:0 0 6px;font-size:16px}
.iconCard p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}

.notice{background:rgba(31,111,61,.14);border:1px solid rgba(31,111,61,.35);border-radius:18px;padding:14px}

.split{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;align-items:start}
@media(max-width:920px){.split{grid-template-columns:1fr}}

/* Rooms page */
.twoCol{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;align-items:start}
@media(max-width:920px){.twoCol{grid-template-columns:1fr}}

.chips{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 16px}
.chip{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);text-decoration:none;color:rgba(255,255,255,.80);font-size:13px;font-weight:600}
.chip:hover{background:rgba(255,255,255,.10)}
.chip.is-active{background:rgba(215,180,106,.20);border-color:rgba(215,180,106,.40);color:rgba(255,255,255,.92)}

.gridMedia{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:920px){.gridMedia{grid-template-columns:1fr}}
.mediaItem{margin:0;border:1px solid var(--border);border-radius:18px;background:var(--panel);overflow:hidden}
.mediaItem img,.mediaItem video{width:100%;height:240px;object-fit:cover;display:block}
.mediaItem figcaption{padding:10px 12px;color:var(--muted);font-size:14px}

.sideCard{background:rgba(7,19,15,.45);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:16px;backdrop-filter:blur(10px)}
.sideTitle{font-weight:800;font-size:16px}
.sideDivider{height:1px;background:rgba(255,255,255,.12);margin:14px 0}
.sideList{display:flex;flex-direction:column;gap:10px}
.sideRow{display:flex;gap:10px;align-items:flex-start;color:rgba(255,255,255,.82)}
.sideRow span{color:rgba(215,180,106,.95);font-weight:900}
.stickySide{position:sticky;top:92px}

/* Map */
.mapCard{padding:0;overflow:hidden}
.mapCard iframe{width:100%;height:380px;border:0;display:block}

/* FOOTER */
.footer{border-top:1px solid rgba(255,255,255,.08);margin-top:30px;padding:24px 0;background:rgba(0,0,0,.10)}
.footerGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.footerTitle{font-weight:800;margin-bottom:8px}
.footerLink{text-decoration:none;color:rgba(255,255,255,.80)}
.footerLink:hover{color:rgba(255,255,255,.95);text-decoration:underline}
.footerBottom{margin-top:14px;color:rgba(255,255,255,.55);font-size:13px}
@media(max-width:920px){.footerGrid{grid-template-columns:1fr}}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery a{display:block}
.gallery img{width:100%;height:170px;object-fit:cover;border-radius:16px;border:1px solid rgba(255,255,255,.12)}
@media(max-width:920px){.gallery{grid-template-columns:1fr 1fr}.gallery img{height:150px}}

/* Reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:920px){.reviews{grid-template-columns:1fr}}
.reviewCard{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:16px}
.reviewTop{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.reviewStars{color:rgba(215,180,106,.95);font-weight:900;letter-spacing:1px}
.reviewName{color:rgba(255,255,255,.90);font-weight:800}

/* Lightbox */
.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.78);z-index:9999;padding:18px}
.lightbox.is-open{display:flex}
.lightboxImg{max-width:min(980px, 100%);max-height:80vh;border-radius:18px;border:1px solid rgba(255,255,255,.14);box-shadow:0 18px 60px rgba(0,0,0,.6)}
.lightboxClose{position:absolute;top:14px;right:14px;width:44px;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.10);color:#fff;font-size:26px;line-height:1;cursor:pointer}
.lb-open{overflow:hidden}

/* Sticky mobile bar */
.mobileBar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none}
.mobileBarInner{max-width:var(--container);margin:0 auto;padding:12px 18px;display:flex;gap:10px;justify-content:center;background:rgba(11,15,12,.72);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.10)}
@media(max-width:920px){
  .mobileBar{display:block}
  body{padding-bottom:78px}
}
