:root{
  --bg:#ffffff;
  --panel:#ffffff;
  --text:#413832;
  --muted:rgba(65,56,50,.72);
  --line:rgba(65,56,50,.14);
  --brand:#413832;
  --brand2:#6f7873;
  --btn:#413832;
  --btnText:#ffffff;
  --radius:16px;
  --headerOffset:84px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--headerOffset)}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  background:var(--bg);
  color:var(--text);
}

a{color:inherit}
img{max-width:100%;height:auto}
main{display:block}

.srOnly{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

section{scroll-margin-top:var(--headerOffset)}

@media (max-width:720px){:root{--headerOffset:124px}}

.container{max-width:1100px;margin:0 auto;padding:0 20px}
@media (max-width:520px){.container{padding:0 16px}}

.header{
  position:sticky;top:0;z-index:20;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.headerRow{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;gap:12px;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.mark{
  width:38px;height:38px;border-radius:12px;
  background: url('logo.png') center / cover no-repeat;
  border:1px solid var(--line);
}
.brandLogo{height:34px;width:auto;display:block;object-fit:contain}
@media (max-width:520px){.brandLogo{height:30px}}

.nav{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.nav a{color:var(--muted);text-decoration:none;font-weight:600;font-size:14px}
.nav a:hover{color:var(--text)}

@media (max-width:720px){
  .headerRow{flex-wrap:wrap;align-items:flex-start}
  .nav{
    order:3;
    width:100%;
    flex-wrap:nowrap;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    gap:8px;
    padding-bottom:6px;
    scrollbar-width:none;
  }
  .nav::-webkit-scrollbar{display:none}
  .nav a{white-space:nowrap;padding:10px 10px;border-radius:999px}
  .lang{order:2;margin-left:auto}
}

.lang{display:flex;gap:8px}
.pill{
  border:1px solid var(--line);
  background:transparent;
  color:var(--muted);
  padding:7px 10px;
  border-radius:999px;
  font-weight:700;
  cursor:pointer;
}
.pill[aria-pressed="true"]{color:var(--text);border-color:rgba(111,120,115,.8)}

.hero{padding:54px 0 0}
.heroGrid{display:grid;grid-template-columns:minmax(220px, 1fr) 1.25fr;gap:24px;align-items:center}
@media (max-width:900px){.heroGrid{grid-template-columns:1fr;align-items:start}}

.hTitle{font-size:44px;line-height:1.05;margin:0 0 10px}
@media (max-width:520px){.hTitle{font-size:36px}}

.heroLogoCol{display:flex;justify-content:flex-start}
.heroLogo{width:100%;max-width:420px;height:auto;display:block}
@media (max-width:900px){.heroLogo{max-width:520px}}

.lead{margin:0 0 18px;color:var(--muted);font-size:16px;line-height:1.6}

.ctaRow{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 22px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:11px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  text-decoration:none;
  font-weight:800;
  font-size:14px;
}
.btn,.pill{min-height:44px}
.btnPrimary{background:var(--btn);color:var(--btnText);border-color:transparent}
.btnPrimary:hover{filter:brightness(.98)}
.btnGhost{color:var(--text)}
.btnGhost:hover{border-color:rgba(231,238,248,.22)}

.card{
  border:1px solid var(--line);
  background:rgba(111,120,115,.08);
  border-radius:var(--radius);
  padding:16px;
}

.stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.stat{padding:12px;border-radius:14px;border:1px solid var(--line);background:rgba(111,120,115,.10)}
.statK{font-size:12px;color:var(--muted);font-weight:700}
.statV{font-size:16px;font-weight:900;margin-top:3px}
@media (max-width:520px){.stats{grid-template-columns:1fr}}

.section{padding:30px 0}
.h2{margin:0 0 12px;font-size:22px}
.sub{margin:0 0 16px;color:var(--muted);line-height:1.6}

/* Make the gap between Gallery and About match 16px */
#gallery.section{padding-top:16px;padding-bottom:0}

/* Keep the gap between these two rows consistent with .grid2 gap (16px) */
#about.section{padding-top:16px;padding-bottom:16px}
.sectionAfterAbout{padding-top:0}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:900px){.grid2{grid-template-columns:1fr}}

.list{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.item{display:flex;gap:10px;align-items:flex-start;color:var(--muted);line-height:1.55}
.item a{overflow-wrap:anywhere;word-break:break-word}
.badge{
  flex:0 0 auto;
  width:22px;height:22px;border-radius:8px;
  background:rgba(111,120,115,.22);
  border:1px solid rgba(111,120,115,.38);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
}

.badge svg{width:14px;height:14px;display:block}

/* Amenities: show checkmarks instead of empty boxes */
#amenities .badge{color:var(--text)}
#amenities .badge::before{content:"✓";font-weight:900;font-size:14px;line-height:1}

.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:900px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.gallery{grid-template-columns:1fr}}

.gallery[data-collapsed="true"] .photo:nth-child(n+7){display:none}

.galleryActions{display:flex;justify-content:center;margin-top:12px}

button[data-gallery-toggle] [data-gallery-label="less"]{display:none}
button[data-gallery-toggle][data-expanded="true"] [data-gallery-label="more"]{display:none}
button[data-gallery-toggle][data-expanded="true"] [data-gallery-label="less"]{display:inline}

.photo{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(111,120,115,.10);
  aspect-ratio: 4 / 3;
}
.photo{cursor:pointer}
.photo img{width:100%;height:100%;object-fit:cover;display:block}

body.lightboxOpen{overflow:hidden}

.lightbox{
  position:fixed;
  inset:0;
  z-index:60;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.lightbox:not([hidden]){display:flex}

.lightboxBackdrop{
  position:absolute;
  inset:0;
  background:rgba(65,56,50,.86);
}

.lightboxInner{
  position:relative;
  z-index:1;
  width:min(100%, 980px);
  display:flex;
  align-items:center;
  justify-content:center;
}

.lightboxImg{
  width:100%;
  max-height:calc(100vh - 110px);
  object-fit:contain;
  border-radius:16px;
  border:1px solid var(--line);
  background:var(--panel);
}

.lightboxClose{
  position:fixed;
  top:16px;
  right:16px;
  z-index:2;
}

.lightboxNav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
}
.lightboxPrev{left:0}
.lightboxNext{right:0}

@media (max-width:520px){
  .lightbox{padding:16px}
}

.mapWrap{
  margin-top:14px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(111,120,115,.10);
  aspect-ratio: 16 / 10;
}
.mapWrap iframe{width:100%;height:100%;border:0;display:block}

/* Let the Location map grow to fill its card height */
#location{display:flex}
#location > div[data-lang]{flex:1;display:flex;flex-direction:column;min-height:0}
#location .mapWrap{flex:1;aspect-ratio:auto;min-height:260px}

.footer{padding:26px 0 46px;border-top:1px solid var(--line);color:var(--muted)}
.footRow{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}

.footLogo{height:35px;width:auto;display:block;object-fit:contain;margin:0 0 10px auto}

@media (max-width:720px){
  .footRow{flex-direction:column;align-items:center;text-align:center}
  .footRow > div{display:flex;flex-direction:column;align-items:center}
  .footLogo{margin-left:auto;margin-right:auto}
}
