:root{--green:#06261d;--green2:#00110d;--cream:#fff7eb;--cream2:#f5ead8;--gold:#c9963b;--gold2:#f1d08a;--rose:#c71954;--rose2:#ffe6ec;--text:#23180c;--muted:#6b5d4a;--shadow:0 20px 60px rgba(15,10,4,.18)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Prompt,sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden}body.lock{overflow:hidden}a{text-decoration:none;color:inherit}img{display:block;max-width:100%}.nav{position:fixed;z-index:50;top:0;left:0;right:0;height:62px;padding:0 max(18px,calc((100vw - 1320px)/2));display:flex;align-items:center;justify-content:space-between;background:rgba(0,14,10,.86);backdrop-filter:blur(16px);border-bottom:1px solid rgba(241,208,138,.32);color:white}.brand{font-family:Cormorant Garamond,serif;font-size:28px;font-weight:700;letter-spacing:.08em;color:white}.brand span{color:var(--gold2);margin-right:6px}.nav nav{display:flex;gap:28px;font-size:15px}.book,.cta,.contact-buttons a{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#201406;padding:12px 22px;border-radius:999px;font-weight:800;box-shadow:0 12px 30px rgba(201,150,59,.26)}.section-dark{background:radial-gradient(circle at top,rgba(241,208,138,.2),transparent 34%),linear-gradient(180deg,#02140f,#06261d 55%,#010705);color:#fff}.section-cream{background:linear-gradient(180deg,#fff7eb,#f4e7d2)}.slim{padding:72px 0}.hero{min-height:720px;position:relative;padding:110px 28px 54px;overflow:hidden}.hero-bg{position:absolute;inset:0;background:linear-gradient(90deg,rgba(1,13,10,.88),rgba(1,13,10,.28),rgba(1,13,10,.9)),url('assets/hero.jpeg') center/cover;opacity:.95}.hero-wrap{position:relative;width:min(1320px,100%);margin:auto;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}.logo-mark{font-family:Cormorant Garamond,serif;font-size:48px;letter-spacing:.06em;color:var(--gold2);line-height:1}.logo-mark small{display:block;font-family:Prompt,sans-serif;font-size:13px;letter-spacing:.18em;color:#fff;margin-top:6px}.hero h1{font-size:clamp(48px,7vw,100px);line-height:.98;margin:26px 0 10px;color:#f7d997;font-weight:900}.hero h1 span{font-size:1.15em}.hero p{font-size:clamp(18px,2vw,28px);line-height:1.65;margin:0 0 22px}.hero-stats{display:flex;flex-wrap:wrap;gap:14px;margin:22px 0 28px}.hero-stats span,.hero-right{border:1px solid rgba(241,208,138,.34);background:rgba(255,255,255,.055);border-radius:999px;padding:12px 18px;color:#f7e5bd}.hero-right{border-radius:28px;padding:32px;backdrop-filter:blur(10px);background:rgba(0,0,0,.26)}.hero-right h3{font-size:26px;color:var(--gold2);margin:0 0 18px}.hero-right li{margin:13px 0;line-height:1.6}.heading{text-align:center;width:min(1180px,calc(100% - 32px));margin:0 auto 46px;display:flex;flex-direction:column;align-items:center;gap:14px;overflow:visible}.heading p{letter-spacing:.22em;color:var(--gold);font-weight:900;margin:0;line-height:1.55;display:block}.heading h2{font-family:Prompt,sans-serif;font-size:clamp(38px,5vw,76px);line-height:1.35;margin:0;color:var(--green);font-weight:800;letter-spacing:-.03em;display:block;overflow:visible}.heading span{font-size:18px;color:var(--muted);line-height:1.65;display:block;margin-top:2px}.heading.light h2,.heading.light span{color:#fff7dc}.heading.light p{color:var(--gold2)}.quick,.spa,.addon{padding:78px 0}.web-layout{width:min(1320px,calc(100% - 32px));margin:auto;display:grid;gap:24px}.quick-layout{grid-template-columns:minmax(0,1fr) 330px;align-items:stretch}.cards{display:grid;gap:18px}.quick-cards{grid-template-columns:repeat(3,1fr)}.mini-card{position:relative;border-radius:20px;padding:22px 18px;background:#fff9f0;border:1px solid rgba(201,150,59,.35);box-shadow:var(--shadow);overflow:hidden;cursor:pointer}.mini-card b,.spa-tile:before{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:50%;background:var(--green);color:#fff;font-weight:900}.mini-card i{position:absolute;top:18px;right:18px;background:var(--rose);color:#fff;border-radius:999px;padding:5px 10px;font-style:normal;font-size:12px}.mini-card h3{font-family:Cormorant Garamond,serif;font-size:34px;color:var(--green);margin:14px 0 0}.mini-card strong{display:block;font-size:44px;color:var(--green);line-height:1;margin:8px 0}.mini-card em{font-style:normal;color:#563b1e}.mini-card img{height:230px;width:100%;object-fit:cover;object-position:top;border-radius:16px;margin:14px 0}.mini-card ul{padding-left:18px;margin:0;line-height:1.7;font-size:14px}.mini-card.rose{background:linear-gradient(180deg,#fff2f5,#f8dbe4)}.mini-card.rose strong,.mini-card.rose h3{color:var(--rose)}.why-panel{border-radius:22px;background:var(--green);color:white;border:1px solid rgba(241,208,138,.42);padding:26px;box-shadow:var(--shadow)}.why-panel h3{font-size:26px;color:var(--gold2);margin:0 0 16px}.why-panel div{border-bottom:1px solid rgba(241,208,138,.22);padding:14px 0}.why-panel b{display:block;font-size:18px}.why-panel span{color:#f0debd}.why-panel .tea{border:0;background:rgba(241,208,138,.12);border-radius:16px;padding:18px;margin-top:18px;color:#fff}.overview{width:min(1320px,calc(100% - 32px));margin:26px auto 0}.overview img{width:100%;border-radius:24px;border:1px solid rgba(201,150,59,.35);box-shadow:var(--shadow)}.dark-overview img{border-color:rgba(241,208,138,.38);box-shadow:0 30px 80px rgba(0,0,0,.36)}.spa-row{width:min(1320px,calc(100% - 32px));margin:0 auto 26px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.spa-tile{position:relative;min-height:335px;border-radius:22px;overflow:hidden;border:1px solid rgba(241,208,138,.48);background:#07140f;box-shadow:0 24px 70px rgba(0,0,0,.28);cursor:pointer}.spa-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top;filter:saturate(1.1)}.spa-tile:after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(1,14,10,.05),rgba(1,14,10,.18) 36%,rgba(1,14,10,.88))}.spa-tile:before{content:attr(data-n);position:absolute;z-index:2;top:16px;left:16px}.spa-tile h3,.spa-tile strong{position:relative;z-index:2;margin-left:24px}.spa-tile h3{font-family:Cormorant Garamond,serif;padding-top:210px;font-size:28px;color:var(--gold2);margin-bottom:2px}.spa-tile strong{display:block;font-size:36px;color:white}.spa-tile.hot h3,.spa-tile.hot strong{color:#ffd4df}.spa-tile.vip{border-color:#c9963b}.detail-grid{width:min(1320px,calc(100% - 32px));margin:28px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:20px}.detail-card{display:grid;grid-template-columns:220px 1fr;gap:22px;border-radius:24px;background:#fff7eb;border:1px solid rgba(201,150,59,.35);box-shadow:0 22px 70px rgba(0,0,0,.18);padding:16px;overflow:hidden;color:#201406}.detail-card img{height:280px;width:100%;object-fit:cover;object-position:top;border-radius:16px}.detail-card h3{font-family:Cormorant Garamond,serif;font-size:34px;color:var(--green);margin:10px 0}.detail-card ul{columns:2;line-height:1.75;padding-left:20px;margin:0}.detail-card.rose{background:#ffe7ed}.detail-card.rose h3{color:var(--rose)}.detail-card.black{background:#050605;color:white;border-color:#c9963b}.detail-card.black h3{color:var(--gold2)}.addon-wrap{width:min(1320px,calc(100% - 32px));margin:auto;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}.addon-img{width:100%;border-radius:28px;box-shadow:var(--shadow);border:1px solid rgba(201,150,59,.32)}.addon-list{background:#fffaf2;border:1px solid rgba(201,150,59,.35);border-radius:28px;padding:30px;box-shadow:var(--shadow)}.addon-list h3{font-family:Cormorant Garamond,serif;font-size:44px;color:var(--green);margin:0 0 18px}.addon-list p{font-size:18px;line-height:1.8;border-bottom:1px solid rgba(201,150,59,.22);padding-bottom:16px}.review-grid{width:min(1180px,calc(100% - 32px));margin:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}blockquote{margin:0;background:#fff;border:1px solid rgba(201,150,59,.3);border-radius:22px;padding:24px;box-shadow:0 14px 38px rgba(0,0,0,.08);line-height:1.8}.contact-grid{width:min(1180px,calc(100% - 32px));margin:auto;display:flex;justify-content:space-between;gap:20px;align-items:center}.contact h2{font-family:Cormorant Garamond,serif;color:var(--gold2);font-size:56px;margin:0}.contact h3{font-size:42px;color:white;margin:10px 0}.contact-buttons{display:flex;gap:12px;flex-wrap:wrap}.float{position:fixed;right:18px;bottom:18px;z-index:40;display:flex;flex-direction:column;gap:10px}.float a{background:#0ba343;color:white;border:1px solid rgba(255,255,255,.28);box-shadow:0 14px 35px rgba(0,0,0,.25);padding:14px 18px;border-radius:999px;font-weight:900;text-align:center}.float a:last-child{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#201406}.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:100;place-items:center;padding:18px}.modal.open{display:grid}.modal img{max-height:92vh;max-width:94vw;border-radius:22px;box-shadow:0 32px 90px rgba(0,0,0,.6)}.modal button{position:absolute;top:20px;right:24px;width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.1);color:white;font-size:30px}.reveal{opacity:0;transform:translateY(24px);transition:.7s ease}.reveal.show{opacity:1;transform:none}@media(max-width:1050px){.nav nav{display:none}.hero-wrap,.quick-layout,.addon-wrap{grid-template-columns:1fr}.quick-cards{grid-template-columns:repeat(3,1fr)}.spa-row{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr}.contact-grid{display:block;text-align:center}.contact-buttons{justify-content:center}.hero{min-height:auto}.hero-right{max-width:640px}.overview img{border-radius:18px}}@media(max-width:720px){.nav{height:54px}.brand{font-size:22px}.book{padding:10px 14px}.hero{padding:96px 18px 42px}.hero h1{font-size:54px}.hero-stats span{width:100%;text-align:center}.quick-cards,.spa-row,.review-grid{grid-template-columns:1fr}.mini-card img{height:260px}.detail-card{grid-template-columns:1fr}.detail-card img{height:auto;max-height:520px;object-fit:contain;background:#111}.detail-card ul{columns:1}.heading h2{font-size:44px}.overview{width:calc(100% - 20px)}.float{left:12px;right:12px;flex-direction:row}.float a{flex:1}.spa-tile{min-height:360px}.contact h2{font-size:42px}.contact h3{font-size:34px}}

/* V7: full package image cards for SPA packages */
.package-gallery{width:min(1320px,calc(100% - 32px));margin:34px auto 0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px;align-items:start}.package-showcase{border-radius:30px;padding:10px;background:linear-gradient(145deg,rgba(255,247,235,.96),rgba(241,208,138,.12));border:1px solid rgba(241,208,138,.46);box-shadow:0 28px 90px rgba(0,0,0,.36);overflow:hidden;cursor:pointer}.package-showcase img{width:100%;height:auto;display:block;border-radius:22px;object-fit:contain;background:#120d07}.spa-package-gallery .package-showcase:nth-child(2){background:linear-gradient(145deg,rgba(255,231,237,.98),rgba(199,25,84,.12));border-color:rgba(255,183,202,.75)}.spa-package-gallery .package-showcase:nth-child(4){background:linear-gradient(145deg,#050505,#171006);border-color:rgba(241,208,138,.62)}
.spa-tile img{object-fit:cover;object-position:top center}.modal img{background:#111;object-fit:contain}
@media(max-width:900px){.package-gallery{grid-template-columns:1fr;width:calc(100% - 22px);gap:22px}.package-showcase{border-radius:22px;padding:7px}.package-showcase img{border-radius:16px}}

/* V8: make QUICK package section use the same full-image function as SPA package 490+ */
.sub-heading{margin-top:46px;margin-bottom:22px}
.sub-heading h2{font-size:clamp(34px,4vw,62px)}
.quick-package-gallery{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:22px}
.quick-package-gallery .package-showcase{background:linear-gradient(145deg,rgba(255,247,235,.98),rgba(241,208,138,.14));border-color:rgba(201,150,59,.45);box-shadow:0 22px 70px rgba(64,40,12,.16)}
.quick-package-gallery .package-showcase:nth-child(2){background:linear-gradient(145deg,rgba(255,231,237,.98),rgba(199,25,84,.12));border-color:rgba(255,160,190,.74)}
.quick-package-gallery .package-showcase img{background:#fff7eb;object-fit:contain}
.quick .mini-card img{object-fit:cover;object-position:top center}
@media(max-width:1050px){.quick-package-gallery{grid-template-columns:1fr}.quick-package-gallery .package-showcase img{max-height:none}}

/* V9: Quick Collection cards styled like SPA 490+ package cards */
.quick-showcase-row{width:min(1320px,calc(100% - 32px));margin:auto;display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:24px;align-items:stretch}
.quick-package-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.quick-tile{position:relative;min-height:365px;border-radius:24px;overflow:hidden;border:1px solid rgba(201,150,59,.5);background:#07140f;box-shadow:0 24px 70px rgba(0,0,0,.24);cursor:pointer;isolation:isolate}
.quick-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;filter:saturate(1.08) contrast(1.02)}
.quick-tile:after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.05) 44%,rgba(0,16,10,.80) 74%,rgba(0,13,9,.95))}
.tile-badge{position:absolute;z-index:2;top:18px;left:18px;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:var(--green);color:#fff;font-weight:900;font-size:20px;border:1px solid rgba(241,208,138,.35);box-shadow:0 12px 30px rgba(0,0,0,.25)}
.rose-badge{background:var(--rose)}
.popular-ribbon{position:absolute;z-index:2;top:18px;right:16px;background:linear-gradient(135deg,var(--rose),#e44173);color:white;padding:8px 14px;border-radius:999px;font-size:12px;font-weight:800;box-shadow:0 12px 30px rgba(199,25,84,.28)}
.tile-content{position:absolute;z-index:2;left:20px;right:20px;bottom:58px;color:#fff;text-shadow:0 3px 14px rgba(0,0,0,.55)}
.tile-content h3{font-family:Cormorant Garamond,serif;font-size:clamp(28px,2.6vw,42px);line-height:1;color:var(--gold2);margin:0 0 4px;letter-spacing:.02em}
.tile-content strong{display:block;font-size:clamp(38px,4vw,58px);line-height:1;color:#fff;font-weight:900;margin-bottom:4px}
.quick-tile.hot .tile-content h3,.quick-tile.hot .tile-content strong{color:#ffd7df}
.tile-content p{margin:0;color:#f8e8c7;font-size:13px;font-weight:600}
.tile-foot{position:absolute;z-index:2;left:14px;right:14px;bottom:14px;display:flex;gap:7px;flex-wrap:wrap}
.tile-foot span{flex:1 1 auto;min-width:70px;text-align:center;padding:7px 8px;border-radius:999px;background:rgba(3,38,29,.88);border:1px solid rgba(241,208,138,.28);color:#f8e8c7;font-size:12px;font-weight:700;backdrop-filter:blur(10px)}
.quick-tile.hot .tile-foot span{background:rgba(151,14,55,.86)}
@media(max-width:1050px){.quick-showcase-row{grid-template-columns:1fr}.quick-package-row{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:720px){.quick-showcase-row{width:calc(100% - 22px)}.quick-package-row{grid-template-columns:1fr}.quick-tile{min-height:430px}.tile-content{bottom:70px}.tile-foot span{font-size:12px}}

/* v10: remove function chips/text under Quick 3-level package cards */
.quick-tile .tile-foot{display:none!important}
.quick-tile .tile-content p{display:none!important}
.quick-tile .tile-content{bottom:28px!important}
.quick-tile:after{background:linear-gradient(180deg,rgba(0,0,0,.03),rgba(0,0,0,.05) 48%,rgba(0,16,10,.76) 78%,rgba(0,13,9,.94))!important}
@media(max-width:720px){.quick-tile .tile-content{bottom:30px!important}}

.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;max-width:1200px;margin:20px auto}.features-grid div{background:#fff;padding:20px;border-radius:16px;text-align:center}.section-dark .features-grid div{background:#17342a;color:#fff}.floating-bar{position:fixed;bottom:10px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:999}.floating-bar a{padding:12px 18px;border-radius:30px;background:#0f3d2e;color:#fff;text-decoration:none}

/* V14 Map Upgrade */
.eyebrow{
  color: var(--gold);
  letter-spacing: .16em;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.map-card{
  min-height: 340px;
  border: 1px solid rgba(212,175,55,.35);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 22px 60px rgba(0,0,0,.28);
  background: rgba(255,255,255,.06);
}
.map-card iframe{
  width: 100%;
  height: 100%;
  min-height: 340px;
  border: 0;
  display: block;
  filter: saturate(.85) contrast(.95);
}
.contact-buttons{
  flex-wrap: wrap;
}
.contact-buttons a{
  white-space: nowrap;
}
.float{
  gap: 8px;
}
@media (max-width: 760px){
  .map-card, .map-card iframe{
    min-height: 280px;
  }
  .float a{
    font-size: 13px;
    padding: 10px 12px;
  }
}


/* V16 Logo Upgrade */
.brand-logo-img{
  width: 128px;
  height: 64px;
  object-fit: cover;
  object-position: center;
  border-radius: 18px;
  border: 1px solid rgba(212,175,55,.55);
  box-shadow: 0 10px 26px rgba(0,0,0,.25);
  display: block;
}
.site-logo{
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}
.hero-logo-badge{
  position: absolute;
  right: clamp(22px, 4vw, 70px);
  bottom: clamp(24px, 5vw, 70px);
  z-index: 3;
  width: clamp(140px, 14vw, 230px);
  aspect-ratio: 1 / 1;
  border-radius: 32px;
  overflow: hidden;
  border: 1px solid rgba(212,175,55,.65);
  box-shadow: 0 24px 70px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.22);
  background: rgba(255,255,255,.08);
}
.hero-logo-badge img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero, .hero-section, section[class*="hero"]{
  position: relative;
}
@media (max-width: 760px){
  .brand-logo-img{
    width: 92px;
    height: 46px;
    border-radius: 14px;
  }
  .hero-logo-badge{
    width: 104px;
    border-radius: 22px;
    right: 16px;
    bottom: 16px;
    opacity: .92;
  }
}

/* V17 Logo Placement Fix */
.hero-logo-badge{display:none!important;}

.site-logo,
header .site-logo,
nav .site-logo{
  position: static!important;
  display: inline-flex!important;
  align-items: center!important;
  justify-content: center!important;
  margin: 0!important;
  padding: 0!important;
  z-index: 10!important;
}

.brand-logo-img{
  width: 98px!important;
  height: 50px!important;
  object-fit: cover!important;
  object-position: center!important;
  border-radius: 14px!important;
  border: 1px solid rgba(212,175,55,.65)!important;
  box-shadow: 0 8px 20px rgba(0,0,0,.25)!important;
  display: block!important;
}

@media (max-width: 760px){
  .brand-logo-img{
    width: 78px!important;
    height: 40px!important;
    border-radius: 12px!important;
  }
}

/* Mobile nav fix */
.brand-text{display:flex;flex-direction:column;line-height:1.2;text-decoration:none}
.brand-text .brand-main{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:#f1d08a;letter-spacing:.06em}
.brand-text .brand-sub{font-size:10px;letter-spacing:.14em;color:#d4c5a0}
@media(max-width:768px){
  .nav{padding:0 6px;gap:3px;flex-wrap:nowrap;align-items:center}
  .brand-text .brand-main{font-size:10px;letter-spacing:.03em}
  .brand-text .brand-sub{font-size:7px;letter-spacing:.06em}
  .nav nav{display:flex!important;gap:4px}
  .nav nav a{font-size:9px;white-space:nowrap}
  .book{padding:5px 8px!important;font-size:9px!important;white-space:nowrap!important;border-radius:999px!important}
}

.brand-main,.logo-text,.navbar-brand{color:#D4AF37!important;font-weight:700;}

/* hero replaced with full banner image */
.hero-img-section{padding:0!important;min-height:0!important;overflow:hidden;line-height:0;margin-top:62px}
.hero-img-section a{display:block;line-height:0}
.hero-img-section img{width:100%;height:auto;display:block}
@media(max-width:720px){.hero-img-section{margin-top:54px}}

/* service journey section replaced with banner image */
.timeline-img-section{padding:0!important;background:var(--cream)!important}
.timeline-banner{width:100%;line-height:0}
.timeline-banner img{width:100%;height:auto;display:block}

/* results section replaced with banner image */
.results-img-section{padding:0!important}
.results-banner{width:100%;line-height:0}
.results-banner img{width:100%;height:auto;display:block}

/* addon-list restructured rows */
.addon-list h3{font-size:clamp(24px,3vw,44px)}
.addon-cat{border-bottom:1px solid rgba(201,150,59,.22);padding:12px 0}
.addon-cat:last-child{border-bottom:none}
.addon-cat-label{font-size:14px;font-weight:700;color:var(--green);margin:0 0 8px}
.addon-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:15px;color:var(--text)}
.addon-row em{font-style:normal;font-weight:700;color:var(--green);white-space:nowrap;margin-left:8px}

/* gallery section replaced with banner image */
.gallery-img-section{padding:0;background:var(--cream);line-height:0}
.gallery-banner{width:100%;line-height:0;max-width:600px;margin:0 auto}
.gallery-banner img{width:100%;height:auto;display:block}

/* why-panel replaced with image */
.why-panel-img{padding:0!important;background:transparent!important;border:none!important;box-shadow:none!important;overflow:hidden;border-radius:22px}
.why-panel-img img{width:100%;height:100%;object-fit:cover;display:block;border-radius:22px}
.why-dysi{padding:80px 20px;text-align:center;background:#0F2E25;color:#fff}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;max-width:1100px;margin:30px auto}
.why-grid div{background:rgba(255,255,255,.08);padding:20px;border-radius:18px}

/* V19: Fix overlapping brand/navbar text */
header, nav, .navbar, .nav{
  min-height: 72px !important;
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
  box-sizing: border-box !important;
}

.brand-text{
  display: inline-flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: flex-start !important;
  gap: 2px !important;
  text-decoration: none !important;
  line-height: 1 !important;
  min-width: 150px !important;
  max-width: 220px !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
  z-index: 20 !important;
}

.brand-main{
  display: block !important;
  font-family: Georgia, 'Times New Roman', serif !important;
  font-size: clamp(22px, 2.2vw, 34px) !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  letter-spacing: 2px !important;
  color: #D4AF37 !important;
  background: linear-gradient(90deg,#C99A32,#F4D77A,#B8862E) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  text-shadow: none !important;
  margin: 0 !important;
}

.brand-sub{
  display: block !important;
  font-size: clamp(8px, .75vw, 11px) !important;
  line-height: 1.2 !important;
  letter-spacing: 2px !important;
  color: #E8D4A2 !important;
  margin: 0 !important;
  padding: 0 !important;
  text-transform: uppercase !important;
}

.brand-logo-img, .hero-logo-badge{
  display: none !important;
}

@media (max-width: 760px){
  header, nav, .navbar, .nav{
    min-height: 62px !important;
    gap: 10px !important;
  }
  .brand-text{
    min-width: 118px !important;
    max-width: 145px !important;
  }
  .brand-main{
    font-size: 21px !important;
    letter-spacing: 1.3px !important;
  }
  .brand-sub{
    font-size: 7px !important;
    letter-spacing: 1.2px !important;
  }
}

/* V21 HARD FIX: Thai/English heading overlap */
.heading,
.heading.light,
.heading.sub-heading{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:14px!important;
  margin:0 auto 52px!important;
  padding:0 16px!important;
  overflow:visible!important;
  position:relative!important;
}

.heading p,
.heading.light p,
.heading.sub-heading p{
  position:relative!important;
  transform:none!important;
  display:block!important;
  margin:0!important;
  padding:0!important;
  line-height:1.55!important;
  min-height:auto!important;
  height:auto!important;
  letter-spacing:.22em!important;
  white-space:normal!important;
}

.heading h2,
.heading.light h2,
.heading.sub-heading h2{
  font-family:'Prompt', sans-serif!important;
  font-size:clamp(36px,5vw,74px)!important;
  line-height:1.34!important;
  font-weight:800!important;
  letter-spacing:-.035em!important;
  margin:0!important;
  padding:0!important;
  position:relative!important;
  transform:none!important;
  display:block!important;
  min-height:auto!important;
  height:auto!important;
  overflow:visible!important;
  text-wrap:balance!important;
}

.heading span,
.heading.light span,
.heading.sub-heading span{
  display:block!important;
  margin:0!important;
  padding:0!important;
  line-height:1.65!important;
  min-height:auto!important;
  height:auto!important;
  position:relative!important;
  transform:none!important;
  white-space:normal!important;
}

#quick .heading,
#spa .heading{
  margin-bottom:56px!important;
}

#quick .heading h2,
#spa .heading h2{
  max-width:1200px!important;
}

@media (max-width: 900px){
  .heading,
  .heading.light,
  .heading.sub-heading{
    gap:10px!important;
    margin-bottom:34px!important;
  }
  .heading h2,
  .heading.light h2,
  .heading.sub-heading h2{
    font-size:clamp(30px,8vw,48px)!important;
    line-height:1.42!important;
    letter-spacing:-.025em!important;
  }
  .heading p,
  .heading.light p,
  .heading.sub-heading p{
    font-size:12px!important;
    letter-spacing:.18em!important;
    line-height:1.6!important;
  }
  .heading span,
  .heading.light span,
  .heading.sub-heading span{
    font-size:15px!important;
    line-height:1.7!important;
  }
}

/* V23 Contact UI: social platform icons + smaller phone */
.contact-luxury .contact-grid{
  align-items:center;
  gap:clamp(28px,4vw,60px);
}
.contact-luxury .contact-copy h2{
  font-size:clamp(44px,6vw,96px)!important;
  line-height:1.18!important;
  margin-bottom:28px!important;
}
.contact-luxury .contact-copy h2 span{
  font-family:Georgia,'Times New Roman',serif;
  font-weight:700;
  color:#f4d77a;
}
.social-platforms{
  display:grid;
  grid-template-columns:repeat(4,minmax(150px,1fr));
  gap:18px;
  margin:28px 0 34px;
}
.social-item{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(212,175,55,.22);
  text-decoration:none;
  color:#fff;
}
.social-item b{
  display:block;
  font-size:18px;
  line-height:1.1;
}
.social-item small{
  display:block;
  color:rgba(255,255,255,.78);
  margin-top:4px;
  font-size:14px;
}
.social-icon{
  width:46px;
  height:46px;
  border-radius:50%;
  display:grid;
  place-items:center;
  flex:0 0 46px;
  color:#fff;
  font-weight:900;
  font-size:24px;
  box-shadow:0 10px 24px rgba(0,0,0,.25);
}
.fb .social-icon{background:#1877f2;font-family:Arial,sans-serif;font-size:34px}
.ig .social-icon{background:radial-gradient(circle at 30% 110%,#feda75 0,#fa7e1e 28%,#d62976 55%,#962fbf 78%,#4f5bd5 100%);font-size:32px}
.tt .social-icon{background:#050505;text-shadow:2px 0 #25f4ee,-2px 0 #fe2c55;font-size:30px}
.line .social-icon{background:#06c755;font-size:13px;letter-spacing:.02em}

.phone-card{
  display:flex;
  align-items:center;
  gap:20px;
  margin:20px 0 26px;
}
.phone-icon{
  width:70px;
  height:70px;
  border-radius:50%;
  display:grid;
  place-items:center;
  border:2px solid rgba(212,175,55,.8);
  color:#f4d77a;
  font-size:36px;
}
.phone-card small{
  display:block;
  color:#d4af37;
  font-size:20px;
  font-weight:700;
  margin-bottom:2px;
}
.contact-phone,
.contact-luxury h3.contact-phone{
  font-size:clamp(38px,4vw,58px)!important;
  line-height:1.05!important;
  margin:0!important;
  color:#fff!important;
  letter-spacing:.02em!important;
  font-weight:700!important;
}
.contact-location{
  font-size:clamp(18px,1.8vw,28px);
  line-height:1.55;
}
.contact-location span{
  color:#d4af37;
  padding:0 12px;
}
.contact-luxury .contact-buttons{
  margin-top:28px;
  display:flex;
  flex-wrap:wrap;
  gap:18px;
}
.contact-luxury .contact-buttons a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:190px;
  padding:16px 26px;
  border-radius:999px;
  background:linear-gradient(135deg,#f4d77a,#c9963b);
  color:#201407;
  font-weight:800;
  text-decoration:none;
  box-shadow:0 14px 34px rgba(0,0,0,.24);
}
@media (max-width:980px){
  .social-platforms{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:620px){
  .social-platforms{grid-template-columns:1fr}
  .phone-icon{width:56px;height:56px;font-size:28px}
  .contact-phone,.contact-luxury h3.contact-phone{font-size:36px!important}
  .contact-luxury .contact-buttons a{width:100%}
}

/* V24 Contact layout: match clean sample and prevent text overflow */
.v24-contact{
  padding: clamp(70px, 7vw, 120px) 0 !important;
  overflow: hidden !important;
}
.v24-contact .contact-wrap{
  width: min(1440px, calc(100% - 64px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(330px, 420px);
  gap: clamp(36px, 6vw, 90px);
  align-items: center;
}
.v24-contact .contact-left{
  min-width: 0;
}
.v24-contact .contact-eyebrow{
  color: #d4af37;
  font-weight: 900;
  letter-spacing: .28em;
  margin: 0 0 22px;
  line-height: 1.4;
}
.v24-contact .contact-title{
  margin: 0 0 34px !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  font-family: Prompt, sans-serif !important;
  line-height: 1.08 !important;
  color: #f2cf77 !important;
  font-size: clamp(54px, 6.3vw, 104px) !important;
  letter-spacing: -0.04em !important;
  max-width: 900px !important;
}
.v24-contact .contact-title span,
.v24-contact .contact-title strong{
  display:block !important;
  line-height:1.08 !important;
  white-space: normal !important;
}
.v24-contact .contact-title strong{
  font-family: Georgia, 'Times New Roman', serif !important;
  font-size: .82em !important;
  letter-spacing: .02em !important;
  font-weight: 700 !important;
  background: linear-gradient(90deg,#f6d978,#b9852b,#f8e6a3);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.v24-contact .social-platforms{
  display:grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px !important;
  margin: 0 0 34px !important;
}
.v24-contact .social-item{
  min-width: 0 !important;
  padding: 14px 16px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(212,175,55,.55) !important;
  background: rgba(255,255,255,.045) !important;
  color:#fff !important;
  text-decoration:none !important;
  display:flex !important;
  align-items:center !important;
  gap:14px !important;
  overflow:hidden !important;
}
.v24-contact .social-item b,
.v24-contact .social-item small{
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.v24-contact .social-icon{
  width:48px !important;
  height:48px !important;
  flex:0 0 48px !important;
}
.v24-contact .phone-card{
  display:flex !important;
  align-items:center !important;
  gap:18px !important;
  margin: 16px 0 24px !important;
}
.v24-contact .phone-icon{
  width:64px !important;
  height:64px !important;
  flex:0 0 64px !important;
}
.v24-contact .contact-phone{
  font-size: clamp(34px, 3.1vw, 52px) !important;
  line-height: 1.08 !important;
  margin:0 !important;
  white-space: nowrap !important;
}
.v24-contact .contact-location{
  font-size: clamp(18px, 1.7vw, 26px) !important;
  line-height:1.55 !important;
  margin: 0 0 28px !important;
}
.v24-contact .contact-buttons{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:18px !important;
  margin-top:0 !important;
}
.v24-contact .contact-buttons a{
  min-width: 190px !important;
  padding: 16px 26px !important;
  border-radius: 999px !important;
  text-align:center !important;
}
.v24-contact .contact-map{
  width:100%;
  aspect-ratio: .92 / 1;
  max-height: 520px;
  border-radius: 28px;
  overflow:hidden;
  border: 2px solid rgba(212,175,55,.7);
  box-shadow: 0 28px 70px rgba(0,0,0,.32);
  align-self:center;
}
.v24-contact .contact-map iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}
.v24-contact .map-card{display:none!important;}

@media (max-width: 1100px){
  .v24-contact .contact-wrap{
    grid-template-columns: 1fr;
  }
  .v24-contact .contact-map{
    max-width: 560px;
    aspect-ratio: 1.25 / 1;
  }
}
@media (max-width: 760px){
  .v24-contact .contact-wrap{
    width: min(100% - 30px, 560px);
  }
  .v24-contact .contact-title{
    font-size: clamp(40px, 12vw, 58px) !important;
  }
  .v24-contact .social-platforms{
    grid-template-columns: 1fr 1fr !important;
  }
  .v24-contact .contact-phone{
    font-size: 28px !important;
    white-space: nowrap !important;
  }
  .v24-contact .contact-location{
    font-size: 14px !important;
    line-height: 1.7 !important;
  }
  .v24-contact .phone-icon{
    width: 48px !important;
    height: 48px !important;
    flex: 0 0 48px !important;
    font-size: 22px !important;
  }
}
@media (max-width: 480px){
  .v24-contact .social-platforms{
    grid-template-columns: 1fr !important;
  }
  .v24-contact .contact-buttons a{
    width:100% !important;
  }
}

/* quick-info-banner: full-width landscape infographic */
.quick-info-banner{width:100%!important;margin:40px 0 0!important;overflow:hidden;cursor:pointer;line-height:0;border:none!important;box-shadow:none!important;border-radius:0!important}
.quick-info-banner img{width:100%;height:auto;display:block}

/* remove bottom padding from quick section so banner reaches edge */
#quick.quick{padding-bottom:0!important}

/* spacing between full-width image sections */
#quick.quick{margin-bottom:60px!important}
.results-img-section{margin-bottom:60px!important}
.timeline-img-section{margin-bottom:60px!important}
.gallery-img-section{margin-bottom:60px!important}
@media(max-width:720px){
  #quick.quick{margin-bottom:36px!important}
  .results-img-section,.timeline-img-section,.gallery-img-section{margin-bottom:36px!important}
}

/* draggable float group */
.float{touch-action:none;user-select:none}

/* force float group to always be vertical column */
.float{flex-direction:column!important}
.float a{flex:unset!important}
