/* Travel Hub Tripgo Bridge — Route Template v2 (RC4). Scoped to .thtb-transfer.
   Presentation only. Reuses Tripgo typography; adds premium booking-landing layout. */
.thtb-transfer{
  --thtb-green:#0f8a68; --thtb-green-dk:#0b6f53;
  --thtb-coral:#ee4d5f; --thtb-coral-dk:#d83a4c;
  --thtb-ink:#1f2a33; --thtb-body:#5a6b78; --thtb-line:#e7ecef;
  --thtb-card:#fff; --thtb-gold:#f6b53f; --thtb-wa:#25d366;
  --thtb-shadow:0 10px 30px rgba(20,40,55,.08);
  --thtb-shadow-lg:0 18px 50px rgba(20,40,55,.14);
  color:var(--thtb-ink);
}
.thtb-transfer svg{width:1em;height:1em;display:inline-block;vertical-align:middle}
.thtb-transfer h2{font-size:1.5rem;font-weight:800;letter-spacing:-.01em;margin:0 0 .5rem;line-height:1.25}
.thtb-transfer .thtb-sub{color:var(--thtb-body);font-size:.95rem;margin:0 0 1.15rem}
.thtb-label{display:inline-block;font-size:.72rem;font-weight:800;color:var(--thtb-green);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.55rem}

/* ---- HERO (P1) ---- */
.thtb-hero{position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--thtb-shadow-lg);margin:8px 0 0;min-height:440px;background:linear-gradient(135deg,#0f8a68,#0b6f53)}
.thtb-hero--noimg{background:linear-gradient(120deg,#0f8a68,#0b6f53 60%,#0a5f47)}
.thtb-hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.thtb-hero__scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,25,20,.88) 0%,rgba(10,25,20,.55) 46%,rgba(10,25,20,.12) 100%)}
.thtb-hero__body{position:relative;z-index:2;max-width:640px;padding:46px 52px;display:flex;flex-direction:column;justify-content:center;min-height:440px}
.thtb-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.16);color:#fff;font-size:.78rem;font-weight:700;padding:6px 12px;border-radius:100px;width:max-content;margin-bottom:16px;text-transform:uppercase;letter-spacing:.04em}
.thtb-hero__title{color:#fff!important;font-size:2.25rem;font-weight:800;line-height:1.2;margin:0 0 12px;letter-spacing:-.015em}
.thtb-hero__lede{color:#e7efec;font-size:1rem;max-width:520px;margin:0 0 18px;line-height:1.55}
.thtb-hero__chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.thtb-chip{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);color:#fff;font-size:.82rem;font-weight:600;padding:8px 13px;border-radius:100px}
.thtb-hero__price{display:flex;align-items:baseline;gap:10px;margin-bottom:22px}
.thtb-hero__price .from{color:#cfe3db;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}
.thtb-hero__price .amt{color:#fff;font-size:2.05rem;font-weight:900}
.thtb-hero__price .amt small{font-size:1rem;font-weight:700;opacity:.85}
.thtb-hero__cta{display:flex;gap:12px;flex-wrap:wrap}

.thtb-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:800;font-size:.98rem;padding:14px 26px;border-radius:12px;border:0;cursor:pointer;transition:.15s;text-decoration:none;line-height:1}
.thtb-btn svg{width:18px;height:18px}
.thtb-btn--primary{background:var(--thtb-coral);color:#fff!important;box-shadow:0 8px 20px rgba(238,77,95,.35)}
.thtb-btn--primary:hover{background:var(--thtb-coral-dk);color:#fff!important}
.thtb-btn--wa{background:var(--thtb-wa);color:#fff!important}
.thtb-btn--wa:hover{filter:brightness(.94);color:#fff!important}

/* ---- FACTS STRIP ---- */
.thtb-transfer ul.thtb-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;list-style:none;margin:18px 0 0;padding:0}
.thtb-transfer ul.thtb-facts li{display:flex;align-items:center;gap:11px;background:var(--thtb-card);border:1px solid var(--thtb-line);border-radius:14px;padding:14px 16px;box-shadow:var(--thtb-shadow);margin:0}
.thtb-transfer ul.thtb-facts svg{width:22px;height:22px;color:var(--thtb-green);flex-shrink:0}
.thtb-transfer ul.thtb-facts span{display:flex;flex-direction:column;line-height:1.2}
.thtb-transfer ul.thtb-facts strong{font-size:1.02rem;color:var(--thtb-ink)}
.thtb-transfer ul.thtb-facts span{font-size:.76rem;color:var(--thtb-body)}
.thtb-transfer ul.thtb-facts strong{font-size:1.02rem}

/* ---- SECTIONS ---- */
.thtb-section{background:var(--thtb-card);border:1px solid var(--thtb-line);border-radius:16px;padding:28px 28px;margin:0 0 22px;box-shadow:var(--thtb-shadow)}

/* ---- HOTEL EXPERIENCE (P5) ---- */
.thtb-hotel__grid{display:grid;grid-template-columns:200px 1fr;gap:22px;align-items:center}
.thtb-hotel__img{width:200px;height:150px;object-fit:cover;border-radius:12px}
.thtb-hotel__meta h2{margin:0 0 6px}
.thtb-stars{color:var(--thtb-gold);display:flex;gap:2px;margin-bottom:8px}
.thtb-stars svg{width:18px;height:18px;fill:var(--thtb-gold);stroke:var(--thtb-gold)}
.thtb-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.thtb-pill{display:inline-flex;align-items:center;gap:5px;background:#eef6f2;color:var(--thtb-green-dk);font-size:.78rem;font-weight:700;padding:5px 11px;border-radius:100px}
.thtb-pill svg{width:13px;height:13px}
.thtb-hotel__intro{color:var(--thtb-body);font-size:.95rem;margin:0}

/* ---- VEHICLE CARDS (P4) ---- */
.thtb-veh-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.thtb-veh{position:relative;border:1.5px solid var(--thtb-line);border-radius:14px;padding:18px;display:flex;flex-direction:column;transition:.15s}
.thtb-veh:hover{border-color:var(--thtb-coral);box-shadow:0 10px 26px rgba(238,77,95,.12);transform:translateY(-2px)}
.thtb-veh--popular{border-color:var(--thtb-gold)}
.thtb-veh__tag{position:absolute;top:-10px;right:14px;background:var(--thtb-gold);color:#3d2c00;font-size:.66rem;font-weight:800;padding:3px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.03em}
.thtb-veh__ico{width:52px;height:52px;border-radius:12px;background:#eef6f2;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.thtb-veh__ico svg{width:30px;height:30px;color:var(--thtb-green)}
.thtb-veh h3{font-size:1.05rem;font-weight:800;margin:0 0 6px}
.thtb-veh__cap{display:flex;gap:14px;font-size:.83rem;color:var(--thtb-body);margin-bottom:14px}
.thtb-veh__cap span{display:inline-flex;align-items:center;gap:5px}
.thtb-veh__cap svg{width:15px;height:15px;opacity:.6}
.thtb-veh__price{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
.thtb-veh__price .p{font-size:1.35rem;font-weight:900;color:var(--thtb-ink)}
.thtb-veh__price .p small{font-size:.72rem;font-weight:700;color:var(--thtb-body)}
.thtb-veh__book{background:#fff;border:1.5px solid var(--thtb-coral);color:var(--thtb-coral)!important;font-weight:800;font-size:.83rem;padding:9px 16px;border-radius:9px;text-decoration:none;transition:.15s}
.thtb-veh__book:hover{background:var(--thtb-coral);color:#fff!important}

/* ---- TRUST CARDS (P3) ---- */
.thtb-trust-cards{display:grid;grid-template-columns:1fr;gap:10px;margin-top:14px}
.thtb-trust{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1px solid var(--thtb-line);border-radius:12px;background:#fcfdfd}
.thtb-trust .ti{width:38px;height:38px;border-radius:10px;background:#eef6f2;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.thtb-trust .ti svg{width:20px;height:20px;color:var(--thtb-green)}
.thtb-trust b{font-size:.87rem;font-weight:700;line-height:1.3}

/* ---- STEPS ---- */
.thtb-steps{list-style:none;margin:16px 0 0;padding:0;display:grid;gap:14px}
.thtb-steps li{display:flex;gap:14px;align-items:flex-start;margin:0}
.thtb-steps .n{width:30px;height:30px;border-radius:50%;background:var(--thtb-green);color:#fff;font-weight:800;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.thtb-steps p{font-size:.93rem;color:var(--thtb-body);margin:2px 0 0}

/* ---- FAQ ---- */
.thtb-faq details{border-bottom:1px solid var(--thtb-line);padding:14px 0}
.thtb-faq summary{font-weight:700;font-size:.98rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.thtb-faq summary::-webkit-details-marker{display:none}
.thtb-faq summary::after{content:"+";color:var(--thtb-coral);font-size:1.4rem;font-weight:400;line-height:1}
.thtb-faq details[open] summary::after{content:"\2013"}
.thtb-faq p{padding-top:10px;color:var(--thtb-body);font-size:.93rem;margin:0}

/* ---- MAP ---- */
.thtb-map{border:1px solid var(--thtb-line);border-radius:12px;width:100%;display:block}

/* ---- BOOKING CARD (P2) ---- */
.thtb-book-wrap{position:sticky;top:20px}
.thtb-booking-card{background:var(--thtb-card);border:1px solid var(--thtb-line);border-radius:18px;box-shadow:var(--thtb-shadow-lg);overflow:hidden;padding:0}
.thtb-book__head{background:linear-gradient(135deg,var(--thtb-green),var(--thtb-green-dk));color:#fff;padding:18px 22px}
.thtb-book__head .bt{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;opacity:.9;display:block}
.thtb-book__head .bp{font-size:1.6rem;font-weight:900;margin-top:2px;display:block}
.thtb-book__head .bp small{font-size:.85rem;font-weight:700;opacity:.85}
.thtb-book__body{padding:20px 22px 6px}
.thtb-booking-card .button.thtb-wa,.thtb-booking-card .button.thtb-phone{display:flex;align-items:center;justify-content:center;gap:9px;width:calc(100% - 44px);margin:0 22px 12px;border-radius:11px;font-weight:800;text-decoration:none;padding:13px}
.thtb-booking-card .button.thtb-wa{background:var(--thtb-wa);color:#fff!important}
.thtb-booking-card .button.thtb-wa svg{width:18px;height:18px}
.thtb-booking-card .button.thtb-phone{background:#fff;color:var(--thtb-green-dk)!important;border:1.5px solid var(--thtb-line);margin-bottom:20px}

/* ---- CROSS-SELL (P6) ---- */
.thtb-xhead{display:flex;align-items:center;gap:10px;margin:34px 0 4px}
.thtb-xhead .ic{width:34px;height:34px;border-radius:9px;background:#eef6f2;display:flex;align-items:center;justify-content:center}
.thtb-xhead .ic svg{width:19px;height:19px;color:var(--thtb-green)}
.thtb-xhead h2{margin:0}
.thtb-related{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.thtb-related a{display:flex;align-items:center;gap:10px;padding:13px 15px;border:1px solid var(--thtb-line);border-radius:11px;background:#fcfdfd;font-size:.9rem;font-weight:600;color:var(--thtb-ink)!important;text-decoration:none}
.thtb-related a:hover{border-color:var(--thtb-coral);color:var(--thtb-coral)!important}
.thtb-related a svg{width:18px;height:18px;color:var(--thtb-green);flex-shrink:0}

/* ---- RESPONSIVE ---- */
@media(max-width:900px){
  .thtb-hero__body{padding:30px 26px;min-height:380px}
  .thtb-hero__title{font-size:1.65rem}
  .thtb-transfer ul.thtb-facts{grid-template-columns:1fr 1fr}
  .thtb-veh-grid{grid-template-columns:1fr}
  .thtb-hotel__grid{grid-template-columns:1fr}
  .thtb-hotel__img{width:100%;height:200px}
  .thtb-related{grid-template-columns:1fr}
  .thtb-book-wrap{position:static}
}
