:root{
  --hdm-ink:#0f172a;--hdm-muted:#64748b;--hdm-soft:#f5f9ff;--hdm-soft2:#edf7ff;--hdm-line:#dbeafe;--hdm-blue:#155ac9;--hdm-blue2:#0f3b86;--hdm-sky:#0ea5e9;--hdm-cyan:#22d3ee;--hdm-green:#10b981;--hdm-orange:#f97316;--hdm-yellow:#facc15;--hdm-pink:#ec4899;--hdm-white:#fff;--hdm-shadow:0 22px 65px rgba(15,35,86,.13);--hdm-strong:0 34px 100px rgba(8,35,79,.24);
}
*{box-sizing:border-box}
.hdm-page{font-family:"Tahoma","Noto Sans Thai","Segoe UI",Arial,sans-serif;color:var(--hdm-ink);background:linear-gradient(180deg,#f7fbff 0%,#eef7ff 45%,#fff 100%);overflow:hidden;padding-top:116px;isolation:isolate}
.hdm-page a{text-decoration:none;color:inherit}.hdm-page img{max-width:100%;display:block}.hdm-wrap{width:min(1180px,calc(100% - 36px));margin-inline:auto}.hdm-reveal{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease}.hdm-reveal.is-visible{opacity:1;transform:translateY(0)}
.hdm-eyebrow{display:inline-flex;width:max-content;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:linear-gradient(135deg,#e0f2fe,#eff6ff);border:1px solid #bae6fd;color:#155ac9;font-size:12px;font-weight:1000;letter-spacing:.08em;text-transform:uppercase}
.hdm-mini-btn,.hdm-main-cta{border:0;display:inline-flex;align-items:center;justify-content:center;padding:13px 18px;border-radius:999px;background:linear-gradient(135deg,#08234f,#155ac9 55%,#38bdf8);color:#fff!important;font-weight:1000;box-shadow:0 18px 42px rgba(37,99,235,.24);cursor:pointer}.hdm-mini-btn:hover,.hdm-main-cta:hover{transform:translateY(-2px)}
.hdm-top-map{position:relative;height:315px;background:#cfeeff;overflow:hidden;box-shadow:inset 0 -1px 0 rgba(15,35,86,.07)}.hdm-top-map-embed{position:absolute;inset:0}.hdm-top-map-embed iframe{width:100%!important;height:100%!important;border:0!important;display:block;filter:saturate(1.1) contrast(1.02)}.hdm-top-map::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,0) 45%,rgba(247,251,255,.75));pointer-events:none}.hdm-map-glass{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;display:flex;align-items:end;justify-content:space-between;gap:20px;padding:18px 20px;border-radius:28px;background:rgba(255,255,255,.86);border:1px solid rgba(219,234,254,.96);box-shadow:0 18px 55px rgba(15,35,86,.18);backdrop-filter:blur(18px)}.hdm-map-glass h1{margin:10px 0 6px;font-size:clamp(27px,3vw,42px);color:#08234f;letter-spacing:-.7px}.hdm-map-glass p{margin:0;color:#475569;font-weight:800;line-height:1.65;max-width:720px}
.hdm-breadcrumb{display:flex;gap:9px;align-items:center;margin-top:24px;margin-bottom:18px;color:#64748b;font-size:13px;font-weight:900}.hdm-breadcrumb a{color:#155ac9}
.hdm-intro-grid{display:grid;grid-template-columns:minmax(0,1.45fr) 390px;gap:24px;align-items:start;margin-bottom:28px}.hdm-gallery-card,.hdm-summary-card,.hdm-tabs,.hdm-side-card{background:rgba(255,255,255,.94);border:1px solid rgba(219,234,254,.98);box-shadow:var(--hdm-shadow);border-radius:32px}.hdm-gallery-card{padding:18px}.hdm-section-title{margin:0 0 18px}.hdm-section-title span{display:block;margin-bottom:6px;color:#0ea5e9;font-size:12px;font-weight:1000;letter-spacing:.12em;text-transform:uppercase}.hdm-section-title h2{margin:0;color:#08234f;font-size:clamp(24px,2.4vw,34px);line-height:1.2;letter-spacing:-.45px}.hdm-section-title.slim{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.hdm-section-title.small h2{font-size:26px}.hdm-section-title.small{margin-top:8px}.hdm-gallery-main{position:relative;display:block;height:520px;border-radius:26px;overflow:hidden;background:#dbeafe;box-shadow:0 16px 40px rgba(15,35,86,.13)}.hdm-gallery-main img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.hdm-gallery-main:hover img{transform:scale(1.025)}.hdm-gallery-main:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(8,35,79,.20));pointer-events:none}.hdm-photo-badge{position:absolute;top:18px;left:18px;z-index:2;display:inline-flex;padding:9px 13px;border-radius:999px;background:linear-gradient(135deg,#fff8c8,#facc15,#f97316);color:#7c4700;font-size:12px;font-weight:1000;box-shadow:0 12px 28px rgba(249,115,22,.2)}.hdm-thumbs{display:flex;gap:10px;overflow-x:auto;padding:14px 2px 2px;scrollbar-width:thin}.hdm-thumbs button{flex:0 0 112px;height:76px;border:2px solid transparent;background:#eff6ff;border-radius:16px;padding:0;cursor:pointer;overflow:hidden;box-shadow:0 8px 18px rgba(15,35,86,.07);transition:.22s}.hdm-thumbs button.is-active{border-color:#0ea5e9;transform:translateY(-2px)}.hdm-thumbs img{width:100%;height:100%;object-fit:cover}
.hdm-summary-card{position:sticky;top:112px;padding:24px;overflow:hidden}.hdm-summary-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(34,211,238,.18),transparent 32%),radial-gradient(circle at bottom left,rgba(250,204,21,.12),transparent 25%);pointer-events:none}.hdm-summary-card>*{position:relative}.hdm-summary-top h2{margin:12px 0 6px;color:#08234f;font-size:25px;line-height:1.25}.hdm-summary-top h3{margin:0;color:#334155;font-size:18px;font-weight:900}.hdm-starline{display:flex;gap:4px;margin:16px 0}.hdm-starline span{font-size:19px;color:#cbd5e1}.hdm-starline span.is-on{color:#f59e0b;text-shadow:0 4px 16px rgba(245,158,11,.25)}.hdm-address-small{padding:14px;border-radius:20px;background:#f8fbff;border:1px solid #e0f2fe;color:#475569;font-weight:800;line-height:1.65;font-size:13px}.hdm-metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:16px 0}.hdm-metric-grid div{border-radius:20px;padding:14px 8px;text-align:center;background:linear-gradient(180deg,#fff,#f4f9ff);border:1px solid #dbeafe}.hdm-metric-grid b{display:block;color:#155ac9;font-size:22px;line-height:1}.hdm-metric-grid span{display:block;color:#64748b;font-size:11px;font-weight:900;margin-top:7px}.hdm-like-button{width:100%;border:0;border-radius:20px;padding:14px 16px;background:linear-gradient(135deg,#fff1f2,#ffe4e6);color:#be123c;font-weight:1000;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 12px 28px rgba(225,29,72,.12)}.hdm-like-button.liked{background:linear-gradient(135deg,#be123c,#ec4899);color:#fff}.hdm-like-button:disabled{opacity:.65;cursor:wait}.hdm-quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}.hdm-quick-actions a,.hdm-quick-actions button{display:flex;align-items:center;justify-content:center;height:42px;border-radius:16px;border:1px solid #dbeafe;background:#fff;color:#0f3b86;font-weight:1000;font-size:12px;cursor:pointer}
.hdm-content-grid{display:grid;grid-template-columns:minmax(0,1fr) 350px;gap:24px;align-items:start;margin-bottom:64px}.hdm-main{min-width:0}.hdm-tabs{overflow:hidden}.hdm-tab-nav{position:sticky;top:88px;z-index:10;display:flex;gap:8px;overflow-x:auto;padding:12px;background:rgba(255,255,255,.96);border-bottom:1px solid #e0f2fe;backdrop-filter:blur(16px)}.hdm-tab-nav button{flex:0 0 auto;border:1px solid #e0f2fe;background:#f8fbff;color:#1e3a8a;border-radius:999px;padding:11px 14px;font-weight:1000;font-size:13px;cursor:pointer;transition:.2s}.hdm-tab-nav button:hover{transform:translateY(-1px)}.hdm-tab-nav button.is-active{background:linear-gradient(135deg,#08234f,#155ac9,#38bdf8);color:#fff;border-color:transparent;box-shadow:0 12px 30px rgba(37,99,235,.22)}.hdm-tab-panel{display:none;padding:28px}.hdm-tab-panel.is-active{display:block;animation:hdmFade .3s ease}@keyframes hdmFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.hdm-divider{height:1px;background:#e0f2fe;margin:24px 0}.hdm-prose{font-size:15px;line-height:1.95;color:#334155;font-weight:700}.hdm-prose p{margin-top:0}.hdm-small-text{color:#64748b;font-weight:800;line-height:1.75;margin-top:-6px}
.hdm-rooms{display:grid;gap:16px}.hdm-room-card{display:grid;grid-template-columns:190px minmax(0,1fr) 145px;gap:18px;align-items:stretch;border:1px solid #dbeafe;border-radius:28px;background:linear-gradient(180deg,#fff,#f8fbff);padding:14px;box-shadow:0 12px 32px rgba(15,35,86,.07);transition:.25s}.hdm-room-card:hover{transform:translateY(-4px);box-shadow:0 24px 55px rgba(15,35,86,.13)}.hdm-room-photo{display:block;border-radius:22px;overflow:hidden;background:#dbeafe;min-height:155px}.hdm-room-photo img{width:100%;height:100%;object-fit:cover}.hdm-room-copy h3{margin:4px 0 8px;color:#08234f;font-size:22px;line-height:1.25}.hdm-room-copy p{margin:8px 0 0;color:#475569;font-weight:700;line-height:1.8}.hdm-chips{display:flex;gap:8px;flex-wrap:wrap}.hdm-chips span{display:inline-flex;border-radius:999px;background:#eff6ff;border:1px solid #dbeafe;color:#1e40af;font-size:12px;font-weight:1000;padding:7px 10px}.hdm-price-box{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;text-align:right;border-left:1px dashed #cfe8ff;padding-left:14px}.hdm-price-box small{color:#94a3b8;text-decoration:line-through;font-weight:900}.hdm-price-box b{font-size:31px;line-height:1.1;color:#f97316}.hdm-price-box span{color:#64748b;font-size:12px;font-weight:1000}.hdm-empty{border:1px dashed #bae6fd;border-radius:22px;background:#f8fbff;color:#64748b;font-weight:900;line-height:1.7;padding:18px}
.hdm-facility-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.hdm-facility{border:1px solid #dbeafe;background:linear-gradient(180deg,#fff,#f8fbff);border-radius:24px;padding:16px;display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:start}.hdm-facility img{width:48px;height:48px;border-radius:16px;box-shadow:0 10px 24px rgba(15,35,86,.09)}.hdm-facility b{display:block;color:#08234f}.hdm-facility span{display:block;margin-top:5px;color:#64748b;font-weight:800;line-height:1.6;font-size:13px}.hdm-facroom-list{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap}.hdm-facroom-list span{display:inline-flex;align-items:center;gap:8px;border:1px solid #bae6fd;background:#ecfeff;color:#0f766e;border-radius:999px;padding:9px 12px;font-weight:950;font-size:13px}.hdm-facroom-list img{width:24px;height:24px;object-fit:contain}
.hdm-review-overview{display:grid;grid-template-columns:225px 1fr;gap:20px;align-items:center}.hdm-review-big{border-radius:30px;background:radial-gradient(circle at top right,rgba(34,211,238,.25),transparent 35%),linear-gradient(135deg,#061632,#155ac9 58%,#0ea5e9);color:#fff;text-align:center;padding:26px;box-shadow:0 18px 48px rgba(37,99,235,.22)}.hdm-review-big b{font-size:64px;line-height:1}.hdm-review-big span{font-size:23px;font-weight:1000;color:#dff7ff}.hdm-review-big em{display:block;font-style:normal;margin-top:8px;color:#dbeafe;font-weight:900}.hdm-review-bars,.hdm-recommend-bars{display:grid;gap:10px}.hdm-recommend-bars{margin:18px 0}.hdm-score-row{display:grid;grid-template-columns:205px 1fr;gap:12px;align-items:center}.hdm-score-row span{font-size:13px;color:#334155;font-weight:950}.hdm-score-row span b{color:#0f3b86}.hdm-score-row i{display:block;height:12px;border-radius:999px;background:#e0f2fe;overflow:hidden}.hdm-score-row i em{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#155ac9,#38bdf8)}.hdm-review-list{display:grid;gap:14px;margin-top:18px}.hdm-review-card{display:grid;grid-template-columns:66px 1fr;gap:14px;border:1px solid #dbeafe;background:#fff;border-radius:24px;padding:16px}.hdm-review-card>img{width:66px;height:66px;border-radius:50%;object-fit:cover;background:#eff6ff}.hdm-review-card b{display:block;color:#08234f}.hdm-review-card p{margin:7px 0;color:#334155;font-weight:700;line-height:1.75}.hdm-review-card span{display:inline-flex;border-radius:999px;background:#fff7ed;color:#c2410c;padding:7px 10px;font-size:12px;font-weight:1000}.hdm-review-form-wrap{margin-top:24px;border-radius:28px;padding:20px;background:linear-gradient(180deg,#f8fbff,#fff);border:1px solid #dbeafe}.hdm-review-form-wrap h3{margin:0 0 14px;color:#08234f}.hdm-review-form label{display:block;color:#1e3a8a;font-weight:1000;margin-bottom:12px}.hdm-review-form input,.hdm-review-form textarea,.hdm-review-form select{display:block;width:100%;margin-top:7px;border:1px solid #dbeafe;background:#fff;border-radius:17px;padding:12px 13px;font:inherit;color:#0f172a}.hdm-review-form textarea{min-height:125px}.hdm-range-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.hdm-range{display:grid;grid-template-columns:1fr 48px;gap:10px;align-items:center;margin-top:7px}.hdm-range input{margin:0;padding:0}.hdm-range output{text-align:center;color:#155ac9;font-weight:1000}.hdm-review-form button{border:0;border-radius:999px;background:linear-gradient(135deg,#155ac9,#0ea5e9);color:#fff;font-weight:1000;padding:14px 22px;cursor:pointer;box-shadow:0 16px 36px rgba(37,99,235,.22)}
.hdm-map-box iframe{width:100%!important;height:440px!important;border:0!important;border-radius:26px!important;display:block}.hdm-map-box>*{max-width:100%!important}.hdm-faq-list{display:grid;gap:12px}.hdm-faq-item{border:1px solid #dbeafe;background:#fff;border-radius:22px;overflow:hidden}.hdm-faq-q{width:100%;border:0;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:17px 18px;text-align:left;color:#08234f;font-weight:1000;cursor:pointer}.hdm-faq-q i{font-style:normal;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#e0f2fe;color:#0ea5e9}.hdm-faq-a{display:none;padding:0 18px 18px;color:#334155;font-weight:700;line-height:1.8}.hdm-faq-item.is-open .hdm-faq-a{display:block}.hdm-faq-item.is-open .hdm-faq-q i{background:#155ac9;color:#fff;transform:rotate(45deg)}
.hdm-sidebar{position:sticky;top:104px;display:grid;gap:18px}.hdm-side-card{padding:18px}.hdm-side-head{margin-bottom:14px}.hdm-side-head span{display:block;color:#0ea5e9;font-size:11px;font-weight:1000;letter-spacing:.12em;text-transform:uppercase}.hdm-side-head h3{margin:5px 0 0;color:#08234f;font-size:19px;line-height:1.32}.hdm-contact-card{padding:0;overflow:hidden}.hdm-contact-card .hdm-side-head{margin:0;padding:18px;background:linear-gradient(135deg,#08234f,#155ac9,#0ea5e9);color:#fff}.hdm-contact-card .hdm-side-head span,.hdm-contact-card .hdm-side-head h3{color:#fff}.hdm-contact-row{display:flex;align-items:flex-start;gap:10px;margin:10px 14px;padding:12px;border-radius:18px;background:#f8fbff;border:1px solid #dbeafe;color:#173057;font-weight:900;line-height:1.55;overflow:hidden}.hdm-contact-row img{width:30px;height:30px;flex:0 0 auto}.hdm-contact-row span{min-width:0;overflow-wrap:anywhere}.hdm-booking-btn{display:flex;margin:14px;border-radius:18px;padding:14px;background:linear-gradient(135deg,#f97316,#facc15);color:#7c4700!important;font-weight:1000;justify-content:center;box-shadow:0 14px 32px rgba(249,115,22,.18)}.hdm-mini-review-track{position:relative}.hdm-mini-review{display:none;border-radius:22px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #e0f2fe;padding:14px}.hdm-mini-review.is-active{display:block}.hdm-mini-review p{margin:0 0 12px;color:#334155;font-weight:700;line-height:1.7}.hdm-mini-review div{display:flex;align-items:center;gap:9px}.hdm-mini-review img{width:42px;height:42px;border-radius:50%;object-fit:cover}.hdm-mini-review b{color:#08234f}.hdm-mini-review span{margin-left:auto;color:#f97316;font-weight:1000}.hdm-near-list{display:grid;gap:12px}.hdm-near-item{display:grid;grid-template-columns:92px 1fr;gap:11px;padding:9px;border-radius:20px;background:#fff;border:1px solid #dbeafe;transition:.22s}.hdm-near-item:hover{transform:translateY(-3px);box-shadow:0 16px 38px rgba(15,35,86,.1)}.hdm-near-item img{width:92px;height:76px;object-fit:cover;border-radius:16px}.hdm-near-item b{display:block;color:#08234f;line-height:1.35}.hdm-near-item em{display:block;color:#64748b;font-style:normal;font-size:12px;font-weight:850;margin-top:3px}.hdm-near-item strong{display:inline-flex;color:#f97316;margin-top:5px;font-size:12px}.hdm-benefits-list,.hdm-why-list{display:grid;gap:11px}.hdm-benefits-list div{display:flex;gap:10px;align-items:flex-start;border:1px solid #dbeafe;background:#f8fbff;border-radius:18px;padding:11px}.hdm-benefits-list img{width:30px;height:30px}.hdm-benefits-list span{font-size:13px;font-weight:900;line-height:1.55;color:#334155}.hdm-why-list div{border-left:4px solid #38bdf8;background:#f8fbff;border-radius:0 18px 18px 0;padding:12px}.hdm-why-list b{display:block;color:#08234f;text-transform:uppercase;font-size:12px;letter-spacing:.05em}.hdm-why-list p{margin:5px 0 0;color:#475569;font-weight:800;line-height:1.65;font-size:13px}
.hdm-floating-contact{display:none;position:fixed;left:12px;right:12px;bottom:12px;z-index:100;border-radius:24px;padding:9px;background:rgba(255,255,255,.9);backdrop-filter:blur(16px);box-shadow:0 18px 55px rgba(15,35,86,.18);border:1px solid #dbeafe;gap:8px}.hdm-floating-contact a{display:flex;align-items:center;justify-content:center;min-height:46px;border-radius:18px;background:linear-gradient(135deg,#155ac9,#0ea5e9);color:#fff;font-weight:1000;font-size:13px}.hdm-floating-contact a:nth-child(2){background:linear-gradient(135deg,#0f766e,#10b981)}.hdm-floating-contact a:nth-child(3){background:linear-gradient(135deg,#1d4ed8,#38bdf8)}
.hdm-lightbox{position:fixed;inset:0;z-index:9999;background:rgba(2,6,23,.86);display:none;align-items:center;justify-content:center;padding:24px}.hdm-lightbox.is-open{display:flex}.hdm-lightbox img{max-width:min(96vw,1200px);max-height:86vh;border-radius:22px;box-shadow:0 24px 80px rgba(0,0,0,.45)}.hdm-lightbox button{position:absolute;top:22px;right:22px;width:48px;height:48px;border:0;border-radius:50%;background:#fff;color:#0f172a;font-size:34px;line-height:1;cursor:pointer}
/* preview-only helpers */.hdm-preview-header{position:fixed;left:0;right:0;top:0;height:88px;background:rgba(255,255,255,.9);backdrop-filter:blur(16px);z-index:300;border-bottom:1px solid #dbeafe;display:flex;align-items:center;justify-content:center;font-weight:1000;color:#0f3b86;box-shadow:0 12px 32px rgba(15,35,86,.08)}.hdm-preview-header span{display:inline-flex;border-radius:18px;background:#fff;border:1px solid #dbeafe;padding:12px 18px}.hdm-fake-map{position:absolute;inset:0;background:linear-gradient(135deg,#c7f9df 0%,#dff6ff 40%,#fef3c7 100%);overflow:hidden}.hdm-fake-map:before,.hdm-fake-map:after{content:"";position:absolute;inset:0;background-image:linear-gradient(30deg,transparent 42%,rgba(59,130,246,.28) 43%,rgba(59,130,246,.28) 46%,transparent 47%),linear-gradient(120deg,transparent 38%,rgba(255,255,255,.7) 39%,rgba(255,255,255,.7) 42%,transparent 43%);background-size:220px 140px}.hdm-fake-pin{position:absolute;left:58%;top:42%;width:22px;height:22px;border-radius:50% 50% 50% 0;background:#ef4444;transform:rotate(-45deg);box-shadow:0 8px 20px rgba(239,68,68,.25)}.hdm-fake-pin:after{content:"";position:absolute;left:6px;top:6px;width:10px;height:10px;border-radius:50%;background:#fff}.hdm-preview-note{position:fixed;z-index:500;left:14px;right:14px;bottom:14px;max-width:620px;margin:auto;padding:12px 16px;border-radius:18px;background:rgba(255,255,255,.92);border:1px solid #dbeafe;box-shadow:0 18px 44px rgba(15,35,86,.16);font-family:Tahoma,sans-serif;color:#0f3b86;font-weight:900;text-align:center}.hdm-preview-note b{color:#f97316}
@media(max-width:1080px){.hdm-page{padding-top:98px}.hdm-intro-grid,.hdm-content-grid{grid-template-columns:1fr}.hdm-summary-card,.hdm-sidebar{position:static}.hdm-gallery-main{height:430px}.hdm-content-grid{gap:18px}.hdm-tab-nav{top:74px}.hdm-room-card{grid-template-columns:180px 1fr}.hdm-price-box{grid-column:2;text-align:left;align-items:flex-start;border-left:0;border-top:1px dashed #cfe8ff;padding:12px 0 0}.hdm-sidebar{display:grid;grid-template-columns:repeat(2,1fr)}.hdm-contact-card{grid-column:span 2}.hdm-top-map{height:290px}}
@media(max-width:720px){.hdm-page{padding-top:82px}.hdm-wrap{width:min(100% - 26px,1180px)}.hdm-top-map{height:300px}.hdm-map-glass{left:13px;right:13px;bottom:14px;transform:none;width:auto;display:block;padding:15px}.hdm-map-glass h1{font-size:26px}.hdm-map-glass p{font-size:13px}.hdm-map-glass .hdm-mini-btn{margin-top:12px;width:100%}.hdm-breadcrumb{margin-top:18px}.hdm-gallery-card,.hdm-summary-card,.hdm-tabs,.hdm-side-card{border-radius:24px}.hdm-gallery-card{padding:12px}.hdm-gallery-main{height:300px;border-radius:20px}.hdm-thumbs button{flex-basis:88px;height:62px}.hdm-summary-card{padding:18px}.hdm-metric-grid{grid-template-columns:1fr 1fr}.hdm-metric-grid div:last-child{grid-column:span 2}.hdm-quick-actions{grid-template-columns:repeat(2,1fr)}.hdm-tab-panel{padding:18px}.hdm-tab-nav{top:64px;padding:10px}.hdm-room-card{grid-template-columns:1fr;padding:12px}.hdm-room-photo{height:215px}.hdm-price-box{grid-column:auto}.hdm-facility-grid,.hdm-review-overview,.hdm-range-grid{grid-template-columns:1fr}.hdm-score-row{grid-template-columns:1fr;gap:6px}.hdm-review-big b{font-size:54px}.hdm-review-card{grid-template-columns:52px 1fr;padding:12px}.hdm-review-card>img{width:52px;height:52px}.hdm-map-box iframe{height:330px!important}.hdm-sidebar{grid-template-columns:1fr}.hdm-contact-card{grid-column:auto}.hdm-floating-contact{display:grid;grid-template-columns:repeat(3,1fr)}.hdm-content-grid{margin-bottom:104px}.hdm-preview-header{height:72px}.hdm-preview-note{font-size:12px}.hdm-side-head h3{font-size:18px}}
@media(max-width:420px){.hdm-floating-contact{grid-template-columns:1fr 1fr}.hdm-floating-contact a:nth-child(3){grid-column:span 2}.hdm-title{font-size:34px}.hdm-section-title h2{font-size:23px}.hdm-gallery-main{height:260px}}

/* ===== V3: review member flow + dynamic contact rows ===== */
.hdm-review-form-head{margin-bottom:16px;padding:18px;border-radius:22px;background:linear-gradient(135deg,#eff6ff,#ecfeff);border:1px solid #dbeafe}
.hdm-review-form-head span{display:block;color:#0ea5e9;font-size:11px;font-weight:1000;letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px}
.hdm-review-form-head h3{margin:0;color:#08234f;font-size:22px;line-height:1.25}
.hdm-review-form-head p{margin:8px 0 0;color:#475569;font-weight:800;line-height:1.7}
.hdm-review-login-card{display:grid;grid-template-columns:56px 1fr auto;gap:16px;align-items:center;padding:18px;border-radius:24px;background:linear-gradient(135deg,#fff,#f8fbff);border:1px solid #dbeafe;box-shadow:0 14px 34px rgba(15,35,86,.08)}
.hdm-review-login-icon{width:56px;height:56px;border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,#155ac9,#0ea5e9);box-shadow:0 14px 30px rgba(37,99,235,.22);font-size:22px;font-weight:1000}
.hdm-review-login-card b{display:block;color:#08234f;font-size:17px;line-height:1.35}
.hdm-review-login-card p{margin:6px 0 0;color:#64748b;font-weight:800;line-height:1.65}
.hdm-review-login-btn{white-space:nowrap;min-width:170px}
.hdm-review-form-member{padding:18px;border-radius:24px;background:#fff;border:1px solid #dbeafe;box-shadow:0 14px 34px rgba(15,35,86,.06)}
.hdm-contact-note{background:linear-gradient(135deg,#eff6ff,#ecfeff)!important;border-color:#bae6fd!important}
.hdm-contact-special{background:linear-gradient(135deg,#fff7ed,#fffbeb)!important;border-color:#fed7aa!important}
.hdm-contact-row strong{color:#08234f;font-weight:1000}.hdm-contact-row:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(15,35,86,.08)}
.hdm-contact-empty{background:#fff7ed!important;border-color:#fed7aa!important;color:#9a3412!important}
@media(max-width:720px){.hdm-review-login-card{grid-template-columns:48px 1fr;align-items:start}.hdm-review-login-icon{width:48px;height:48px;border-radius:16px}.hdm-review-login-btn{grid-column:1 / -1;width:100%;min-width:0}.hdm-review-form-head{padding:15px}.hdm-review-form-head h3{font-size:20px}}

/* ===== V4: Facilities use original DB icons from /img/facroom/ ===== */
.hdm-facroom-modern{
  position:relative;
  padding:4px 0 10px;
}
.hdm-facroom-modern::before{
  content:"";
  position:absolute;
  inset:-10px -10px auto auto;
  width:170px;
  height:170px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(14,165,233,.12),transparent 68%);
  pointer-events:none;
}
.hdm-facroom-sub{
  position:relative;
  margin:0 0 22px;
  color:#334155;
  font-size:15px;
  font-weight:900;
  line-height:1.7;
}
.hdm-facroom-grid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px 18px;
}
.hdm-facroom-item{
  display:grid;
  grid-template-columns:54px minmax(0,1fr);
  align-items:center;
  gap:13px;
  min-height:74px;
  padding:12px 14px;
  border:1px solid rgba(186,230,253,.95);
  border-radius:22px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  box-shadow:0 12px 30px rgba(15,35,86,.06);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.hdm-facroom-item:hover{
  transform:translateY(-3px);
  border-color:#7dd3fc;
  box-shadow:0 20px 45px rgba(15,35,86,.11);
}
.hdm-facroom-icon{
  width:54px;
  height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:linear-gradient(135deg,#eff6ff,#ecfeff);
  border:1px solid #dbeafe;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85),0 10px 22px rgba(14,165,233,.10);
  overflow:hidden;
}
.hdm-facroom-icon img{
  width:38px;
  height:38px;
  object-fit:contain;
  filter:drop-shadow(0 5px 10px rgba(37,99,235,.12));
}
.hdm-facroom-name{
  min-width:0;
  color:#173057;
  font-size:14px;
  font-weight:950;
  line-height:1.55;
  word-break:break-word;
}
@media(max-width:1080px){
  .hdm-facroom-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:720px){
  .hdm-facroom-sub{font-size:14px;margin-bottom:16px}
  .hdm-facroom-grid{grid-template-columns:1fr;gap:10px}
  .hdm-facroom-item{min-height:66px;border-radius:19px;padding:10px 12px;grid-template-columns:48px 1fr}
  .hdm-facroom-icon{width:48px;height:48px;border-radius:16px}
  .hdm-facroom-icon img{width:34px;height:34px}
  .hdm-facroom-name{font-size:13px}
}


/* ===== V5 Production Polish: stronger hero, premium gallery, sticky contact, cleaner review form ===== */
.hdm-page{
  background:
    radial-gradient(circle at 8% 10%,rgba(14,165,233,.10),transparent 28%),
    radial-gradient(circle at 92% 6%,rgba(250,204,21,.10),transparent 24%),
    linear-gradient(180deg,#f7fbff 0%,#eef7ff 44%,#ffffff 100%)!important;
}
.hdm-top-map{
  height:360px;
  border-bottom:1px solid rgba(186,230,253,.75);
}
.hdm-top-map::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:
    linear-gradient(135deg,rgba(255,255,255,.70) 0%,rgba(255,255,255,.20) 36%,rgba(14,165,233,.10) 100%),
    repeating-linear-gradient(45deg,rgba(37,99,235,.08) 0 3px,transparent 3px 34px);
  mix-blend-mode:normal;
}
.hdm-top-map::after{
  z-index:2;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,0) 42%,rgba(247,251,255,.88));
}
.hdm-top-map-embed{z-index:1}.hdm-top-map-embed iframe{filter:saturate(1.18) contrast(1.04) brightness(1.02)}
.hdm-map-glass.hdm-hero-polish{
  bottom:34px;
  align-items:center;
  padding:24px;
  border-radius:34px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.96);
  box-shadow:0 26px 80px rgba(15,35,86,.20), inset 0 1px 0 rgba(255,255,255,.95);
}
.hdm-hero-copy h1{margin:12px 0 4px!important;font-size:clamp(34px,4vw,56px)!important;line-height:1.05!important;color:#061632!important;letter-spacing:-1.2px!important;text-shadow:0 10px 26px rgba(15,35,86,.10)}
.hdm-hero-copy h2{margin:0 0 10px;color:#155ac9;font-size:18px;font-weight:1000;letter-spacing:.02em}.hdm-hero-copy p{max-width:760px!important;color:#334155!important}
.hdm-hero-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.hdm-hero-tags span{display:inline-flex;align-items:center;height:34px;padding:0 12px;border-radius:999px;background:linear-gradient(135deg,#eff6ff,#ecfeff);border:1px solid #cfe8ff;color:#1e3a8a;font-size:12px;font-weight:1000;box-shadow:0 8px 18px rgba(15,35,86,.06)}
.hdm-hero-actions{display:flex;flex-direction:column;gap:10px;min-width:174px}.hdm-mini-btn-soft{background:linear-gradient(135deg,#0f766e,#14b8a6,#22d3ee)!important}.hdm-mini-btn-map{background:linear-gradient(135deg,#f97316,#facc15)!important;color:#7c4700!important}
.hdm-gallery-card{position:relative;box-shadow:0 28px 80px rgba(15,35,86,.14)!important}.hdm-gallery-card::before{content:"";position:absolute;inset:-1px;border-radius:32px;background:linear-gradient(135deg,rgba(14,165,233,.22),rgba(250,204,21,.10),rgba(236,72,153,.08));z-index:-1;filter:blur(12px);opacity:.75}.hdm-gallery-title-v5{align-items:flex-end!important}.hdm-gallery-all-btn{border:1px solid #bae6fd;background:linear-gradient(135deg,#eff6ff,#ecfeff);color:#155ac9;border-radius:999px;padding:10px 13px;font-weight:1000;cursor:pointer;box-shadow:0 10px 24px rgba(15,35,86,.07)}
.hdm-gallery-main{height:545px}.hdm-gallery-main::before{content:"กดรูปเพื่อดูภาพใหญ่";position:absolute;right:16px;bottom:16px;z-index:3;padding:10px 13px;border-radius:999px;background:rgba(255,255,255,.92);color:#0f3b86;font-size:12px;font-weight:1000;box-shadow:0 14px 28px rgba(15,35,86,.16);backdrop-filter:blur(12px)}
.hdm-thumbs{padding-top:16px}.hdm-thumbs button{position:relative;flex-basis:122px;height:82px;border-radius:18px}.hdm-thumbs button::after{content:"";position:absolute;inset:0;border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(8,35,79,.18));opacity:.45}.hdm-thumbs button.is-active{border-color:#38bdf8;box-shadow:0 14px 30px rgba(14,165,233,.20)}
.hdm-tab-nav{gap:10px;padding:14px}.hdm-tab-nav button{display:inline-flex;align-items:center;gap:7px;min-height:44px;padding:11px 15px;background:#fff;border-color:#dbeafe;box-shadow:0 8px 18px rgba(15,35,86,.045)}.hdm-tab-nav button::before{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:#eff6ff;color:#155ac9;font-size:12px}.hdm-tab-nav button:nth-child(1)::before{content:"฿"}.hdm-tab-nav button:nth-child(2)::before{content:"i"}.hdm-tab-nav button:nth-child(3)::before{content:"✓"}.hdm-tab-nav button:nth-child(4)::before{content:"★"}.hdm-tab-nav button:nth-child(5)::before{content:"⌖"}.hdm-tab-nav button:nth-child(6)::before{content:"?"}.hdm-tab-nav button.is-active::before{background:rgba(255,255,255,.92);color:#155ac9}.hdm-tab-panel{padding:32px}.hdm-tabs{box-shadow:0 24px 70px rgba(15,35,86,.11)!important}
.hdm-room-card{border-radius:30px;background:linear-gradient(135deg,#fff 0%,#f8fbff 70%,#ecfeff 100%)}.hdm-room-photo{position:relative}.hdm-room-photo::after{content:"ดูแกลเลอรี่";position:absolute;left:10px;bottom:10px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.92);color:#0f3b86;font-size:11px;font-weight:1000}.hdm-price-box{border-left:0;background:linear-gradient(180deg,#fff7ed,#fff);border:1px solid #fed7aa;border-radius:22px;padding:14px;align-items:center;text-align:center}.hdm-price-box b{font-size:34px}
.hdm-sidebar{align-self:start}.hdm-contact-card{position:sticky;top:104px;z-index:6;border-radius:30px!important;overflow:hidden}.hdm-contact-card::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#155ac9,#22d3ee,#facc15)}.hdm-contact-row{border-radius:17px!important}.hdm-contact-row img{background:linear-gradient(180deg,#fff,#eef6ff)}.hdm-booking-btn{background:linear-gradient(135deg,#f97316,#facc15)!important;color:#7c4700!important;box-shadow:0 16px 36px rgba(249,115,22,.20)!important}
.hdm-facroom-grid{gap:16px}.hdm-facroom-item{background:linear-gradient(135deg,#ffffff 0%,#f8fbff 76%,#ecfeff 100%);border-color:#dbeafe}.hdm-facroom-icon{background:linear-gradient(135deg,#e0f2fe,#ffffff)}.hdm-facroom-item:hover .hdm-facroom-icon img{transform:scale(1.08)}.hdm-facroom-icon img{transition:transform .22s ease}
.hdm-review-form-collapsible{display:none;margin-top:16px}.hdm-review-form-collapsible.is-open{display:block;animation:hdmFade .25s ease}.hdm-review-open-btn{width:100%;margin:16px 0 0;border:0;border-radius:18px;padding:14px 16px;background:linear-gradient(135deg,#155ac9,#0ea5e9);color:#fff;font-weight:1000;cursor:pointer;box-shadow:0 16px 36px rgba(37,99,235,.22)}
.hdm-review-overview{background:linear-gradient(135deg,#fff,#f8fbff 70%,#ecfeff)!important;border-radius:28px}.hdm-review-big b{color:#155ac9}
.hdm-lightbox{background:rgba(3,14,33,.88);backdrop-filter:blur(10px)}.hdm-lightbox img{box-shadow:0 34px 90px rgba(0,0,0,.45)}.hdm-lightbox .hdm-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border:0;border-radius:999px;background:rgba(255,255,255,.16);color:#fff;font-size:34px;line-height:1;cursor:pointer}.hdm-lightbox .hdm-lightbox-prev{left:24px}.hdm-lightbox .hdm-lightbox-next{right:24px}.hdm-lightbox .hdm-lightbox-count{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);padding:9px 13px;border-radius:999px;background:rgba(255,255,255,.16);color:#fff;font-weight:900;font-size:12px}
.hdm-floating-contact{box-shadow:0 -18px 50px rgba(15,35,86,.18);backdrop-filter:blur(16px)}.hdm-floating-contact a{position:relative;overflow:hidden}.hdm-floating-contact a::before{margin-right:5px}.hdm-float-call::before{content:"☎"}.hdm-float-line::before{content:"LINE";font-size:10px}.hdm-float-facebook::before{content:"f"}.hdm-float-map::before{content:"⌖"}
@media(max-width:1080px){.hdm-map-glass.hdm-hero-polish{align-items:flex-start}.hdm-hero-actions{flex-direction:row;flex-wrap:wrap;min-width:0}.hdm-hero-actions .hdm-mini-btn{min-width:132px}.hdm-contact-card{position:static}.hdm-gallery-main{height:430px}.hdm-tab-panel{padding:24px}}
@media(max-width:720px){.hdm-top-map{height:390px}.hdm-map-glass.hdm-hero-polish{bottom:18px;padding:18px;border-radius:26px}.hdm-hero-copy h1{font-size:30px!important}.hdm-hero-copy h2{font-size:15px}.hdm-hero-tags span{height:30px;font-size:11px}.hdm-hero-actions{display:grid;grid-template-columns:1fr 1fr;width:100%}.hdm-hero-actions .hdm-mini-btn{min-width:0;padding:11px 12px}.hdm-gallery-main{height:320px;border-radius:22px}.hdm-gallery-main::before{font-size:11px;right:10px;bottom:10px}.hdm-thumbs button{flex-basis:92px;height:64px}.hdm-gallery-title-v5{align-items:flex-start!important}.hdm-gallery-all-btn{padding:8px 11px}.hdm-tab-nav{top:0;padding:10px}.hdm-tab-nav button{font-size:12px;min-height:40px;padding:9px 11px}.hdm-room-card{grid-template-columns:1fr}.hdm-price-box{align-items:flex-start;text-align:left}.hdm-facroom-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px}.hdm-facroom-item{display:flex;flex-direction:column;align-items:center;text-align:center;min-height:118px}.hdm-facroom-name{font-size:12px}.hdm-review-open-btn{border-radius:16px}.hdm-lightbox .hdm-lightbox-nav{width:44px;height:44px;font-size:28px}.hdm-lightbox .hdm-lightbox-prev{left:10px}.hdm-lightbox .hdm-lightbox-next{right:10px}.hdm-floating-contact{grid-template-columns:repeat(4,1fr)}}

/* ===== V6 Map-first hero + full modern tabs ===== */
.hdm-top-map{
  height:340px!important;
  background:#dff6ff!important;
  overflow:hidden!important;
  border-bottom:1px solid rgba(186,230,253,.9)!important;
  box-shadow:inset 0 -1px 0 rgba(15,35,86,.06)!important;
}
.hdm-top-map::after{
  background:
    linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,0) 34%,rgba(247,251,255,.22) 100%)!important;
  pointer-events:none!important;
}
.hdm-top-map-embed iframe,
.hdm-top-map-embed div{
  min-height:100%;
}
.hdm-map-tools{
  position:absolute!important;
  left:50%!important;
  right:auto!important;
  bottom:16px!important;
  z-index:4!important;
  transform:translateX(-50%)!important;
  display:flex!important;
  justify-content:flex-end!important;
  pointer-events:none!important;
}
.hdm-map-tool-panel{
  pointer-events:auto!important;
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  padding:10px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.88)!important;
  border:1px solid rgba(219,234,254,.96)!important;
  box-shadow:0 18px 48px rgba(15,35,86,.16)!important;
  backdrop-filter:blur(16px)!important;
}
.hdm-map-tool-panel span{
  display:inline-flex!important;
  align-items:center!important;
  gap:7px!important;
  padding:0 8px 0 4px!important;
  color:#0f3b86!important;
  font-size:12px!important;
  font-weight:1000!important;
  white-space:nowrap!important;
}
.hdm-map-tool-panel span::before{
  content:'📍';
  width:26px;height:26px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;background:#eff6ff;border:1px solid #dbeafe;
}
.hdm-map-tool-panel a{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:34px!important;
  padding:8px 12px!important;
  border-radius:999px!important;
  background:linear-gradient(135deg,#08234f,#155ac9,#38bdf8)!important;
  color:#fff!important;
  font-size:12px!important;
  font-weight:1000!important;
  box-shadow:0 10px 22px rgba(37,99,235,.18)!important;
  white-space:nowrap!important;
}
.hdm-map-tool-panel a:last-child{
  background:linear-gradient(135deg,#0f766e,#14b8a6,#22d3ee)!important;
}
.hdm-hero-strip{
  position:relative!important;
  z-index:5!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) 190px!important;
  gap:22px!important;
  align-items:center!important;
  margin-top:24px!important;
  margin-bottom:22px!important;
  padding:22px 24px!important;
  border-radius:32px!important;
  background:
    radial-gradient(circle at 84% 0%,rgba(34,211,238,.12),transparent 26%),
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,251,255,.96))!important;
  border:1px solid rgba(219,234,254,.98)!important;
  box-shadow:0 24px 70px rgba(15,35,86,.13)!important;
}
.hdm-hero-strip::before{
  content:'';
  position:absolute;inset:0;
  border-radius:32px;
  background:linear-gradient(90deg,rgba(14,165,233,.08),transparent 38%,rgba(250,204,21,.08));
  pointer-events:none;
}
.hdm-hero-strip .hdm-hero-copy,
.hdm-hero-strip .hdm-hero-actions{position:relative;z-index:1}
.hdm-hero-strip .hdm-hero-copy h1{
  margin:12px 0 4px!important;
  font-size:clamp(34px,4vw,54px)!important;
  line-height:1.05!important;
  color:#061632!important;
  letter-spacing:-1.1px!important;
  text-shadow:0 10px 26px rgba(15,35,86,.08)!important;
}
.hdm-hero-strip .hdm-hero-copy h2{
  margin:0 0 10px!important;
  color:#155ac9!important;
  font-size:18px!important;
  font-weight:1000!important;
}
.hdm-hero-strip .hdm-hero-copy p{
  margin:0!important;
  max-width:760px!important;
  color:#334155!important;
  font-weight:850!important;
  line-height:1.75!important;
}
.hdm-hero-strip .hdm-hero-actions{
  display:flex!important;
  flex-direction:column!important;
  gap:10px!important;
  min-width:0!important;
}
.hdm-hero-strip .hdm-mini-btn{
  width:100%!important;
  min-height:44px!important;
}
.hdm-breadcrumb{margin-top:0!important}

/* Full tabs: no old scrollbar on desktop */
.hdm-tab-nav{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(142px,1fr))!important;
  gap:10px!important;
  overflow:visible!important;
  padding:14px!important;
  background:rgba(255,255,255,.97)!important;
  border-bottom:1px solid #e0f2fe!important;
  backdrop-filter:blur(16px)!important;
  scrollbar-width:none!important;
}
.hdm-tab-nav::-webkit-scrollbar{display:none!important}
.hdm-tab-nav button{
  position:relative!important;
  flex:unset!important;
  width:100%!important;
  min-height:50px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  white-space:normal!important;
  line-height:1.22!important;
  text-align:center!important;
  padding:11px 12px!important;
  border-radius:18px!important;
  background:linear-gradient(180deg,#ffffff,#f8fbff)!important;
  border:1px solid #dbeafe!important;
  color:#1e3a8a!important;
  box-shadow:0 10px 22px rgba(15,35,86,.055)!important;
}
.hdm-tab-nav button::before{
  width:24px;height:24px;flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;
  background:#eff6ff;border:1px solid #dbeafe;
  color:#155ac9;font-size:13px;
  box-shadow:0 6px 14px rgba(15,35,86,.06);
}
.hdm-tab-nav button[data-tab-target="rooms"]::before{content:'฿'}
.hdm-tab-nav button[data-tab-target="detail"]::before{content:'i';font-weight:1000}
.hdm-tab-nav button[data-tab-target="facilities"]::before{content:'✓'}
.hdm-tab-nav button[data-tab-target="reviews"]::before{content:'★'}
.hdm-tab-nav button[data-tab-target="map"]::before{content:'◆'}
.hdm-tab-nav button[data-tab-target="faq"]::before{content:'?';font-weight:1000}
.hdm-tab-nav button span{display:block;min-width:0}
.hdm-tab-nav button:hover{
  transform:translateY(-2px)!important;
  border-color:#bae6fd!important;
  box-shadow:0 16px 34px rgba(15,35,86,.10)!important;
}
.hdm-tab-nav button.is-active{
  background:linear-gradient(135deg,#08234f,#155ac9 54%,#38bdf8)!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:0 16px 38px rgba(37,99,235,.24)!important;
}
.hdm-tab-nav button.is-active::before{
  background:rgba(255,255,255,.95)!important;
  color:#155ac9!important;
  border-color:rgba(255,255,255,.8)!important;
}

@media(max-width:1080px){
  .hdm-top-map{height:310px!important}
  .hdm-hero-strip{grid-template-columns:1fr!important;gap:16px!important;margin-top:18px!important;padding:20px!important}
  .hdm-hero-strip .hdm-hero-actions{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important}
  .hdm-tab-nav{position:sticky!important;top:74px!important;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))!important}
}
@media(max-width:720px){
  .hdm-top-map{height:255px!important}
  .hdm-map-tools{left:13px!important;right:13px!important;bottom:12px!important;transform:none!important;width:auto!important;justify-content:center!important}
  .hdm-map-tool-panel{width:100%!important;justify-content:center!important;border-radius:22px!important;gap:6px!important;flex-wrap:wrap!important;padding:8px!important}
  .hdm-map-tool-panel span{width:100%!important;justify-content:center!important;padding:0!important;font-size:11px!important}
  .hdm-map-tool-panel a{flex:1 1 120px!important;min-height:36px!important;font-size:11px!important;padding:8px 10px!important}
  .hdm-hero-strip{margin-top:16px!important;margin-bottom:16px!important;border-radius:26px!important;padding:18px!important}
  .hdm-hero-strip .hdm-hero-copy h1{font-size:30px!important;letter-spacing:-.4px!important}
  .hdm-hero-strip .hdm-hero-copy h2{font-size:15px!important}
  .hdm-hero-strip .hdm-hero-tags span{height:30px!important;font-size:11px!important}
  .hdm-hero-strip .hdm-hero-actions{grid-template-columns:1fr 1fr!important;gap:8px!important}
  .hdm-hero-strip .hdm-hero-actions .hdm-mini-btn:first-child{grid-column:span 2!important}
  .hdm-tab-nav{top:64px!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;padding:10px!important}
  .hdm-tab-nav button{min-height:48px!important;border-radius:16px!important;font-size:12px!important;padding:9px 8px!important}
  .hdm-tab-nav button::before{width:22px;height:22px;font-size:12px!important}
}

/* ===== V7: Map minimal + premium focus polish ===== */
.hdm-top-map{
  height:320px!important;
  background:#e8f7ff!important;
  border-bottom:1px solid rgba(186,230,253,.9)!important;
}
/* ให้แผนที่จริงอ่านง่าย ไม่โดนลายกราฟิกทับ */
.hdm-top-map::before{display:none!important;content:none!important}
.hdm-top-map::after{
  z-index:2!important;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,0) 62%,rgba(247,251,255,.26))!important;
}
.hdm-top-map-embed iframe{filter:saturate(1.08) contrast(1.02) brightness(1.01)!important}
.hdm-map-tools{
  left:auto!important;
  right:max(20px,calc((100vw - 1180px)/2 + 20px))!important;
  bottom:18px!important;
  transform:none!important;
  width:auto!important;
  justify-content:flex-end!important;
}
.hdm-map-tool-panel-v7,
.hdm-map-tool-panel{
  padding:8px 9px!important;
  border-radius:999px!important;
  gap:8px!important;
  background:rgba(255,255,255,.92)!important;
  border:1px solid rgba(219,234,254,.96)!important;
  box-shadow:0 16px 42px rgba(15,35,86,.16)!important;
}
.hdm-map-tool-panel-v7 span,
.hdm-map-tool-panel span{
  font-size:12px!important;
  color:#0f3b86!important;
  opacity:.96!important;
}
.hdm-map-tool-panel-v7 a,
.hdm-map-open-only{
  min-height:38px!important;
  padding:9px 16px!important;
  background:linear-gradient(135deg,#08234f,#155ac9 58%,#0ea5e9)!important;
  color:#fff!important;
  box-shadow:0 12px 26px rgba(37,99,235,.20)!important;
}
.hdm-map-tool-panel-v7 a::after,
.hdm-map-open-only::after{content:'↗';margin-left:7px;font-size:12px;opacity:.9}

.hdm-hero-strip{
  margin-top:22px!important;
  border-radius:34px!important;
  background:
    radial-gradient(circle at 86% 16%,rgba(14,165,233,.16),transparent 24%),
    radial-gradient(circle at 100% 100%,rgba(250,204,21,.13),transparent 24%),
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,251,255,.97))!important;
  box-shadow:0 28px 80px rgba(15,35,86,.13)!important;
}
.hdm-hero-strip::after{
  content:'';
  position:absolute;
  left:22px;right:22px;bottom:-10px;height:22px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(14,165,233,.12),transparent 70%);
  filter:blur(10px);
  pointer-events:none;
}
.hdm-hero-actions-v7{display:grid!important;grid-template-columns:1fr!important;gap:10px!important;min-width:190px!important}
.hdm-mini-btn-share{
  border:0!important;
  cursor:pointer!important;
  background:linear-gradient(135deg,#7c3aed,#ec4899,#f97316)!important;
  color:#fff!important;
  font-weight:1000!important;
  font-family:inherit!important;
}
.hdm-mini-btn-share::before{content:'↗';margin-right:7px}

/* Tabs: ใช้ 5 เมนูหลัก ไม่ซ้ำแผนที่ */
.hdm-tab-nav{
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
  gap:11px!important;
  padding:15px!important;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,251,255,.96))!important;
}
.hdm-tab-nav button[data-tab-target="map"]{display:none!important}
.hdm-tab-nav button[data-tab-target="faq"]::before{content:'?'!important;font-weight:1000!important}
.hdm-tab-nav button{
  min-height:54px!important;
  border-radius:20px!important;
}
.hdm-tab-nav button.is-active{
  transform:translateY(-1px)!important;
}
.hdm-tabs{
  border-radius:32px!important;
  overflow:hidden!important;
}

/* Contact / trust cards ให้ดูน่าเชื่อถือขึ้น */
.hdm-contact-card{box-shadow:0 28px 80px rgba(15,35,86,.14)!important}
.hdm-contact-row{
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease!important;
}
.hdm-contact-row:hover{
  transform:translateY(-2px)!important;
  border-color:#bae6fd!important;
  box-shadow:0 12px 28px rgba(15,35,86,.08)!important;
}
.hdm-benefits-list div,.hdm-why-list div{
  transition:transform .2s ease, box-shadow .2s ease!important;
}
.hdm-benefits-list div:hover,.hdm-why-list div:hover{
  transform:translateY(-2px)!important;
  box-shadow:0 12px 26px rgba(15,35,86,.07)!important;
}

/* Preview map ให้ดูคล้ายแผนที่ขึ้น */
.hdm-fake-map{
  background:
    linear-gradient(0deg,rgba(255,255,255,.18),rgba(255,255,255,.18)),
    radial-gradient(circle at 25% 28%,rgba(34,197,94,.16),transparent 18%),
    radial-gradient(circle at 74% 56%,rgba(14,165,233,.13),transparent 18%),
    linear-gradient(135deg,#e8fff1 0%,#eaf8ff 48%,#fff9df 100%)!important;
}
.hdm-fake-map:before{
  background-image:
    linear-gradient(28deg,transparent 46%,rgba(59,130,246,.30) 47%,rgba(59,130,246,.30) 49%,transparent 50%),
    linear-gradient(118deg,transparent 38%,rgba(255,255,255,.78) 39%,rgba(255,255,255,.78) 42%,transparent 43%),
    linear-gradient(0deg,transparent 48%,rgba(148,163,184,.30) 49%,rgba(148,163,184,.30) 50%,transparent 51%)!important;
  background-size:240px 150px,260px 170px,180px 130px!important;
  opacity:.85!important;
}
.hdm-fake-map:after{
  background-image:
    linear-gradient(70deg,transparent 44%,rgba(20,184,166,.35) 45%,rgba(20,184,166,.35) 47%,transparent 48%),
    linear-gradient(150deg,transparent 42%,rgba(251,146,60,.28) 43%,rgba(251,146,60,.28) 45%,transparent 46%)!important;
  background-size:330px 190px,290px 180px!important;
  opacity:.75!important;
}

/* มือถือ: ปุ่มชัด ไม่ซ้ำ และไม่มีแผนที่ลอยด้านล่าง */
@media(max-width:1080px){
  .hdm-tab-nav{grid-template-columns:repeat(3,minmax(0,1fr))!important}
  .hdm-hero-actions-v7{grid-template-columns:repeat(3,minmax(0,1fr))!important;min-width:0!important}
}
@media(max-width:720px){
  .hdm-top-map{height:245px!important}
  .hdm-map-tools{left:13px!important;right:13px!important;bottom:12px!important;justify-content:center!important}
  .hdm-map-tool-panel-v7,.hdm-map-tool-panel{width:100%!important;border-radius:20px!important;padding:8px!important}
  .hdm-map-tool-panel-v7 span,.hdm-map-tool-panel span{width:auto!important;flex:1 1 auto!important;justify-content:flex-start!important;font-size:11px!important}
  .hdm-map-tool-panel-v7 a,.hdm-map-open-only{flex:0 0 auto!important;min-height:36px!important;padding:8px 12px!important;font-size:11px!important}
  .hdm-hero-actions-v7{grid-template-columns:1fr 1fr!important;gap:8px!important;width:100%!important}
  .hdm-hero-actions-v7 .hdm-mini-btn:first-child{grid-column:span 2!important}
  .hdm-tab-nav{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;padding:10px!important}
  .hdm-tab-nav button{min-height:48px!important;border-radius:16px!important;font-size:12px!important}
  .hdm-floating-contact{grid-template-columns:repeat(3,1fr)!important}
}


/* ===== V8 softer tabs + useful widgets ===== */
.hdm-widget-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:24px}.hdm-widget-card{position:relative;padding:18px 18px 16px;border-radius:24px;background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(240,249,255,.96));border:1px solid #d9edff;box-shadow:0 14px 32px rgba(15,35,86,.07);overflow:hidden}.hdm-widget-card::before{content:"";position:absolute;inset:auto -30px -35px auto;width:110px;height:110px;border-radius:999px;background:radial-gradient(circle,rgba(56,189,248,.13),transparent 66%)}.hdm-widget-card span{display:block;font-size:12px;font-weight:1000;letter-spacing:.06em;text-transform:uppercase;color:#0284c7;margin-bottom:10px}.hdm-widget-card b{display:block;font-size:34px;line-height:1;color:#0f172a;letter-spacing:-.04em;margin-bottom:6px}.hdm-widget-card small{display:block;color:#64748b;font-size:13px;font-weight:800}

.hdm-tab-nav{display:grid!important;grid-template-columns:repeat(5,minmax(0,1fr))!important;gap:10px!important;overflow:visible!important;padding:14px 14px 8px!important;position:sticky;top:88px}.hdm-tab-nav button{justify-content:center!important;min-width:0!important;white-space:nowrap!important;text-align:center!important;padding:12px 10px!important;font-size:13px!important;letter-spacing:0!important;border-radius:18px!important;border:1px solid #dcecff!important;background:linear-gradient(180deg,#ffffff,#f8fbff)!important;color:#234b8f!important;box-shadow:0 10px 22px rgba(15,35,86,.05)!important}.hdm-tab-nav button::before{display:none!important}.hdm-tab-nav button span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hdm-tab-nav button:hover{transform:translateY(-1px);background:linear-gradient(180deg,#ffffff,#f0f9ff)!important;border-color:#bfe4ff!important}.hdm-tab-nav button.is-active{background:linear-gradient(135deg,#4f8ff8,#39bdf8)!important;color:#fff!important;border-color:transparent!important;box-shadow:0 16px 36px rgba(56,189,248,.24)!important}

.hdm-map-tool-panel.hdm-map-tool-panel-v7{padding:10px 12px!important}.hdm-map-tool-panel.hdm-map-tool-panel-v7 span{display:none!important}.hdm-map-open-only{background:linear-gradient(135deg,#4f8ff8,#39bdf8)!important;color:#fff!important;box-shadow:0 12px 26px rgba(56,189,248,.24)!important}
.hdm-mini-btn{box-shadow:0 14px 28px rgba(56,189,248,.18)!important}.hdm-mini-btn-share{background:linear-gradient(135deg,#7c9cfb,#48c6ef)!important;color:#fff!important}.hdm-mini-btn-soft{background:linear-gradient(135deg,#11b8c9,#31d0aa)!important}

.hdm-contact-card .hdm-side-head h3,.hdm-trust-card .hdm-side-head h3,.hdm-why-card .hdm-side-head h3{letter-spacing:-.02em}

@media(max-width:1080px){.hdm-widget-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.hdm-tab-nav{grid-template-columns:repeat(3,minmax(0,1fr))!important;top:76px}.hdm-tab-nav button{font-size:12.5px!important}}
@media(max-width:720px){.hdm-widget-strip{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.hdm-widget-card{padding:14px 14px 13px;border-radius:20px}.hdm-widget-card b{font-size:28px}.hdm-widget-card small{font-size:12px}.hdm-tab-nav{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;padding:10px!important;top:0}.hdm-tab-nav button{min-height:42px!important;padding:10px 8px!important;font-size:12px!important;border-radius:16px!important}.hdm-map-tool-panel.hdm-map-tool-panel-v7{padding:8px!important}.hdm-map-open-only{font-size:11px!important;padding:8px 11px!important}}


/* ===== V9 Gallery arrows + sharper premium cards ===== */
.hdm-gallery-nav-shell{
  position:relative;
  display:grid;
  grid-template-columns:42px minmax(0,1fr) 42px;
  align-items:center;
  gap:8px;
  margin-top:14px;
}
.hdm-thumbs{
  overflow:hidden!important;
  scrollbar-width:none!important;
  -ms-overflow-style:none!important;
  padding:2px!important;
  scroll-behavior:smooth;
}
.hdm-thumbs::-webkit-scrollbar{display:none!important}
.hdm-gallery-arrow{
  width:42px;
  height:76px;
  border:1px solid #d7ebff;
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff,#eef8ff);
  color:#155ac9;
  font-size:34px;
  line-height:1;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 14px 28px rgba(15,35,86,.08);
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease, background .18s ease;
}
.hdm-gallery-arrow:hover{
  transform:translateY(-2px);
  background:linear-gradient(135deg,#f8fbff,#e0f2fe);
  box-shadow:0 20px 38px rgba(15,35,86,.13);
}
.hdm-gallery-arrow:disabled{
  opacity:.35;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}
.hdm-thumbs button{
  flex:0 0 126px!important;
  height:80px!important;
  border-radius:18px!important;
}
.hdm-thumbs button img{
  transform:scale(1.001);
  transition:transform .24s ease, filter .24s ease;
}
.hdm-thumbs button:hover img{transform:scale(1.06);filter:saturate(1.08) contrast(1.04)}

.hdm-gallery-card,.hdm-summary-card,.hdm-tabs,.hdm-side-card,.hdm-widget-card{
  border-color:rgba(198,226,255,.95)!important;
  box-shadow:0 26px 62px rgba(15,35,86,.11)!important;
}
.hdm-gallery-card,.hdm-tabs,.hdm-side-card,.hdm-summary-card{
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,252,255,.96))!important;
}
.hdm-room-card{
  border:1px solid rgba(190,224,255,.95)!important;
  box-shadow:0 18px 44px rgba(15,35,86,.09)!important;
}
.hdm-room-card:hover{
  transform:translateY(-5px)!important;
  box-shadow:0 30px 70px rgba(15,35,86,.15)!important;
}
.hdm-price-box{
  background:linear-gradient(180deg,#fffaf3,#fff)!important;
  border-color:#ffd9a8!important;
}
.hdm-contact-row{
  background:linear-gradient(180deg,#ffffff,#f7fbff)!important;
  border:1px solid #dbeafe!important;
  box-shadow:0 10px 22px rgba(15,35,86,.045)!important;
  transition:transform .18s ease, box-shadow .18s ease;
}
a.hdm-contact-row:hover{
  transform:translateX(3px);
  box-shadow:0 16px 30px rgba(15,35,86,.08)!important;
}
.hdm-trust-card .hdm-contact-row,.hdm-why-card .hdm-why-item{
  background:linear-gradient(180deg,#ffffff,#f8fbff)!important;
}
.hdm-tab-nav button{
  box-shadow:0 12px 24px rgba(15,35,86,.055)!important;
}
.hdm-tab-nav button.is-active{
  background:linear-gradient(135deg,#3b82f6,#38bdf8)!important;
  box-shadow:0 18px 38px rgba(56,189,248,.25)!important;
}
.hdm-widget-card{
  transition:transform .22s ease, box-shadow .22s ease;
}
.hdm-widget-card:hover{
  transform:translateY(-4px);
  box-shadow:0 28px 62px rgba(15,35,86,.13)!important;
}
.hdm-widget-card b{
  background:linear-gradient(135deg,#08234f,#0284c7);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

@media(max-width:720px){
  .hdm-gallery-nav-shell{
    grid-template-columns:36px minmax(0,1fr) 36px;
    gap:6px;
  }
  .hdm-gallery-arrow{
    width:36px;
    height:62px;
    border-radius:15px;
    font-size:28px;
  }
  .hdm-thumbs button{
    flex-basis:88px!important;
    height:60px!important;
    border-radius:14px!important;
  }
}



/* ===== V10 Glass Motion Theme ===== */
.hdm-page{position:relative;overflow:hidden;background:radial-gradient(circle at 12% 10%,rgba(56,189,248,.18),transparent 28%),radial-gradient(circle at 88% 18%,rgba(250,204,21,.12),transparent 24%),radial-gradient(circle at 76% 74%,rgba(14,165,233,.10),transparent 30%),linear-gradient(180deg,#f6fbff 0%,#eef8ff 46%,#fff 100%)!important}
.hdm-page:before,.hdm-page:after{content:"";position:fixed;width:360px;height:360px;border-radius:999px;z-index:0;pointer-events:none;opacity:.42;filter:blur(28px);animation:hdmGlassOrb 14s ease-in-out infinite}
.hdm-page:before{left:-120px;top:24%;background:radial-gradient(circle,rgba(56,189,248,.38),rgba(56,189,248,0) 68%)}
.hdm-page:after{right:-130px;top:48%;background:radial-gradient(circle,rgba(45,212,191,.26),rgba(45,212,191,0) 70%);animation-delay:-5s}
@keyframes hdmGlassOrb{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(18px,-22px,0) scale(1.08)}}
.hdm-wrap,.hdm-top-map,.hdm-hero-strip,.hdm-intro-grid,.hdm-content-grid,.hdm-breadcrumb{position:relative;z-index:1}
.hdm-gallery-card,.hdm-summary-card,.hdm-tabs,.hdm-side-card,.hdm-widget-card,.hdm-hero-strip{background:linear-gradient(145deg,rgba(255,255,255,.78),rgba(255,255,255,.54))!important;border:1px solid rgba(255,255,255,.72)!important;box-shadow:0 24px 68px rgba(15,35,86,.13),inset 0 1px 0 rgba(255,255,255,.78)!important;backdrop-filter:blur(18px) saturate(1.12);-webkit-backdrop-filter:blur(18px) saturate(1.12)}
.hdm-gallery-card,.hdm-summary-card,.hdm-tabs,.hdm-contact-card,.hdm-trust-card,.hdm-why-card,.hdm-widget-card,.hdm-room-card{transform-style:preserve-3d;will-change:transform}
.hdm-gallery-card:after,.hdm-summary-card:after,.hdm-tabs:after,.hdm-contact-card:after,.hdm-widget-card:after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:linear-gradient(120deg,rgba(255,255,255,.42),rgba(255,255,255,0) 34%,rgba(56,189,248,.08) 68%,rgba(255,255,255,.16));opacity:.72;mix-blend-mode:screen}
.hdm-gallery-card,.hdm-summary-card,.hdm-tabs,.hdm-side-card,.hdm-widget-card{transition:transform .28s cubic-bezier(.2,.8,.2,1),box-shadow .28s ease,border-color .28s ease,background .28s ease}
.hdm-gallery-card:hover,.hdm-summary-card:hover,.hdm-tabs:hover,.hdm-side-card:hover,.hdm-widget-card:hover{border-color:rgba(147,197,253,.95)!important;box-shadow:0 34px 88px rgba(15,35,86,.17),inset 0 1px 0 rgba(255,255,255,.88)!important}
.hdm-room-card{position:relative;overflow:hidden}
.hdm-room-card:before{content:"";position:absolute;inset:-1px;z-index:0;pointer-events:none;background:radial-gradient(circle at var(--hdm-x,20%) var(--hdm-y,20%),rgba(56,189,248,.18),transparent 28%),linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,0));opacity:0;transition:opacity .25s ease}
.hdm-room-card:hover:before{opacity:1}.hdm-room-card>*{position:relative;z-index:1}
.hdm-gallery-main:after{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(8,35,79,.16)),radial-gradient(circle at 74% 20%,rgba(255,255,255,.18),transparent 22%)!important}
.hdm-gallery-main img{transition:transform .65s cubic-bezier(.2,.8,.2,1),filter .45s ease!important}
.hdm-gallery-main:hover img{transform:scale(1.038)!important;filter:saturate(1.08) contrast(1.04)}
.hdm-mini-btn,.hdm-booking-btn,.hdm-review-open-btn,.hdm-gallery-all-btn,.hdm-map-open-only{position:relative;overflow:hidden}
.hdm-mini-btn:after,.hdm-booking-btn:after,.hdm-review-open-btn:after,.hdm-gallery-all-btn:after,.hdm-map-open-only:after{content:"";position:absolute;top:-40%;bottom:-40%;width:34%;left:-46%;pointer-events:none;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.48),rgba(255,255,255,0));transform:rotate(18deg);animation:hdmShine 4.6s ease-in-out infinite}
@keyframes hdmShine{0%,62%{left:-48%}100%{left:125%}}
.hdm-tab-nav{background:rgba(255,255,255,.68)!important;border-bottom:1px solid rgba(186,230,253,.72)!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.hdm-tab-nav button{background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(248,251,255,.74))!important;border-color:rgba(191,219,254,.82)!important}
.hdm-tab-nav button.is-active{background:linear-gradient(135deg,rgba(59,130,246,.98),rgba(56,189,248,.96))!important}
.hdm-contact-row img{transition:transform .22s ease,box-shadow .22s ease}
.hdm-contact-row:hover img{transform:scale(1.08) rotate(-3deg);box-shadow:0 12px 24px rgba(14,165,233,.18)}
.hdm-trust-card .hdm-contact-row:hover,.hdm-why-card .hdm-why-item:hover{transform:translateX(4px)}
.hdm-metric-grid b,.hdm-widget-card b,.hdm-price-box b{animation:hdmNumberBreath 4.8s ease-in-out infinite}
@keyframes hdmNumberBreath{0%,100%{filter:drop-shadow(0 0 0 rgba(56,189,248,0))}50%{filter:drop-shadow(0 8px 18px rgba(56,189,248,.16))}}
.hdm-floating-contact{background:rgba(255,255,255,.76)!important;border-top:1px solid rgba(186,230,253,.85)!important;backdrop-filter:blur(18px) saturate(1.12)!important;-webkit-backdrop-filter:blur(18px) saturate(1.12)!important}
@media(max-width:720px){.hdm-page:before,.hdm-page:after{width:260px;height:260px;opacity:.34}.hdm-gallery-card,.hdm-summary-card,.hdm-tabs,.hdm-side-card,.hdm-widget-card,.hdm-hero-strip{backdrop-filter:blur(12px) saturate(1.08);-webkit-backdrop-filter:blur(12px) saturate(1.08)}}
@media (prefers-reduced-motion:reduce){.hdm-page:before,.hdm-page:after,.hdm-mini-btn:after,.hdm-booking-btn:after,.hdm-review-open-btn:after,.hdm-gallery-all-btn:after,.hdm-map-open-only:after,.hdm-metric-grid b,.hdm-widget-card b,.hdm-price-box b{animation:none!important}.hdm-gallery-card,.hdm-summary-card,.hdm-tabs,.hdm-side-card,.hdm-widget-card,.hdm-room-card{transform:none!important}}



/* ===== V11 Summary 3D + Modern Share System ===== */
.hdm-summary-card.hdm-share-summary{
  border-radius:34px!important;
  background:
    radial-gradient(circle at 18% 0%,rgba(255,255,255,.94),rgba(255,255,255,0) 34%),
    radial-gradient(circle at 100% 20%,rgba(34,211,238,.20),transparent 36%),
    linear-gradient(145deg,rgba(255,255,255,.86),rgba(239,248,255,.72))!important;
  box-shadow:
    0 30px 82px rgba(15,35,86,.18),
    0 12px 22px rgba(14,165,233,.08),
    inset 0 1px 0 rgba(255,255,255,.9)!important;
  border:1px solid rgba(214,236,255,.95)!important;
}
.hdm-summary-card.hdm-share-summary::before{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:28px;
  pointer-events:none;
  border:1px solid rgba(255,255,255,.72);
  box-shadow:inset 0 0 30px rgba(56,189,248,.08);
}
.hdm-summary-card .hdm-eyebrow{
  display:inline-flex;
  width:max-content;
  padding:9px 13px;
  border-radius:999px;
  background:linear-gradient(135deg,#eff6ff,#e0f2fe);
  border:1px solid #bae6fd;
  color:#2563eb!important;
  letter-spacing:.08em!important;
}
.hdm-metric-grid div{
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,251,255,.84))!important;
  border:1px solid #dbeafe!important;
  box-shadow:0 14px 28px rgba(15,35,86,.07), inset 0 1px 0 rgba(255,255,255,.8);
  transform:translateZ(10px);
}
.hdm-like-button{
  min-height:54px!important;
  border-radius:22px!important;
  background:
    radial-gradient(circle at 20% 20%,rgba(255,255,255,.74),transparent 34%),
    linear-gradient(135deg,#ffe4ee,#ffd4df 60%,#fff3f6)!important;
  border:1px solid rgba(255,182,193,.75)!important;
  box-shadow:
    0 18px 34px rgba(236,72,153,.13),
    inset 0 1px 0 rgba(255,255,255,.92)!important;
  color:#be123c!important;
  font-weight:1000!important;
  transition:transform .22s ease, box-shadow .22s ease;
}
.hdm-like-button:hover{
  transform:translateY(-2px) scale(1.01);
  box-shadow:0 24px 44px rgba(236,72,153,.20), inset 0 1px 0 rgba(255,255,255,.95)!important;
}
.hdm-like-button .heart-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:999px;
  background:rgba(255,255,255,.78);
  margin-right:7px;
  animation:hdmHeartBeat 2.4s ease-in-out infinite;
}
@keyframes hdmHeartBeat{
  0%,100%{transform:scale(1)}
  15%{transform:scale(1.12)}
  30%{transform:scale(1)}
}

.hdm-share-panel{
  margin-top:14px;
  padding:14px;
  border-radius:26px;
  background:
    radial-gradient(circle at top right,rgba(56,189,248,.16),transparent 36%),
    linear-gradient(180deg,rgba(255,255,255,.92),rgba(248,252,255,.76));
  border:1px solid #dbeafe;
  box-shadow:0 18px 38px rgba(15,35,86,.08), inset 0 1px 0 rgba(255,255,255,.85);
}
.hdm-share-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:11px;
}
.hdm-share-head span{
  color:#0f3b86;
  font-size:13px;
  font-weight:1000;
}
.hdm-share-head b{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:7px 10px;
  border-radius:999px;
  background:linear-gradient(135deg,#eff6ff,#ecfeff);
  border:1px solid #bae6fd;
  color:#0284c7;
  font-size:12px;
  font-weight:1000;
  white-space:nowrap;
}
.hdm-share-actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:9px;
}
.hdm-share-btn{
  min-height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #dbeafe;
  border-radius:16px;
  background:rgba(255,255,255,.88);
  color:#0f3b86;
  font-size:12px;
  font-weight:1000;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  text-decoration:none!important;
}
.hdm-share-btn:hover{
  transform:translateY(-2px);
  border-color:#93c5fd;
  box-shadow:0 14px 26px rgba(15,35,86,.09);
}
.hdm-share-native{
  background:linear-gradient(135deg,#155ac9,#38bdf8)!important;
  color:#fff!important;
}
.hdm-share-fb{
  background:linear-gradient(135deg,#eff6ff,#e0f2fe)!important;
  color:#1d4ed8!important;
}
.hdm-share-line{
  background:linear-gradient(135deg,#ecfdf5,#d1fae5)!important;
  color:#047857!important;
}
.hdm-share-copy{
  background:linear-gradient(135deg,#fff7ed,#ffedd5)!important;
  color:#c2410c!important;
}
.hdm-share-panel small{
  display:block;
  margin-top:10px;
  color:#64748b;
  font-size:11px;
  line-height:1.45;
  font-weight:800;
  text-align:center;
}
.hdm-contact-actions{
  margin-top:12px!important;
}
@media(max-width:720px){
  .hdm-summary-card.hdm-share-summary{
    width:100%;
    max-width:430px;
    margin-left:auto;
    margin-right:auto;
  }
  .hdm-share-actions{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .hdm-share-btn{
    min-height:42px;
    font-size:12px;
  }
}
@media (prefers-reduced-motion: reduce){
  .hdm-like-button .heart-icon{animation:none!important}
}



/* ===== V12 Index-style floating share widget ===== */
.hdm-share-panel{display:none!important}
.hdm-floating-share-v12{position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:80;display:flex;flex-direction:column;align-items:center;gap:9px;padding:10px;border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(236,248,255,.76));border:1px solid rgba(191,219,254,.88);box-shadow:0 24px 58px rgba(15,35,86,.18),inset 0 1px 0 rgba(255,255,255,.9);backdrop-filter:blur(18px) saturate(1.15);-webkit-backdrop-filter:blur(18px) saturate(1.15)}
.hdm-share-total{width:58px;height:58px;border-radius:22px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;background:linear-gradient(145deg,#172033,#0f172a);box-shadow:0 16px 32px rgba(15,23,42,.24),inset 0 1px 0 rgba(255,255,255,.18);text-align:center}
.hdm-share-total b{display:block;font-size:15px;line-height:1;font-weight:1000;letter-spacing:-.02em}.hdm-share-total small{display:block;margin-top:4px;font-size:9px;line-height:1;font-weight:900;letter-spacing:.08em;opacity:.88}
.hdm-share-circle{width:48px;height:48px;border:0;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;color:#fff!important;font-size:16px;line-height:1;font-weight:1000;cursor:pointer;text-decoration:none!important;box-shadow:0 14px 28px rgba(15,35,86,.13),inset 0 1px 0 rgba(255,255,255,.20);transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}
.hdm-share-circle:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 20px 38px rgba(15,35,86,.20),inset 0 1px 0 rgba(255,255,255,.25);filter:saturate(1.08)}
.hdm-share-circle-fb{background:linear-gradient(135deg,#1d4ed8,#0ea5e9)}.hdm-share-circle-line{background:linear-gradient(135deg,#04a84f,#22c55e);font-size:11px}.hdm-share-circle-x{background:linear-gradient(135deg,#020617,#111827)}.hdm-share-circle-native{background:linear-gradient(135deg,#0284c7,#38bdf8)}.hdm-share-circle-copy{background:linear-gradient(135deg,#f97316,#ef4444)}
.hdm-share-status-mini{position:absolute;right:72px;top:50%;transform:translateY(-50%);min-width:180px;max-width:220px;padding:9px 12px;border-radius:16px;color:#0f3b86;background:rgba(255,255,255,.94);border:1px solid #dbeafe;box-shadow:0 16px 34px rgba(15,35,86,.12);font-size:12px;font-weight:900;line-height:1.45;opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s ease}.hdm-share-status-mini:not(:empty){opacity:1;transform:translateY(-50%) translateX(-4px)}
.hdm-contact-actions{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:9px!important}.hdm-contact-actions a{min-height:42px!important;border-radius:16px!important;background:rgba(255,255,255,.85)!important;border:1px solid #dbeafe!important;box-shadow:0 12px 24px rgba(15,35,86,.06)!important}
@media(max-width:900px){.hdm-floating-share-v12{left:14px;right:14px;top:auto;bottom:14px;transform:none;flex-direction:row;justify-content:center;gap:10px;padding:10px;border-radius:30px;background:linear-gradient(135deg,rgba(236,254,255,.92),rgba(255,247,237,.86))}.hdm-share-total{width:76px;height:56px;border-radius:22px}.hdm-share-total b{font-size:17px}.hdm-share-total small{font-size:10px}.hdm-share-circle{width:52px;height:52px;border-radius:18px}.hdm-share-status-mini{left:50%;right:auto;top:auto;bottom:74px;transform:translateX(-50%);text-align:center}.hdm-share-status-mini:not(:empty){transform:translateX(-50%) translateY(-4px)}body{padding-bottom:86px}}
@media(max-width:420px){.hdm-floating-share-v12{left:10px;right:10px;gap:8px;padding:9px}.hdm-share-total{width:72px;height:54px}.hdm-share-circle{width:48px;height:48px;border-radius:17px}}
@media(max-width:370px){.hdm-share-total{width:66px}.hdm-share-circle{width:43px;height:43px;font-size:14px}.hdm-share-circle-line{font-size:10px}}


/* ===== V13 share counter is persistent after first random seed ===== */

/* ===== V14 Mobile share/contact collision fix + summary action polish ===== */
.hdm-summary-actions-v14{
  grid-template-columns:repeat(auto-fit,minmax(72px,1fr))!important;
}
.hdm-summary-actions-v14 a,
.hdm-summary-actions-v14 button{
  min-height:44px!important;
  border-radius:17px!important;
  border:1px solid rgba(186,230,253,.95)!important;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(240,249,255,.82))!important;
  color:#0f3b86!important;
  box-shadow:0 12px 25px rgba(15,35,86,.06)!important;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease!important;
}
.hdm-summary-actions-v14 button{
  font:inherit;
  cursor:pointer;
}
.hdm-summary-actions-v14 a:hover,
.hdm-summary-actions-v14 button:hover{
  transform:translateY(-2px);
  border-color:#93c5fd!important;
  box-shadow:0 18px 34px rgba(15,35,86,.11)!important;
}
.hdm-summary-actions-v14 button[data-hdm-share-native]{
  background:linear-gradient(135deg,#155ac9,#38bdf8)!important;
  color:#fff!important;
  border-color:transparent!important;
}
.hdm-contact-card{
  max-height:calc(100vh - 126px);
  overflow:auto!important;
  scrollbar-width:thin;
}
.hdm-contact-card::-webkit-scrollbar{width:6px}
.hdm-contact-card::-webkit-scrollbar-thumb{background:#bfdbfe;border-radius:999px}
.hdm-room-card{
  grid-template-columns:204px minmax(0,1fr) 154px;
}
.hdm-room-copy h3{
  letter-spacing:-.02em;
}
.hdm-room-copy p{
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.hdm-price-box small:empty{display:none}
@media(max-width:1080px){
  .hdm-contact-card{max-height:none;overflow:hidden!important}
  .hdm-room-card{grid-template-columns:180px 1fr}
}
@media(max-width:900px){
  .hdm-floating-contact{
    bottom:100px!important;
    z-index:79!important;
    left:14px!important;
    right:14px!important;
    box-shadow:0 -14px 36px rgba(15,35,86,.14)!important;
  }
  .hdm-floating-share-v12{
    z-index:80!important;
  }
  body{
    padding-bottom:176px!important;
  }
  .hdm-content-grid{
    margin-bottom:178px!important;
  }
}
@media(max-width:720px){
  .hdm-room-card{grid-template-columns:1fr!important}
  .hdm-room-copy p{-webkit-line-clamp:5}
  .hdm-summary-actions-v14{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .hdm-summary-actions-v14 button[data-hdm-share-native]{grid-column:span 2}
  .hdm-floating-contact{
    padding:8px!important;
    gap:7px!important;
  }
  .hdm-floating-contact a{
    min-height:42px!important;
    border-radius:16px!important;
    font-size:12px!important;
  }
}
@media(max-width:420px){
  .hdm-floating-contact{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    bottom:94px!important;
    left:10px!important;
    right:10px!important;
  }
  .hdm-floating-contact a:nth-child(3){grid-column:auto!important}
  .hdm-floating-contact a{font-size:11px!important;min-height:40px!important}
  body{padding-bottom:164px!important}
  .hdm-content-grid{margin-bottom:166px!important}
  .hdm-share-circle{width:46px!important;height:46px!important}
  .hdm-share-total{width:68px!important;height:52px!important}
}


/* ===== V15 Summary Home button ===== */
.hdm-home-button-v15{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:52px;
  margin-top:13px;
  border-radius:20px;
  text-decoration:none!important;
  color:#075985!important;
  font-size:15px;
  font-weight:1000;
  letter-spacing:.04em;
  background:
    radial-gradient(circle at 18% 18%,rgba(255,255,255,.86),transparent 34%),
    linear-gradient(135deg,#e0f7ff 0%,#bdeeff 45%,#8fdcff 100%);
  border:1px solid rgba(125,211,252,.92);
  box-shadow:
    0 18px 36px rgba(14,165,233,.16),
    inset 0 1px 0 rgba(255,255,255,.92);
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, filter .2s ease;
}
.hdm-home-button-v15::before{
  content:"⌂";
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  margin-right:8px;
  border-radius:999px;
  color:#0284c7;
  background:rgba(255,255,255,.76);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.92);
}
.hdm-home-button-v15::after{
  content:"";
  position:absolute;
  top:-60%;
  bottom:-60%;
  left:-48%;
  width:38%;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.58),rgba(255,255,255,0));
  transform:rotate(18deg);
  animation:hdmHomeShineV15 4.8s ease-in-out infinite;
}
.hdm-home-button-v15:hover{
  transform:translateY(-2px);
  border-color:#38bdf8;
  filter:saturate(1.06);
  box-shadow:
    0 24px 46px rgba(14,165,233,.23),
    inset 0 1px 0 rgba(255,255,255,.96);
}
@keyframes hdmHomeShineV15{
  0%,64%{left:-52%}
  100%{left:124%}
}
@media(max-width:720px){
  .hdm-home-button-v15{min-height:50px;border-radius:18px;font-size:14px}
}


/* ===== V16 Summary Home icon polish ===== */
.hdm-home-button-v16{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  min-height:54px;
  margin-top:13px;
  border-radius:22px;
  text-decoration:none!important;
  color:#0f3b86!important;
  font-size:15px;
  font-weight:1000;
  letter-spacing:.02em;
  background:
    radial-gradient(circle at 18% 18%,rgba(255,255,255,.86),transparent 34%),
    linear-gradient(135deg,#eefbff 0%,#caefff 48%,#8ed8ff 100%);
  border:1px solid rgba(125,211,252,.92);
  box-shadow:
    0 18px 36px rgba(14,165,233,.16),
    inset 0 1px 0 rgba(255,255,255,.92);
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, filter .2s ease;
}
.hdm-home-button-v16:hover{
  transform:translateY(-2px) scale(1.01);
  border-color:#38bdf8;
  filter:saturate(1.06);
  box-shadow:
    0 24px 46px rgba(14,165,233,.23),
    inset 0 1px 0 rgba(255,255,255,.96);
}
.hdm-home-button-v16::after{
  content:"";
  position:absolute;
  top:-60%;
  bottom:-60%;
  left:-48%;
  width:38%;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.58),rgba(255,255,255,0));
  transform:rotate(18deg);
  animation:hdmHomeShineV16 4.8s ease-in-out infinite;
}
.hdm-home-icon{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.94);
  flex:0 0 30px;
}
.hdm-home-icon img{
  display:block;
  width:16px;
  height:16px;
}
.hdm-home-button-v16 > span:last-child{
  position:relative;
  z-index:1;
}
@keyframes hdmHomeShineV16{
  0%,64%{left:-52%}
  100%{left:124%}
}
@media(max-width:720px){
  .hdm-home-button-v16{min-height:52px;border-radius:20px;font-size:14px}
}


/* ===== V17 Summary button match + like shine ===== */
.hdm-like-button-v17,
.hdm-home-button-v17{
  box-sizing:border-box;
  width:100%;
  min-height:56px;
  padding:14px 16px;
  border-radius:22px;
}
.hdm-like-button-v17{
  position:relative;
  overflow:hidden;
  gap:10px!important;
}
.hdm-like-button-v17::after{
  content:"";
  position:absolute;
  top:-60%;
  bottom:-60%;
  left:-48%;
  width:38%;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.54),rgba(255,255,255,0));
  transform:rotate(18deg);
  animation:hdmLikeShineV17 4.8s ease-in-out infinite;
}
.hdm-like-button-v17 > span{
  position:relative;
  z-index:1;
}
.hdm-like-button-v17 .heart-icon,
.hdm-home-button-v17 .hdm-home-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.94);
  flex:0 0 30px;
}
.hdm-like-button-v17 .heart-icon{
  margin-right:0;
  font-size:15px;
  line-height:1;
}
.hdm-home-button-v17{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-top:13px;
  text-decoration:none!important;
  color:#0f3b86!important;
  font-size:15px;
  font-weight:1000;
  letter-spacing:.02em;
  background:
    radial-gradient(circle at 18% 18%,rgba(255,255,255,.86),transparent 34%),
    linear-gradient(135deg,#eefbff 0%,#caefff 48%,#8ed8ff 100%);
  border:1px solid rgba(125,211,252,.92);
  box-shadow:
    0 18px 36px rgba(14,165,233,.16),
    inset 0 1px 0 rgba(255,255,255,.92);
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, filter .2s ease;
}
.hdm-home-button-v17::after{
  content:"";
  position:absolute;
  top:-60%;
  bottom:-60%;
  left:-48%;
  width:38%;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.58),rgba(255,255,255,0));
  transform:rotate(18deg);
  animation:hdmHomeShineV16 4.8s ease-in-out infinite;
}
.hdm-home-button-v17:hover{
  transform:translateY(-2px) scale(1.01);
  border-color:#38bdf8;
  filter:saturate(1.06);
  box-shadow:
    0 24px 46px rgba(14,165,233,.23),
    inset 0 1px 0 rgba(255,255,255,.96);
}
.hdm-home-button-v17 .hdm-home-icon{
  position:relative;
  z-index:1;
}
.hdm-home-button-v17 .hdm-home-icon img{
  display:block;
  width:16px;
  height:16px;
}
.hdm-home-button-v17 > span:last-child{
  position:relative;
  z-index:1;
}
@keyframes hdmLikeShineV17{
  0%,64%{left:-52%}
  100%{left:124%}
}
@media(max-width:720px){
  .hdm-like-button-v17,
  .hdm-home-button-v17{min-height:54px;border-radius:20px;font-size:14px}
}


/* ===== V18 widget strip remove + home icon balance ===== */
.hdm-home-button-v17 .hdm-home-icon img{
  width:19px!important;
  height:19px!important;
}
@media(max-width:720px){
  .hdm-home-button-v17 .hdm-home-icon img{
    width:19px!important;
    height:19px!important;
  }
}


/* ===== V19 Tab header clear + review score white ===== */
.hdm-tabs .hdm-tab-nav{
  position:relative!important;
  top:auto!important;
  z-index:5!important;
}
.hdm-tabs .hdm-tab-panel{
  position:relative!important;
  z-index:1!important;
  padding-top:30px!important;
}
.hdm-tabs .hdm-section-title:first-child{
  margin-top:0!important;
}
.hdm-review-big b{
  color:#ffffff!important;
  text-shadow:0 8px 22px rgba(0,0,0,.16);
}
@media(max-width:720px){
  .hdm-tabs .hdm-tab-panel{padding-top:24px!important}
}


/* ===== V20 Facebook booking CTA polish ===== */
.hdm-booking-btn-v20{
  position:relative;
  min-height:58px;
  margin:16px 14px 14px!important;
  padding:13px 18px 13px 58px!important;
  border-radius:22px!important;
  display:flex!important;
  flex-direction:column;
  align-items:flex-start!important;
  justify-content:center!important;
  gap:2px;
  overflow:hidden;
  text-decoration:none!important;
  color:#fff!important;
  background:
    radial-gradient(circle at 18% 18%,rgba(255,255,255,.26),transparent 30%),
    linear-gradient(135deg,#ff8a1d 0%,#ffc928 54%,#1fa8ff 100%)!important;
  border:1px solid rgba(255,255,255,.68);
  box-shadow:
    0 18px 36px rgba(249,115,22,.23),
    0 10px 22px rgba(14,165,233,.14),
    inset 0 1px 0 rgba(255,255,255,.45)!important;
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.hdm-booking-btn-v20::before{
  content:"f";
  position:absolute;
  left:18px;
  top:50%;
  transform:translateY(-50%);
  width:30px;
  height:30px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.94);
  color:#1877f2;
  font-family:Arial, sans-serif;
  font-weight:1000;
  font-size:20px;
  line-height:1;
  box-shadow:0 10px 18px rgba(15,35,86,.14);
}
.hdm-booking-btn-v20::after{
  content:"";
  position:absolute;
  top:-70%;
  bottom:-70%;
  left:-44%;
  width:34%;
  background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.55),rgba(255,255,255,0));
  transform:rotate(18deg);
  animation:hdmBookingShineV20 4.9s ease-in-out infinite;
  pointer-events:none;
}
.hdm-booking-btn-v20 span,
.hdm-booking-btn-v20 small{
  position:relative;
  z-index:1;
}
.hdm-booking-btn-v20 span{
  font-size:15px;
  font-weight:1000;
  line-height:1.15;
  text-shadow:0 2px 8px rgba(15,23,42,.16);
}
.hdm-booking-btn-v20 small{
  font-size:11px;
  font-weight:900;
  color:rgba(255,255,255,.90);
}
.hdm-booking-btn-v20:hover{
  transform:translateY(-2px);
  filter:saturate(1.08);
  box-shadow:
    0 24px 46px rgba(249,115,22,.28),
    0 14px 30px rgba(14,165,233,.18),
    inset 0 1px 0 rgba(255,255,255,.50)!important;
}
@keyframes hdmBookingShineV20{
  0%,64%{left:-50%}
  100%{left:124%}
}
@media(max-width:720px){
  .hdm-booking-btn-v20{
    min-height:56px;
    border-radius:20px!important;
  }
}


/* ===== V21 generic booking icon + live review prep ===== */
.hdm-booking-btn-v21{
  position:relative;
  min-height:62px;
  margin:16px 14px 14px!important;
  padding:13px 16px!important;
  border-radius:22px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:12px;
  overflow:hidden;
  text-decoration:none!important;
  color:#fff!important;
  background:
    radial-gradient(circle at 16% 18%,rgba(255,255,255,.26),transparent 28%),
    linear-gradient(135deg,#ff9a1f 0%,#ffc928 52%,#6cc7df 100%)!important;
  border:1px solid rgba(255,255,255,.68);
  box-shadow:
    0 18px 36px rgba(249,115,22,.22),
    0 10px 22px rgba(14,165,233,.14),
    inset 0 1px 0 rgba(255,255,255,.45)!important;
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.hdm-booking-btn-v21::after{
  content:"";
  position:absolute;
  top:-70%;
  bottom:-70%;
  left:-44%;
  width:34%;
  background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.55),rgba(255,255,255,0));
  transform:rotate(18deg);
  animation:hdmBookingShineV21 4.9s ease-in-out infinite;
  pointer-events:none;
}
.hdm-booking-icon,
.hdm-booking-copy{
  position:relative;
  z-index:1;
}
.hdm-booking-icon{
  width:34px;
  height:34px;
  border-radius:999px;
  flex:0 0 34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.94);
  box-shadow:0 10px 18px rgba(15,35,86,.14);
}
.hdm-booking-icon img{
  width:18px;
  height:18px;
  display:block;
}
.hdm-booking-copy{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.hdm-booking-copy b{
  font-size:15px;
  line-height:1.15;
  font-weight:1000;
  color:#ffffff;
  text-shadow:0 2px 8px rgba(15,23,42,.16);
}
.hdm-booking-copy small{
  font-size:11px;
  font-weight:900;
  color:rgba(255,255,255,.92);
}
.hdm-booking-btn-v21:hover{
  transform:translateY(-2px);
  filter:saturate(1.08);
  box-shadow:
    0 24px 46px rgba(249,115,22,.28),
    0 14px 30px rgba(14,165,233,.18),
    inset 0 1px 0 rgba(255,255,255,.50)!important;
}
@keyframes hdmBookingShineV21{
  0%,64%{left:-50%}
  100%{left:124%}
}
@media(max-width:720px){
  .hdm-booking-btn-v21{min-height:58px;border-radius:20px!important}
  .hdm-booking-copy b{font-size:14px}
}


/* ===== V22 booking button calendar icon polish ===== */
.hdm-booking-btn-v21{
  isolation:isolate;
  background:
    radial-gradient(circle at 14% 50%,rgba(255,255,255,.24),transparent 23%),
    radial-gradient(circle at 88% 22%,rgba(255,255,255,.18),transparent 18%),
    linear-gradient(135deg,#ff9a1f 0%,#ffd02b 48%,#26c6e8 100%)!important;
}
.hdm-booking-btn-v21::before{
  content:"";
  position:absolute;
  left:13px;
  top:50%;
  width:46px;
  height:46px;
  transform:translateY(-50%);
  border-radius:999px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.48);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.42);
  z-index:0;
  pointer-events:none;
}
.hdm-booking-icon{
  width:38px;
  height:38px;
  flex-basis:38px;
  background:linear-gradient(180deg,#ffffff,#eef8ff);
  box-shadow:
    0 12px 22px rgba(15,35,86,.18),
    inset 0 1px 0 rgba(255,255,255,.9);
  transform:rotate(-3deg);
}
.hdm-booking-icon::after{
  content:"";
  position:absolute;
  right:-2px;
  top:5px;
  width:7px;
  height:7px;
  border-radius:999px;
  background:#facc15;
  box-shadow:0 0 0 3px rgba(250,204,21,.22);
}
.hdm-booking-icon img{
  width:28px;
  height:28px;
  filter:drop-shadow(0 3px 3px rgba(15,35,86,.14));
}
.hdm-booking-btn-v21:hover .hdm-booking-icon{
  transform:rotate(0deg) scale(1.06);
}
@media(max-width:720px){
  .hdm-booking-icon{width:36px;height:36px;flex-basis:36px}
  .hdm-booking-icon img{width:26px;height:26px}
  .hdm-booking-btn-v21::before{left:12px;width:44px;height:44px}
}

/* ===== V24 final checked booking button calendar icon center fix ===== */
.hdm-booking-btn-v21::before{
  left:12px;
  width:48px;
  height:48px;
}
.hdm-booking-icon{
  width:40px;
  height:40px;
  flex:0 0 40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  overflow:visible;
  transform:none;
}
.hdm-booking-icon::after{
  right:1px;
  top:3px;
  width:6px;
  height:6px;
  opacity:.9;
}
.hdm-booking-icon img{
  width:31px;
  height:31px;
  display:block;
  object-fit:contain;
  object-position:center center;
  transform:none;
}
.hdm-booking-btn-v21:hover .hdm-booking-icon{
  transform:scale(1.05);
}
@media(max-width:720px){
  .hdm-booking-btn-v21::before{left:11px;width:46px;height:46px}
  .hdm-booking-icon{width:38px;height:38px;flex:0 0 38px}
  .hdm-booking-icon img{width:30px;height:30px}
}


/* ===== V25 LIVE urgent fix: remove header-to-map gap + hide old ShareThis widget ===== */
.hdm-page{
  padding-top:0!important;
  margin-top:0!important;
}
.hdm-page .hdm-top-map{
  margin-top:0!important;
}
@media(max-width:1080px){
  .hdm-page{padding-top:0!important;margin-top:0!important}
}
@media(max-width:720px){
  .hdm-page{padding-top:0!important;margin-top:0!important}
}
/* Hide legacy ShareThis / old social floating bar that may still be loaded by the main template */
body .st-sticky-share-buttons,
body .st-sticky-share-buttons *,
body .sharethis-sticky-share-buttons,
body .sharethis-sticky-share-buttons *,
body .sharethis-inline-share-buttons,
body .sharethis-inline-share-buttons *,
body div[id^="st-"],
body div[class^="st-"],
body div[class*=" st-"],
body .st-total,
body .st-btn,
body .st-label,
body .st-logo,
body .st-count{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}


/* ===== V26 urgent hotfix: stable room/service card hover + clean FAQ display ===== */
.hdm-room-card,
.hdm-room-card:hover{
  transform:none!important;
}
.hdm-room-card:hover{
  border-color:rgba(125,211,252,.95)!important;
  box-shadow:0 24px 62px rgba(14,165,233,.16),0 0 0 1px rgba(186,230,253,.82),inset 0 1px 0 rgba(255,255,255,.95)!important;
}
.hdm-room-card:before{
  background:radial-gradient(circle at var(--hdm-x,50%) var(--hdm-y,50%),rgba(56,189,248,.20),transparent 34%),linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,0))!important;
}
.hdm-room-card:hover:before{opacity:1!important}
.hdm-faq-clean{
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
  color:#334155;
  font-size:14px;
  line-height:1.9;
}
.hdm-faq-clean br+br{display:block;content:"";margin-top:8px}
.hdm-faq-q span{
  line-height:1.55;
  overflow-wrap:anywhere;
}


/* ===== V27 Stable tabs/room cards: no tilt, no shrink, glow only ===== */
.hdm-tabs,
.hdm-tabs:hover,
.hdm-tabs:focus-within,
.hdm-room-card,
.hdm-room-card:hover,
.hdm-room-card:focus-within,
.hdm-price-box,
.hdm-price-box:hover{
  transform:none!important;
  scale:1!important;
}
.hdm-tabs{
  transform-style:flat!important;
  will-change:auto!important;
}
.hdm-room-card{
  min-width:0!important;
  overflow:visible!important;
  transition:box-shadow .22s ease, border-color .22s ease, background .22s ease, filter .22s ease!important;
}
.hdm-room-card:hover,
.hdm-room-card:focus-within{
  border-color:rgba(56,189,248,.62)!important;
  box-shadow:0 24px 60px rgba(14,165,233,.16), 0 0 0 4px rgba(56,189,248,.10)!important;
  filter:saturate(1.02)!important;
}
.hdm-room-copy,
.hdm-room-copy h3,
.hdm-room-copy p,
.hdm-price-box{
  min-width:0!important;
  max-width:100%!important;
}
.hdm-room-card:hover .hdm-room-photo,
.hdm-room-card:hover .hdm-room-copy,
.hdm-room-card:hover .hdm-price-box{
  transform:none!important;
}
.hdm-room-copy p{
  word-break:break-word!important;
  overflow-wrap:anywhere!important;
}
.hdm-contact-row img{
  object-fit:contain!important;
  background:#fff!important;
}


/* ===== V28 Premium Contact Circle Icons ===== */
.hdm-contact-card .hdm-side-head{
  background:linear-gradient(135deg,#0f2f6f 0%,#1769d5 58%,#10b7e8 100%)!important;
}
.hdm-contact-row{
  align-items:center!important;
  gap:13px!important;
  min-height:58px!important;
  padding:12px 13px!important;
  background:rgba(255,255,255,.88)!important;
  border:1px solid rgba(186,230,253,.95)!important;
  box-shadow:0 10px 24px rgba(15,35,86,.045)!important;
  transform:none!important;
  transition:box-shadow .22s ease,border-color .22s ease,background .22s ease!important;
}
.hdm-contact-row:hover,
a.hdm-contact-row:hover{
  transform:none!important;
  background:#ffffff!important;
  border-color:#93c5fd!important;
  box-shadow:0 0 0 4px rgba(56,189,248,.12),0 18px 36px rgba(15,35,86,.10)!important;
}
.hdm-contact-row img{
  width:38px!important;
  height:38px!important;
  flex:0 0 38px!important;
  object-fit:contain!important;
  border-radius:50%!important;
  background:transparent!important;
  box-shadow:0 8px 18px rgba(15,35,86,.08)!important;
  transform:none!important;
  transition:filter .22s ease,box-shadow .22s ease!important;
}
.hdm-contact-row:hover img{
  transform:none!important;
  filter:saturate(1.08) brightness(1.02)!important;
  box-shadow:0 10px 24px rgba(14,165,233,.18)!important;
}
.hdm-contact-row span{
  display:block!important;
  min-width:0!important;
  color:#11284d!important;
  font-weight:850!important;
  line-height:1.48!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
}
.hdm-contact-row strong{
  color:#08234f!important;
  font-weight:1000!important;
}
.hdm-contact-note img,
.hdm-contact-special img,
.hdm-contact-empty img{
  width:32px!important;
  height:32px!important;
  flex-basis:32px!important;
  border-radius:12px!important;
  box-shadow:none!important;
}
@media(max-width:720px){
  .hdm-contact-row{min-height:56px!important;padding:11px 12px!important;gap:12px!important}
  .hdm-contact-row img{width:36px!important;height:36px!important;flex-basis:36px!important}
}


/* ===== V29 Complete Contact Circle Icons + mobile polish ===== */
.hdm-contact-card .hdm-side-head h3::after{
  content:"";display:inline-block;width:8px;height:8px;margin-left:7px;border-radius:50%;
  background:#facc15;box-shadow:0 0 0 5px rgba(250,204,21,.16);vertical-align:middle;
}
.hdm-contact-row[href*="youtube" i] img,
.hdm-contact-row[href*="youtu.be" i] img{
  border-radius:50%!important;
}
.hdm-contact-row:focus-visible{
  outline:3px solid rgba(56,189,248,.45)!important;
  outline-offset:3px!important;
}
@media(max-width:520px){
  .hdm-contact-card .hdm-side-head{padding:16px 15px!important}
  .hdm-contact-card .hdm-side-head h3{font-size:18px!important}
  .hdm-contact-row{margin:9px 11px!important;border-radius:16px!important}
  .hdm-contact-row span{font-size:13px!important;line-height:1.48!important}
}


/* ===== V31 Safe Floating Share Fix =====
   แก้ปุ่มแชร์ลอยหายหลังคลิก โดยไม่ใช้ MutationObserver เพื่อไม่ให้หน้าเว็บค้าง */
.hdm-page .hdm-floating-share-v12{
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-total,
.hdm-page .hdm-floating-share-v12 .hdm-share-circle{
  display:inline-flex!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-status-mini{
  pointer-events:none!important;
}


/* ===== V32 Strong Floating Share Fix ===== */
.hdm-page .hdm-floating-share-v12{
  display:flex!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-total,
.hdm-page .hdm-floating-share-v12 .hdm-share-circle,
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-fb,
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-line,
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-x,
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-native,
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-copy{
  display:inline-flex!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-total{
  flex-direction:column!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-status-mini{
  pointer-events:none!important;
}


/* ===== V33 Floating Share Real Fix =====
   ใช้ button ล้วนและบังคับ Layout แบบ Grid เพื่อไม่ให้ ShareThis/สคริปต์ภายนอกซ่อนปุ่มหลังคลิก */
.hdm-page .hdm-floating-share-v12{
  display:grid!important;
  grid-template-columns:58px!important;
  grid-auto-rows:auto!important;
  justify-items:center!important;
  align-items:center!important;
  gap:9px!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
  contain:layout paint!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-total,
.hdm-page .hdm-floating-share-v12 .hdm-share-circle{
  position:relative!important;
  display:inline-flex!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
  transform:none!important;
  flex:0 0 auto!important;
  margin:0!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-total{
  width:58px!important;
  height:58px!important;
  flex-direction:column!important;
  background:linear-gradient(145deg,#172033,#0f172a)!important;
  color:#fff!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-circle{
  width:48px!important;
  height:48px!important;
  border:0!important;
  border-radius:18px!important;
  appearance:none!important;
  -webkit-appearance:none!important;
}
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-fb{background:linear-gradient(135deg,#1d4ed8,#0ea5e9)!important;}
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-line{background:linear-gradient(135deg,#04a84f,#22c55e)!important;}
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-x{background:linear-gradient(135deg,#020617,#111827)!important;}
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-native{background:linear-gradient(135deg,#0284c7,#38bdf8)!important;}
.hdm-page .hdm-floating-share-v12 .hdm-share-circle-copy{background:linear-gradient(135deg,#f97316,#ef4444)!important;}
.hdm-page .hdm-floating-share-v12.hdm-share-repaired{
  animation:hdmShareRepairPulse .18s ease-out 1;
}
@keyframes hdmShareRepairPulse{from{filter:brightness(1.06)}to{filter:brightness(1)}}
@media(max-width:900px){
  .hdm-page .hdm-floating-share-v12{
    grid-template-columns:76px repeat(5,52px)!important;
    grid-auto-flow:column!important;
    justify-content:center!important;
  }
  .hdm-page .hdm-floating-share-v12 .hdm-share-total{width:76px!important;height:56px!important;}
  .hdm-page .hdm-floating-share-v12 .hdm-share-circle{width:52px!important;height:52px!important;}
}
@media(max-width:420px){
  .hdm-page .hdm-floating-share-v12{grid-template-columns:68px repeat(5,46px)!important;gap:8px!important;}
  .hdm-page .hdm-floating-share-v12 .hdm-share-total{width:68px!important;height:52px!important;}
  .hdm-page .hdm-floating-share-v12 .hdm-share-circle{width:46px!important;height:46px!important;}
}


/* ===== V34 Contact Icons from USE1 ===== */
.hdm-contact-row img{
  width:40px!important;
  height:40px!important;
  flex:0 0 40px!important;
  object-fit:contain!important;
  border-radius:50%!important;
  background:transparent!important;
  padding:0!important;
  box-shadow:none!important;
}
.hdm-contact-row:hover img{
  transform:scale(1.05)!important;
  box-shadow:none!important;
}
@media (max-width:640px){
  .hdm-contact-row img{
    width:40px!important;
    height:40px!important;
    flex-basis:40px!important;
  }
}
