/* ============================================================
   TBS Hotel Listing — hotel-listing.css v1.0
   ============================================================ */
.tbs-hl {
  --hl-gold:#C8973A;--hl-gold-l:#E8B865;--hl-gold-pale:#FEF8EE;--hl-gold-d:#9E6E22;
  --hl-ink:#0E1621;--hl-slate:#4A5568;--hl-mist:#8A99A8;--hl-border:#E8ECF0;
  --hl-white:#FFFFFF;--hl-cloud:#F4F6F9;--hl-r:20px;--hl-r-sm:12px;
  --hl-shadow:0 8px 32px rgba(14,22,33,.10);--hl-shadow-gold:0 8px 24px rgba(200,151,58,.22);
  --hl-t:all .22s cubic-bezier(.4,0,.2,1);
  --hl-font:'DM Sans',-apple-system,Arial,sans-serif;
  --hl-font-d:'Playfair Display',Georgia,serif;
  font-family:var(--hl-font);color:var(--hl-ink);-webkit-font-smoothing:antialiased;
  padding:40px 0 80px;
}

/* ---- Header ---- */
.tbs-hl-header { text-align:center;margin-bottom:40px; }
.tbs-hl-title { font-family:var(--hl-font-d);font-size:clamp(28px,4vw,48px);font-weight:700;color:var(--hl-ink);margin:0 0 12px;line-height:1.15; }
.tbs-hl-sub { color:var(--hl-mist);font-size:16px;margin:0 auto;max-width:560px;line-height:1.6; }
.tbs-hl-list-header { margin-bottom:24px; }
.tbs-hl-breadcrumb { display:flex;align-items:center;gap:8px;font-size:14px;margin-bottom:20px;flex-wrap:wrap; }
.tbs-hl-breadcrumb a { color:var(--hl-mist);text-decoration:none;font-weight:600;transition:var(--hl-t); }
.tbs-hl-breadcrumb a:hover { color:var(--hl-gold-d);text-decoration:none; }
.tbs-hl-breadcrumb span { color:var(--hl-mist); }
.tbs-hl-breadcrumb strong { color:var(--hl-ink); }
.tbs-hl-back { display:inline-flex;align-items:center;gap:6px;color:var(--hl-mist);text-decoration:none;font-size:14px;font-weight:600;margin-bottom:20px;transition:var(--hl-t); }
.tbs-hl-back:hover { color:var(--hl-gold-d);text-decoration:none; }

/* ---- Country grid ---- */
.tbs-hl-country-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px; }
.tbs-hl-country-card { display:block;text-decoration:none;border-radius:var(--hl-r);overflow:hidden;aspect-ratio:16/10;position:relative;transition:var(--hl-t);box-shadow:var(--hl-shadow); }
.tbs-hl-country-card:hover { transform:translateY(-5px);box-shadow:0 20px 56px rgba(14,22,33,.17);text-decoration:none; }
.tbs-hl-country-img { position:absolute;inset:0;background:linear-gradient(135deg,#1A2F4A,#243B55) center/cover no-repeat;transition:transform .5s ease; }
.tbs-hl-country-card:hover .tbs-hl-country-img { transform:scale(1.04); }
.tbs-hl-country-img span { position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);font-size:60px;opacity:.3; }
.tbs-hl-country-overlay { position:absolute;inset:0;background:linear-gradient(to bottom,rgba(14,22,33,0) 30%,rgba(14,22,33,.88) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:26px 22px; }
.tbs-hl-country-overlay h3 { font-family:var(--hl-font-d);font-size:clamp(18px,2.5vw,26px);font-weight:700;color:#fff;margin:0 0 4px;text-shadow:0 2px 10px rgba(0,0,0,.25); }
.tbs-hl-country-overlay span { font-size:13px;color:rgba(255,255,255,.75);font-weight:500;margin-bottom:10px;display:block; }
.tbs-hl-country-cta { display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--hl-gold),var(--hl-gold-d));color:#fff;border-radius:999px;padding:8px 18px;font-size:13px;font-weight:700;align-self:flex-start;transition:var(--hl-t);box-shadow:var(--hl-shadow-gold); }
.tbs-hl-country-card:hover .tbs-hl-country-cta { transform:translateX(4px); }

/* ---- Hotel list ---- */
.tbs-hl-list { display:flex;flex-direction:column;gap:20px; }
.tbs-hl-card { display:grid;grid-template-columns:320px 1fr;text-decoration:none;color:inherit;background:var(--hl-white);border:1.5px solid var(--hl-border);border-radius:var(--hl-r);overflow:hidden;transition:var(--hl-t);box-shadow:var(--hl-shadow); }
.tbs-hl-card:hover { border-color:var(--hl-gold);box-shadow:0 16px 48px rgba(14,22,33,.14);transform:translateY(-3px);text-decoration:none; }
.tbs-hl-card-img-wrap { position:relative;overflow:hidden; }
.tbs-hl-card-img { height:100%;min-height:220px;background:linear-gradient(135deg,#CBD5E1,#94A3B8) center/cover no-repeat;transition:transform .4s ease;position:relative;display:flex;align-items:center;justify-content:center;font-size:52px; }
.tbs-hl-card:hover .tbs-hl-card-img { transform:scale(1.04); }
.tbs-hl-card-nav { position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.92);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;font-weight:700;z-index:3;box-shadow:0 2px 10px rgba(0,0,0,.2);transition:var(--hl-t);padding:0; }
.tbs-hl-card-nav:hover { background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.25); }
.tbs-hl-card-prev { left:8px; }
.tbs-hl-card-next { right:8px; }
.tbs-hl-card-stars { position:absolute;bottom:10px;left:10px;z-index:3;background:rgba(14,22,33,.75);backdrop-filter:blur(4px);color:var(--hl-gold-l);border-radius:999px;padding:4px 12px;font-size:12px;font-weight:700; }
.tbs-hl-card-body { padding:20px 22px;display:flex;flex-direction:column;gap:10px; }
.tbs-hl-card-top { display:flex;flex-direction:column;gap:5px; }
.tbs-hl-card-name { font-family:var(--hl-font-d);font-size:20px;font-weight:700;color:var(--hl-ink);margin:0;line-height:1.25; }
.tbs-hl-card-address { margin:0;font-size:13px;color:var(--hl-mist);font-weight:500; }
.tbs-hl-card-desc { margin:0;font-size:13px;color:var(--hl-slate);line-height:1.6; }
.tbs-hl-card-amen { display:flex;flex-wrap:wrap;gap:6px;padding:8px 0;border-top:1px solid var(--hl-border); }
.tbs-hl-card-amen span { font-size:12px;font-weight:600;color:var(--hl-slate);background:var(--hl-cloud);border-radius:999px;padding:3px 10px; }
.tbs-hl-card-meal { background:#ECFDF5 !important;color:#166534 !important; }
.tbs-hl-card-room-features { display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 0;border-top:1px solid var(--hl-border); }
.tbs-hl-card-room-label { font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--hl-mist);margin-right:2px; }
.tbs-hl-card-room-features span:not(.tbs-hl-card-room-label) { font-size:12px;font-weight:600;color:var(--hl-slate);background:var(--hl-cloud);border-radius:999px;padding:3px 10px; }
.tbs-hl-card-price-row { margin-top:auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:10px;border-top:1px solid var(--hl-border); }
.tbs-hl-card-from { font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--hl-mist);margin-right:3px; }
.tbs-hl-card-price { font-size:24px;font-weight:800;color:var(--hl-ink);font-family:var(--hl-font-d); }
.tbs-hl-card-night { font-size:13px;color:var(--hl-mist);font-weight:500; }
.tbs-hl-view-btn { display:inline-flex;align-items:center;gap:4px;padding:10px 20px;border-radius:999px;background:linear-gradient(135deg,var(--hl-gold),var(--hl-gold-d));color:#fff;font-size:13px;font-weight:700;white-space:nowrap;box-shadow:var(--hl-shadow-gold);transition:var(--hl-t); }
.tbs-hl-card:hover .tbs-hl-view-btn { transform:translateX(4px); }

/* ---- Empty ---- */
.tbs-hl-empty { text-align:center;padding:80px 24px;background:var(--hl-cloud);border-radius:var(--hl-r);border:2px dashed var(--hl-border); }
.tbs-hl-empty span { font-size:64px;display:block;margin-bottom:14px; }
.tbs-hl-empty p { color:var(--hl-slate);font-size:16px;margin:0; }

/* ============================================================
   DETAIL PAGE
   ============================================================ */
.tbs-hl-detail { padding:24px 0 80px; }

/* Gallery */
.tbs-hl-gallery { border-radius:var(--hl-r);overflow:hidden;margin-bottom:28px; }
.tbs-hl-gallery-main { height:420px;background:linear-gradient(135deg,#1A2F4A,#243B55) center/cover no-repeat;position:relative;display:flex;align-items:center;justify-content:center;border-radius:var(--hl-r) var(--hl-r) 0 0; }
.tbs-hl-gal-nav { position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.9);border:none;border-radius:50%;width:44px;height:44px;cursor:pointer;font-size:22px;font-weight:700;z-index:3;box-shadow:0 2px 12px rgba(0,0,0,.18);transition:var(--hl-t);display:flex;align-items:center;justify-content:center;padding:0; }
.tbs-hl-gal-nav:hover { background:#fff;box-shadow:0 4px 20px rgba(0,0,0,.25); }
.tbs-hl-gal-prev { left:16px; }
.tbs-hl-gal-next { right:16px; }
.tbs-hl-gal-counter { position:absolute;bottom:14px;right:16px;background:rgba(14,22,33,.7);color:#fff;border-radius:999px;padding:5px 14px;font-size:12px;font-weight:700; }
.tbs-hl-gallery-thumbs { display:flex;gap:6px;padding:6px;background:#f0f0f0; }
.tbs-hl-gal-thumb { flex:0 0 80px;height:60px;border-radius:8px;background:center/cover no-repeat;cursor:pointer;opacity:.65;transition:var(--hl-t);border:2px solid transparent; }
.tbs-hl-gal-thumb.is-active,.tbs-hl-gal-thumb:hover { opacity:1;border-color:var(--hl-gold); }

/* Detail body layout */
.tbs-hl-detail-body { display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start; }
.tbs-hl-detail-left { display:flex;flex-direction:column;gap:24px; }

/* Detail header */
.tbs-hl-detail-header { display:flex;flex-direction:column;gap:6px; }
.tbs-hl-detail-stars { font-size:14px;font-weight:700;color:var(--hl-gold-d); }
.tbs-hl-detail-name { font-family:var(--hl-font-d);font-size:clamp(24px,3vw,36px);font-weight:700;color:var(--hl-ink);margin:0;line-height:1.2; }
.tbs-hl-detail-address { font-size:14px;color:var(--hl-mist);font-weight:500;margin:0; }

/* Highlights */
.tbs-hl-highlights { background:var(--hl-gold-pale);border:1.5px solid rgba(200,151,58,.25);border-radius:var(--hl-r-sm);padding:20px 24px; }
.tbs-hl-highlights h3 { font-family:var(--hl-font-d);font-size:18px;color:var(--hl-ink);margin:0 0 12px; }
.tbs-hl-highlights ul { margin:0;padding-left:18px; }
.tbs-hl-highlights li { font-size:14px;color:var(--hl-slate);margin-bottom:6px;line-height:1.5; }

/* Description */
.tbs-hl-desc { background:var(--hl-white);border:1.5px solid var(--hl-border);border-radius:var(--hl-r-sm);padding:20px 24px;box-shadow:var(--hl-shadow); }
.tbs-hl-desc h3 { font-family:var(--hl-font-d);font-size:18px;color:var(--hl-ink);margin:0 0 10px; }
.tbs-hl-desc p { font-size:15px;color:var(--hl-slate);line-height:1.7;margin:0; }

/* Amenity blocks */
.tbs-hl-amen-block { background:var(--hl-white);border:1.5px solid var(--hl-border);border-radius:var(--hl-r-sm);padding:20px 24px;box-shadow:var(--hl-shadow); }
.tbs-hl-amen-block h3 { font-family:var(--hl-font-d);font-size:18px;color:var(--hl-ink);margin:0 0 14px; }
.tbs-hl-amen-grid { display:flex;flex-wrap:wrap;gap:8px; }
.tbs-hl-amen-tag { font-size:13px;font-weight:600;color:var(--hl-slate);background:var(--hl-cloud);border:1px solid var(--hl-border);border-radius:999px;padding:5px 14px; }
.tbs-hl-amen-view { background:#EFF6FF;border-color:#BFDBFE;color:#1E40AF; }

/* Room section */
.tbs-hl-rooms-section { background:var(--hl-white);border:1.5px solid var(--hl-border);border-radius:var(--hl-r);padding:28px;box-shadow:var(--hl-shadow); }
.tbs-hl-rooms-title { font-family:var(--hl-font-d);font-size:24px;font-weight:700;color:var(--hl-ink);margin:0 0 20px; }
.tbs-hl-rooms-grid { display:flex;flex-direction:column;gap:16px; }

/* Room card */
.tbs-hl-room-card { border:1.5px solid var(--hl-border);border-radius:var(--hl-r-sm);overflow:hidden;display:grid;grid-template-columns:200px 1fr;transition:var(--hl-t); }
.tbs-hl-room-card:hover { border-color:var(--hl-gold);box-shadow:0 4px 20px rgba(200,151,58,.12); }
.tbs-hl-room-img { background:linear-gradient(135deg,#CBD5E1,#94A3B8) center/cover no-repeat;min-height:160px; }
.tbs-hl-room-body { padding:16px 20px;display:flex;flex-direction:column;gap:8px; }
.tbs-hl-room-name { font-family:var(--hl-font-d);font-size:18px;font-weight:700;color:var(--hl-ink);margin:0; }
.tbs-hl-room-specs { display:flex;flex-wrap:wrap;gap:6px;padding:8px 0;border-top:1px solid var(--hl-border);border-bottom:1px solid var(--hl-border); }
.tbs-hl-room-specs span { font-size:12px;font-weight:600;color:var(--hl-slate);background:var(--hl-cloud);border-radius:999px;padding:3px 10px; }
.tbs-hl-room-footer { display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-top:auto; }
.tbs-hl-room-price { font-size:22px;font-weight:800;color:var(--hl-ink);font-family:var(--hl-font-d); }
.tbs-hl-room-night { font-size:13px;color:var(--hl-mist); }
.tbs-hl-room-scarcity { font-size:12px;font-weight:700;color:#DC2626;margin-top:2px; }

/* Room counter */
.tbs-hl-room-counter { display:flex;align-items:center;gap:8px; }
.tbs-hl-room-dec,.tbs-hl-room-inc { width:32px;height:32px;border-radius:50%;border:1.5px solid var(--hl-border);background:var(--hl-white);cursor:pointer;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:var(--hl-t);padding:0; }
.tbs-hl-room-dec:hover,.tbs-hl-room-inc:hover { border-color:var(--hl-gold);background:var(--hl-gold-pale);color:var(--hl-gold-d); }
.tbs-hl-room-qty { font-size:18px;font-weight:700;color:var(--hl-ink);min-width:24px;text-align:center; }
.tbs-hl-room-reserve { margin-top:6px; }
.tbs-hl-reserve-btn { display:inline-flex;align-items:center;gap:6px;padding:8px 20px;border-radius:999px;background:linear-gradient(135deg,var(--hl-gold),var(--hl-gold-d));color:#fff;border:none;cursor:pointer;font-size:13px;font-weight:700;font-family:var(--hl-font);box-shadow:var(--hl-shadow-gold);transition:var(--hl-t); }
.tbs-hl-reserve-btn:hover { transform:translateY(-1px);box-shadow:0 8px 24px rgba(200,151,58,.35); }

/* Summary bar */
.tbs-hl-summary-bar { display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;background:linear-gradient(135deg,var(--hl-ink),#1A2A3A);border-radius:var(--hl-r-sm);padding:16px 22px;margin-top:20px;box-shadow:0 8px 28px rgba(14,22,33,.2); }
.tbs-hl-summary-info { display:flex;flex-direction:column;gap:2px; }
.tbs-hl-summary-info span { font-size:14px;font-weight:700;color:#fff; }
.tbs-hl-summary-total { font-size:20px;font-weight:800;color:var(--hl-gold-l);font-family:var(--hl-font-d); }
.tbs-hl-book-btn { display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:999px;background:linear-gradient(135deg,var(--hl-gold),var(--hl-gold-d));color:#fff;border:none;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--hl-font);box-shadow:var(--hl-shadow-gold);transition:var(--hl-t); }
.tbs-hl-book-btn:hover { transform:translateY(-1px);box-shadow:0 10px 28px rgba(200,151,58,.4); }

/* Sticky card */
.tbs-hl-detail-right { position:sticky;top:24px; }
.tbs-hl-sticky-card { background:var(--hl-white);border:1.5px solid var(--hl-border);border-radius:var(--hl-r);padding:24px;box-shadow:var(--hl-shadow); }
.tbs-hl-sticky-price { margin-bottom:14px; }
.tbs-hl-sticky-from { font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--hl-mist);margin-right:4px; }
.tbs-hl-sticky-amount { font-size:32px;font-weight:800;color:var(--hl-ink);font-family:var(--hl-font-d); }
.tbs-hl-sticky-night { font-size:14px;color:var(--hl-mist); }
.tbs-hl-sticky-btn { display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border:none;border-radius:999px;background:linear-gradient(135deg,var(--hl-gold),var(--hl-gold-d));color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:var(--hl-font);box-shadow:var(--hl-shadow-gold);transition:var(--hl-t);margin-bottom:18px; }
.tbs-hl-sticky-btn:hover { transform:translateY(-1px);box-shadow:0 10px 28px rgba(200,151,58,.38); }
.tbs-hl-sticky-amen { display:flex;flex-direction:column;gap:6px;padding-top:16px;border-top:1px solid var(--hl-border); }
.tbs-hl-sticky-amen-item { font-size:13px;font-weight:600;color:var(--hl-slate); }

/* ============================================================
   BOOKING MODAL
   ============================================================ */
.tbs-hl-booking-modal-inner { background:#ffffff !important;border-radius:var(--hl-r);max-width:600px;width:100%;max-height:92vh;overflow-y:auto;position:relative;box-shadow:0 32px 80px rgba(14,22,33,.3); }
.tbs-hl-modal-close { position:sticky;top:0;float:right;margin:16px 16px 0 0;background:var(--hl-cloud);border:1.5px solid var(--hl-border);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:700;z-index:10;transition:var(--hl-t);padding:0; }
.tbs-hl-modal-close:hover { background:#FFF0F0;border-color:#FECACA;color:#9A1B1B; }
.tbs-hl-booking-head { padding:20px 28px 16px;border-bottom:1px solid var(--hl-border); }
.tbs-hl-booking-head h2 { font-family:var(--hl-font-d);font-size:22px;font-weight:700;color:var(--hl-ink);margin:0 0 6px; }
.tbs-hl-booking-head p { font-size:14px;color:var(--hl-mist);margin:0; }
.tbs-hl-booking-body { padding:20px 28px 28px; }

/* Form */
.tbs-hl-form { display:flex;flex-direction:column;gap:12px; }
.tbs-hl-form-section { font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--hl-gold-d);padding:6px 0 4px;border-bottom:1.5px solid var(--hl-border); }
.tbs-hl-form-row { display:grid;grid-template-columns:1fr 1fr;gap:12px; }
.tbs-hl-form-field { display:flex;flex-direction:column;gap:4px; }
.tbs-hl-form-field label { font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--hl-mist); }
.tbs-hl-input { border:1.5px solid #CBD5E0;border-radius:var(--hl-r-sm);padding:10px 13px;font-size:14px;font-family:var(--hl-font);color:#0E1621;background:#ffffff;transition:var(--hl-t);width:100%;box-sizing:border-box; }
.tbs-hl-input:focus { outline:none;border-color:var(--hl-gold);box-shadow:0 0 0 3px rgba(200,151,58,.12);background:#ffffff; }
textarea.tbs-hl-input { resize:vertical;min-height:60px; }
.tbs-hl-price-estimate { display:flex;flex-direction:column;gap:3px;background:var(--hl-gold-pale);border:1.5px solid rgba(200,151,58,.3);border-radius:var(--hl-r-sm);padding:14px 16px; }
.tbs-hl-price-estimate strong { font-family:var(--hl-font-d);font-size:22px;color:var(--hl-ink); }
.tbs-hl-form-feedback { border-radius:var(--hl-r-sm);padding:11px 14px;font-size:13px;font-weight:600;background:#FFF0F0;border:1px solid #FECACA;color:#9A1B1B; }
.tbs-hl-submit-btn { display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:15px;border:none;border-radius:999px;background:linear-gradient(135deg,var(--hl-gold),var(--hl-gold-d));color:#fff;font-family:var(--hl-font);font-size:15px;font-weight:700;cursor:pointer;box-shadow:var(--hl-shadow-gold);transition:var(--hl-t);margin-top:4px; }
.tbs-hl-submit-btn:hover { transform:translateY(-1px);box-shadow:0 12px 32px rgba(200,151,58,.38); }
.tbs-hl-submit-btn:disabled { opacity:.6;cursor:not-allowed;transform:none; }

/* Success */
.tbs-hl-success-inner { background:var(--hl-white);border-radius:var(--hl-r);padding:48px 44px;text-align:center;max-width:500px;width:100%;box-shadow:0 32px 80px rgba(14,22,33,.25); }
.tbs-hl-success-inner h2 { font-family:var(--hl-font-d);font-size:30px;font-weight:700;color:var(--hl-ink);margin:0 0 12px; }
.tbs-hl-success-inner p { font-size:15px;color:var(--hl-slate);line-height:1.7;margin:0 0 22px; }
.tbs-hl-ref-box { display:flex;flex-direction:column;gap:4px;background:var(--hl-gold-pale);border:1.5px solid rgba(200,151,58,.3);border-radius:var(--hl-r-sm);padding:16px 28px;margin-bottom:24px; }
.tbs-hl-ref-box span { font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--hl-mist); }
.tbs-hl-ref-box strong { font-family:var(--hl-font-d);font-size:26px;color:var(--hl-gold-d); }
.tbs-hl-success-btn { display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:999px;background:linear-gradient(135deg,var(--hl-gold),var(--hl-gold-d));color:#fff;font-size:15px;font-weight:700;text-decoration:none;box-shadow:var(--hl-shadow-gold);transition:var(--hl-t); }
.tbs-hl-success-btn:hover { transform:translateY(-1px);text-decoration:none;color:#fff; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:900px) {
  .tbs-hl-card { grid-template-columns:240px 1fr; }
  .tbs-hl-detail-body { grid-template-columns:1fr; }
  .tbs-hl-detail-right { position:static; }
  .tbs-hl-gallery-main { height:300px; }
}
@media(max-width:680px) {
  .tbs-hl-card { grid-template-columns:1fr; }
  .tbs-hl-card-img { min-height:200px; }
  .tbs-hl-room-card { grid-template-columns:1fr; }
  .tbs-hl-room-img { min-height:180px; }
  .tbs-hl-country-grid { grid-template-columns:1fr 1fr; }
  .tbs-hl-form-row { grid-template-columns:1fr; }
  .tbs-hl-booking-modal-inner { max-height:96vh;border-radius:20px 20px 0 0; }
  .tbs-hl-booking-body { padding:16px 18px 24px; }
  .tbs-hl-booking-head { padding:16px 18px 14px; }
  .tbs-hl-success-inner { padding:36px 24px; }
}
@media(max-width:400px) {
  .tbs-hl-country-grid { grid-template-columns:1fr; }
  .tbs-hl-gallery-main { height:220px; }
}

/* ============================================================
   SEARCH & FILTER BAR
   ============================================================ */
.tbs-hl-filter-bar {
    display:flex;align-items:center;flex-wrap:wrap;gap:12px;
    background:var(--hl-white);border:1.5px solid var(--hl-border);
    border-radius:var(--hl-r);padding:16px 20px;
    margin-bottom:24px;box-shadow:var(--hl-shadow);
}
.tbs-hl-filter-icon { font-size:18px;flex-shrink:0; }
.tbs-hl-filter-search { display:flex;align-items:center;gap:10px;flex:1;min-width:200px; }
.tbs-hl-filter-input {
    flex:1;border:1.5px solid var(--hl-border);border-radius:999px;
    padding:9px 16px;font-size:14px;font-family:var(--hl-font);
    color:var(--hl-ink);background:#fff;transition:var(--hl-t);
}
.tbs-hl-filter-input:focus { outline:none;border-color:var(--hl-gold);box-shadow:0 0 0 3px rgba(200,151,58,.1); }
.tbs-hl-filter-select-wrap { display:flex;align-items:center;gap:10px;flex-shrink:0; }
.tbs-hl-filter-select {
    border:1.5px solid var(--hl-border);border-radius:999px;
    padding:9px 16px;font-size:14px;font-family:var(--hl-font);
    color:var(--hl-ink);background:#fff;cursor:pointer;transition:var(--hl-t);
    appearance:none;-webkit-appearance:none;padding-right:32px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238A99A8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 12px center;
}
.tbs-hl-filter-select:focus { outline:none;border-color:var(--hl-gold); }
.tbs-hl-filter-stars-wrap { display:flex;align-items:center;gap:10px;flex-shrink:0; }
.tbs-hl-star-filters { display:flex;gap:6px;flex-wrap:wrap; }
.tbs-hl-star-btn {
    padding:7px 14px;border-radius:999px;border:1.5px solid var(--hl-border);
    background:#fff;color:var(--hl-slate);font-size:13px;font-weight:700;
    cursor:pointer;transition:var(--hl-t);white-space:nowrap;font-family:var(--hl-font);
}
.tbs-hl-star-btn:hover { border-color:var(--hl-gold);color:var(--hl-gold-d);background:var(--hl-gold-pale); }
.tbs-hl-star-btn.is-active {
    background:linear-gradient(135deg,var(--hl-gold),var(--hl-gold-d));
    color:#fff;border-color:transparent;
    box-shadow:0 4px 12px rgba(200,151,58,.25);
}

/* No results */
.tbs-hl-no-results { text-align:center;padding:48px 24px;background:var(--hl-cloud);border-radius:var(--hl-r);border:2px dashed var(--hl-border);margin-bottom:20px; }
.tbs-hl-no-results span { font-size:48px;display:block;margin-bottom:10px; }
.tbs-hl-no-results p { color:var(--hl-slate);font-size:15px;margin:0; }

/* Mobile filter bar */
@media(max-width:680px) {
    .tbs-hl-filter-bar { flex-direction:column;align-items:stretch; }
    .tbs-hl-filter-search,.tbs-hl-filter-select-wrap,.tbs-hl-filter-stars-wrap { width:100%; }
    .tbs-hl-filter-select { width:100%; }
    .tbs-hl-star-filters { justify-content:center; }
}
