:root{--navy:#071d36;--blue:#0e3a66;--gold:#d8a03b;--cream:#fff8ed;--text:#172033}*{box-sizing:border-box}body{font-family:'Be Vietnam Pro',Arial,sans-serif;color:var(--text);background:#fff}.navbar{background:rgba(7,29,54,.92);backdrop-filter:blur(14px)}.navbar .nav-link{color:#fff!important;font-weight:700}.btn-gold{background:linear-gradient(135deg,#d8a03b,#ffe09a);color:#071d36!important;font-weight:900;border:0}.hero{min-height:92vh;background:linear-gradient(110deg,rgba(7,29,54,.9),rgba(7,29,54,.55)),var(--hero,url('../img/hero.jpg')) center/cover;display:flex;align-items:center;color:#fff;padding-top:100px}.hero h1{font-size:clamp(44px,6vw,76px);font-weight:900;letter-spacing:-2px;line-height:1.05;max-width:820px}.hero .lead{font-size:22px;max-width:760px}.booking-bar{background:#fff;border-radius:28px;padding:22px;box-shadow:0 24px 80px rgba(7,29,54,.18);margin-top:-55px;position:relative;z-index:3}.section{padding:80px 0}.section-title{font-weight:900;color:var(--navy);font-size:38px}.room-card{border:0;border-radius:26px;overflow:hidden;box-shadow:0 18px 55px rgba(10,40,75,.12);height:100%;transition:.25s;background:#fff}.room-card:hover{transform:translateY(-6px)}.room-card img{height:235px;object-fit:cover;background:#e7eef5}.badge-kind{background:var(--cream);color:var(--blue);border:1px solid #f0d7a0}.price{color:var(--gold);font-weight:900;font-size:22px}.service{background:#fff;border-radius:24px;padding:28px;box-shadow:0 12px 40px rgba(7,29,54,.08);height:100%}.service .icon{font-size:34px}.gallery-img{width:100%;height:240px;object-fit:cover;border-radius:24px;background:#e7eef5}.contact-box{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-radius:30px;padding:35px}.footer{background:#06192f;color:#dbe7f5;padding:60px 0 24px}.copyright{border-top:1px solid rgba(255,255,255,.12);margin-top:30px;padding-top:20px;color:#9fb1c4}.wa-float{position:fixed;right:18px;bottom:18px;background:#25d366;color:#fff;text-decoration:none;border-radius:999px;padding:14px 22px;font-weight:900;box-shadow:0 15px 40px rgba(0,0,0,.25);z-index:99}.admin-wrap{background:#f3f6fb;min-height:100vh}.admin-card,.table-card{background:#fff;border-radius:22px;padding:24px;box-shadow:0 15px 55px rgba(7,29,54,.12)}.admin-sidebar{background:#071d36;color:#fff;min-height:100vh}.admin-sidebar a{display:block;color:#fff;text-decoration:none;padding:12px 16px;border-radius:12px;margin:4px 0}.admin-sidebar a:hover,.admin-sidebar a.active{background:rgba(255,255,255,.12)}.form-control,.form-select{border-radius:14px;padding:11px 14px}@media(max-width:768px){.booking-bar{margin-top:0;border-radius:0}.section{padding:55px 0}.hero{min-height:82vh}.room-card img{height:210px}}

/* ===================== ADMIN VIP UPGRADE ===================== */
.admin-vip-wrap,
.admin-login-vip{font-family:'Be Vietnam Pro',Arial,Helvetica,sans-serif!important;background:#f4f7fb;color:#0b1b31;min-height:100vh}
.admin-vip-shell{display:flex;min-height:100vh;background:radial-gradient(circle at top right,rgba(216,160,59,.16),transparent 32%),linear-gradient(135deg,#f7fbff,#eef3f9)}
.admin-vip-sidebar{width:285px;position:fixed;left:0;top:0;bottom:0;background:linear-gradient(180deg,#071d36,#0a2a4e 55%,#06172c);color:#fff;padding:22px 18px;z-index:1000;box-shadow:24px 0 70px rgba(7,29,54,.22);overflow-y:auto}
.admin-vip-brand{display:flex;align-items:center;gap:12px;padding:10px 10px 22px;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:18px}
.admin-vip-brand img{width:86px;height:46px;object-fit:contain;background:rgba(255,255,255,.06);border-radius:14px;padding:5px}
.admin-vip-brand strong{display:block;font-size:18px;line-height:1;color:#fff}.admin-vip-brand span{font-size:12px;color:#9fb8d5}
.admin-vip-section{font-size:11px;text-transform:uppercase;letter-spacing:1.4px;color:#83a2c7;margin:22px 12px 9px;font-weight:800}
.admin-vip-link{display:flex;align-items:center;gap:12px;color:#d9e8f7;text-decoration:none;padding:12px 13px;border-radius:16px;font-weight:700;margin:4px 0;transition:.2s;border:1px solid transparent}
.admin-vip-link span{width:26px;height:26px;display:grid;place-items:center;background:rgba(255,255,255,.08);border-radius:10px}.admin-vip-link b{font-size:14px}
.admin-vip-link:hover,.admin-vip-link.active{color:#071d36;background:linear-gradient(135deg,#ffcf72,#fff0bf);box-shadow:0 12px 32px rgba(216,160,59,.22);transform:translateX(3px)}
.admin-vip-link.logout{margin-top:16px;color:#ffd7d7}.admin-vip-link.logout:hover{background:#ffebeb;color:#9b1c1c}
.admin-vip-main{margin-left:285px;width:calc(100% - 285px);min-height:100vh}.admin-vip-topbar{height:82px;background:rgba(255,255,255,.88);backdrop-filter:blur(18px);border-bottom:1px solid rgba(10,38,72,.08);display:flex;align-items:center;justify-content:space-between;gap:18px;padding:0 30px;position:sticky;top:0;z-index:900;box-shadow:0 12px 45px rgba(7,29,54,.06)}
.admin-vip-title{font-size:20px;font-weight:900;color:#071d36}.admin-vip-subtitle{font-size:13px;color:#6b7c93}.admin-vip-top-actions{display:flex;align-items:center;gap:10px}.admin-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#071d36,#1d5e9d);color:#fff;font-weight:900;border:3px solid #fff;box-shadow:0 10px 25px rgba(7,29,54,.18)}.admin-menu-btn{display:none;border:0;background:#071d36;color:#fff;border-radius:14px;width:44px;height:44px;font-weight:900}
.admin-vip-content{padding:32px;max-width:1500px;margin:0 auto}.admin-page-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:28px}.admin-page-head h1{font-size:34px;font-weight:900;margin:0;color:#071d36;letter-spacing:-.8px}.admin-page-head p{margin:6px 0 0;color:#667792}.admin-kicker{text-transform:uppercase;letter-spacing:1.6px;color:#d39a31!important;font-weight:900;font-size:12px!important;margin-bottom:5px!important}
.vip-stat-card{border-radius:28px;padding:26px;min-height:190px;color:#fff;position:relative;overflow:hidden;box-shadow:0 24px 70px rgba(7,29,54,.15)}.vip-stat-card:after{content:'';position:absolute;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.16);right:-60px;top:-60px}.vip-stat-card span{font-size:34px;display:block;margin-bottom:22px}.vip-stat-card small{display:block;font-weight:700;opacity:.9}.vip-stat-card strong{font-size:34px;font-weight:900;display:block;letter-spacing:-1px}.vip-stat-card em{font-style:normal;font-size:13px;opacity:.85}.gradient-blue{background:linear-gradient(135deg,#0b2d55,#1565b1)}.gradient-gold{background:linear-gradient(135deg,#c8861c,#f4c160)}.gradient-green{background:linear-gradient(135deg,#08764f,#1db879)}.gradient-purple{background:linear-gradient(135deg,#5433a6,#8c6ff0)}
.vip-panel,.table-card,.admin-card{background:rgba(255,255,255,.92)!important;border:1px solid rgba(10,38,72,.08)!important;border-radius:28px!important;box-shadow:0 20px 70px rgba(7,29,54,.09)!important;padding:26px!important}.vip-panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.vip-panel-head h3{font-weight:900;color:#071d36;margin:0}.vip-panel-head a{font-weight:800;text-decoration:none;color:#0d6efd}.vip-table thead th{font-size:12px;color:#7b8da5;text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid #e7edf5}.vip-table td{border-color:#edf2f7;padding:16px 10px}.vip-action-grid{display:grid;gap:14px}.vip-action-grid a{display:flex;flex-direction:column;text-decoration:none;color:#071d36;background:linear-gradient(135deg,#f8fbff,#eef4fb);border:1px solid #e5edf6;border-radius:22px;padding:18px;transition:.2s}.vip-action-grid a:hover{transform:translateY(-3px);box-shadow:0 16px 35px rgba(7,29,54,.1)}.vip-action-grid span{font-size:28px}.vip-action-grid b{font-size:16px}.vip-action-grid small{color:#6e7e94;margin-top:2px}
.vip-status-tabs{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}.vip-status-tabs a{white-space:nowrap;text-decoration:none;color:#51627a;background:#fff;border:1px solid #e2eaf3;padding:12px 18px;border-radius:999px;font-weight:800;box-shadow:0 8px 24px rgba(7,29,54,.05)}.vip-status-tabs a.active,.vip-status-tabs a:hover{background:#071d36;color:#fff}.vip-status-tabs b{background:rgba(216,160,59,.18);padding:2px 8px;border-radius:999px;margin-left:6px;color:#d39a31}.vip-status-tabs a.active b{background:rgba(255,255,255,.18);color:#ffd98d}
.vip-booking-list{display:grid;gap:18px}.vip-booking-card{background:rgba(255,255,255,.95);border:1px solid #e5edf6;border-radius:30px;padding:22px;box-shadow:0 18px 55px rgba(7,29,54,.08)}.vip-booking-main{display:grid;grid-template-columns:1.2fr 1.6fr 1.6fr 1.2fr;gap:18px;align-items:center}.vip-booking-code span{font-size:12px;color:#72839b;text-transform:uppercase;font-weight:800}.vip-booking-code b{display:block;font-size:19px;color:#08764f}.vip-booking-code small,.vip-booking-guest p,.vip-booking-stay span,.vip-booking-money span{display:block;color:#6d7d94;font-size:13px}.vip-booking-guest h4{font-size:20px;font-weight:900;margin:0 0 6px;color:#071d36}.vip-booking-stay b{display:block;color:#071d36}.vip-booking-money{text-align:right}.vip-booking-money b{display:block;font-size:22px;color:#071d36;font-weight:900}.vip-booking-money em{font-style:normal;margin-top:8px}.vip-booking-items{background:#f7faff;border:1px solid #e6eef8;border-radius:20px;margin:18px 0;padding:12px 16px;display:grid;gap:8px}.vip-booking-items div{display:flex;justify-content:space-between;gap:12px}.vip-booking-actions{display:grid;grid-template-columns:1fr 1fr 2fr auto auto;gap:10px;align-items:center}
.admin-vip-wrap .form-control,.admin-vip-wrap .form-select{border-radius:16px;border:1px solid #dbe5f0;padding:11px 14px}.admin-vip-wrap .form-control:focus,.admin-vip-wrap .form-select:focus{border-color:#d8a03b;box-shadow:0 0 0 .22rem rgba(216,160,59,.16)}.admin-vip-wrap .btn{font-weight:800}.admin-vip-wrap .table img{border-radius:12px;box-shadow:0 8px 20px rgba(7,29,54,.12)}
.admin-login-vip{display:grid;place-items:center;padding:24px;position:relative;overflow:hidden}.login-vip-bg{position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(216,160,59,.28),transparent 28%),radial-gradient(circle at 80% 80%,rgba(21,101,177,.26),transparent 28%),linear-gradient(135deg,#071d36,#0b315c);z-index:0}.login-vip-card{position:relative;z-index:1;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);width:100%;max-width:460px;border-radius:34px;padding:36px;box-shadow:0 30px 100px rgba(0,0,0,.24);border:1px solid rgba(255,255,255,.48)}.login-vip-logo{height:70px;background:#0b315c;border-radius:18px;padding:8px;margin-bottom:18px}.login-vip-card h1{font-size:28px;font-weight:900;color:#071d36}.login-vip-card p{color:#6d7d94;margin:0}
@media(max-width:1199px){.admin-vip-sidebar{transform:translateX(-110%);transition:.25s}.admin-sidebar-open .admin-vip-sidebar{transform:translateX(0)}.admin-vip-main{margin-left:0;width:100%}.admin-menu-btn{display:block}.admin-sidebar-backdrop{position:fixed;inset:0;background:rgba(5,17,32,.48);z-index:999;display:none}.admin-sidebar-open .admin-sidebar-backdrop{display:block}.admin-vip-content{padding:22px}.admin-vip-topbar{padding:0 18px}.admin-vip-top-actions .btn{display:none}.vip-booking-main{grid-template-columns:1fr}.vip-booking-money{text-align:left}.vip-booking-actions{grid-template-columns:1fr}.admin-page-head{display:block}.admin-page-head .btn{margin-top:14px}}
@media(max-width:575px){.admin-vip-title{font-size:16px}.admin-vip-subtitle{display:none}.admin-vip-content{padding:16px}.vip-stat-card{min-height:155px}.admin-page-head h1{font-size:28px}.vip-panel,.table-card,.admin-card{padding:18px!important;border-radius:22px!important}}

/* Home search bar upgrade */
.booking-search-pro{border:1px solid rgba(7,29,54,.08);padding:24px 26px;border-radius:30px;background:rgba(255,255,255,.98);box-shadow:0 26px 85px rgba(7,29,54,.18)}
.booking-search-pro .form-label{color:#071d36;margin-bottom:8px;font-size:15px}.booking-search-pro .search-input{height:54px;border-radius:18px;border:1px solid #dbe5f0;background:#fff;font-weight:700;color:#071d36}.booking-search-pro .search-input:focus{border-color:#d8a03b;box-shadow:0 0 0 .22rem rgba(216,160,59,.16)}.booking-search-pro .search-btn{height:54px;display:flex;align-items:center;justify-content:center;gap:6px;font-size:18px;white-space:nowrap}
@media(max-width:991px){.booking-search-pro{margin-top:-35px;border-radius:24px}.booking-search-pro .search-btn{margin-top:4px}}
@media(max-width:576px){.booking-search-pro{padding:18px;border-radius:22px}.booking-search-pro .search-input,.booking-search-pro .search-btn{height:50px}}


/* Admin room amenities */
.amenity-admin-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.amenity-check{display:flex;gap:8px;align-items:center;border:1px solid #dfe8f3;border-radius:14px;padding:10px 12px;background:#fff;cursor:pointer;font-weight:700}
.amenity-check input{width:18px;height:18px}
@media(max-width:992px){.amenity-admin-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:576px){.amenity-admin-grid{grid-template-columns:1fr}}


/* Admin account/profile security */
.admin-avatar{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:#123d6a;color:#fff!important;font-weight:900;box-shadow:0 8px 24px rgba(7,29,54,.18);border:3px solid #fff}
.vip-panel{background:#fff;border-radius:28px;padding:28px;box-shadow:0 18px 60px rgba(7,29,54,.09);border:1px solid rgba(7,29,54,.06)}
.vip-panel .form-control,.vip-panel .form-select{border-radius:16px;border-color:#d9e4ef}
.vip-panel .form-control:focus,.vip-panel .form-select:focus{border-color:#d8a03b;box-shadow:0 0 0 .2rem rgba(216,160,59,.16)}


/* Booking detail Pro */
.booking-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:24px;align-items:start}
.booking-detail-main,.booking-detail-side{display:grid;gap:24px}
.booking-vip-card{background:rgba(255,255,255,.96);border:1px solid rgba(7,29,54,.07);border-radius:30px;padding:26px;box-shadow:0 18px 60px rgba(7,29,54,.09)}
.booking-card-title{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.booking-card-title>span{width:48px;height:48px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff8ed,#ffe6a8);font-size:24px;box-shadow:0 10px 30px rgba(216,160,59,.16)}
.booking-card-title h3{font-size:20px;font-weight:900;color:#071d36;margin:0}
.booking-card-title p{margin:3px 0 0;color:#6d7d94;font-size:13px}
.booking-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.booking-info-box{background:#f7faff;border:1px solid #e6eef8;border-radius:20px;padding:14px 16px;min-height:78px}
.booking-info-box small,.booking-note-box small,.booking-stay-strip small{display:block;color:#6d7d94;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px}
.booking-info-box b{display:block;color:#071d36;font-size:16px;word-break:break-word}
.booking-note-box{background:#fff8ed;border:1px solid #f1ddb3;border-radius:22px;padding:16px;color:#172033}
.booking-stay-strip{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin-bottom:18px}
.booking-stay-strip>div{background:linear-gradient(180deg,#f7faff,#fff);border:1px solid #e6eef8;border-radius:20px;padding:14px 12px}
.booking-stay-strip b{display:block;color:#071d36;font-size:17px}
.booking-room-cards{display:grid;gap:12px}
.booking-room-mini{display:flex;justify-content:space-between;gap:16px;align-items:center;border:1px solid #e6eef8;background:#fff;border-radius:22px;padding:16px}
.booking-room-mini>div{display:flex;gap:12px;align-items:center}
.booking-room-mini b{display:block;color:#071d36}
.booking-room-mini small{display:block;color:#6d7d94;margin-top:3px}
.booking-room-mini strong{font-size:18px;color:#08764f;white-space:nowrap}
.room-dot{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:16px;background:#f1f6ff}
.booking-payment-card{position:sticky;top:92px}
.payment-total{font-size:34px;line-height:1;font-weight:950;color:#071d36;margin-bottom:12px}
.payment-progress{height:14px;background:#eef3f8;border-radius:999px;overflow:hidden;margin-bottom:8px}
.payment-progress div{height:100%;background:linear-gradient(90deg,#d8a03b,#14a36f);border-radius:999px}
.payment-percent{font-weight:800;color:#08764f;font-size:13px;margin-bottom:18px}
.pay-row{display:flex;justify-content:space-between;gap:16px;align-items:center;border-bottom:1px solid #eef3f8;padding:12px 0;color:#42526a}
.pay-row b{color:#071d36}
.pay-remain{border-bottom:0;margin-top:4px;font-size:20px}
.pay-remain b{color:#d13b3b;font-size:24px}
.booking-timeline{position:relative;display:grid;gap:14px}
.timeline-item{display:grid;grid-template-columns:18px minmax(0,1fr);gap:12px}
.timeline-item>span{width:12px;height:12px;margin-top:6px;border-radius:50%;background:#d8a03b;box-shadow:0 0 0 5px rgba(216,160,59,.13)}
.timeline-item b{display:block;color:#071d36}
.timeline-item small{display:block;color:#6d7d94}
.timeline-item p{margin:4px 0 0;color:#42526a}
@media(max-width:1199px){.booking-detail-grid{grid-template-columns:1fr}.booking-payment-card{position:static}.booking-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.booking-stay-strip{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:575px){.booking-info-grid,.booking-stay-strip{grid-template-columns:1fr}.booking-room-mini{align-items:flex-start;flex-direction:column}.booking-vip-card{padding:18px;border-radius:24px}.payment-total{font-size:28px}}
@media print{
  .admin-vip-sidebar,.admin-vip-topbar,.no-print,.admin-sidebar-backdrop{display:none!important}
  .admin-vip-main{margin-left:0!important;width:100%!important}
  .admin-vip-content{padding:0!important}
  .booking-detail-grid{grid-template-columns:1fr!important}
  .booking-detail-side{display:block}
  .booking-vip-card{box-shadow:none!important;border:1px solid #ddd!important;break-inside:avoid}
  body{background:#fff!important}
}


/* === The Bok Admin Booking UI fix: no overlap, PMS style === */
.vip-booking-actions{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr))!important;
  gap:12px!important;
  align-items:stretch!important;
}
.vip-booking-actions .btn,
.vip-booking-actions .form-control,
.vip-booking-actions .form-select{
  width:100%!important;
  min-height:48px;
}
.vip-booking-main{
  grid-template-columns:minmax(180px,1.1fr) minmax(220px,1.5fr) minmax(220px,1.5fr) minmax(160px,1fr)!important;
}
@media(max-width:1200px){
  .vip-booking-main{grid-template-columns:1fr 1fr!important;}
  .vip-booking-money{text-align:left!important;}
}
@media(max-width:768px){
  .vip-booking-main{grid-template-columns:1fr!important;}
  .vip-payment-summary .col-md-3{width:100%;}
}

.booking-detail-grid{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:24px!important;
  align-items:start!important;
  max-width:1180px;
  margin:0 auto;
}
.booking-detail-main,
.booking-detail-side{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:24px!important;
}
.booking-payment-card{
  position:static!important;
  top:auto!important;
}
.booking-info-grid{
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr))!important;
}
.booking-stay-strip{
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr))!important;
  gap:12px!important;
}
.booking-stay-strip>div{
  min-height:92px;
  overflow:visible!important;
}
.booking-stay-strip b{
  font-size:16px!important;
  word-break:keep-all;
  white-space:normal;
}
.booking-room-mini{
  flex-wrap:wrap!important;
}
.booking-room-mini>div{
  min-width:240px;
}
.booking-room-mini strong{
  margin-left:auto;
}
.booking-detail-side .booking-vip-card{
  width:100%;
}
.payment-total{
  font-size:clamp(28px,4vw,40px)!important;
}
.pay-row{
  font-size:16px;
}
.pay-remain{
  background:#fff6f6;
  border-radius:18px;
  padding:16px!important;
  margin-top:12px!important;
}
@media(max-width:576px){
  .booking-vip-card{padding:18px!important;border-radius:24px!important;}
  .booking-info-grid,.booking-stay-strip{grid-template-columns:1fr!important;}
  .booking-room-mini{align-items:flex-start!important;flex-direction:column!important;}
  .booking-room-mini strong{margin-left:0!important;}
}


/* === Booking Calendar PMS === */
.booking-calendar-legend{display:flex;gap:12px;flex-wrap:wrap;align-items:center;color:#42526a;font-weight:700}
.booking-calendar-legend span{background:#fff;border:1px solid #e3edf8;border-radius:999px;padding:8px 12px;box-shadow:0 8px 24px rgba(7,29,54,.06)}
.cal-dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:6px;vertical-align:-1px}
.booking-calendar-wrap{background:#fff;border-radius:28px;box-shadow:0 20px 70px rgba(7,29,54,.10);overflow:auto;border:1px solid #e4edf7}
.booking-calendar-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}
.booking-calendar-table th,.booking-calendar-table td{border-right:1px solid #e9f1f8;border-bottom:1px solid #e9f1f8;vertical-align:top}
.booking-calendar-table thead th{position:sticky;top:0;background:#f7fbff;z-index:3;text-align:center;min-width:128px;padding:14px 10px;color:#071d36}
.booking-calendar-table thead th small{display:block;color:#6c7d95;font-weight:700;margin-top:3px}
.cal-room-head{left:0;z-index:5!important;text-align:left!important;min-width:245px!important}
.cal-room-name{position:sticky;left:0;background:#fff;z-index:2;min-width:245px;max-width:245px;padding:16px;color:#071d36;box-shadow:8px 0 18px rgba(7,29,54,.04)}
.cal-room-name b{display:block;font-size:15px}
.cal-room-name small{display:block;color:#6c7d95;margin-top:6px;font-weight:700}
.cal-day-cell{min-width:128px;height:92px;padding:8px;background:#fff}
.cal-today{background:#fff7df!important;box-shadow:inset 0 4px 0 #d8a03b}
.cal-full{background:#fff8f8}
.cal-booking-pill{display:block;text-decoration:none;border-radius:13px;padding:7px 8px;font-size:12px;font-weight:800;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#071d36}
.cal-pending{background:#fff1c9!important;color:#7c4a00!important}
.cal-confirmed{background:#dff8eb!important;color:#08764f!important}
.cal-checkedin{background:#dfeeff!important;color:#0d4c99!important}
.cal-completed{background:#eef2f6!important;color:#344054!important}
.cal-cancelled{background:#ffe3e3!important;color:#b42318!important}
.cal-gohost{background:#e8ddff!important;color:#5b2bbf!important}
.cal-empty{display:inline-flex;align-items:center;justify-content:center;background:#f5f9fd;color:#6c7d95;border:1px dashed #d5e2ef;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800}
.cal-left{display:block;margin-top:4px;color:#6c7d95;font-weight:800}
@media(max-width:768px){
  .cal-room-head,.cal-room-name{min-width:190px!important;max-width:190px!important}
  .booking-calendar-table thead th,.cal-day-cell{min-width:112px}
}

/* === Floating contact buttons: Hotline / Zalo / WhatsApp === */
.wa-float{display:none!important}
.contact-float{position:fixed;right:18px;bottom:18px;z-index:9999;display:flex;flex-direction:column;gap:10px;align-items:flex-end;font-family:'Be Vietnam Pro',Arial,sans-serif}
.contact-float-btn{height:52px;min-width:52px;display:flex;align-items:center;justify-content:flex-start;gap:10px;text-decoration:none;color:#fff!important;border-radius:999px;padding:8px 16px 8px 8px;font-weight:900;box-shadow:0 15px 40px rgba(7,29,54,.24);transition:.22s ease;overflow:hidden;border:2px solid rgba(255,255,255,.85)}
.contact-float-btn:hover{transform:translateY(-3px);box-shadow:0 18px 48px rgba(7,29,54,.32);filter:saturate(1.05)}
.contact-float-btn .contact-icon{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.18);font-size:17px;font-weight:950;line-height:1;flex:0 0 34px}
.contact-float-btn .contact-text{white-space:nowrap;font-size:15px;letter-spacing:-.2px}
.contact-float-btn.call{background:linear-gradient(135deg,#d8a03b,#ffcf70);color:#071d36!important}
.contact-float-btn.call .contact-icon{background:rgba(7,29,54,.12);color:#071d36}
.contact-float-btn.zalo{background:linear-gradient(135deg,#0068ff,#00a3ff)}
.contact-float-btn.whatsapp{background:linear-gradient(135deg,#10b95d,#25d366)}
@media(max-width:768px){
  .contact-float{right:12px;bottom:12px;gap:8px}
  .contact-float-btn{width:52px;height:52px;min-width:52px;padding:8px;border-radius:50%;justify-content:center}
  .contact-float-btn .contact-text{display:none}
  .contact-float-btn .contact-icon{width:34px;height:34px;background:transparent;font-size:18px}
}
@media(min-width:769px){
  .contact-float-btn{transform:translateX(calc(100% - 54px));}
  .contact-float:hover .contact-float-btn,.contact-float-btn:hover{transform:translateX(0) translateY(-2px);}
}

/* === Contact floating arc menu: support button opens Hotline / Zalo / WhatsApp === */
.contact-float{display:none!important}
.contact-arc{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:10000;
  width:74px;
  height:74px;
  font-family:'Be Vietnam Pro',Arial,sans-serif;
}
.contact-arc-check{position:absolute;opacity:0;pointer-events:none}
.contact-arc-main,
.contact-arc-item{
  position:absolute;
  right:0;
  bottom:0;
  width:62px;
  height:62px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none!important;
  cursor:pointer;
  border:2px solid rgba(255,255,255,.92);
  box-shadow:0 18px 48px rgba(7,29,54,.28);
  transition:transform .32s cubic-bezier(.2,.9,.2,1), opacity .24s ease, box-shadow .24s ease, filter .24s ease;
  -webkit-tap-highlight-color:transparent;
}
.contact-arc-main{
  background:linear-gradient(135deg,#071d36,#0e3a66 60%,#d8a03b);
  color:#fff;
  z-index:4;
  overflow:hidden;
}
.contact-arc-main:before{
  content:'';
  position:absolute;
  inset:-12px;
  background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.45),transparent 35%);
  opacity:.7;
}
.contact-arc-main-icon{position:relative;font-size:24px;line-height:1;filter:drop-shadow(0 2px 3px rgba(0,0,0,.18))}
.contact-arc-main-text{display:none;position:relative;margin-left:8px;font-weight:900;white-space:nowrap}
.contact-arc-item{
  opacity:0;
  pointer-events:none;
  z-index:3;
  color:#fff!important;
  gap:9px;
  padding:0 14px;
  justify-content:flex-start;
  overflow:visible;
}
.contact-arc-icon{
  width:38px;
  height:38px;
  border-radius:50%;
  display:grid;
  place-items:center;
  flex:0 0 38px;
  background:rgba(255,255,255,.18);
  font-size:17px;
  font-weight:950;
}
.contact-arc-label{
  position:absolute;
  right:70px;
  background:#fff;
  color:#071d36;
  border:1px solid rgba(7,29,54,.08);
  border-radius:999px;
  padding:10px 14px;
  min-width:max-content;
  font-size:14px;
  font-weight:900;
  box-shadow:0 14px 36px rgba(7,29,54,.18);
  opacity:0;
  transform:translateX(10px);
  transition:.22s ease;
  pointer-events:none;
}
.contact-arc-call{background:linear-gradient(135deg,#d8a03b,#ffcf70);color:#071d36!important}
.contact-arc-call .contact-arc-icon{background:rgba(7,29,54,.12);color:#071d36}
.contact-arc-zalo{background:linear-gradient(135deg,#0068ff,#00a3ff)}
.contact-arc-whatsapp{background:linear-gradient(135deg,#10b95d,#25d366)}
.contact-arc:hover .contact-arc-main,
.contact-arc:focus-within .contact-arc-main,
.contact-arc-check:checked + .contact-arc-main{
  transform:scale(.94) rotate(8deg);
  box-shadow:0 12px 32px rgba(7,29,54,.22);
}
.contact-arc:hover .contact-arc-item,
.contact-arc:focus-within .contact-arc-item,
.contact-arc-check:checked ~ .contact-arc-item{
  opacity:1;
  pointer-events:auto;
}
.contact-arc:hover .contact-arc-call,
.contact-arc:focus-within .contact-arc-call,
.contact-arc-check:checked ~ .contact-arc-call{transform:translate(-6px,-82px)}
.contact-arc:hover .contact-arc-zalo,
.contact-arc:focus-within .contact-arc-zalo,
.contact-arc-check:checked ~ .contact-arc-zalo{transform:translate(-68px,-58px)}
.contact-arc:hover .contact-arc-whatsapp,
.contact-arc:focus-within .contact-arc-whatsapp,
.contact-arc-check:checked ~ .contact-arc-whatsapp{transform:translate(-106px,-4px)}
.contact-arc-item:hover{filter:saturate(1.08);box-shadow:0 22px 58px rgba(7,29,54,.34)}
.contact-arc-item:hover .contact-arc-label{opacity:1;transform:translateX(0)}
@media(max-width:768px){
  .contact-arc{right:14px;bottom:14px;width:68px;height:68px}
  .contact-arc-main,.contact-arc-item{width:56px;height:56px}
  .contact-arc-icon{width:34px;height:34px;flex-basis:34px;font-size:16px}
  .contact-arc:hover .contact-arc-call,
  .contact-arc:focus-within .contact-arc-call,
  .contact-arc-check:checked ~ .contact-arc-call{transform:translate(-2px,-72px)}
  .contact-arc:hover .contact-arc-zalo,
  .contact-arc:focus-within .contact-arc-zalo,
  .contact-arc-check:checked ~ .contact-arc-zalo{transform:translate(-58px,-52px)}
  .contact-arc:hover .contact-arc-whatsapp,
  .contact-arc:focus-within .contact-arc-whatsapp,
  .contact-arc-check:checked ~ .contact-arc-whatsapp{transform:translate(-90px,-3px)}
  .contact-arc-label{display:none}
}


/* Payment UI */
.payment-method-box{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:22px;padding:18px;box-shadow:0 12px 30px rgba(15,23,42,.06)}
.bank-info-small{display:grid;gap:8px;margin-bottom:12px}
.bank-info-small div{display:flex;justify-content:space-between;gap:12px;border-bottom:1px dashed rgba(15,23,42,.12);padding-bottom:6px}
.bank-info-small span{color:#64748b;font-size:13px}
.bank-info-small b{text-align:right;color:#0f172a}
.bank-qr-img{max-width:210px;width:100%;border-radius:18px;border:1px solid rgba(15,23,42,.08);background:#fff;padding:8px;display:block;margin:8px auto}
@media(max-width:768px){.bank-info-small div{display:block}.bank-info-small b{text-align:left;display:block}.bank-qr-img{max-width:190px}}

.pay-hotel-card{border:1px solid rgba(216,160,59,.35);background:linear-gradient(180deg,#fffaf0,#ffffff)}
.pay-hotel-card h5{color:#071d36}

/* === Admin booking compact horizontal actions + footer settings === */
.vip-booking-actions{
  display:grid!important;
  grid-template-columns: 1fr 1fr 150px 150px minmax(220px,1.2fr)!important;
  gap:10px 12px!important;
  align-items:center!important;
}
.vip-booking-actions > input[name="admin_note"]{
  grid-column:1 / -1;
  min-height:46px!important;
}
.admin-action-pill-group{
  grid-column:1 / -1;
  display:flex!important;
  flex-wrap:wrap!important;
  gap:10px!important;
  align-items:center!important;
  justify-content:flex-start!important;
}
.admin-action-pill-group .btn{
  width:auto!important;
  min-width:112px!important;
  min-height:42px!important;
  padding:9px 18px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-weight:800!important;
  white-space:nowrap!important;
}
.settings-pro-form .form-control,
.settings-pro-form .form-select{
  border-radius:16px;
  border:1px solid #dce7f4;
}
.settings-pro-form h4{color:#071d36;font-weight:900;}
.footer p{line-height:1.55;}
@media(max-width:992px){
  .vip-booking-actions{grid-template-columns:1fr 1fr!important;}
  .vip-booking-actions > input[name="payment_note"],
  .vip-booking-actions > input[name="admin_note"]{grid-column:1 / -1;}
  .admin-action-pill-group .btn{flex:1 1 140px;}
}
@media(max-width:576px){
  .vip-booking-actions{grid-template-columns:1fr!important;}
  .admin-action-pill-group{display:grid!important;grid-template-columns:1fr 1fr;}
  .admin-action-pill-group .btn{min-width:0!important;width:100%!important;}
}

/* Trip eBooking-style admin booking UI */
.trip-page-head h1{font-size:34px;font-weight:900;margin:0;color:#071b35}.trip-toolbar{background:#fff;border:1px solid #e6edf5;border-radius:18px;padding:14px;margin-bottom:18px;box-shadow:0 12px 35px rgba(7,27,53,.06)}.trip-filter-form{display:grid;grid-template-columns:2fr 1.1fr 1fr 1fr 1fr auto auto;gap:10px;align-items:center}.trip-filter-form .form-control,.trip-filter-form .form-select{border-radius:10px;border-color:#d9e3ee;min-height:44px}.trip-tabs{gap:8px}.trip-booking-panel{background:#fff;border:1px solid #e6edf5;border-radius:22px;padding:0;box-shadow:0 20px 55px rgba(7,27,53,.07);overflow:hidden}.trip-list-title{padding:20px 24px;border-bottom:1px solid #edf2f7;display:flex;align-items:end;justify-content:space-between;gap:12px}.trip-list-title h2{font-size:22px;font-weight:900;margin:0;color:#071b35}.trip-list-title h2 span{font-size:18px;color:#1d4ed8}.trip-list-title small{color:#73839b}.trip-booking-table{width:100%;border-collapse:separate;border-spacing:0}.trip-booking-table th{font-size:13px;color:#071b35;font-weight:900;padding:16px 14px;background:#fff;border-bottom:1px solid #edf2f7;white-space:nowrap}.trip-booking-table td{padding:16px 14px;border-bottom:1px solid #edf2f7;vertical-align:top;color:#071b35}.trip-booking-table tbody tr:hover{background:#f8fbff}.trip-guest-name,.trip-code{font-weight:800;text-decoration:none;color:#1769ff}.trip-guest-cell div,.trip-booking-table small{display:block;color:#60718a;font-size:12px;margin-top:4px}.trip-room-cell{font-weight:800}.trip-room-cell small{font-weight:500}.trip-booking-table td b{font-size:16px}.trip-alert-text{display:inline-flex;margin-top:7px;padding:3px 8px;border-radius:999px;background:#fff2f2;color:#dc2626;font-size:12px;font-weight:800}.trip-status{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:900;white-space:nowrap}.trip-status-warning{background:#fff4d8;color:#9a6500}.trip-status-success{background:#e8f8ef;color:#08763f}.trip-status-primary{background:#e9f1ff;color:#155bcc}.trip-status-info{background:#e7f8ff;color:#036b86}.trip-status-dark{background:#edf0f4;color:#111827}.trip-status-danger{background:#ffe8e8;color:#b91c1c}.trip-status-secondary{background:#edf0f4;color:#526174}.trip-row-actions{display:flex;gap:6px;flex-wrap:wrap;min-width:290px}.trip-row-actions .btn{border-radius:999px;font-weight:800}.trip-row.has-cancel-request{background:#fffafa}.trip-detail-top{background:#fff;border:1px solid #e6edf5;border-radius:22px;padding:22px 26px;margin-bottom:18px;display:flex;justify-content:space-between;gap:16px;align-items:flex-start;box-shadow:0 18px 45px rgba(7,27,53,.06)}.trip-detail-top h1{font-size:28px;font-weight:900;color:#071b35;margin:0 0 8px}.trip-detail-top p{color:#64748b;margin:0}.trip-detail-top-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.trip-detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 290px;gap:18px}.trip-detail-main{display:flex;flex-direction:column;gap:16px}.trip-confirm-box,.trip-section-card,.trip-side-card{background:#fff;border:1px solid #e6edf5;border-radius:18px;box-shadow:0 18px 45px rgba(7,27,53,.06)}.trip-confirm-box{padding:16px 18px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.trip-confirm-box b{margin-right:8px}.trip-section-card{padding:22px}.trip-section-card h2,.trip-side-card h3{font-size:21px;font-weight:900;color:#071b35;margin:0 0 18px}.trip-info-table{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid #edf2f7}.trip-info-table>div{display:flex;justify-content:space-between;gap:20px;padding:12px 0;border-bottom:1px solid #edf2f7}.trip-info-table span{color:#64748b}.trip-info-table b{text-align:right}.trip-money-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.trip-money-grid>div{background:#f8fbff;border:1px solid #e6edf5;border-radius:16px;padding:14px}.trip-money-grid span{display:block;color:#64748b;font-size:13px}.trip-money-grid b{font-size:19px;font-weight:900}.trip-note{background:#f8fbff;border:1px solid #e6edf5;border-radius:14px;padding:14px;color:#24364d}.trip-room-list{display:flex;flex-direction:column;gap:10px}.trip-room-list>div{border:1px solid #e6edf5;border-radius:16px;padding:14px;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.trip-room-list b{font-weight:900}.trip-room-list span{display:block;color:#64748b}.trip-room-list strong{font-size:18px}.trip-cancel-card{border-color:#ffd2d2;background:#fffafa}.trip-action-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.trip-action-row .form-control{max-width:360px;border-radius:999px}.trip-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.trip-edit-grid label{font-weight:800;color:#071b35}.trip-edit-grid .form-control,.trip-edit-grid .form-select{margin-top:7px;border-radius:12px;border-color:#dbe5ef}.trip-edit-grid .span-2{grid-column:1/-1}.trip-timeline{display:flex;flex-direction:column;gap:12px}.trip-timeline>div{display:grid;grid-template-columns:18px 1fr;gap:10px}.trip-timeline>div>span{width:12px;height:12px;border-radius:50%;background:#e0aa35;margin-top:5px}.trip-timeline b{display:block}.trip-timeline small{display:block;color:#64748b}.trip-timeline p{margin:4px 0 0;color:#334155}.trip-detail-side{display:flex;flex-direction:column;gap:14px}.trip-side-card{padding:16px}.trip-side-card h3{font-size:18px;padding-bottom:12px;border-bottom:1px solid #edf2f7}.trip-side-card a,.trip-side-card button{display:flex;width:100%;align-items:center;justify-content:space-between;text-decoration:none;color:#071b35;background:#fff;border:1px solid #cfd9e6;border-radius:10px;padding:10px 12px;margin-top:8px;font-weight:800}.trip-side-card a:hover,.trip-side-card button:hover{background:#f8fbff}.trip-side-card a.danger{color:#dc2626;border-color:#ffd2d2}.trip-bill-item{border:1px solid #edf2f7;border-radius:12px;padding:10px;margin-bottom:8px}.trip-bill-item b,.trip-bill-item span{display:block}.trip-bill-item span{font-size:12px;color:#64748b}.payment-progress{height:10px;background:#edf2f7;border-radius:99px;overflow:hidden}.payment-progress>div{height:100%;background:#16a34a;border-radius:99px}
@media(max-width:1100px){.trip-filter-form{grid-template-columns:1fr 1fr}.trip-detail-layout{grid-template-columns:1fr}.trip-detail-side{display:grid;grid-template-columns:1fr 1fr}.trip-booking-table{min-width:1050px}}@media(max-width:768px){.trip-filter-form,.trip-info-table,.trip-money-grid,.trip-edit-grid{grid-template-columns:1fr}.trip-detail-top{display:block}.trip-detail-top-actions{justify-content:flex-start;margin-top:14px}.trip-detail-side{display:flex}.trip-list-title{display:block}.trip-room-list>div{grid-template-columns:1fr}.trip-action-row .form-control{max-width:none}.trip-booking-table{min-width:980px}.trip-toolbar{padding:10px}}
@media print{.no-print,.admin-vip-sidebar,.admin-vip-topbar,.admin-sidebar-backdrop{display:none!important}.admin-vip-main{margin:0!important}.admin-vip-content{padding:0!important}.trip-detail-layout{grid-template-columns:1fr}.trip-section-card,.trip-confirm-box{box-shadow:none;border-color:#ddd}}

/* The Bok PMS/Trip-style refinements */
.trip-info-compact{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 26px;border-top:1px solid #edf2f7;padding-top:12px}
.trip-info-compact .info-line{display:flex;align-items:flex-start;gap:8px;min-height:30px;padding:4px 0;border-bottom:1px dashed #edf2f7}
.trip-info-compact .info-line span{color:#64748b;font-weight:800;min-width:112px;flex:0 0 112px}
.trip-info-compact .info-line b{font-weight:900;color:#071b35;text-align:left;word-break:break-word}
.trip-info-table{grid-template-columns:repeat(2,minmax(0,1fr))}
.trip-info-table>div{justify-content:flex-start;gap:8px}
.trip-info-table span{min-width:120px;font-weight:800}.trip-info-table b{text-align:left}
.trip-timeline{position:relative;margin-top:4px}
.trip-timeline>div{display:grid;grid-template-columns:20px minmax(110px,150px) 1fr;gap:10px 12px;align-items:start;padding:8px 0;border-bottom:1px solid #eef3f8}
.trip-timeline>div>span{grid-column:1;grid-row:1 / span 2;width:10px;height:10px;background:#e0aa35;border-radius:50%;margin-top:5px}
.trip-timeline b{grid-column:2;font-weight:900;color:#071b35}
.trip-timeline small{grid-column:2;color:#64748b;line-height:1.35}
.trip-timeline p{grid-column:3;grid-row:1 / span 2;margin:0;color:#334155;line-height:1.45}
@media(max-width:900px){.trip-info-compact{grid-template-columns:1fr}.trip-timeline>div{grid-template-columns:18px 1fr}.trip-timeline p{grid-column:2;grid-row:auto}.trip-timeline small{grid-column:2}}


/* === The Bok final compact support/cancel/admin polish === */
.cancel-request-compact{border:1px solid #fee2e2;border-radius:20px;background:#fff;overflow:hidden}
.cancel-request-toggle{width:100%;border:0;background:linear-gradient(180deg,#fff,#fff7f7);display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px;color:#dc2626;font-weight:900;text-align:left}
.cancel-request-toggle small{color:#64748b;font-weight:700}
.cancel-request-panel{display:none;padding:16px;border-top:1px solid #fee2e2;background:#fff}
.cancel-request-compact.open .cancel-request-panel{display:block}
.support-action-center{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap}
.support-action-btn{min-width:132px;text-align:center;text-decoration:none!important;border-radius:999px;padding:10px 16px;font-weight:900;border:1px solid rgba(15,23,42,.12);box-shadow:0 10px 24px rgba(7,29,54,.08);transition:.18s ease}
.support-action-btn:hover{transform:translateY(-2px)}
.support-action-btn.wa{background:#22c55e;color:#fff}
.support-action-btn.zalo{background:#0a84ff;color:#fff}
.support-action-btn.call{background:#f4bd4a;color:#071b35}
.trip-row-actions{display:flex!important;gap:7px!important;flex-wrap:nowrap!important;align-items:center;min-width:max-content!important}
.trip-row-actions form{margin:0!important}
.trip-row-actions .btn{white-space:nowrap;padding:.35rem .7rem}
.trip-actions-cell{min-width:330px}
.trip-info-compact{display:grid!important;grid-template-columns:repeat(2,minmax(260px,1fr))!important;gap:8px 18px!important;border-top:1px solid #edf2f7;padding-top:12px}
.trip-info-compact .info-line{display:flex!important;align-items:baseline!important;gap:6px!important;min-height:auto!important;padding:8px 0!important;border-bottom:1px dashed #edf2f7!important}
.trip-info-compact .info-line span{min-width:auto!important;flex:0 0 auto!important;color:#64748b;font-weight:800}
.trip-info-compact .info-line span:after{content:"";} 
.trip-info-compact .info-line b{font-weight:900;color:#071b35;text-align:left!important}
.trip-timeline{display:flex!important;flex-direction:column!important;gap:14px!important}
.trip-timeline>div{display:grid!important;grid-template-columns:18px minmax(0,1fr)!important;gap:10px!important;align-items:start}
.trip-timeline>div>span{grid-row:1/4;width:12px;height:12px;border-radius:50%;background:#e0aa35;margin-top:6px}
.trip-timeline b,.trip-timeline small,.trip-timeline p{grid-column:2!important}
.trip-timeline small{display:block;color:#64748b;margin-top:2px;line-height:1.4}
.trip-timeline p{margin:4px 0 0;color:#334155;line-height:1.45}
@media(max-width:900px){
  .trip-info-compact{grid-template-columns:1fr!important}
  .trip-row-actions{flex-wrap:wrap!important}
  .trip-actions-cell{min-width:260px}
  .support-action-btn{flex:1 1 145px}
}


/* ===== Sunset Town style header upgrade ===== */
.thebok-sunset-nav{
  min-height:78px;
  background:rgba(255,255,255,.96)!important;
  backdrop-filter:blur(18px);
  box-shadow:0 10px 35px rgba(7,29,54,.08);
  border-bottom:1px solid rgba(7,29,54,.06);
}
.thebok-sunset-brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:220px;
  color:#071d36!important;
  font-weight:900;
  text-decoration:none;
}
.thebok-sunset-brand img{
  height:54px;
  max-width:150px;
  object-fit:contain;
}
.thebok-sunset-brand span{
  color:#071d36!important;
  font-size:19px;
  line-height:1.1;
  white-space:nowrap;
}
.thebok-sunset-menu{
  gap:18px;
}
.thebok-sunset-menu .nav-link,
.thebok-sunset-actions .nav-link{
  color:#071d36!important;
  font-weight:900;
  text-transform:none;
  letter-spacing:-.2px;
  padding:13px 4px;
  position:relative;
}
.thebok-sunset-menu .nav-link:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:7px;
  height:2px;
  background:#d8a03b;
  transform:scaleX(0);
  transform-origin:center;
  transition:.22s ease;
}
.thebok-sunset-menu .nav-link:hover:after{
  transform:scaleX(1);
}
.thebok-icon-btn{
  width:42px;
  height:42px;
  border-radius:999px;
  display:flex!important;
  align-items:center;
  justify-content:center;
  background:#f3f6fb;
  border:1px solid #e3eaf3;
  font-size:18px;
}
.thebok-icon-btn:hover{
  background:#fff7e2;
  border-color:#f1cc71;
}
.thebok-search-menu{
  width:min(390px,92vw);
  border:0;
  border-radius:18px;
  box-shadow:0 22px 60px rgba(7,29,54,.18);
}
.thebok-lang-btn{
  background:#f3f6fb;
  border:1px solid #e3eaf3;
  border-radius:999px;
  padding:9px 14px!important;
  line-height:1;
}
.thebok-lang-menu{
  border:0;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 22px 60px rgba(7,29,54,.18);
  min-width:130px;
}
.thebok-lang-menu .dropdown-item{
  display:flex;
  justify-content:space-between;
  gap:10px;
  font-weight:800;
  padding:11px 16px;
}
.thebok-book-btn{
  min-width:142px;
  padding:11px 23px!important;
  box-shadow:0 10px 24px rgba(216,160,59,.25);
}
.thebok-sunset-toggler{
  border:0;
  background:#f3f6fb;
  border-radius:14px;
  padding:10px 12px;
}
@media(max-width:991.98px){
  .thebok-sunset-nav{
    min-height:70px;
  }
  .thebok-sunset-brand{
    min-width:auto;
  }
  .thebok-sunset-brand img{
    height:44px;
  }
  .thebok-sunset-brand span{
    font-size:16px;
  }
  .thebok-sunset-menu,
  .thebok-sunset-actions{
    gap:0;
    padding:12px 0;
  }
  .thebok-sunset-menu .nav-link,
  .thebok-sunset-actions .nav-link{
    padding:12px 10px;
    border-radius:12px;
  }
  .thebok-sunset-menu .nav-link:hover,
  .thebok-sunset-actions .nav-link:hover{
    background:#f3f6fb;
  }
  .thebok-icon-btn{
    width:100%;
    justify-content:flex-start;
    background:transparent;
    border:0;
  }
  .thebok-icon-btn:after{content:" Tìm kiếm";font-weight:900;margin-left:8px;}
  .thebok-lang-btn{
    display:inline-flex!important;
    width:max-content;
    margin:8px 10px;
  }
  .thebok-book-btn{
    display:block;
    text-align:center;
    margin:8px 10px 4px;
  }
}
/* keep hero/content below the taller white header */
body{padding-top:78px;}
.hero{padding-top:30px;}
.admin-wrap body{padding-top:0;}


/* Modern Admin Settings + easy Google Map paste */
.settings-head-pro{
  align-items:center;
}
.settings-head-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.settings-modern-form{
  display:block;
}
/* Settings submenu: split large settings screen into compact child menus */
.settings-submenu-wrap{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:12px;
  margin:0 0 18px;
  position:sticky;
  top:88px;
  z-index:12;
}
.settings-subtab{
  border:1px solid #e2ebf6;
  background:rgba(255,255,255,.94);
  border-radius:22px;
  padding:13px 12px;
  text-align:left;
  box-shadow:0 14px 35px rgba(7,29,54,.07);
  cursor:pointer;
  display:flex;
  flex-direction:column;
  gap:3px;
  min-height:92px;
  transition:.18s ease;
}
.settings-subtab span{font-size:23px;line-height:1}
.settings-subtab b{font-size:14px;color:#071d36;font-weight:900;line-height:1.1}
.settings-subtab small{font-size:11px;color:#718198;line-height:1.25}
.settings-subtab:hover{transform:translateY(-2px);border-color:#c9d9ec}
.settings-subtab.active{
  background:linear-gradient(135deg,#071d36,#123f6d);
  border-color:#123f6d;
  box-shadow:0 18px 46px rgba(7,29,54,.18);
}
.settings-subtab.active b,.settings-subtab.active small{color:#fff}
.settings-panel{display:none}
.settings-panel.active{display:block;animation:settingsFade .18s ease}
@keyframes settingsFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media(max-width:1100px){.settings-submenu-wrap{grid-template-columns:repeat(3,minmax(0,1fr));position:static}}
@media(max-width:640px){.settings-submenu-wrap{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.settings-subtab{min-height:82px;border-radius:18px;padding:11px}.settings-subtab small{display:none}}

.settings-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
}
.settings-card{
  background:#fff;
  border:1px solid #e7edf6;
  border-radius:28px;
  padding:26px;
  box-shadow:0 20px 60px rgba(7,29,54,.08);
}
.settings-card-title{
  display:flex;
  gap:14px;
  align-items:flex-start;
  margin-bottom:20px;
}
.settings-card-title h4{
  margin:0;
  color:#071d36;
  font-weight:900;
  font-size:22px;
}
.settings-card-title p{
  margin:3px 0 0;
  color:#6b7a90;
  font-size:14px;
}
.settings-icon{
  width:48px;
  height:48px;
  border-radius:18px;
  background:linear-gradient(135deg,#fff3c4,#f7bd42);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  box-shadow:0 10px 25px rgba(232,174,55,.22);
  flex:0 0 48px;
}
.settings-card .form-control,
.settings-card .form-select{
  border-radius:16px;
  border:1px solid #dce7f4;
  min-height:48px;
}
.settings-card textarea.form-control{
  min-height:auto;
}
.map-input-pro{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;
  font-size:14px;
}
.map-help-box{
  margin-top:12px;
  padding:13px 15px;
  background:#f6f9fd;
  border:1px dashed #c8d7ea;
  border-radius:18px;
  color:#26384e;
}
.map-preview-toolbar{
  margin-top:16px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  font-weight:800;
  color:#071d36;
}
.map-preview-pro{
  margin-top:10px;
  border-radius:24px;
  overflow:hidden;
  border:1px solid #dfe8f4;
  background:#eef3f8;
  min-height:310px;
}
.map-preview-pro iframe{
  width:100%;
  height:310px;
  border:0;
  display:block;
}
.settings-sticky-save{
  margin-top:22px;
  background:rgba(255,255,255,.94);
  border:1px solid #e7edf6;
  border-radius:26px;
  padding:16px 18px;
  box-shadow:0 20px 55px rgba(7,29,54,.12);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  position:sticky;
  bottom:18px;
  z-index:10;
}
.settings-sticky-save b{
  display:block;
  color:#071d36;
  font-weight:900;
}
.settings-sticky-save span{
  color:#6b7a90;
  font-size:14px;
}
@media(max-width:768px){
  .settings-card{padding:20px;border-radius:22px;}
  .settings-sticky-save{
    flex-direction:column;
    align-items:stretch;
    position:static;
  }
  .settings-sticky-save .btn{width:100%;}
  .map-preview-toolbar{flex-direction:column;align-items:flex-start;}
}


/* === Pro contact card & channels === */
.contact-box-pro .contact-info-item,
.contact-card-pro .contact-info-item{display:flex;gap:12px;align-items:flex-start;margin:12px 0;color:#fff}
.contact-info-item span{width:38px;height:38px;border-radius:14px;background:rgba(255,255,255,.14);display:grid;place-items:center;flex:0 0 38px}
.contact-info-item p{margin:0;line-height:1.55}
.contact-info-item a{color:inherit;text-decoration:none;font-weight:800}
.contact-card-pro{padding:34px!important;display:flex;flex-direction:column;justify-content:center;gap:8px;min-height:385px}
.contact-card-kicker{display:inline-flex;align-self:flex-start;background:rgba(216,160,59,.18);border:1px solid rgba(216,160,59,.4);color:#ffe2a0;padding:7px 12px;border-radius:999px;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.contact-info-list{margin:14px 0 10px}
.contact-channel-title{font-weight:900;color:#ffe2a0;margin:18px 0 10px}
.contact-actions-mini,.contact-channel-grid,.footer-channel-grid{display:flex;flex-wrap:wrap;gap:10px}
.contact-actions-mini a,.contact-channel,.footer-channel{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:11px 16px;text-decoration:none!important;font-weight:900;border:1px solid rgba(255,255,255,.2);box-shadow:0 12px 28px rgba(7,29,54,.12);transition:.22s ease}
.contact-actions-mini a{background:#fff;color:#071d36!important}
.contact-channel{color:#fff!important;min-width:116px}
.footer-channel{color:#fff!important;padding:9px 13px;font-size:13px;min-width:94px}
.contact-channel.whatsapp,.footer-channel.whatsapp{background:linear-gradient(135deg,#10b95d,#25d366)}
.contact-channel.zalo,.footer-channel.zalo{background:linear-gradient(135deg,#0068ff,#00a3ff)}
.contact-channel.line,.footer-channel.line{background:linear-gradient(135deg,#06c755,#00a86b)}
.contact-channel.wechat,.footer-channel.wechat{background:linear-gradient(135deg,#19c15f,#05a844)}
.contact-channel.telegram,.footer-channel.telegram{background:linear-gradient(135deg,#2aabee,#1376c8)}
.contact-channel:hover,.footer-channel:hover,.contact-actions-mini a:hover{transform:translateY(-2px);filter:saturate(1.08)}
.contact-map-pro{border:0;border-radius:28px;min-height:385px;box-shadow:0 20px 60px rgba(7,29,54,.13);background:#e5e7eb}
.footer-pro .footer-contact-line{display:flex;gap:12px;align-items:flex-start;color:#dbe7f5}
.footer-pro .footer-contact-line span{width:34px;height:34px;border-radius:12px;background:rgba(255,255,255,.1);display:grid;place-items:center;flex:0 0 34px}
.footer-pro .footer-contact-line p{margin:0;line-height:1.55}
.footer-contact-list{display:grid;gap:8px}
.footer-contact-list a{display:flex;align-items:center;gap:10px;color:#dbe7f5;text-decoration:none}
.footer-contact-list span{width:34px;height:34px;border-radius:12px;background:rgba(255,255,255,.1);display:grid;place-items:center}
.contact-arc-telegram{background:linear-gradient(135deg,#2aabee,#1376c8)}
@media(max-width:768px){.contact-card-pro{padding:26px!important}.contact-channel{width:100%;min-width:0}.contact-map-pro{min-height:320px}.footer-channel{flex:1 1 120px}}

/* expanded contact arc positions */
.contact-arc:hover .contact-arc-telegram,
.contact-arc:focus-within .contact-arc-telegram,
.contact-arc-check:checked ~ .contact-arc-telegram{transform:translate(-114px,-80px)}
@media(max-width:768px){
  .contact-arc:hover .contact-arc-telegram,
  .contact-arc:focus-within .contact-arc-telegram,
  .contact-arc-check:checked ~ .contact-arc-telegram{transform:translate(-94px,-74px)}
}


/* === Guest review carousel / Admin review polish === */
.reviews-section-pro{overflow:hidden;background:linear-gradient(180deg,#f8fafc 0%,#fff 100%)}
.reviews-marquee-wrap{position:relative;overflow:hidden;padding:8px 0 18px;mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.reviews-marquee-track{display:flex;gap:18px;width:max-content;animation:reviewsScroll 42s linear infinite}
.reviews-marquee-wrap:hover .reviews-marquee-track{animation-play-state:paused}
@keyframes reviewsScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.review-card-pro{width:360px;min-height:220px;background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:28px;padding:22px;box-shadow:0 18px 45px rgba(7,29,54,.08);display:flex;flex-direction:column;gap:12px}
.review-card-head{display:flex;align-items:center;gap:12px}
.review-avatar{width:52px;height:52px;border-radius:18px;object-fit:cover;box-shadow:0 10px 20px rgba(7,29,54,.1)}
.review-avatar-text{display:grid;place-items:center;background:linear-gradient(135deg,#0b315a,#f4bd4a);color:#fff;font-weight:900;font-size:22px}
.review-card-head h5{margin:0;font-weight:900;color:#071b35;font-size:17px}
.review-meta{font-size:13px;color:#64748b;font-weight:700}
.review-stars{color:#f59e0b;font-weight:900;letter-spacing:1px;font-size:18px}.review-stars span{margin-left:8px;color:#64748b;font-size:13px;letter-spacing:0}
.review-card-pro p{margin:0;color:#334155;line-height:1.65;font-weight:600;font-size:14.5px}
.reviews-empty-pro{max-width:760px;margin:auto;background:#fff;border:1px dashed #cbd5e1;border-radius:24px;padding:24px;text-align:center;color:#64748b;font-weight:700}
.review-switch{display:flex;align-items:center;gap:10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;padding:12px 18px;font-weight:900;color:#071b35}
.review-switch input{width:18px;height:18px}
.admin-clean-table th{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:#64748b}.admin-clean-table td{vertical-align:middle}
@media(max-width:768px){.review-card-pro{width:300px}.reviews-marquee-track{animation-duration:34s}}


/* === The Bok quick introduction section === */
.intro-hotel-pro{background:#fff;padding-top:72px;padding-bottom:72px}
.intro-card-pro{display:grid;grid-template-columns:minmax(320px,0.95fr) minmax(360px,1.05fr);gap:54px;align-items:center;background:#fff;border-radius:34px;padding:28px;box-shadow:0 26px 80px rgba(7,29,54,.08)}
.intro-photo-wrap{position:relative;min-height:500px;border-radius:28px;overflow:hidden;background:#eef3f8;box-shadow:0 18px 45px rgba(7,29,54,.12)}
.intro-photo-main{width:100%;height:100%;min-height:500px;object-fit:cover;display:block;filter:saturate(1.04)}
.intro-photo-wrap:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,29,54,0) 55%,rgba(7,29,54,.38));pointer-events:none}
.intro-photo-badge{position:absolute;left:22px;bottom:22px;z-index:2;background:#fff;color:#071d36;border-radius:999px;padding:10px 18px;font-weight:900;box-shadow:0 12px 28px rgba(7,29,54,.2)}
.intro-content-pro{text-align:center;padding:22px 8px}
.intro-kicker-pro{text-transform:uppercase;letter-spacing:.35em;color:#d49a2f;font-size:12px;font-weight:800;margin-bottom:6px}
.intro-content-pro h2{font-size:clamp(30px,3vw,46px);line-height:1.08;color:#071d36;font-weight:950;margin:0;text-transform:uppercase}
.intro-script-pro{font-family:Georgia,serif;font-style:italic;color:#d49a2f;font-size:25px;margin:8px 0 8px}
.intro-script-pro:after{content:"";display:block;width:74px;height:2px;background:#d49a2f;margin:10px auto 0;opacity:.8}
.intro-subtitle-pro{font-size:18px;color:#34455c;font-weight:700;margin:18px auto 16px;max-width:620px}
.intro-text-pro{max-width:680px;margin:0 auto;color:#334155;font-size:16px;line-height:1.72}
.intro-text-pro p{margin:0 0 10px}
.intro-feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:22px auto 0;max-width:620px;text-align:left}
.intro-feature-grid span{background:#f8fafc;border:1px solid #e5edf6;border-radius:999px;padding:10px 14px;color:#071d36;font-weight:800;font-size:14px;white-space:nowrap}
.intro-actions-pro{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.content-admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.content-admin-box{background:#f8fafc;border:1px solid #e5edf6;border-radius:22px;padding:18px}
.content-admin-box h5{font-weight:950;color:#071d36;margin-bottom:14px}
@media(max-width:991px){.intro-card-pro{grid-template-columns:1fr;padding:18px;gap:26px}.intro-photo-wrap,.intro-photo-main{min-height:340px}.intro-content-pro{text-align:left}.intro-script-pro:after{margin-left:0}.intro-subtitle-pro,.intro-text-pro{margin-left:0}.intro-actions-pro{justify-content:flex-start}.content-admin-grid{grid-template-columns:1fr}}
@media(max-width:575px){.intro-hotel-pro{padding-top:46px;padding-bottom:46px}.intro-photo-wrap,.intro-photo-main{min-height:260px}.intro-feature-grid{grid-template-columns:1fr}.intro-feature-grid span{white-space:normal}.intro-card-pro{border-radius:24px}.intro-content-pro h2{font-size:28px}}


/* Hero slider fixed size - auto crop large images */
.hero.hero-slider-fixed{
  position:relative;
  height:560px;
  min-height:420px;
  max-height:72vh;
  padding-top:0;
  overflow:hidden;
  display:flex;
  align-items:center;
  color:#fff;
  background:#0b2742;
}
.hero-slider-fixed .hero-slides,
.hero-slider-fixed .hero-slide-bg,
.hero-slider-fixed .hero-overlay{
  position:absolute;
  inset:0;
}
.hero-slider-fixed .hero-slide-bg{
  background-size:cover;
  background-position:center;
  opacity:0;
  transform:scale(1.04);
  transition:opacity 900ms ease, transform 5000ms ease;
  will-change:opacity, transform;
}
.hero-slider-fixed .hero-slide-bg.active{
  opacity:1;
  transform:scale(1);
}
.hero-slider-fixed .hero-overlay{
  z-index:1;
  background:
    linear-gradient(110deg,rgba(7,29,54,.88),rgba(7,29,54,.48)),
    linear-gradient(180deg,rgba(7,29,54,.20),rgba(7,29,54,.30));
}
.hero-slider-fixed .hero-content{
  position:relative;
  z-index:2;
  padding-top:70px;
}
.hero-slider-fixed h1{
  font-size:clamp(40px,5vw,72px);
  font-weight:900;
  letter-spacing:-1.8px;
  line-height:1.05;
  max-width:820px;
}
.hero-slider-fixed .lead{
  font-size:clamp(18px,2vw,24px);
  max-width:760px;
}
.hero-slider-fixed .hero-dots{
  position:absolute;
  z-index:3;
  left:50%;
  bottom:26px;
  transform:translateX(-50%);
  display:flex;
  gap:10px;
}
.hero-slider-fixed .hero-dots button{
  width:10px;
  height:10px;
  border-radius:999px;
  border:0;
  padding:0;
  background:rgba(255,255,255,.55);
  cursor:pointer;
  transition:.25s;
}
.hero-slider-fixed .hero-dots button.active{
  width:28px;
  background:#f2c465;
}
@media(max-width:991px){
  .hero.hero-slider-fixed{
    height:520px;
    min-height:480px;
    max-height:none;
  }
  .hero-slider-fixed .hero-content{
    padding-top:52px;
  }
}
@media(max-width:575px){
  .hero.hero-slider-fixed{
    height:500px;
    min-height:500px;
  }
  .hero-slider-fixed h1{
    letter-spacing:-1px;
  }
  .hero-slider-fixed .btn-lg{
    padding:.75rem 1rem;
    font-size:1rem;
  }
}

/* === Hero brighter + professional promo popup === */
.hero-slider-fixed .hero-slide-bg{
  filter:brightness(.98) saturate(1.08) contrast(1.02);
}
.hero-slider-fixed .hero-overlay{
  background:
    linear-gradient(110deg,rgba(7,29,54,.58) 0%,rgba(7,29,54,.30) 48%,rgba(7,29,54,.14) 100%),
    linear-gradient(180deg,rgba(7,29,54,.08),rgba(7,29,54,.22))!important;
}
.hero-slider-fixed h1,.hero-slider-fixed .lead{
  text-shadow:0 3px 18px rgba(0,0,0,.38);
}

.promo-popup-backdrop{
  position:fixed;inset:0;z-index:10050;display:none;align-items:center;justify-content:center;
  padding:22px;background:rgba(4,18,34,.42);backdrop-filter:blur(8px);
}
.promo-popup-backdrop.show{display:flex;animation:promoFade .22s ease both}
@keyframes promoFade{from{opacity:0}to{opacity:1}}
.promo-popup-card{
  position:relative;display:grid;grid-template-columns:minmax(220px,42%) minmax(280px,58%);
  width:min(860px,94vw);overflow:hidden;border-radius:28px;background:#fffdf7;
  box-shadow:0 30px 90px rgba(7,29,54,.34);border:1px solid rgba(255,255,255,.75);
  animation:promoPop .32s cubic-bezier(.2,.9,.2,1) both;
}
@keyframes promoPop{from{transform:translateY(12px) scale(.97);opacity:.3}to{transform:none;opacity:1}}
.promo-popup-close{
  position:absolute;right:16px;top:16px;width:42px;height:42px;border:0;border-radius:50%;background:#fff;
  box-shadow:0 10px 30px rgba(7,29,54,.18);font-size:28px;line-height:1;color:#071d36;z-index:3;cursor:pointer;
}
.promo-popup-img{min-height:420px;background:#eaf1f8;overflow:hidden}
.promo-popup-img img{width:100%;height:100%;object-fit:cover;display:block}
.promo-popup-body{padding:44px 42px 34px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:420px}
.promo-kicker{color:#c08a24;font-weight:950;letter-spacing:.08em;text-transform:uppercase;font-size:16px;margin-bottom:10px}
.promo-subtitle{font-weight:800;color:#071d36;font-size:19px;margin-bottom:2px}
.promo-big{font-size:clamp(54px,8vw,92px);font-weight:950;line-height:.92;color:#c89535;letter-spacing:-4px;margin:4px 0 14px}
.promo-ribbon{background:linear-gradient(90deg,#c48a2b,#f4c86d,#c48a2b);color:#071d36;font-weight:950;padding:10px 22px;border-radius:999px;margin-bottom:18px;box-shadow:0 10px 24px rgba(196,138,43,.20)}
.promo-list{list-style:none;padding:0;margin:0 0 20px;text-align:left;display:grid;gap:10px;width:100%;max-width:340px}
.promo-list li{font-weight:700;color:#27364a;display:flex;gap:10px;align-items:flex-start}
.promo-list li:before{content:'✓';display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#fff2cd;color:#b87911;font-weight:950;flex:0 0 22px}
.promo-cta{display:inline-flex;align-items:center;justify-content:center;padding:13px 28px;border-radius:999px;background:#071d36;color:#fff!important;text-decoration:none;font-weight:950;box-shadow:0 12px 30px rgba(7,29,54,.22)}
.promo-cta:hover{transform:translateY(-2px);filter:brightness(1.05)}
.promo-note{margin-top:16px;color:#9a6b19;font-weight:800;font-size:13px}
@media(max-width:760px){
  .promo-popup-card{grid-template-columns:1fr;border-radius:24px;max-height:90vh;overflow:auto}
  .promo-popup-img{min-height:210px;max-height:260px}
  .promo-popup-body{min-height:0;padding:32px 24px 26px}
  .promo-big{letter-spacing:-2px}
}

/* Admin banner / promo settings polish */
.banner-slide-admin-box,.promo-admin-toggle{
  background:linear-gradient(180deg,#f8fbff,#ffffff);
  border:1px solid #e3edf8;
  border-radius:22px;
  padding:16px;
}
.promo-admin-card .form-control,.promo-admin-card .form-select{
  border-radius:16px;
}
.promo-admin-toggle .form-check-input{
  width:3.1rem;height:1.55rem;margin-right:10px;cursor:pointer;
}
.promo-admin-toggle .form-check-input:checked{background-color:#16a05d;border-color:#16a05d}


/* === SEO/Admin and compact contact channels update === */
.contact-channel-title{margin:14px 0 8px!important;font-size:15px!important}
.contact-channel-grid{gap:8px!important}
.contact-channel{min-width:88px!important;height:36px!important;padding:0 13px!important;border-radius:999px!important;font-size:13px!important;font-weight:800!important;box-shadow:0 8px 18px rgba(7,29,54,.12)!important;gap:6px!important}
.contact-channel.whatsapp::before{content:'●';font-size:10px}.contact-channel.zalo::before{content:'Z';font-size:12px}.contact-channel.line::before{content:'●';font-size:10px}.contact-channel.wechat::before{content:'●';font-size:10px}.contact-channel.telegram::before{content:'✈';font-size:13px}
.contact-card-pro{padding:30px 34px!important}
.contact-info-list{gap:12px!important}.contact-info-item{gap:12px!important}.contact-info-item span{width:38px!important;height:38px!important;min-width:38px!important}
.seo-admin-card textarea{resize:vertical}.seo-preview-box{border:1px solid #dbe6f3;border-radius:18px;background:#fff;padding:18px;box-shadow:0 14px 30px rgba(15,23,42,.06)}
.seo-preview-url{font-size:13px;color:#64748b;margin-bottom:4px}.seo-preview-title{font-size:20px;color:#1a0dab;font-weight:700;margin-bottom:6px}.seo-preview-desc{font-size:14px;color:#334155;line-height:1.5}
@media(max-width:768px){.contact-channel{flex:1 1 calc(50% - 8px)!important;min-width:0!important}.contact-card-pro{padding:24px!important}}

/* === Room detail multi-image gallery === */
.room-gallery-pro{background:#fff;border-radius:28px;box-shadow:0 20px 70px rgba(7,29,54,.10);padding:14px;border:1px solid #e6eef7}
.room-gallery-main{height:460px;border-radius:22px;overflow:hidden;position:relative;background:#edf3f8;cursor:zoom-in}
.room-gallery-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:0;transition:opacity .45s ease, transform .65s ease;transform:scale(1.015)}
.room-gallery-slide.active{opacity:1;transform:scale(1)}
.room-gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:0;background:rgba(255,255,255,.92);color:#071d36;font-size:34px;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px rgba(0,0,0,.18);z-index:3}
.room-gallery-nav.prev{left:16px}.room-gallery-nav.next{right:16px}
.room-gallery-counter{position:absolute;right:18px;bottom:18px;background:rgba(7,29,54,.72);color:#fff;font-weight:800;border-radius:999px;padding:8px 14px;font-size:14px;z-index:3;backdrop-filter:blur(8px)}
.room-gallery-thumbs{display:flex;gap:10px;margin-top:12px;overflow-x:auto;padding-bottom:3px}
.room-gallery-thumb{border:2px solid transparent;background:#fff;border-radius:15px;padding:0;min-width:92px;height:68px;overflow:hidden;opacity:.72;transition:.2s ease;box-shadow:0 8px 22px rgba(7,29,54,.08)}
.room-gallery-thumb.active,.room-gallery-thumb:hover{opacity:1;border-color:#d8a03b;transform:translateY(-1px)}
.room-gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.room-lightbox{position:fixed;inset:0;background:rgba(4,13,25,.86);z-index:99999;display:none;align-items:center;justify-content:center;padding:24px}
.room-lightbox.open{display:flex}
.room-lightbox img{max-width:min(1100px,94vw);max-height:86vh;object-fit:contain;border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.35)}
.room-lightbox-close{position:fixed;right:24px;top:20px;width:48px;height:48px;border-radius:50%;border:0;background:#fff;color:#071d36;font-size:34px;line-height:1;box-shadow:0 15px 40px rgba(0,0,0,.25)}
.room-gallery-admin{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;background:#f8fbff;border:1px solid #e6eef7;border-radius:22px;padding:14px}
.room-gallery-admin-item{background:#fff;border:1px solid #e8f0f8;border-radius:18px;padding:10px;box-shadow:0 8px 24px rgba(7,29,54,.06)}
.room-gallery-admin-item img{width:100%;height:105px;object-fit:cover;border-radius:14px;display:block}
@media(max-width:768px){
  .room-gallery-main{height:320px;border-radius:20px}
  .room-gallery-pro{padding:10px;border-radius:22px}
  .room-gallery-thumb{min-width:78px;height:58px}
  .room-gallery-nav{width:38px;height:38px;font-size:28px}
}


/* Admin amenity icon checklist */
.amenity-check-icon{gap:10px!important;align-items:center!important}
.amenity-check-emoji{width:30px;height:30px;border-radius:12px;background:#fff7e5;display:inline-flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 1px rgba(216,160,59,.22);font-size:17px;flex:0 0 30px}


/* =========================================================
   THE BOK - Agent Price Admin + Quick Support Widget
   ========================================================= */
.agent-price-admin-card,
.admin-form-card{
  background:#fff;
  border:1px solid #e5edf7;
  border-radius:24px;
  box-shadow:0 18px 45px rgba(7,29,54,.07);
  padding:22px;
}
.agent-price-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.agent-price-toolbar h2{font-size:24px;font-weight:900;color:#071d38;margin:0 0 4px}
.agent-price-toolbar p{margin:0;color:#64748b;font-weight:500}
.agent-price-table th{font-size:13px;color:#41546b;font-weight:900;background:#f7faff;white-space:nowrap}
.agent-price-table td{vertical-align:middle;border-color:#eef3f8}
.agent-room-cell{display:flex;align-items:center;gap:12px;min-width:240px}
.agent-room-cell img{width:54px;height:46px;object-fit:cover;border-radius:12px;box-shadow:0 6px 15px rgba(7,29,54,.12)}
.agent-room-cell b{display:block;color:#071d38;font-weight:900}
.agent-room-cell small{display:block;color:#64748b;font-weight:600;margin-top:2px}
.agent-switch{width:42px;height:22px;cursor:pointer}
.agent-price-guide{display:flex;gap:14px;flex-wrap:wrap;margin-top:16px;background:#f8fbff;border:1px solid #e6eef7;border-radius:18px;padding:14px;color:#52657a;font-size:13px}
.agent-price-guide b{color:#071d38}
@media(max-width:768px){.agent-price-toolbar{align-items:flex-start;flex-direction:column}.agent-room-cell{min-width:190px}}

.quick-support-widget{position:fixed;right:22px;bottom:22px;z-index:9990;font-family:'Be Vietnam Pro',system-ui,sans-serif}
.quick-support-check{position:absolute;opacity:0;pointer-events:none}
.quick-support-main{
  width:62px;height:62px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
  background:linear-gradient(135deg,#08223d,#0d4b85);color:#fff;font-size:30px;font-weight:300;
  box-shadow:0 18px 45px rgba(7,29,54,.28), inset 0 0 0 3px rgba(255,255,255,.9);
  transition:.25s ease; user-select:none;
}
.quick-support-main:hover{transform:translateY(-3px) scale(1.03)}
.quick-support-check:not(:checked) ~ .quick-support-main{font-size:28px}
.quick-support-check:not(:checked) ~ .quick-support-main::before{content:'🎧'}
.quick-support-check:not(:checked) ~ .quick-support-main{color:transparent}
.quick-support-check:checked ~ .quick-support-main{color:#fff;background:#071d38}
.quick-support-panel{
  position:absolute;right:0;bottom:78px;width:286px;background:#fff;border:1px solid #e2eaf5;border-radius:24px;
  overflow:hidden;box-shadow:0 24px 75px rgba(7,29,54,.22);opacity:0;pointer-events:none;
  transform:translateY(12px) scale(.96);transition:.22s ease;
}
.quick-support-check:checked ~ .quick-support-panel{opacity:1;pointer-events:auto;transform:none}
.quick-support-title{background:#08223d;color:#fff;font-weight:900;font-size:17px;padding:18px 20px}
.quick-support-close{position:absolute;right:15px;top:13px;color:#fff;font-size:24px;cursor:pointer;line-height:1}
.quick-support-list{display:grid;gap:10px;padding:14px}
.quick-support-link{display:grid;grid-template-columns:46px 1fr;grid-template-rows:auto auto;column-gap:12px;align-items:center;text-decoration:none;border:1px solid #e5edf7;border-radius:18px;padding:12px;background:#f8fbff;transition:.2s ease;color:#071d38}
.quick-support-link:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(7,29,54,.10);color:#071d38}
.quick-support-link span{grid-row:1/3;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:900;font-size:18px}
.quick-support-link b{font-size:14px;font-weight:900;line-height:1.1}
.quick-support-link small{font-size:12px;color:#64748b;font-weight:600;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.quick-support-link.whatsapp{background:#f0fff7;border-color:#bff0d5}.quick-support-link.whatsapp span{background:#20c76a}
.quick-support-link.zalo{background:#f1f7ff;border-color:#cfe4ff}.quick-support-link.zalo span{background:#0a8cff}
.quick-support-link.phone{background:#f6f1ff;border-color:#dfd0ff}.quick-support-link.phone span{background:#8157e8}
.quick-support-link.telegram{background:#eff8ff;border-color:#cbefff}.quick-support-link.telegram span{background:#2da9e9}
.quick-support-link.email{background:#fff8eb;border-color:#f6dfad}.quick-support-link.email span{background:#f1b744}
.quick-support-note{text-align:center;color:#64748b;font-size:12px;font-weight:700;padding:0 14px 16px}
@media(max-width:575px){.quick-support-widget{right:15px;bottom:15px}.quick-support-panel{width:calc(100vw - 30px);right:0}.quick-support-main{width:58px;height:58px}}

/* =========================================================
   THE BOK - QUICK SUPPORT 24/7 + AGENT PRICE DATE POLISH
   ========================================================= */
.quick-support-widget{right:22px!important;bottom:22px!important}
.quick-support-main{
    width:auto!important;
    min-width:146px!important;
    height:56px!important;
    padding:0 18px!important;
    border-radius:999px!important;
    background:#082b52!important;
    color:#fff!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    gap:9px!important;
    font-size:15px!important;
    font-weight:900!important;
    letter-spacing:-.2px!important;
    box-shadow:0 14px 34px rgba(7,29,56,.28)!important;
    border:2px solid rgba(255,255,255,.75)!important;
}
.quick-support-check:not(:checked) ~ .quick-support-main{color:#fff!important;font-size:15px!important}
.quick-support-check:not(:checked) ~ .quick-support-main::before{content:'💬';font-size:19px;line-height:1}
.quick-support-check:not(:checked) ~ .quick-support-main::after{content:'Hỗ trợ 24/7'}
.quick-support-check:checked ~ .quick-support-main{width:58px!important;min-width:58px!important;padding:0!important;border-radius:50%!important;background:#071d38!important;color:#fff!important}
.quick-support-check:checked ~ .quick-support-main::before{content:'×';font-size:30px;line-height:1;margin-top:-2px}
.quick-support-check:checked ~ .quick-support-main::after{content:''}
.quick-support-panel{bottom:74px!important}
.quick-support-title{font-size:16px!important;padding:17px 20px!important}
.quick-support-note{display:none!important}
.agent-price-table th,.agent-price-table td{vertical-align:middle!important;white-space:nowrap}
.agent-date-input{min-width:138px!important}
.agent-value-input{min-width:120px!important}
.agent-price-guide{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:16px;color:#64748b;font-size:13px}
.agent-price-guide b{color:#071d38}.agent-price-guide span{background:#f8fafc;border:1px solid #e7edf5;border-radius:999px;padding:7px 11px}
.agent-note-line.is-muted{color:#b45309!important;background:#fff8e7!important;border-color:#f4d38a!important}
@media(max-width:575px){
    .quick-support-main{width:58px!important;min-width:58px!important;padding:0!important;border-radius:50%!important}
    .quick-support-check:not(:checked) ~ .quick-support-main::after{content:''}
    .quick-support-panel{bottom:70px!important}
}

/* ===== Agent bulk pricing UI ===== */
.agent-bulk-card,.agent-price-admin-card{background:#fff;border:1px solid #e5edf7;border-radius:24px;padding:20px;box-shadow:0 14px 36px rgba(7,29,56,.06)}
.agent-bulk-head,.agent-price-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.agent-bulk-head h2,.agent-price-toolbar h2{font-weight:900;color:#071d38;margin:0 0 4px}
.agent-bulk-head p,.agent-price-toolbar p{margin:0;color:#64748b;font-weight:600}
.agent-bulk-room-list{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;padding:12px;border:1px dashed #d6e2f2;border-radius:18px;background:#f8fbff}
.agent-bulk-room-list label{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid #e5edf7;border-radius:999px;padding:8px 12px;font-weight:700;color:#071d38;cursor:pointer}
.agent-bulk-room-list .agent-check-all{background:#fff7e8;border-color:#f4d28a;color:#8a5a00}
.agent-bulk-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.agent-bulk-option{display:grid;gap:8px;border:1px solid #e5edf7;border-radius:18px;padding:14px;background:#fff}
.agent-bulk-option>span{font-weight:900;color:#071d38;display:flex;align-items:center;gap:8px}
.agent-price-table th{white-space:nowrap;font-size:13px;color:#334155}
.agent-price-table td{vertical-align:middle}
.agent-room-cell{display:flex;align-items:center;gap:12px;min-width:210px}
.agent-room-cell img{width:54px;height:46px;border-radius:12px;object-fit:cover;border:1px solid #e5edf7}
.agent-room-cell b{display:block;color:#071d38;font-weight:900}
.agent-room-cell small{display:block;color:#64748b;font-weight:600}
.agent-money-input{min-width:120px;font-weight:800}
.agent-qty-input{width:76px;font-weight:800;text-align:center}
.agent-date-input{min-width:120px;font-weight:700;text-align:center}
.agent-value-input{min-width:105px;font-weight:800}
.agent-price-guide{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:14px;color:#64748b;font-size:13px;font-weight:700}
.agent-price-guide b{color:#071d38}
@media(max-width:992px){.agent-bulk-head,.agent-price-toolbar{display:block}.agent-bulk-head .btn,.agent-price-toolbar .btn{margin-top:12px}.agent-bulk-grid{grid-template-columns:1fr}}


/* ===== THE BOK SERVICES MODULE ===== */
.services-home-pro{background:#fff}
.service-home-card{
    display:block;
    height:100%;
    padding:28px;
    border-radius:26px;
    background:#fff;
    color:#071d36;
    text-decoration:none;
    border:1px solid #edf1f6;
    box-shadow:0 14px 40px rgba(7,29,54,.07);
    transition:.22s ease;
}
.service-home-card:hover{transform:translateY(-5px);box-shadow:0 22px 60px rgba(7,29,54,.12);border-color:#f0cf84}
.service-home-icon{
    width:58px;height:58px;border-radius:18px;background:#fff7e8;
    display:flex;align-items:center;justify-content:center;font-size:30px;margin-bottom:18px;
}
.service-home-card h3{font-size:21px;font-weight:900;margin-bottom:10px}
.service-home-card p{color:#687587;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:72px}
.service-home-card span{font-weight:800;color:#d8a03b}

.service-hero-page{padding:145px 0 45px;background:linear-gradient(135deg,#071d36,#0e3a66);color:#fff}
.service-hero-card{max-width:850px}
.service-hero-card h1{font-size:clamp(36px,5vw,62px);font-weight:900;letter-spacing:-1px}
.service-hero-card p{font-size:19px;color:#dbe7f5}

.service-list-page{background:#f7f9fc}
.service-page-card{border-radius:28px;overflow:hidden;background:#fff;box-shadow:0 18px 55px rgba(7,29,54,.09);border:1px solid #edf1f6}
.service-page-img{height:190px;display:block;background:#eaf0f7;overflow:hidden;text-decoration:none}
.service-page-img img{width:100%;height:100%;object-fit:cover;transition:.25s}
.service-page-card:hover .service-page-img img{transform:scale(1.04)}
.service-page-placeholder{height:100%;display:flex;align-items:center;justify-content:center;font-size:58px;background:linear-gradient(135deg,#fff7e8,#eaf0f7)}
.service-page-body{padding:24px;position:relative}
.service-page-icon{width:52px;height:52px;border-radius:18px;background:#fff7e8;display:flex;align-items:center;justify-content:center;font-size:27px;margin-top:-52px;margin-bottom:16px;box-shadow:0 10px 25px rgba(7,29,54,.12)}
.service-page-body h3{font-size:22px;font-weight:900;color:#071d36;margin-bottom:10px}
.service-page-body p{color:#687587;min-height:72px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.service-price{font-weight:900;color:#d8a03b;margin-bottom:16px}

.service-detail-hero{padding:135px 0 55px;background:#f7f9fc}
.service-detail-card{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center;background:#fff;border-radius:34px;padding:28px;box-shadow:0 24px 70px rgba(7,29,54,.10)}
.service-detail-media{height:430px;border-radius:28px;overflow:hidden;background:#eaf0f7}
.service-detail-media img{width:100%;height:100%;object-fit:cover}
.service-detail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:90px;background:linear-gradient(135deg,#fff7e8,#eaf0f7)}
.service-detail-icon{width:68px;height:68px;border-radius:22px;background:#fff7e8;display:flex;align-items:center;justify-content:center;font-size:36px;margin-bottom:18px}
.service-detail-content h1{font-size:clamp(34px,4vw,58px);font-weight:900;color:#071d36;line-height:1.05}
.service-detail-price{display:inline-flex;padding:10px 18px;border-radius:999px;background:#fff7e8;color:#b77a10;font-weight:900;margin:12px 0 22px}
.service-detail-actions{display:flex;flex-wrap:wrap;gap:12px}
.service-content-box{background:#fff;border-radius:28px;padding:34px;box-shadow:0 16px 45px rgba(7,29,54,.08);font-size:17px;line-height:1.8;color:#334155}

.service-admin-card,.service-admin-table{font-size:14px}
.service-admin-icon{width:44px;height:44px;border-radius:15px;background:#fff7e8;display:flex;align-items:center;justify-content:center;font-size:24px;flex:0 0 44px}

@media(max-width:991px){
    .service-detail-card{grid-template-columns:1fr;padding:18px;border-radius:26px}
    .service-detail-media{height:300px}
}


/* === Service Tickets Price Table === */
.ticket-price-section{background:#fff;border:1px solid #e7edf6;border-radius:28px;padding:28px;box-shadow:0 18px 50px rgba(7,29,56,.07)}
.ticket-price-title{font-size:28px;font-weight:900;color:#071d38}
.ticket-price-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.ticket-price-card{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid #e7edf6;border-radius:22px;padding:20px;box-shadow:0 10px 28px rgba(7,29,56,.06)}
.ticket-price-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;color:#071d38;font-size:18px;font-weight:900}
.ticket-price-head span{width:38px;height:38px;border-radius:14px;background:#fff6df;display:flex;align-items:center;justify-content:center}
.ticket-price-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-top:1px dashed #dce6f2;color:#536275;font-weight:700}
.ticket-price-row strong{color:#0b3768;font-size:18px;white-space:nowrap}
.ticket-price-note{margin-top:12px;background:#f8fafc;border-radius:14px;padding:10px 12px;color:#64748b;font-size:13px;font-weight:700}
.ticket-admin-table td{vertical-align:middle}
@media(max-width:992px){.ticket-price-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:576px){.ticket-price-section{padding:18px;border-radius:22px}.ticket-price-grid{grid-template-columns:1fr}.ticket-price-title{font-size:24px}}


/* ===== Service ticket grouped price table ===== */
.ticket-group-block{margin-top:24px}
.ticket-group-title{font-size:22px;font-weight:900;color:#071d38;margin:0 0 14px;display:flex;align-items:center;gap:8px}
.ticket-group-title:before{content:'🎫';font-size:20px}
.ticket-table-wrap{overflow-x:auto;border-radius:18px;border:1px solid #e7edf6;background:#fff;box-shadow:0 12px 35px rgba(7,29,56,.06)}
.ticket-table{width:100%;border-collapse:collapse;background:#fff;margin:0;min-width:760px}
.ticket-table th{background:#0d3565;color:#fff;padding:15px 14px;text-align:center;font-weight:800;white-space:nowrap}
.ticket-table th:first-child{text-align:left}
.ticket-table td{padding:15px 14px;border-bottom:1px solid #edf2f7;text-align:center;font-weight:800;color:#0b3768;white-space:nowrap}
.ticket-table td:first-child{text-align:left;color:#071d38;min-width:280px}
.ticket-table tbody tr:last-child td{border-bottom:0}
.ticket-table tbody tr:hover{background:#fbfdff}
.ticket-note{font-size:12px;color:#64748b;font-weight:600;margin-top:3px;white-space:normal}
@media(max-width:768px){
  .ticket-table{min-width:0;border-collapse:separate;border-spacing:0;background:transparent}
  .ticket-table thead{display:none}
  .ticket-table,.ticket-table tbody,.ticket-table tr,.ticket-table td{display:block;width:100%}
  .ticket-table-wrap{border:0;box-shadow:none;background:transparent;overflow:visible}
  .ticket-table tr{background:#fff;border:1px solid #e7edf6;border-radius:16px;margin-bottom:12px;padding:12px;box-shadow:0 8px 24px rgba(7,29,56,.05)}
  .ticket-table td{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;text-align:right;border:0;padding:8px 0;white-space:normal}
  .ticket-table td:first-child{display:block;min-width:0;text-align:left;font-size:16px;padding-bottom:10px;border-bottom:1px dashed #e2e8f0;margin-bottom:4px}
  .ticket-table td:nth-child(2):before{content:'Người lớn';color:#64748b;font-weight:700;text-align:left}
  .ticket-table td:nth-child(3):before{content:'Trẻ em dưới 1,4m';color:#64748b;font-weight:700;text-align:left}
  .ticket-table td:nth-child(4):before{content:'Người trên 60 tuổi';color:#64748b;font-weight:700;text-align:left}
}

.footer-simple-menu{display:grid;gap:8px;margin-top:8px}
.footer-simple-menu a{display:inline-flex;align-items:center;gap:9px;width:max-content;max-width:100%;color:#e8f1fb;text-decoration:none;font-weight:900;line-height:1.35;transition:.2s ease}
.footer-simple-menu a span{width:22px;min-width:22px;text-align:center;color:#ffd777;font-size:15px}
.footer-simple-menu a:hover{color:#ffd777;transform:translateX(3px)}
.footer-service-menu a b,.footer-partner-menu a b{font-weight:900}


/* === Footer alignment refinement 20260623 === */
.footer-pro{padding:58px 0 24px;background:#06192f;color:#eaf3ff;}
.footer-pro .footer-grid{display:grid;grid-template-columns:1.18fr 1.05fr .85fr 1fr;gap:52px;align-items:start;}
.footer-pro h5{font-size:22px;font-weight:900;color:#fff;margin:0 0 14px;line-height:1.15;letter-spacing:-.3px;}
.footer-pro .footer-logo{width:118px;height:auto;max-height:78px;object-fit:contain;display:block;margin:0 0 20px;}
.footer-pro .footer-contact-line{display:flex;align-items:flex-start;gap:13px;margin-top:0;max-width:285px;}
.footer-pro .footer-contact-line span,
.footer-pro .footer-contact-list span{width:36px;height:36px;border-radius:13px;background:rgba(255,255,255,.09);display:inline-flex;align-items:center;justify-content:center;flex:0 0 36px;color:#ffd66b;font-size:16px;}
.footer-pro .footer-contact-line p{margin:0;color:#fff;font-size:17px;font-weight:800;line-height:1.55;}
.footer-pro .footer-contact-list{display:flex;flex-direction:column;gap:12px;margin-top:0;}
.footer-pro .footer-contact-list a{display:flex;align-items:center;gap:13px;color:#fff;text-decoration:none;font-size:17px;line-height:1.3;}
.footer-pro .footer-contact-list b{font-weight:900;}
.footer-pro .footer-simple-menu{display:flex;flex-direction:column;gap:9px;margin-top:2px;}
.footer-pro .footer-simple-menu a{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-size:17px;font-weight:900;line-height:1.35;padding:0;border:0;background:transparent;box-shadow:none;}
.footer-pro .footer-simple-menu a:hover{color:#ffd66b;transform:translateX(2px);}
.footer-pro .footer-simple-menu span{width:18px;min-width:18px;text-align:center;font-size:14px;line-height:1;color:#ffd66b;}
.footer-pro .footer-service-menu span{font-size:15px;}
.footer-pro .copyright{margin-top:36px;padding-top:20px;border-top:1px solid rgba(255,255,255,.14);color:#a9bdd2;font-size:15px;}
@media(max-width:992px){.footer-pro .footer-grid{grid-template-columns:1fr 1fr;gap:34px 42px}.footer-pro .footer-logo{width:110px}}
@media(max-width:576px){.footer-pro{padding:42px 0 22px}.footer-pro .footer-grid{grid-template-columns:1fr;gap:26px}.footer-pro h5{font-size:20px}.footer-pro .footer-contact-line p,.footer-pro .footer-contact-list a,.footer-pro .footer-simple-menu a{font-size:16px}.footer-pro .footer-logo{width:105px;margin-bottom:14px}}


/* === Footer clean alignment fix 20260623 === */
.footer-pro{padding:54px 0 24px;background:#06192f;color:#eaf3ff;overflow:hidden;}
.footer-pro .footer-grid-clean{display:grid!important;grid-template-columns:1.25fr 1fr .9fr .95fr;gap:46px;align-items:start;width:100%;}
.footer-pro .footer-col{min-width:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:0!important;margin:0!important;}
.footer-pro h5{font-size:22px;font-weight:900;color:#fff;margin:0 0 14px!important;line-height:1.15;letter-spacing:-.3px;min-height:26px;}
.footer-pro .footer-logo{width:112px;height:62px;object-fit:contain;object-position:left center;display:block;margin:0 0 18px!important;}
.footer-pro .footer-contact-line{display:grid!important;grid-template-columns:36px minmax(0,1fr);align-items:flex-start;column-gap:13px;margin:0!important;max-width:310px;}
.footer-pro .footer-contact-line span,
.footer-pro .footer-contact-list span{width:36px!important;height:36px!important;border-radius:13px;background:rgba(255,255,255,.09);display:inline-flex;align-items:center;justify-content:center;flex:0 0 36px;color:#ffd66b;font-size:16px;line-height:1;}
.footer-pro .footer-contact-line p{margin:0!important;color:#fff;font-size:16.5px;font-weight:800;line-height:1.55;}
.footer-pro .footer-contact-list{display:flex!important;flex-direction:column;gap:12px;margin:0!important;padding:0!important;}
.footer-pro .footer-contact-list a{display:grid!important;grid-template-columns:36px minmax(0,1fr);align-items:center;column-gap:13px;color:#fff;text-decoration:none;font-size:16.5px;line-height:1.35;min-height:36px;}
.footer-pro .footer-contact-list b{font-weight:900;overflow-wrap:anywhere;}
.footer-pro .footer-simple-menu{display:flex!important;flex-direction:column;gap:10px;margin:0!important;padding:0!important;}
.footer-pro .footer-simple-menu a{display:grid!important;grid-template-columns:20px minmax(0,1fr);align-items:center;column-gap:9px;color:#fff;text-decoration:none;font-size:16.5px;font-weight:900;line-height:1.35;padding:0!important;border:0!important;background:transparent!important;box-shadow:none!important;width:auto!important;max-width:100%;}
.footer-pro .footer-simple-menu a:hover{color:#ffd66b;transform:translateX(2px);}
.footer-pro .footer-simple-menu span{width:20px!important;min-width:20px;text-align:center;font-size:14px;line-height:1;color:#ffd66b;display:inline-block;}
.footer-pro .copyright{margin-top:34px;padding-top:20px;border-top:1px solid rgba(255,255,255,.14);color:#a9bdd2;font-size:15px;}
@media(max-width:1100px){.footer-pro .footer-grid-clean{grid-template-columns:1fr 1fr;gap:34px 44px;}}
@media(max-width:576px){.footer-pro{padding:40px 0 22px}.footer-pro .footer-grid-clean{grid-template-columns:1fr;gap:24px}.footer-pro .footer-logo{width:105px;height:58px;margin-bottom:14px!important}.footer-pro h5{font-size:20px;min-height:0}.footer-pro .footer-contact-line p,.footer-pro .footer-contact-list a,.footer-pro .footer-simple-menu a{font-size:16px}}


/* Footer logo only layout - The Bok 20260623 */
.footer-pro{padding:52px 0 24px;background:#06192f;color:#eaf3ff;overflow:hidden;}
.footer-pro .footer-grid-clean{
  display:grid!important;
  grid-template-columns:1fr 1.15fr .95fr 1fr;
  gap:56px;
  align-items:start;
  width:100%;
}
.footer-pro .footer-col{min-width:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:0!important;margin:0!important;}
.footer-pro .footer-brand-col{align-items:flex-start;justify-content:flex-start;}
.footer-pro .footer-logo{width:118px!important;height:78px!important;object-fit:contain;object-position:left center;display:block;margin:0!important;}
.footer-pro h5{font-size:22px;font-weight:900;color:#fff;margin:0 0 14px!important;line-height:1.15;letter-spacing:-.3px;min-height:26px;}
.footer-pro .footer-contact-line{display:none!important;}
.footer-pro .footer-contact-list{display:flex!important;flex-direction:column;gap:12px;margin:0!important;padding:0!important;}
.footer-pro .footer-contact-list a{display:grid!important;grid-template-columns:36px minmax(0,1fr);align-items:center;column-gap:13px;color:#fff;text-decoration:none;font-size:16.5px;line-height:1.35;min-height:36px;}
.footer-pro .footer-contact-list span{width:36px!important;height:36px!important;border-radius:13px;background:rgba(255,255,255,.09);display:inline-flex;align-items:center;justify-content:center;flex:0 0 36px;color:#ffd66b;font-size:16px;line-height:1;}
.footer-pro .footer-contact-list b{font-weight:900;white-space:nowrap;overflow:visible;}
.footer-pro .footer-simple-menu{display:flex!important;flex-direction:column;gap:10px;margin:0!important;padding:0!important;}
.footer-pro .footer-simple-menu a{display:grid!important;grid-template-columns:20px minmax(0,1fr);align-items:center;column-gap:9px;color:#fff;text-decoration:none;font-size:16.5px;font-weight:900;line-height:1.35;padding:0!important;border:0!important;background:transparent!important;box-shadow:none!important;width:auto!important;max-width:100%;}
.footer-pro .footer-simple-menu a:hover{color:#ffd66b;transform:translateX(2px);}
.footer-pro .footer-simple-menu span{width:20px!important;min-width:20px;text-align:center;font-size:14px;line-height:1;color:#ffd66b;display:inline-block;}
.footer-pro .copyright{margin-top:34px;padding-top:20px;border-top:1px solid rgba(255,255,255,.14);color:#a9bdd2;font-size:15px;}
@media(max-width:1100px){.footer-pro .footer-grid-clean{grid-template-columns:1fr 1fr;gap:34px 44px;}.footer-pro .footer-contact-list b{white-space:normal;overflow-wrap:anywhere;}}
@media(max-width:576px){.footer-pro{padding:40px 0 22px}.footer-pro .footer-grid-clean{grid-template-columns:1fr;gap:24px}.footer-pro .footer-logo{width:105px!important;height:58px!important}.footer-pro h5{font-size:20px;min-height:0}.footer-pro .footer-contact-list a,.footer-pro .footer-simple-menu a{font-size:16px}}


/* Footer email smaller */
.footer-contact-list a{display:flex;align-items:center;gap:12px;text-decoration:none}
.footer-contact-list a:last-child b{
 font-size:14px !important;
 font-weight:600 !important;
 word-break:break-word;
}

/* footer tune */
.footer-copyright{text-align:center!important;width:100%!important;}
.footer-contact-email,.footer-contact a[href^='mailto']{font-size:13px!important;}
.footer-contact-icon,.footer-contact i{transform:scale(.8);}

/* === Footer final contact polish - The Bok 20260623 v3 === */
.footer-pro .footer-contact-list{
  gap:10px!important;
}
.footer-pro .footer-contact-list a{
  display:grid!important;
  grid-template-columns:30px minmax(0,1fr)!important;
  column-gap:11px!important;
  align-items:center!important;
  min-height:30px!important;
}
.footer-pro .footer-contact-list .footer-contact-icon,
.footer-pro .footer-contact-list span{
  width:30px!important;
  height:30px!important;
  flex:0 0 30px!important;
  border-radius:10px!important;
  background:rgba(255,255,255,.08)!important;
  color:#ffd66b!important;
  font-size:13px!important;
  line-height:1!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
}
.footer-pro .footer-contact-phone{
  font-size:16px!important;
  line-height:1.25!important;
  font-weight:900!important;
  color:#fff!important;
  white-space:nowrap!important;
}
.footer-pro .footer-contact-email{
  font-size:13px!important;
  line-height:1.25!important;
  font-weight:600!important;
  letter-spacing:-.15px!important;
  color:#dbeafe!important;
  white-space:nowrap!important;
}
.footer-pro .copyright,
.footer-pro .container > .copyright,
.footer .copyright{
  text-align:center!important;
  width:100%!important;
  margin-left:auto!important;
  margin-right:auto!important;
  display:block!important;
  font-size:14px!important;
  color:#a9bdd2!important;
}
@media(max-width:576px){
  .footer-pro .footer-contact-email{white-space:normal!important;overflow-wrap:anywhere!important;}
  .footer-pro .copyright{font-size:13px!important;line-height:1.5!important;}
}

/* === The Bok Notifications Manager PRO - 20260624 === */
.notif-head{align-items:flex-start!important}.notif-head-actions .btn{font-weight:800}.notif-panel{background:#fff;border:1px solid #e5edf6;border-radius:18px;box-shadow:0 18px 55px rgba(7,27,53,.06);overflow:hidden;margin-bottom:22px}.notif-panel-top{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:20px 22px 12px;border-bottom:1px solid #edf2f7}.notif-tabs{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.notif-tab{display:inline-flex;gap:6px;align-items:center;text-decoration:none;color:#0f3f72;font-weight:800;background:#fff;border:1px solid #e5edf6;border-radius:12px;padding:10px 14px}.notif-tab.active{background:#eaf3ff;border-color:#cfe2ff;color:#075bbd}.notif-tab b{font-weight:900}.notif-type-filter .form-select{min-width:155px;border-radius:12px;font-weight:700}.notif-unread-pill{background:#fff9ec;border:1px solid #ffe3a3;color:#6e4a00;border-radius:999px;padding:9px 13px;font-weight:800;white-space:nowrap}.notif-actions-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:16px 18px;border-bottom:1px solid #edf2f7;background:#fbfdff}.notif-actions-bar .btn{border-radius:10px;font-weight:800}.notif-check-all{display:inline-flex;align-items:center;gap:8px;border:1px solid #dfe8f2;border-radius:10px;padding:9px 13px;background:#fff;font-weight:700;color:#233b55}.notif-per-page{font-weight:700;color:#64748b}.notif-table-wrap{overflow:auto}.notif-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1040px}.notif-table th{font-size:13px;color:#10223a;font-weight:900;background:#fff;padding:14px 12px;border-bottom:1px solid #edf2f7;white-space:nowrap}.notif-table td{padding:14px 12px;border-bottom:1px solid #edf2f7;vertical-align:middle;color:#1c2e45}.notif-table tbody tr:hover{background:#f8fbff}.notif-table tbody tr.is-unread{background:#fffdf8}.notif-table .w-check{width:40px}.notif-type{display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:10px;min-width:150px}.notif-type span{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:#eef6ff;font-size:17px}.notif-type b{font-size:13px;font-weight:900}.notif-title{font-weight:900;color:#0b203a;margin-bottom:4px}.notif-message{font-size:13.5px;color:#5d6d82;line-height:1.45;max-width:560px}.notif-code{display:inline-flex;margin-top:7px;background:#f4f7fb;border:1px solid #e4ebf4;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:800;color:#42536a}.notif-link{font-weight:800;text-decoration:none;color:#075fe9;white-space:nowrap}.notif-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;padding:6px 9px;font-size:12px;font-weight:900;white-space:nowrap}.notif-badge.unread{background:#ef4444;color:#fff}.notif-badge.read{background:#16a34a;color:#fff}.notif-row-actions{display:flex;gap:7px;align-items:center;white-space:nowrap}.notif-row-actions .btn{border-radius:8px;font-weight:800}.notif-empty{text-align:center;color:#718198;padding:46px!important}.notif-maintenance{display:flex;justify-content:space-between;align-items:center;gap:20px;background:#fff;border:1px solid #e5edf6;border-radius:18px;box-shadow:0 18px 55px rgba(7,27,53,.05);padding:20px 22px;margin-bottom:28px}.notif-maintenance h3{font-size:20px;font-weight:900;color:#10223a;margin:0 0 4px}.notif-maintenance p{margin:0;color:#64748b}.notif-maintenance-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.notif-maintenance-actions .btn{border-radius:10px;font-weight:800}.notif-row-check,#checkAllNotif{width:16px;height:16px;accent-color:#1769ff}@media(max-width:992px){.notif-panel-top,.notif-maintenance{display:block}.notif-unread-pill{display:inline-flex;margin-top:12px}.notif-maintenance-actions{justify-content:flex-start;margin-top:15px}.notif-actions-bar .ms-auto{margin-left:0!important;width:100%}}@media(max-width:575px){.notif-head-actions .btn{width:100%}.notif-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px}.notif-tabs .notif-type-filter{grid-column:1/-1}.notif-type-filter .form-select{width:100%}.notif-actions-bar .btn,.notif-check-all,.notif-maintenance-actions .btn{width:100%;justify-content:center}.notif-unread-pill{width:100%;justify-content:center}.notif-panel{border-radius:14px}.notif-panel-top{padding:16px}.notif-table{min-width:920px}}
