/*
  Luxury property page (Soho-inspired) — used for Amara Luxury 305.
  Goal: match the approved mockup (beige + gold, big hero, alternating feature blocks,
  gallery carousel + lightbox, no calendar).
*/

:root{
  --lux-bg: #f6f1ea;
  --lux-surface: #ffffff;
  --lux-ink: #1a1a1a;
  --lux-muted: #6b6b6b;
  --lux-line: rgba(0,0,0,.08);
  --lux-gold: #c7a56a;
  --lux-gold-dk: #a78755;
  --lux-shadow: 0 14px 40px rgba(0,0,0,.10);
  --lux-radius: 16px;
}

/* page wrapper */
body.layout-lux-property{ background: #f8f5f0; color: var(--lux-ink); font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; padding: 0; }

/* override the global footer spacing for this layout */
body.layout-lux-property .spacer-bottom{ height: 90px; }

/* compact top bar like mockup */
.lux-topbar{
  position: sticky; top: 14px; z-index: 50;
  background: rgba(246,241,234,.94);
  color: var(--lux-ink);
  border: 1px solid rgba(0,0,0,.10);
  border-bottom: 1px solid rgba(0,0,0,.12);
  border-radius: 18px;
  box-shadow: 0 10px 28px rgba(0,0,0,.10);
  backdrop-filter: blur(10px);
}
.lux-topbar__inner{
  max-width: 1040px;
  margin: 0 auto;
  padding: 10px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 13px;
  letter-spacing: .2px;
}
.lux-topbar__left{ display:flex; align-items:center; gap: 10px; white-space: nowrap; overflow:hidden; text-overflow: ellipsis; }
.lux-dot{ opacity:.9; }
.lux-sep{ opacity:.45; }
.lux-topbar__right{ display:flex; align-items:center; gap: 10px; }
.lux-cur{
  background: transparent;
  color:#fff;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  padding: 6px 10px;
  cursor: pointer;
  font-weight: 600;
}
.lux-cur.is-active{ border-color: rgba(255,255,255,.55); }
.lux-cta{
  background: var(--lux-gold);
  color: #161616;
  border: 0;
  border-radius: 10px;
  padding: 8px 14px;
  cursor: pointer;
  font-weight: 800;
  letter-spacing: .2px;
}
.lux-cta:hover{ background: var(--lux-gold-dk); }

/* main container */
.lux-main{ padding: 0; background: var(--lux-bg); border-radius: 0 0 18px 18px; box-shadow: 0 22px 60px rgba(0,0,0,.14); overflow: hidden; border: 1px solid rgba(0,0,0,.06); border-top: 0; }

/* hero */
.lux-hero{
  width: 100%;
  margin: 0;
  min-height: 460px;
  display:flex;
  align-items:center;
  justify-content:center;
  position: relative;
  overflow:hidden;
}
.lux-hero__bg{ position:absolute; inset:0; }
.lux-hero__bg img{ width:100%; height:100%; object-fit: cover; transform: scale(1.00); }

/* Hero background slider (keeps original Lux hero styles) */
.lux-hs{ position:absolute; inset:0; }
.lux-hs-track{ position:relative; width:100%; height:100%; }
.lux-hs-slide{ position:absolute; inset:0; opacity:0; transition:opacity .55s ease; }
.lux-hs-slide.is-active{ opacity:1; }
.lux-hs-slide img{ width:100%; height:100%; object-fit:cover; display:block; }

.lux-hs-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  width:44px; height:44px; border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.28); color:#fff;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .2s ease;
  z-index:3;
}
.lux-hs-arrow.prev{ left:16px; }
.lux-hs-arrow.next{ right:16px; }
.lux-hero:hover .lux-hs-arrow{ opacity:1; }

.lux-hs-dots{ position:absolute; left:0; right:0; bottom:18px; display:flex; justify-content:center; gap:8px; z-index:3; }
.lux-hs-dot{ width:9px; height:9px; border-radius:999px; border:1px solid rgba(255,255,255,.55); background:rgba(255,255,255,.22); cursor:pointer; }
.lux-hs-dot.is-active{ background:rgba(255,255,255,.78); }

.lux-hero__shade{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55)),
    radial-gradient(1000px 400px at 50% 20%, rgba(0,0,0,.20), rgba(0,0,0,.65));
}
.lux-hero__inner{
  position: relative;
  max-width: 1040px;
  width: 100%;
  padding: 84px 28px 72px;
  text-align:center;
  color:#fff;
}
.lux-hero__title{
  font-family: "Playfair Display", serif;
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.05;
  margin: 0;
  letter-spacing: .2px;
}
.lux-hero__sub{
  margin: 12px auto 0;
  opacity: .95;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .12px;
  max-width: 820px;
  line-height: 1.55;
}
.lux-hero__btn{
  margin-top: 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  background: var(--lux-gold);
  color:#161616;
  padding: 12px 22px;
  border-radius: 12px;
  font-weight: 900;
  border: 0;
  cursor: pointer;
  box-shadow: 0 12px 30px rgba(0,0,0,.28);
}
.lux-hero__btn:hover{ background: var(--lux-gold-dk); }

/* content width */
.lux-wrap{ max-width: 1040px; margin: 0 auto; padding: 26px 28px 64px; }

/* highlight cards */
.lux-hi{ display:grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 18px; position: relative; z-index: 2; }
.lux-hi .card{
  background: rgba(255,255,255,.92);
  border: 1px solid var(--lux-line);
  border-radius: var(--lux-radius);
  padding: 18px 18px;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
}
.lux-hi .card.gold{ background: rgba(199,165,106,.22); border-color: rgba(199,165,106,.35); }
.lux-hi .card.dark{ background: rgba(12,12,12,.82); border-color: rgba(255,255,255,.14); }
.lux-hi .card.dark h3{ color: rgba(255,255,255,.92); }
.lux-hi .card.dark p{ color: rgba(255,255,255,.72); }
.lux-hi .card.light{ background: rgba(255,255,255,.78); border-color: rgba(255,255,255,.55); }
.lux-hi h3{ margin: 0; font-weight: 800; font-size: 18px; font-family: "Playfair Display", Georgia, serif; letter-spacing: .2px; }
.lux-hi p{ margin: 8px 0 0; color: var(--lux-muted); font-weight: 550; line-height: 1.55; }

/* section headers */
.lux-h2{ font-size: 28px; margin: 34px 0 14px; font-weight: 800; color: var(--lux-ink); font-family: "Playfair Display", Georgia, serif; letter-spacing: .2px; }
.lux-rule{ height:1px; background: var(--lux-line); margin: 30px 0; }

/* About row */
.lux-about{ display:grid; grid-template-columns: 1.15fr .85fr; gap: 18px; align-items: start; }
.lux-box{
  background: var(--lux-surface);
  border: 1px solid var(--lux-line);
  border-radius: var(--lux-radius);
  padding: 18px 18px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}
.lux-bullets{ margin: 10px 0 0; padding: 0; list-style: none; display:grid; gap: 10px; }
.lux-bullets li{ display:flex; gap: 10px; align-items:flex-start; color: var(--lux-ink); font-weight: 700; }
.lux-bullets .tick{ color: var(--lux-gold-dk); }
.lux-photo{
  border-radius: var(--lux-radius);
  overflow:hidden;
  border: 1px solid var(--lux-line);
  background:#eee;
  aspect-ratio: 16 / 10;
  height: auto;
  max-height: clamp(220px, 28vw, 360px);
}
.lux-photo img{ width:100%; height:100%; object-fit: cover; display:block; }

/* amenities */
.lux-amenities{ margin-top: 18px; }
.lux-amen-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.lux-amen{
  background: var(--lux-surface);
  border: 1px solid var(--lux-line);
  border-radius: 14px;
  padding: 12px 12px;
  display:flex;
  align-items:center;
  gap: 10px;
}
.lux-amen .ico{ width: 26px; height: 26px; color: var(--lux-gold-dk); }
.lux-amen .lbl{ font-weight: 800; color: var(--lux-ink); font-size: 14px; }


/* video tour */
.lux-video{ margin-top: 26px; }
.lux-video__card{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 18px; align-items: start; }
.lux-video__frame{ border-radius: var(--lux-radius); overflow:hidden; border: 1px solid var(--lux-line); background:#111; aspect-ratio: 16 / 9; box-shadow: 0 10px 24px rgba(0,0,0,.06); }
.lux-video__frame iframe, .lux-video__frame video{ width:100%; height:100%; border:0; display:block; }
.lux-video__placeholder{ width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding: 18px; background: linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.75)), url('../img/hero.jpg'); background-size: cover; background-position:center; color:#fff; }
.lux-video__ph-title{ font-family: "Playfair Display", serif; font-size: 28px; font-weight: 800; letter-spacing: .2px; }
.lux-video__ph-sub{ margin-top: 8px; opacity: .92; font-weight: 600; line-height: 1.55; max-width: 520px; }
.lux-video__ph-btn{ margin-top: 14px; display:inline-flex; align-items:center; justify-content:center; gap: 10px; background: var(--lux-gold); color:#161616; padding: 10px 16px; border-radius: 12px; font-weight: 900; text-decoration:none; }
.lux-video__note{ background: rgba(255,255,255,.78); border: 1px solid var(--lux-line); border-radius: var(--lux-radius); padding: 16px 16px; box-shadow: 0 10px 24px rgba(0,0,0,.05); }
.lux-video__note-title{ font-family: "Playfair Display", serif; font-weight: 800; font-size: 18px; }
.lux-video__note-p{ margin: 10px 0 0; color: var(--lux-muted); font-weight: 520; line-height: 1.65; }

/* alternating feature blocks */
.lux-features{ margin-top: 22px; display:grid; gap: 18px; }
.lux-feature{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 18px;
  align-items: start;
  padding: 18px;
  background: rgba(255,255,255,.78);
  border: 1px solid var(--lux-line);
  border-radius: var(--lux-radius);
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
}
.lux-feature.is-rev{ grid-template-columns: .95fr 1.05fr; }
.lux-feature.is-rev .lux-feature__img{ order: 2; }
.lux-feature__img{ border-radius: 14px; overflow:hidden; border: 1px solid var(--lux-line); background:#eee; aspect-ratio: 16 / 10; max-height: clamp(220px, 30vw, 380px); }
.lux-feature__img img{ width:100%; height:100%; object-fit: cover; display:block; }

/* Feature slider (admin-selected multiple images). Keep ratio without distortion. */
.lux-feature__img .lux-img-slider{ height:100%; position:relative; }
.lux-feature__img .lux-img-slider .cs-viewport{ height:100%; overflow:hidden; }
.lux-feature__img .lux-img-slider .cs-track{ height:100%; padding:0; gap:0; }
.lux-feature__img .lux-img-slider .cs-slide{ height:100%; flex:0 0 100%; min-width:100%; display:flex; align-items:stretch; justify-content:stretch; background: transparent; padding:0; }
.lux-feature__img .lux-img-slider .cs-slide img{ width:100%; height:100%; object-fit: cover; display:block; }
.lux-feature__img .lux-img-slider .cs-dots{ position:absolute; left:0; right:0; bottom:8px; justify-content:center; }
.lux-feature__img .lux-img-slider .cs-dot{ border-color:rgba(255,255,255,.6); background:rgba(255,255,255,.35); }
.lux-feature__img .lux-img-slider .cs-dot.is-active{ background:rgba(255,255,255,.8); }
.lux-feature__img .lux-img-slider .cs-arrow{ background:rgba(255,255,255,.92); }
.lux-feature__h{ font-weight: 800; font-size: 24px; margin: 0; font-family: "Playfair Display", Georgia, serif; letter-spacing: .2px; }
.lux-feature__p{ margin: 10px 0 0; color: var(--lux-muted); font-weight: 520; line-height: 1.6; }

/* gallery carousel */
.lux-gallery{ margin-top: 26px; }
.lux-gallery__head{ display:flex; align-items:center; justify-content:center; gap: 12px; }
.lux-gallery__title{ font-size: 28px; font-weight: 800; margin: 0; font-family: "Playfair Display", Georgia, serif; letter-spacing: .2px; }
.lux-carousel{ margin-top: 12px; position: relative; }
.lux-track{ display:flex; gap: 10px; overflow-x:auto; overflow-y:hidden; scroll-behavior: smooth; -webkit-overflow-scrolling: touch; scrollbar-width:none; }
.lux-track::-webkit-scrollbar{ height:0; }
.lux-slide{ flex: 0 0 calc((100% - 30px)/4); border-radius: 14px; overflow:hidden; border: 1px solid var(--lux-line); cursor: pointer; background:#eee; }
.lux-slide img{ width:100%; height: 132px; object-fit: cover; display:block; }
.lux-nav{ position:absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 12px; border: 1px solid var(--lux-line); background: rgba(255,255,255,.92); box-shadow: 0 12px 24px rgba(0,0,0,.10); cursor: pointer; display:flex; align-items:center; justify-content:center; }
.lux-nav:hover{ background: #fff; }
 .lux-nav.prev{ left: 8px; }
 .lux-nav.next{ right: 8px; }

/* lightbox */
.lux-lightbox{ position: fixed; inset: 0; background: rgba(0,0,0,.86); z-index: 1000; display:none; }
.lux-lightbox.is-open{ display:block; }
.lux-lightbox__inner{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; padding:22px; pointer-events:none; }
.lux-lightbox__img{ pointer-events:auto; }
.lux-x, .lux-lbnav{ z-index: 1002; pointer-events:auto; }
.lux-lightbox__img{ max-width: min(1100px, 92vw); max-height: 86vh; border-radius: 16px; box-shadow: var(--lux-shadow); }
.lux-x{ position:absolute; top: 18px; right: 18px; width: 44px; height: 44px; border-radius: 12px; border: 1px solid rgba(255,255,255,.18); background: rgba(0,0,0,.35); color:#fff; cursor:pointer; }
.lux-lbnav{ position:absolute; top: 50%; transform: translateY(-50%); width: 54px; height: 54px; border-radius: 14px; border: 1px solid rgba(255,255,255,.18); background: rgba(0,0,0,.35); color:#fff; cursor:pointer; }
.lux-lbnav.prev{ left: 16px; }
.lux-lbnav.next{ right: 16px; }

/* WhatsApp CTA */
.lux-wa{ margin: 18px auto 0; display:flex; justify-content:center; }
.lux-wa a{ display:inline-flex; align-items:center; justify-content:center; gap: 10px; padding: 12px 18px; background: #25D366; color:#fff; border-radius: 12px; text-decoration:none; font-weight: 900; box-shadow: 0 14px 30px rgba(0,0,0,.12); }

/* reserve modal */
.lux-modal{ position: fixed; inset: 0; z-index: 1100; display:none; background: rgba(0,0,0,.55); }
.lux-modal.is-open{ display:block; }
.lux-modal__panel{ width: min(720px, 92vw); margin: 10vh auto 0; background: var(--lux-surface); border-radius: 18px; border: 1px solid var(--lux-line); box-shadow: var(--lux-shadow); overflow:hidden; }
.lux-modal__head{ padding: 14px 18px; display:flex; align-items:center; justify-content: space-between; border-bottom: 1px solid var(--lux-line); }
.lux-modal__title{ font-weight: 1000; margin: 0; }
.lux-modal__close{ width: 40px; height: 40px; border-radius: 12px; border: 1px solid var(--lux-line); background: #fff; cursor:pointer; }
.lux-modal__body{ padding: 18px; }
.lux-form{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.lux-field label{ display:block; font-weight: 800; font-size: 13px; color: var(--lux-ink); margin-bottom: 6px; }
.lux-field input, .lux-field select{ width: 100%; padding: 12px 12px; border-radius: 12px; border: 1px solid var(--lux-line); font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight: 600; }
.lux-form .lux-actions{ grid-column: 1 / -1; display:flex; gap: 10px; justify-content:flex-end; margin-top: 6px; }
.lux-btn{ border: 0; border-radius: 12px; padding: 12px 16px; cursor:pointer; font-weight: 900; }
.lux-btn.primary{ background: var(--lux-gold); color:#161616; }
.lux-btn.ghost{ background: #f4f4f4; color:#111; border: 1px solid var(--lux-line); }

/* responsive */
@media (max-width: 980px){
  body.layout-lux-property{ padding: 0; }
  .lux-topbar{ top: 10px; }
  .lux-hi{ grid-template-columns: 1fr; margin-top: 16px; }
  .lux-about{ grid-template-columns: 1fr; }
  .lux-amen-grid{ grid-template-columns: repeat(2, 1fr); }
  .lux-feature, .lux-feature.is-rev{ grid-template-columns: 1fr; }
  .lux-feature.is-rev .lux-feature__img{ order: 0; }
  .lux-slide{ flex-basis: calc((100% - 10px)/2); }
  .lux-nav.prev{ left: 8px; }
  .lux-nav.next{ right: 8px; }
  .lux-video__card{ grid-template-columns: 1fr; }
  .lux-form{ grid-template-columns: 1fr; }
}
