
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@600;700&family=Inter:wght@400;500;600&display=swap');
@import url('https://cdn.jsdelivr.net/npm/@tabler/icons-webfont@3.44.0/dist/tabler-icons.min.css');
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --P:#0E3348;--S:#2A6F86;--A:#C8A96A;--A-light:#E5D4A8;--A-deep:#B89555;--A-ink:#9B6A25;--BG:#F8F2E8;
  --white:#FFFDF8;--muted:#6F7E82;--light:#F4EBDC;--border:rgba(14,51,72,0.12);
  --shadow:0 18px 45px rgba(31,44,50,0.08);
  --logo-w:265px;
  --logo-h:189px;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:Inter,system-ui,sans-serif;
}
body{font-family:var(--font-body);background:var(--BG);color:var(--P);font-size:14px;line-height:1.6;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.2}
/* Cormorant "1" reads as "I" — sans-serif for labels, prices, times and counters */
.tour-day-label,
.tour-related-link,
.tour-price-row strong,
.tour-price-head,
.tps-cta-from,
.tps-cta-from span,
.pkg-cta-from span,
.pkg-card-from,
.gallery-lightbox-counter,
.tour-gallery-carousel-counter,
.fc-counter,
.trust-score,
.ft-rating,
.transfer-service-card::before{
  font-family:var(--font-body);
  font-variant-numeric:lining-nums tabular-nums;
}
.num-digit{font-family:var(--font-body);font-variant-numeric:lining-nums tabular-nums;font-weight:inherit}
img,video,svg{max-width:100%;height:auto}
.site-wrap{width:100%;background:var(--BG)}
.container{width:100%;max-width:1200px;margin:0 auto;padding-left:1.25rem;padding-right:1.25rem}
body.nav-open{overflow:hidden}

.nav{position:absolute;top:0;left:0;right:0;z-index:10;background:transparent;border-bottom:none}
.nav-bar{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:1.25rem;max-width:100%;margin:0 auto;padding:1.15rem 3.4rem;min-height:calc(var(--logo-h) + 2.3rem)}
.nav-logo{position:absolute;left:3.4rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;flex-shrink:0;line-height:0;text-decoration:none;z-index:2;background:transparent;border:0;box-shadow:none;padding:0}
.nav-logo img,.nav-logo .logo-frame{width:var(--logo-w);height:auto;max-width:100%;display:block;object-fit:contain;background:transparent;border:0;box-shadow:none;filter:none}
.logo-link{display:block;line-height:0;text-decoration:none;background:transparent;border:0;box-shadow:none;padding:0}
.nav-links--hero{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;gap:2rem;white-space:nowrap;z-index:1}
.nav-end{display:flex;align-items:center;flex-shrink:0;z-index:2}
.nav-desktop{display:flex;align-items:center;gap:2rem}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center;margin:0;padding:0}
.nav-links a{color:rgba(255,253,248,0.94);font-size:11.5px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;text-decoration:none;transition:color .3s ease}
.nav-links a:hover,.nav-links a.is-active{color:var(--A-light)}
.nav-cta{background:linear-gradient(180deg,#E5D4A8 0%,var(--A) 50%,var(--A-deep) 100%);color:var(--P);border:none;padding:11px 24px;border-radius:4px;font-size:11.5px;font-weight:700;text-decoration:none;letter-spacing:0.14em;text-transform:uppercase;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;box-shadow:0 8px 22px rgba(0,0,0,0.22);transition:background .3s ease,box-shadow .3s ease,transform .3s ease}
.nav-cta .ti{font-size:15px;line-height:1;letter-spacing:0;text-transform:none}
.nav-cta:hover{background:linear-gradient(180deg,#F0E0B8 0%,#D9BC7A 45%,var(--A) 100%);color:var(--P);box-shadow:0 10px 26px rgba(0,0,0,0.28);transform:translateY(-1px)}
.nav:not(.nav--inner) .nav-wa{background:transparent;color:var(--A);border:1px solid rgba(200,169,106,0.72);padding:10px 22px;border-radius:4px;font-size:10px;font-weight:600;text-decoration:none;letter-spacing:0.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;backdrop-filter:none;-webkit-backdrop-filter:none;transition:background .3s ease,border-color .3s ease,color .3s ease}
.nav:not(.nav--inner) .nav-wa:hover{background:rgba(200,169,106,0.12);border-color:var(--A-light);color:var(--A-light)}
.nav-wa{background:rgba(255,253,248,0.08);color:var(--white);border:1px solid rgba(200,169,106,0.42);padding:10px 20px;border-radius:4px;font-size:10px;font-weight:600;text-decoration:none;letter-spacing:0.1em;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:background .28s ease,border-color .28s ease,color .28s ease}
.nav-wa:hover{background:rgba(255,253,248,0.16);border-color:rgba(200,169,106,0.72);color:var(--white)}
.nav-mobile-actions{display:none;align-items:center;gap:0.65rem}
.nav-wa--compact{padding:9px 11px}
.nav-toggle{width:44px;height:44px;border:1px solid rgba(14,51,72,0.12);border-radius:8px;background:var(--white);display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;padding:0;flex-shrink:0}
.nav-toggle-line{display:block;width:18px;height:1.5px;background:var(--P);transition:transform .25s ease,opacity .25s ease}
.nav-toggle[aria-expanded=true] .nav-toggle-line:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle[aria-expanded=true] .nav-toggle-line:nth-child(2){opacity:0}
.nav-toggle[aria-expanded=true] .nav-toggle-line:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav-overlay{position:fixed;inset:0;background:rgba(8,37,56,0.45);z-index:9998;backdrop-filter:blur(2px)}
.nav-overlay[hidden]{display:none!important}
.nav-drawer{position:fixed;top:0;right:0;width:min(320px,88vw);max-width:100%;height:100dvh;background:var(--white);z-index:9999;padding:5.5rem 1.5rem 2rem;box-shadow:-12px 0 40px rgba(8,37,56,0.12);flex-direction:column;gap:1.5rem;overflow-y:auto;-webkit-overflow-scrolling:touch;display:none;transform:translate3d(100%,0,0);transition:transform .32s ease;visibility:hidden;pointer-events:none}
.nav-drawer.is-open{display:flex;transform:translate3d(0,0,0);visibility:visible;pointer-events:auto}
.nav-drawer[hidden]{display:none!important;transform:translate3d(100%,0,0)!important;visibility:hidden!important;pointer-events:none!important}
body.nav-open .weather-widget-hero-overlay{visibility:hidden!important;pointer-events:none!important;opacity:0!important}
.nav-links--drawer{display:flex;flex-direction:column;align-items:flex-start;gap:0}
.nav-links--drawer a{color:var(--P);font-size:13px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;display:block;width:100%;padding:0.85rem 0;border-bottom:1px solid rgba(14,51,72,0.08);transition:color .28s ease}
.nav-links--drawer a:hover,.nav-links--drawer a.is-active{color:var(--A-deep)}
.nav-cta--drawer{width:100%;margin-top:1.25rem;padding:14px 20px;font-size:11px;letter-spacing:0.16em}
.nav-wa--drawer{width:100%;justify-content:center;background:var(--P);color:var(--white);border:none;margin-top:auto}
.nav--inner{position:sticky;top:0;left:0;right:0;z-index:100;background:var(--white);border-bottom:1px solid rgba(14,51,72,0.08)}
.nav--inner .nav-links a{color:var(--P)}
.nav--inner .nav-links a:hover,.nav--inner .nav-links a.is-active{color:var(--A-deep)}
.nav--inner .nav-bar{min-height:72px;padding:0.65rem 3.4rem}

.hero{position:relative;height:82vh;min-height:720px;max-height:900px;overflow:visible;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;padding-bottom:0;background:#0F2847}
.hero-slides{position:absolute;inset:0;z-index:0;overflow:hidden;transform:translateZ(0)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease-in-out;z-index:0;pointer-events:none;transform:translateZ(0)}
.hero-slide.is-active{opacity:1;z-index:2}
.hero-slide.is-active.is-leaving{opacity:0;z-index:1}
.hero-slide-media{width:100%;height:100%;transform:scale(1) translateZ(0);transform-origin:center center;will-change:transform,opacity;backface-visibility:hidden;-webkit-backface-visibility:hidden}
.hero-slide-media.is-zooming{animation:heroKenBurns 7s ease-out forwards}
.hero-slide-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:auto;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0);filter:contrast(1.05) saturate(1.08) brightness(1.03)}
@keyframes heroKenBurns{from{transform:scale(1) translateZ(0)}to{transform:scale(1.012) translateZ(0)}}
.hero-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(20,18,48,0.45) 0%,rgba(20,18,48,0.1) 18%,transparent 38%),linear-gradient(90deg,rgba(15,40,71,0.55) 0%,rgba(15,40,71,0.25) 35%,rgba(15,40,71,0.05) 62%,transparent 100%);pointer-events:none}
.hero-inner{position:relative;z-index:3;width:100%;max-width:600px;min-width:0;box-sizing:border-box;padding:0 3.4rem 3.5rem;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start}
.hero-dots{position:absolute;bottom:1.75rem;right:3.4rem;z-index:4;display:flex;align-items:center;gap:7px}
.hero-dot{width:26px;height:2px;padding:0;border:none;background:rgba(255,253,248,0.32);cursor:pointer;transition:background .35s ease,width .35s ease,opacity .35s ease;border-radius:1px}
.hero-dot:hover{background:rgba(255,253,248,0.55)}
.hero-dot.is-active{width:34px;background:var(--A)}
.hero-dot:focus-visible{outline:2px solid var(--A);outline-offset:3px}
@media (prefers-reduced-motion:reduce){
  .hero-slide{transition:opacity .4s ease}
  .hero-slide-media.is-zooming{animation:none}
  .hero-slide-img{filter:contrast(1.02) saturate(1.01) brightness(1.01)}
}
.hero-tag{font-size:11px;font-weight:600;letter-spacing:0.24em;text-transform:uppercase;color:var(--A);margin-bottom:1.25rem;display:flex;align-items:center;gap:10px;text-shadow:0 1px 10px rgba(0,0,0,0.3)}
.hero-tag::before{content:'';display:inline-block;width:36px;height:1px;background:var(--A)}
.hero h1{font-size:clamp(2.25rem,3.2vw,3.5rem);color:var(--white);margin-bottom:1.15rem;font-weight:600;line-height:1.02;letter-spacing:-0.03em;text-shadow:0 2px 28px rgba(0,0,0,0.35);max-width:100%}
.hero h1 span{color:var(--white)}
.hero-sub{font-size:clamp(15px,1.05vw,17px);color:rgba(255,253,248,0.9);max-width:480px;margin-bottom:1.65rem;line-height:1.6;text-shadow:0 1px 16px rgba(0,0,0,0.28);font-weight:400}
.hero-btns{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:14px;margin-top:0;width:auto;max-width:640px}
.hero-btns .btn-p,.hero-btns .btn-s{width:auto;max-width:none;flex:0 0 auto;justify-content:center;padding:12px 26px;font-size:10px;letter-spacing:0.12em}
.hero .btn-p--light{background:linear-gradient(180deg,#D9BC7A 0%,var(--A) 45%,var(--A-deep) 100%);color:var(--P);border:none;box-shadow:0 10px 28px rgba(0,0,0,0.22)}
.hero .btn-p--light:hover{background:linear-gradient(180deg,#E5D4A8 0%,#D4B06A 50%,var(--A) 100%);color:var(--P)}
.hero .btn-s--light{background:transparent;color:var(--A);border:1px solid rgba(200,169,106,0.72);font-weight:600}
.hero .btn-s--light:hover{border-color:var(--A-light);color:var(--A-light);background:rgba(200,169,106,0.1)}
.btn-p{background:var(--P);color:var(--white);padding:11px 23px;border-radius:5px;font-size:11px;font-weight:700;border:none;cursor:pointer;letter-spacing:0.08em;text-transform:uppercase;display:flex;align-items:center;gap:6px;box-shadow:0 14px 26px rgba(14,51,72,0.18)}
.btn-p--light{background:var(--white);color:var(--P);box-shadow:0 14px 32px rgba(0,0,0,0.22)}
.btn-s{background:rgba(255,253,248,0.78);color:var(--P);border:1px solid rgba(14,51,72,0.18);padding:11px 23px;border-radius:5px;font-size:11px;font-weight:700;cursor:pointer;letter-spacing:0.08em;text-transform:uppercase;display:flex;align-items:center;gap:6px}
.btn-s:hover{border-color:var(--A);color:var(--P);background:var(--white)}
.btn-s--light{background:transparent;color:rgba(255,253,248,0.78);border:1px solid rgba(255,253,248,0.22);backdrop-filter:none;font-weight:600}
.btn-s--light:hover{border-color:rgba(255,253,248,0.4);color:var(--white);background:rgba(255,253,248,0.06)}

.page-sec{padding:80px 1.25rem}
.page-sec>.sec-header,.page-sec>.experiences-grid,.page-sec>.services-grid,.page-sec>.why-grid,.page-sec>.reviews-cta,.page-sec>.family-banner,.page-sec>.founder-card,.page-sec>.dest-grid,.page-sec>.experiences-sub,.page-sec>.services-sub,.page-sec>.why-bar-label,.page-sec>.catalog-grid,.page-sec>.transfer-services-grid,.page-sec>.vehicle-grid,.split-features{max-width:1200px;margin-left:auto;margin-right:auto}
.trust-strip{background:var(--BG);padding:14px 1.25rem;text-align:center;border-bottom:1px solid rgba(14,51,72,0.06)}
.trust-inner{display:inline-grid;grid-template-columns:auto auto auto;gap:1.2rem;align-items:center;color:var(--P);font-size:12px;letter-spacing:0.08em;text-transform:uppercase}
.trust-stars{color:var(--A);font-size:15px;letter-spacing:0.16em}
.trust-score{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:700;letter-spacing:0.02em;text-transform:none}
.trust-copy{color:var(--muted);font-size:10px;font-weight:600}
.why-bar{background:var(--BG);padding:0}
.why-bar.page-sec{padding-top:80px;padding-bottom:80px}
.why-bar-label{text-align:center;font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--A);margin-bottom:1.25rem}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0.9rem;max-width:1200px;margin:0 auto}
.why-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.15rem 1rem 1.05rem;max-height:280px;background:rgba(255,253,248,0.78);border:1px solid rgba(14,51,72,0.08);border-radius:12px;transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease}
.why-item:hover{border-color:rgba(200,169,106,0.32);box-shadow:0 12px 28px rgba(15,40,71,0.05);transform:translateY(-2px)}
.why-icon{width:56px;height:56px;flex-shrink:0;border-radius:50%;background:rgba(200,169,106,0.1);border:1px solid rgba(200,169,106,0.35);display:flex;align-items:center;justify-content:center;margin-bottom:0.7rem;color:var(--A)}
.why-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.45;stroke-linecap:round;stroke-linejoin:round}
.why-title{font-family:'Cormorant Garamond',serif;font-weight:700;font-size:20px;color:var(--P);margin-bottom:0.35rem;line-height:1.12;letter-spacing:0.01em}
.why-desc{font-size:12px;color:var(--muted);line-height:1.45;max-width:220px}

/* Compact trust strip after discovery (homepage) */
.why-bar--compact.page-sec{padding-top:2.5rem;padding-bottom:2.5rem}
@media (max-width:767px){
  .why-bar--compact.page-sec{padding:1rem 1rem 1.1rem}
  .why-bar--compact .why-bar-label{margin-bottom:0.55rem;font-size:9px;letter-spacing:0.16em}
  .why-bar--compact .why-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:0.45rem}
  .why-bar--compact .why-item{
    display:grid;
    grid-template-columns:34px 1fr;
    grid-template-rows:auto auto;
    column-gap:0.45rem;
    row-gap:0.15rem;
    align-items:start;
    text-align:left;
    padding:0.5rem 0.5rem 0.48rem;
    max-height:none;
    border-radius:10px;
  }
  .why-bar--compact .why-item:hover{transform:none;box-shadow:none}
  .why-bar--compact .why-icon{
    width:34px;height:34px;margin:0;
    grid-row:1 / span 2;
    align-self:center;
    border-radius:9px;
  }
  .why-bar--compact .why-icon svg{width:17px;height:17px}
  .why-bar--compact .why-title{
    font-size:12.5px;
    margin:0;
    line-height:1.2;
    grid-column:2;
    max-width:none;
  }
  .why-bar--compact .why-desc{
    font-size:10px;
    line-height:1.32;
    max-width:none;
    grid-column:2;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
}

/* Why bar on navy transfer pages */
.why-bar--on-dark{background:#08152A}
.why-bar--on-dark .why-bar-label{color:rgba(200,169,106,0.85)}
.why-bar--on-dark .why-item{background:rgba(255,255,255,0.04);border-color:rgba(200,169,106,0.14)}
.why-bar--on-dark .why-title{color:#F0EDE6}
.why-bar--on-dark .why-desc{color:rgba(245,242,236,0.52)}

.sec-header{text-align:center;margin-bottom:1.5rem}
.sec-eyebrow{font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--A);margin-bottom:8px}
.sec-title{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:700;color:var(--P)}

.experiences-sec{background:#FBF6ED;padding:0}
.experiences-sec.page-sec{padding-top:52px;padding-bottom:40px}
.experiences-sub{max-width:520px;margin:0.5rem auto 0;font-size:14px;line-height:1.65;color:var(--muted)}
.experiences-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;max-width:1200px;margin:1.25rem auto 0;width:100%}
.exp-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:rgba(255,253,248,0.72);border:1px solid rgba(14,51,72,0.08);border-radius:12px;overflow:hidden;transition:transform .42s ease,border-color .42s ease,background .42s ease}
.exp-card:hover{transform:translateY(-3px);border-color:rgba(200,169,106,0.34);background:var(--white)}
.exp-image{position:relative;height:300px;overflow:hidden;background:#0F2847;isolation:isolate}
.exp-image img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;image-rendering:auto;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0) scale(1);transition:transform .6s ease;will-change:transform}
.exp-card:hover .exp-image img{transform:translateZ(0) scale(1.03)}
.exp-body{padding:1.25rem 1.35rem 1.45rem;display:flex;flex-direction:column;flex:1}
.exp-meta{display:flex;justify-content:space-between;align-items:center;gap:0.75rem;margin-bottom:0.75rem;font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase}
.exp-duration{color:var(--S)}
.exp-price{color:var(--A)}
.exp-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:var(--P);margin-bottom:0.55rem;line-height:1.15}
.exp-desc{font-size:12px;line-height:1.65;color:var(--muted);margin-top:auto}
.experiences-cta{text-align:center;margin-top:2.4rem}
.btn-exp-all{display:inline-block;padding:12px 30px;border:1px solid rgba(14,51,72,0.18);border-radius:5px;background:transparent;color:var(--P);font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;text-decoration:none;transition:border-color .28s ease,color .28s ease,background .28s ease}
.btn-exp-all:hover{border-color:var(--A);color:var(--P);background:rgba(200,169,106,0.08)}

.services-sec{background:var(--BG);padding:0}
.services-sec.page-sec{padding-top:36px;padding-bottom:72px}
.services-sub{max-width:560px;margin:0.5rem auto 0;font-size:14px;line-height:1.7;color:var(--muted)}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.35rem;max-width:1200px;margin:1.35rem auto 0;width:100%}
.service-card{display:flex;flex-direction:column;background:rgba(255,253,248,0.82);border:1px solid rgba(14,51,72,0.08);border-radius:24px;overflow:hidden;transition:transform .45s ease,border-color .45s ease,box-shadow .45s ease;width:100%;min-width:0}
a.service-card--link{text-decoration:none;color:inherit;cursor:pointer}
.service-card:hover{transform:translateY(-4px);border-color:rgba(200,169,106,0.32);box-shadow:0 20px 44px rgba(15,40,71,0.07)}
.service-image{height:240px;background-size:cover;background-position:center;transition:transform .7s ease;overflow:hidden}
.service-card:hover .service-image{transform:scale(1.04)}
.service-body{padding:1.5rem 1.55rem 1.65rem;display:flex;flex-direction:column;flex:1}
.service-title{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:700;color:var(--P);margin-bottom:0.65rem;line-height:1.12}
.service-desc{font-size:13px;line-height:1.7;color:var(--muted);margin-bottom:1.1rem}
.service-features{list-style:none;display:grid;gap:0.45rem;margin-bottom:1.35rem;flex:1}
.service-features li{font-size:12px;color:var(--P);padding-left:1rem;position:relative;line-height:1.5}
.service-features li::before{content:'';position:absolute;left:0;top:0.55em;width:4px;height:4px;border-radius:50%;background:var(--A)}
.service-cta{display:inline-flex;align-items:center;gap:0.25rem;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--P);text-decoration:none;border-bottom:1px solid rgba(200,169,106,0.45);padding-bottom:2px;width:fit-content;transition:color .28s ease,border-color .28s ease,gap .28s ease}
.service-cta:hover{color:var(--S);border-color:var(--A);gap:0.45rem}

.logo-link{display:block;text-decoration:none;background:transparent;border:0;box-shadow:none;padding:0}
.logo-mark{width:38px;height:38px;background:var(--P);border-radius:50%;display:flex;align-items:center;justify-content:center}
.logo-mark svg{width:22px;height:22px}
.logo-text{line-height:1.1}
.logo-text .l1{font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:700;color:var(--P);letter-spacing:0.06em;text-transform:uppercase}
.logo-text .l2{font-size:9px;font-weight:500;letter-spacing:0.18em;color:var(--S);text-transform:uppercase}
.tour-hero{position:relative;min-height:560px;height:68vh;max-height:780px;overflow:visible;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;padding:0 3.4rem 3.5rem;background:#0F2847;width:100%}
.tour-hero .nav{z-index:10}
.tour-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;display:block;image-rendering:auto;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0)}
.tour-hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,18,48,0.38) 0%,rgba(20,18,48,0.08) 20%,transparent 42%),linear-gradient(90deg,rgba(15,40,71,0.48) 0%,rgba(15,40,71,0.2) 38%,rgba(15,40,71,0.04) 65%,transparent 100%);pointer-events:none}
.tour-hero--phuket-city .tour-hero-overlay{background:linear-gradient(180deg,rgba(20,18,48,0.46) 0%,rgba(20,18,48,0.14) 24%,transparent 48%),linear-gradient(90deg,rgba(15,40,71,0.58) 0%,rgba(15,40,71,0.28) 42%,rgba(15,40,71,0.08) 70%,transparent 100%)}
.tour-hero--transfer .tour-hero-bg{object-position:62% center}
.tour-hero--plain{background:linear-gradient(135deg,#0B2A3D 0%,var(--P) 48%,#164E63 100%)}
.tour-hero--plain::after{content:'';position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse 80% 60% at 18% 100%,rgba(200,169,106,0.14) 0%,transparent 62%),radial-gradient(ellipse 55% 45% at 88% 12%,rgba(42,111,134,0.22) 0%,transparent 58%);pointer-events:none}
.tour-hero--plain .tour-hero-inner{z-index:3}
.transfer-table-wrap{overflow-x:auto;margin:1rem 0 1.25rem;-webkit-overflow-scrolling:touch}
.transfer-table{width:100%;min-width:480px;border-collapse:collapse;font-size:12px;background:rgba(255,253,248,0.88);border:1px solid rgba(14,51,72,0.08);border-radius:10px;overflow:hidden}
.transfer-table th,.transfer-table td{padding:0.75rem 1rem;text-align:left;border-bottom:1px solid rgba(14,51,72,0.06)}
.transfer-table th{font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);background:rgba(14,51,72,0.04)}
.transfer-table td{color:var(--P)}
.transfer-table td:not(:first-child),.transfer-table th:not(:first-child){text-align:right;white-space:nowrap}
.transfer-table tr:last-child td{border-bottom:none}
.transfer-table tbody tr:hover td{background:rgba(200,169,106,0.06)}
.tour-hero-inner{position:relative;z-index:3;max-width:650px;width:100%;color:var(--white)}
.tour-back{display:inline-block;margin-bottom:1rem;font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,253,248,0.88);text-decoration:none;text-shadow:0 2px 12px rgba(0,0,0,0.35)}
.tour-back:hover{color:var(--A)}
.tour-hero--catalog .tour-hero-tag--eyebrow{font-size:11px;font-weight:600;letter-spacing:0.24em;color:var(--A);margin-bottom:1.1rem;display:flex;align-items:center;gap:10px}
.tour-hero--catalog .tour-hero-tag--eyebrow::before{content:'';display:inline-block;width:36px;height:1px;background:var(--A);flex-shrink:0}
.tour-hero--catalog h1{font-size:clamp(36px,4.2vw,52px);max-width:720px;line-height:1.08;letter-spacing:-0.01em}
.tour-hero--catalog .tour-hero-sub{font-size:18px;max-width:560px;line-height:1.65;margin-bottom:1.25rem}
.tour-hero--catalog .tour-hero-meta{font-size:10px;letter-spacing:0.14em;gap:0.85rem 1.25rem;margin-bottom:0}
.tour-hero-tag{font-size:14px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--A);margin-bottom:0.85rem;text-shadow:0 2px 12px rgba(0,0,0,0.35)}
.tour-hero h1{font-family:'Cormorant Garamond',serif;font-size:64px;font-weight:700;line-height:1.05;margin-bottom:0.75rem;color:var(--white);text-shadow:0 2px 12px rgba(0,0,0,0.35)}
.tour-hero-sub{font-size:20px;line-height:1.7;color:rgba(255,253,248,0.95);margin-bottom:1.35rem;max-width:650px;text-shadow:0 2px 12px rgba(0,0,0,0.35)}
.tour-hero-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,253,248,0.92);text-shadow:0 2px 12px rgba(0,0,0,0.35)}
.tour-hero-cta{margin-top:0.25rem;position:relative;z-index:1}
.tour-page{background:var(--BG);padding:3rem 3rem 4rem}
.tour-layout{display:grid;grid-template-columns:1fr 300px;gap:2.5rem;max-width:1200px;margin:0 auto;align-items:start;width:100%}
.tour-block{margin-bottom:2.5rem}
.tour-block h2{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--P);margin-bottom:0.85rem}
.tour-block p{font-size:14px;line-height:1.85;color:#3E5964;margin-bottom:0.85rem}
.tour-note{font-size:12px;color:var(--muted);margin-bottom:1rem}
.tour-disclaimer{font-size:12px;color:var(--muted);font-style:italic;margin-top:0.5rem}
.tour-list{list-style:none;display:grid;gap:0.55rem}
.tour-list li{font-size:13px;color:var(--P);padding-left:1rem;position:relative;line-height:1.6}
.tour-list li::before{content:"";position:absolute;left:0;top:0.55em;width:5px;height:5px;border-radius:50%;background:var(--A)}
.tour-list--inline{display:flex;flex-wrap:wrap;gap:0.75rem 1.5rem}
.tour-list--inline li{padding-left:0}
.tour-list--inline li::before{display:none}
.tour-timeline{list-style:none;counter-reset:tour-step;display:grid;gap:0.85rem;padding-left:0}
.tour-timeline li{font-size:13px;line-height:1.65;color:var(--P);padding-left:1.35rem;border-left:1px solid rgba(200,169,106,0.35);margin-left:0.35rem}
.tour-timeline li strong{color:var(--P);font-weight:600;font-family:var(--font-body);font-variant-numeric:lining-nums tabular-nums;letter-spacing:0.02em}
.tour-sidebar{position:sticky;top:1.5rem}
.tour-price-card{background:rgba(255,253,248,0.88);border:1px solid rgba(14,51,72,0.08);border-radius:12px;padding:1.5rem}
.tour-price-head{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:var(--P);margin-bottom:1rem;padding-bottom:0.75rem;border-bottom:1px solid rgba(14,51,72,0.08)}
.tour-price-row{display:flex;justify-content:space-between;align-items:baseline;gap:0.75rem;padding:0.45rem 0;font-size:12px;color:var(--P)}
.tour-price-row strong{color:var(--P);font-size:14px;font-weight:700}
.tour-price-row--sub{font-size:11px;color:var(--muted);padding-top:0;padding-bottom:0.65rem;border-bottom:1px solid rgba(14,51,72,0.05)}
.tour-sidebar-cta{width:100%;justify-content:center;margin-top:1.25rem}
.tour-sidebar-wa{display:block;text-align:center;margin-top:0.85rem;font-size:11px;color:var(--S);text-decoration:none}
.tour-sidebar-wa:hover{color:var(--A)}
.tour-related{max-width:1200px;margin:2rem auto 0;padding-top:2.5rem;border-top:1px solid rgba(14,51,72,0.08);width:100%}
.tour-related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem}
.tour-related-link{display:block;padding:1rem 1.1rem;border:1px solid rgba(14,51,72,0.1);border-radius:8px;background:rgba(255,253,248,0.6);font-family:var(--font-body);font-size:14px;font-weight:600;letter-spacing:0.02em;color:var(--P);text-decoration:none;text-align:center;transition:border-color .28s ease,background .28s ease}
.tour-related-link:hover{border-color:rgba(200,169,106,0.4);background:var(--white)}

.family-wrap{padding:0;background:var(--BG)}
.family-wrap.page-sec{padding-top:80px;padding-bottom:80px}
.family-banner{display:grid;grid-template-columns:1.45fr 1fr;background:rgba(255,253,248,0.82);margin:0 auto;border-radius:14px;overflow:hidden;border:1px solid rgba(14,51,72,0.08);max-width:1200px;box-shadow:0 22px 48px rgba(15,40,71,0.055);width:100%}
.fam-img{background:linear-gradient(180deg,rgba(14,51,72,0.04),rgba(14,51,72,0.08)),url('../images/family-snorkeling.png') center/cover no-repeat;min-height:280px}
.fam-content{padding:2.4rem 2.75rem;display:flex;flex-direction:column;justify-content:center;position:relative}
.fam-title{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:700;color:var(--P);margin-bottom:0.75rem}
.fam-desc{font-size:14px;color:var(--muted);margin-bottom:1.25rem;line-height:1.75}
.fam-list{list-style:none}
.fam-list li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--P);margin-bottom:6px}
.fam-dot{width:16px;height:16px;border-radius:50%;background:rgba(185,151,91,0.16);border:1px solid rgba(185,151,91,0.55);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fam-dot i{font-size:9px;color:var(--P)}

.dest-sec{padding:0;background:var(--BG)}
.dest-sec.page-sec{padding-top:80px;padding-bottom:80px}
.dest-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:1.25rem auto 0;max-width:1200px;width:100%}
.dest-card{border-radius:10px;overflow:hidden;position:relative;cursor:pointer;background:var(--white);width:100%;min-width:0}
.dest-img{height:190px;display:flex;align-items:flex-end;padding:14px;box-shadow:inset 0 -85px 75px rgba(14,51,72,0.42);background-size:cover;background-position:center;transition:transform .55s ease,filter .55s ease}
.dest-card:hover .dest-img{transform:scale(1.045);filter:saturate(1.06)}
.dest-name{color:var(--white);font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:700;text-align:left;text-shadow:0 1px 12px rgba(0,0,0,0.45);padding-top:0;position:relative;z-index:1}

.reviews-sec{background:var(--BG);padding:0}
.reviews-sec.page-sec{padding-top:52px;padding-bottom:52px}
.reviews-sec .sec-header{margin-bottom:1rem}
.review-card{padding:1.15rem;border-radius:8px;border:1px solid rgba(14,51,72,0.08);background:rgba(255,253,248,0.58);box-shadow:none;width:100%;min-width:0}
.review-q{font-size:22px;color:var(--A);font-family:'Cormorant Garamond',serif;font-weight:700;line-height:1;margin-bottom:6px}
.review-text{font-size:13px;color:var(--P);line-height:1.55;margin:0 0 0.8rem;font-style:italic}
.review-author{font-size:12px;font-weight:600;color:var(--P)}
.review-location{font-size:11px;color:var(--muted)}
.stars{color:var(--A);font-size:12px;margin-bottom:6px;letter-spacing:1px}

.reviews-rail-wrap{margin-top:0.75rem;width:100%}
.reviews-rail{
  position:relative;
  overflow:hidden;
  cursor:grab;
  touch-action:pan-y;
  padding:0.35rem 0;
  -webkit-user-select:none;
  user-select:none;
}
.reviews-rail.is-dragging{cursor:grabbing;touch-action:none}
.reviews-rail:focus-visible{outline:2px solid rgba(200,169,106,0.55);outline-offset:4px;border-radius:4px}
.reviews-rail-fade{
  position:absolute;
  top:0;
  bottom:0;
  width:clamp(48px,8vw,120px);
  z-index:2;
  pointer-events:none;
}
.reviews-rail-fade--left{left:0;background:linear-gradient(90deg,var(--BG) 12%,rgba(251,246,237,0) 100%)}
.reviews-rail-fade--right{right:0;background:linear-gradient(270deg,var(--BG) 12%,rgba(251,246,237,0) 100%)}
.reviews-rail-track{
  display:flex;
  gap:1rem;
  width:max-content;
  will-change:transform;
  backface-visibility:hidden;
}
.reviews-rail-set{display:flex;gap:1rem;flex-shrink:0;align-items:stretch}
.review-card--rail{
  flex:0 0 clamp(272px,30vw,360px);
  width:clamp(272px,30vw,360px);
  display:flex;
  flex-direction:column;
  padding:1.2rem 1.3rem;
  border-radius:10px;
  background:rgba(255,253,248,0.72);
  border:1px solid rgba(14,51,72,0.07);
  box-shadow:0 10px 28px rgba(14,51,72,0.04);
  transition:box-shadow .35s ease,border-color .35s ease,transform .35s ease;
}
.reviews-rail.is-paused .review-card--rail:hover{
  border-color:rgba(200,169,106,0.28);
  box-shadow:0 14px 34px rgba(14,51,72,0.07);
  transform:translateY(-2px);
}
.review-card--rail .review-text{flex:1}
.reviews-rail--reduced{overflow-x:auto;cursor:auto;touch-action:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.reviews-rail--reduced::-webkit-scrollbar{display:none}
.reviews-rail--reduced .reviews-rail-fade{display:none}
.reviews-rail--reduced .reviews-rail-track{transform:none!important}

.founder-sec{background:#FBF6ED;padding:0}
.founder-sec.page-sec{padding-top:80px;padding-bottom:80px}
.founder-card{display:grid;grid-template-columns:0.9fr 1.1fr;gap:2.75rem;align-items:center;max-width:1200px;margin:0 auto;width:100%}
.founder-photo{min-height:400px;border-radius:14px;background:linear-gradient(180deg,rgba(14,51,72,0.08),rgba(14,51,72,0.24)),url('../images/hero-road-clean.png') center/cover no-repeat;box-shadow:0 28px 58px rgba(15,40,71,0.08);position:relative;overflow:hidden}
.founder-photo::after{content:"Nickie";position:absolute;left:2rem;bottom:1.6rem;font-family:'Cormorant Garamond',serif;font-size:36px;color:var(--white);letter-spacing:0.04em}
.founder-copy{max-width:100%}
.founder-kicker{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--A);margin-bottom:1rem}
.founder-title{font-family:'Cormorant Garamond',serif;font-size:42px;color:var(--P);margin-bottom:1rem}
.founder-text{font-size:15px;color:#3E5964;line-height:1.85;margin-bottom:1.4rem}
.founder-list{display:grid;gap:0.75rem;list-style:none;color:var(--P);font-size:13px}
.founder-list li{display:flex;gap:0.65rem;align-items:center}
.founder-list li::before{content:"";width:6px;height:6px;border:1px solid var(--A);border-radius:50%;flex:0 0 auto}

.cta-footer{background:linear-gradient(180deg,#0E3348,#082538);padding:2rem 1.25rem;display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:center;max-width:100%;overflow:hidden}
.cta-left{display:grid;grid-template-columns:auto 1fr;gap:1.25rem;align-items:center;min-width:0}
.cta-left .cta-logo{display:flex;align-items:center;gap:10px;margin-bottom:0;background:transparent;border:0;box-shadow:none}
.cta-left .cta-logo img{width:min(var(--logo-w),42vw);height:auto;display:block;object-fit:contain;background:transparent;border:0;box-shadow:none;filter:none}
.footer-bottom{background:#082538;border-top:1px solid rgba(255,255,255,0.08);padding:2rem 1.25rem 1.25rem;overflow:hidden}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 0.9fr 0.9fr 1fr;gap:1.75rem;margin-bottom:1.5rem;max-width:1200px;margin-left:auto;margin-right:auto}
.ft-bottom-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:0.75rem;font-size:11px;color:rgba(247,250,252,0.28);padding-top:1.25rem;border-top:1px solid rgba(255,255,255,0.07);max-width:1200px;margin-left:auto;margin-right:auto}
.exp-card{width:100%;min-width:0}
.btn-p,.btn-s{max-width:100%}
.ft-brand{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--A);font-weight:700;margin-bottom:8px}
.ft-desc{font-size:12px;color:rgba(247,250,252,0.52);line-height:1.8;max-width:300px}
.ft-col-title{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--A);opacity:0.7;margin-bottom:10px}
.ft-links{list-style:none}
.ft-links li{margin-bottom:6px}
.ft-links a{color:rgba(247,250,252,0.5);font-size:12px;text-decoration:none}
.ft-links a:hover{color:var(--A)}
.ft-contact{font-size:12px;color:rgba(247,250,252,0.5);line-height:2}
.ft-contact strong{color:rgba(247,250,252,0.8)}
.ft-rating{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--white);line-height:1.1;margin-bottom:5px}
.ft-stars{color:var(--A);letter-spacing:0.12em;font-size:13px;margin-bottom:5px}
.ft-wa{display:inline-block;margin-top:12px;color:var(--P);background:var(--A);padding:9px 14px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;text-decoration:none}
.cta-logo-mark{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center}
.cta-brand{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--white);font-weight:700;letter-spacing:0.06em;text-transform:uppercase}
.cta-tagline{font-size:11px;color:rgba(247,250,252,0.45);letter-spacing:0.12em;text-transform:uppercase}
.cta-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,4vw,2rem);color:var(--white);margin-bottom:6px;line-height:1.15}
.cta-sub{font-size:13px;color:rgba(247,250,252,0.6);line-height:1.65}
.btn-accent{background:var(--A);color:var(--P);padding:13px 24px;border-radius:5px;font-size:12px;font-weight:700;border:none;cursor:pointer;letter-spacing:0.08em;text-transform:uppercase;white-space:normal;text-align:center;max-width:100%}
.social-row{display:flex;gap:8px}
.social-btn{width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;color:rgba(247,250,252,0.5);font-size:13px;text-decoration:none;cursor:pointer}
.social-btn:hover{border-color:var(--A);color:var(--A)}
.ft-contact .ti{font-size:14px;vertical-align:-2px;margin-right:2px;opacity:0.75}

.accent-line{height:3px;background:linear-gradient(90deg,var(--P) 0%,var(--S) 50%,var(--A) 100%)}

@media (min-width:901px){
  .nav-mobile-actions,.nav-drawer,.nav-overlay{display:none!important}
  .nav-desktop{display:flex}
}
@media (min-width:1200px){
  .nav-links--hero{gap:2.25rem}
  .nav-links a{font-size:12.5px;letter-spacing:0.2em}
  .exp-image{height:320px}
}
@media (min-width:901px) and (max-width:1199px){
  .nav-links--hero{gap:1.35rem}
  .nav-links a{font-size:10.5px;letter-spacing:0.14em}
  .nav:not(.nav--inner) .nav-cta{padding:9px 16px;font-size:10.5px}
}
@media (min-width:1440px){
  .hero-inner{max-width:540px;padding-bottom:3rem}
  .hero h1{font-size:3.15rem;margin-bottom:1rem}
  .hero-sub{font-size:16px;max-width:460px;margin-bottom:1.5rem}
}
@media (min-width:1920px){
  .hero h1{font-size:3.35rem}
  .hero-sub{font-size:17px;max-width:480px}
}
@media (max-width:900px){
  :root{--logo-w:228px;--logo-h:162px}
  .nav-drawer:not(.is-open){display:none!important;transform:translate3d(100%,0,0)!important;visibility:hidden!important}
  .page-sec{padding:60px 1.25rem}
  .experiences-sec.page-sec{padding-top:44px;padding-bottom:32px}
  .services-sec.page-sec{padding-top:28px;padding-bottom:60px}
  .why-bar.page-sec,.family-wrap.page-sec,.founder-sec.page-sec,.dest-sec.page-sec{padding-top:60px;padding-bottom:60px}
  .reviews-sec.page-sec{padding-top:40px;padding-bottom:40px}
  .nav{background:linear-gradient(180deg,rgba(20,18,48,0.55) 0%,rgba(20,18,48,0.15) 70%,transparent 100%);backdrop-filter:none;border-bottom:none}
  .nav--inner{background:var(--white);border-bottom:1px solid rgba(14,51,72,0.08)}
  .nav--inner .nav-toggle{border-color:rgba(14,51,72,0.12);background:var(--white)}
  .nav--inner .nav-toggle-line{background:var(--P)}
  .nav-bar{padding:0.75rem 1.25rem;min-height:calc(var(--logo-h) + 1.5rem)}
  .nav-logo{left:1.25rem;top:50%;transform:translateY(-50%)}
  .nav-links--hero{display:none}
  .nav-end{display:none}
  .nav-mobile-actions{display:flex;margin-left:auto;z-index:2}
  .nav-toggle{display:flex;border-color:rgba(200,169,106,0.45);background:rgba(15,40,71,0.35)}
  .nav-toggle-line{background:var(--A-light)}
  .hero{height:auto;min-height:min(78vh,680px);max-height:none}
  .hero-inner{padding:0 1.5rem 0.65rem;max-width:100%}
  .hero-dots{right:1.5rem;bottom:1rem}
  .hero h1{font-size:58px;max-width:600px}
  .hero-sub{font-size:17px;max-width:600px;line-height:1.6}
  .exp-image{height:260px}
  .why-grid{grid-template-columns:1fr 1fr;gap:0.75rem}
  .why-item{max-height:none;padding:1rem 0.85rem}
  .why-title{font-size:18px}
  .trust-strip{padding:12px 1.25rem}
  .trust-inner{grid-template-columns:1fr;gap:0.35rem}
  .tour-hero{height:62vh;min-height:480px;max-height:none;padding:0 1.5rem 2.5rem}
  .tour-hero h1{font-size:42px}
  .tour-hero-sub{font-size:18px}
  .tour-page{padding:2rem 1.25rem 3rem}
  .tour-layout{grid-template-columns:1fr}
  .tour-sidebar{position:static}
  .tour-related-grid{grid-template-columns:1fr 1fr}
  .why-grid,.experiences-grid,.services-grid,.dest-grid{grid-template-columns:1fr 1fr}
  .why-bar--compact .why-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .footer-grid{grid-template-columns:1fr 1fr}
  .family-banner,.cta-footer,.footer-grid,.founder-card{grid-template-columns:1fr}
  .cta-left{grid-template-columns:1fr}
}
@media (max-width:560px){
  :root{--logo-w:159px;--logo-h:114px}
  .page-sec{padding:40px 1.25rem}
  .experiences-sec.page-sec,.why-bar.page-sec:not(.why-bar--compact),.family-wrap.page-sec,.founder-sec.page-sec,.dest-sec.page-sec{padding-top:40px;padding-bottom:40px}
  .reviews-sec.page-sec{padding-top:28px;padding-bottom:28px}
  .why-bar--compact.page-sec{padding-top:1rem;padding-bottom:1.1rem}
  .experiences-sec.page-sec{padding-top:36px;padding-bottom:28px}
  .services-sec.page-sec{padding-top:24px;padding-bottom:40px}
  .experiences-grid,.services-grid,.dest-grid{grid-template-columns:1fr}
  .why-bar--compact .why-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero{height:auto;min-height:min(74vh,640px);max-height:none;padding-bottom:0}
  .hero-inner{padding:2rem 1.15rem 0.5rem}
  .hero-dots{right:1.25rem;bottom:0.85rem;gap:5px}
  .hero-dot{width:20px}
  .hero-dot.is-active{width:28px}
  .hero h1{font-size:42px;line-height:1.06}
  .hero-sub{font-size:15px;line-height:1.6}
  .hero-btns{flex-direction:column;align-items:stretch;width:100%;max-width:none}
  .hero-btns .btn-p,.hero-btns .btn-s{width:100%;max-width:none;flex:0 0 auto;justify-content:center}
  .exp-image{height:240px}
  .dest-img{height:230px}
  .tour-related-grid{grid-template-columns:1fr}
  .tour-hero{padding:0 1.25rem 2rem;min-height:420px}
  .tour-hero h1{font-size:36px}
  .nav-bar{padding:0.55rem 1rem;min-height:calc(var(--logo-h) + 1.1rem)}
}

/* Homepage split feature blocks */
.split-features{display:grid;grid-template-columns:1fr 1fr;gap:1.35rem;padding:3rem 1.25rem 4rem;width:100%}
.split-feature{position:relative;min-height:440px;border-radius:20px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:2.5rem 2.25rem;text-decoration:none;color:var(--white);border:1px solid rgba(14,51,72,0.08);box-shadow:0 20px 44px rgba(15,40,71,0.06);transition:transform .45s ease,box-shadow .45s ease,border-color .45s ease}
.split-feature:hover{transform:translateY(-4px);box-shadow:0 28px 52px rgba(15,40,71,0.1);border-color:rgba(200,169,106,0.32)}
.split-feature-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transition:transform .75s ease}
.split-feature:hover .split-feature-bg{transform:scale(1.05)}
.split-feature-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,40,71,0.12) 0%,rgba(15,40,71,0.5) 50%,rgba(15,40,71,0.88) 100%);z-index:1}
.split-feature-content{position:relative;z-index:2}
.split-feature-tag{font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--A-light);margin-bottom:0.65rem}
.split-feature-tag--eyebrow{font-size:10px;font-weight:600;letter-spacing:0.22em;color:var(--A);margin-bottom:0.6rem;display:flex;align-items:center;gap:10px}
.split-feature-tag--eyebrow::before{content:'';display:inline-block;width:28px;height:1px;background:var(--A);flex-shrink:0}
.split-feature-title{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,3.5vw,42px);font-weight:700;margin-bottom:0.75rem;line-height:1.08;text-shadow:0 2px 16px rgba(0,0,0,0.25)}
.split-feature-desc{font-size:14px;line-height:1.75;color:rgba(255,253,248,0.92);margin-bottom:1.35rem;max-width:440px}
.split-feature-btn{display:inline-flex;align-items:center;gap:0.35rem;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--P);background:linear-gradient(180deg,#E5D4A8 0%,var(--A) 100%);padding:12px 24px;border-radius:4px;box-shadow:0 8px 20px rgba(0,0,0,0.18)}

/* Catalog pages (Tours / Transfers) */
.catalog-page{background:#08152A;padding:4.5rem 1.25rem 5.5rem;position:relative;overflow-x:hidden;container-type:inline-size;container-name:catalog}
.catalog-page::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(200,169,106,0.55),transparent)}
.catalog-page::after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(200,169,106,0.28),transparent)}
.catalog-intro{max-width:720px;margin:0 auto 3rem;text-align:center}
.catalog-intro .sec-eyebrow{color:rgba(200,169,106,0.85)}
.catalog-intro .sec-title{color:#F5F2EC}
.catalog-intro p{font-size:15px;line-height:1.75;color:rgba(245,242,236,0.52)}
.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.35rem;width:100%}
.catalog-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:rgba(255,253,248,0.82);border:1px solid rgba(14,51,72,0.08);border-radius:16px;overflow:hidden;transition:transform .42s ease,border-color .42s ease,box-shadow .42s ease}
.catalog-card:hover{transform:translateY(-4px);border-color:rgba(200,169,106,0.34);box-shadow:0 20px 44px rgba(15,40,71,0.08)}
.catalog-card-image{position:relative;height:260px;overflow:hidden;background:#0F2847}
.catalog-card-image img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .6s ease}
.catalog-card:hover .catalog-card-image img{transform:scale(1.04)}
.catalog-card-body{padding:1.35rem 1.45rem 1.5rem;display:flex;flex-direction:column;flex:1}
.catalog-card-title{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:700;color:var(--P);margin-bottom:0.55rem;line-height:1.12}
.catalog-card-desc{font-size:13px;line-height:1.65;color:var(--muted);margin-bottom:1.15rem;flex:1}
.catalog-card-footer{display:flex;align-items:center;justify-content:space-between;gap:0.75rem;padding-top:0.85rem;border-top:1px solid rgba(14,51,72,0.06)}
.catalog-price{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--A)}
.catalog-btn{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--P);padding:10px 18px;border-radius:4px;background:rgba(200,169,106,0.14);border:1px solid rgba(200,169,106,0.35);transition:background .28s ease,border-color .28s ease}
.catalog-card:hover .catalog-btn{background:var(--P);color:var(--white);border-color:var(--P)}

.transfer-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;margin-bottom:3rem}
.transfer-service-card{display:flex;flex-direction:column;padding:1.8rem 1.6rem 1.6rem;background:rgba(255,255,255,0.04);border:1px solid rgba(200,169,106,0.15);border-radius:20px;text-decoration:none;color:inherit;transition:transform .38s cubic-bezier(.25,.46,.45,.94),border-color .38s,box-shadow .38s,background .38s;position:relative;overflow:hidden}
.transfer-service-card::before{content:attr(data-num);position:absolute;top:-14px;right:10px;font-family:var(--font-body);font-size:130px;font-weight:700;line-height:1;color:rgba(200,169,106,0.065);pointer-events:none;user-select:none;transition:color .38s;font-variant-numeric:lining-nums tabular-nums}
.transfer-service-card:hover{transform:translateY(-5px);border-color:rgba(200,169,106,0.42);box-shadow:0 24px 56px rgba(0,0,0,0.45),0 0 0 1px rgba(200,169,106,0.18);background:rgba(255,255,255,0.07)}
.transfer-service-card:hover::before{color:rgba(200,169,106,0.10)}
.tsv-icon{width:40px;height:40px;border-radius:10px;background:rgba(200,169,106,0.12);border:1px solid rgba(200,169,106,0.22);display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;color:rgba(200,169,106,0.85);flex-shrink:0;transition:background .38s,border-color .38s}
.transfer-service-card:hover .tsv-icon{background:rgba(200,169,106,0.20);border-color:rgba(200,169,106,0.45)}
.transfer-service-num{display:none}
.transfer-service-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:#F0EDE6;margin-bottom:0.5rem;line-height:1.25}
.transfer-service-desc{font-size:13px;line-height:1.70;color:rgba(245,242,236,0.50);flex:1}
.transfer-service-link{display:inline-flex;align-items:center;gap:4px;margin-top:1.1rem;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(200,169,106,0.80);border-bottom:1px solid rgba(200,169,106,0.35);padding-bottom:2px;width:fit-content;transition:color .3s,border-color .3s}
.transfer-service-card:hover .transfer-service-link{color:rgba(200,169,106,1);border-color:rgba(200,169,106,0.7)}

.vehicle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.35rem;width:100%}
.vehicle-card{border-radius:16px;overflow:hidden;background:rgba(255,253,248,0.82);border:1px solid rgba(14,51,72,0.08)}
.vehicle-card-image{height:220px;background-size:cover;background-position:center}
.vehicle-card-image--innova{background-image:url('../images/vehicles/vehicle-innova.jpg');background-position:50% 60%}
.vehicle-card-image--van{background-image:url('../images/vehicles/vehicle-van-fleet.jpg');background-position:50% 55%}
.vehicle-card-image--alphard{background-image:url('../images/vehicles/vehicle-vip-van.jpg');background-position:50% 40%}
.vehicle-card-body{padding:1.25rem 1.35rem 1.4rem}
.vehicle-card-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:var(--P);margin-bottom:0.4rem}
.vehicle-card-desc{font-size:12px;line-height:1.6;color:var(--muted)}

.tour-gallery{padding:4.25rem 1.25rem 3.75rem;background:var(--BG)}
.tour-gallery-header{text-align:center;max-width:640px;margin:0 auto 2.85rem}
.tour-gallery-lead{font-size:15px;line-height:1.8;color:var(--muted);margin-top:0.65rem}
.tour-gallery-mosaic{display:grid;grid-template-columns:minmax(0,1.42fr) minmax(0,1fr);gap:1.1rem;max-width:1200px;margin:0 auto;height:clamp(380px,52vh,560px)}
.tour-gallery-stack{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr));gap:1.1rem;min-height:0}
.tour-gallery-cell{position:relative;display:block;width:100%;height:100%;min-height:0;border:0;padding:0;cursor:pointer;border-radius:18px;overflow:hidden;background:#0F2847;box-shadow:0 16px 38px rgba(15,40,71,0.08);transition:transform .45s ease,box-shadow .45s ease}
.tour-gallery-cell:hover{transform:translateY(-2px);box-shadow:0 22px 48px rgba(15,40,71,0.12)}
.tour-gallery-cell--feature{border-radius:20px}
.tour-gallery-cell img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .7s cubic-bezier(.25,.46,.45,.94)}
.tour-gallery-cell:hover img{transform:scale(1.06)}
.tour-gallery-more-badge{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,rgba(8,24,38,0.18) 0%,rgba(8,24,38,0.62) 100%);pointer-events:none;transition:background .35s ease}
.tour-gallery-more-badge span{font-family:var(--serif,Georgia,serif);font-size:clamp(0.5rem,1.1vw,0.68rem);font-weight:500;letter-spacing:0.03em;color:rgba(255,253,248,0.96);text-shadow:0 1px 10px rgba(0,0,0,0.35);padding:0.25rem 0.5rem;border:1px solid rgba(200,169,106,0.45);border-radius:999px;background:rgba(15,40,71,0.35);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);white-space:nowrap;line-height:1.2}
.tour-gallery-cell:hover .tour-gallery-more-badge{background:linear-gradient(180deg,rgba(8,24,38,0.28) 0%,rgba(8,24,38,0.72) 100%)}
.tour-gallery-carousel-slide{position:relative}
.tour-gallery-carousel-slide .tour-gallery-more-badge span{font-size:clamp(0.45rem,1.9vw,0.58rem);padding:0.2rem 0.45rem}
.tour-gallery-carousel{display:none;max-width:1200px;margin:0 auto}
.tour-gallery-carousel-track{display:flex;gap:0.85rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0.15rem 0 0.35rem}
.tour-gallery-carousel-track::-webkit-scrollbar{display:none}
.tour-gallery-carousel-slide{flex:0 0 min(88vw,420px);scroll-snap-align:center;border:0;padding:0;border-radius:18px;overflow:hidden;background:#0F2847;box-shadow:0 16px 36px rgba(15,40,71,0.08);cursor:pointer;aspect-ratio:4/5}
.tour-gallery-carousel-slide img{width:100%;height:100%;object-fit:cover;display:block}
.tour-gallery-carousel-counter{display:none}
.gallery-lightbox{position:fixed;inset:0;z-index:200;background:rgba(6,18,30,0.96);display:flex;align-items:center;justify-content:center;padding:1.25rem;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:galleryLbIn .32s ease}
.gallery-lightbox[hidden]{display:none!important}
@keyframes galleryLbIn{from{opacity:0}to{opacity:1}}
body.gallery-lightbox-open{overflow:hidden}
.gallery-lightbox-stage{max-width:min(1200px,92vw);max-height:min(86vh,900px);display:flex;align-items:center;justify-content:center}
.gallery-lightbox-img{max-width:100%;max-height:min(86vh,900px);width:auto;height:auto;object-fit:contain;border-radius:12px;box-shadow:0 28px 60px rgba(0,0,0,0.45);opacity:1;transition:opacity .32s ease}
.gallery-lightbox-img.is-fading{opacity:0}
.gallery-lightbox-close,.gallery-lightbox-prev,.gallery-lightbox-next{position:absolute;border:1px solid rgba(200,169,106,0.22);background:rgba(255,253,248,0.08);color:var(--white);cursor:pointer;transition:background .28s ease,border-color .28s ease,color .28s ease,transform .28s ease}
.gallery-lightbox-close{top:1.25rem;right:1.25rem;width:44px;height:44px;border-radius:50%;font-size:28px;line-height:1}
.gallery-lightbox-prev,.gallery-lightbox-next{top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;font-size:32px;line-height:1}
.gallery-lightbox-prev{left:max(1rem,2vw)}
.gallery-lightbox-next{right:max(1rem,2vw)}
.gallery-lightbox-close:hover,.gallery-lightbox-prev:hover,.gallery-lightbox-next:hover{background:rgba(200,169,106,0.24);border-color:rgba(200,169,106,0.5);color:var(--white)}
.gallery-lightbox-prev:disabled,.gallery-lightbox-next:disabled{opacity:0.35;cursor:default}
.gallery-lightbox-counter{position:absolute;bottom:1.35rem;left:50%;transform:translateX(-50%);font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,253,248,0.82);padding:0.45rem 0.9rem;border-radius:999px;background:rgba(15,40,71,0.45);border:1px solid rgba(200,169,106,0.2)}

@media (max-width:900px){
  .tour-gallery{padding:3.25rem 1.25rem 2.75rem}
  .tour-gallery-mosaic{display:none}
  .tour-gallery-carousel{display:block}
  .tour-gallery-header{margin-bottom:1.85rem}
}
@media (max-width:1023px){
  .split-features{grid-template-columns:1fr;gap:1rem;padding:2.5rem 1.25rem 3rem}
  .split-feature{min-height:360px}
  .catalog-grid,.transfer-services-grid,.vehicle-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:767px){
  .catalog-grid,.transfer-services-grid,.vehicle-grid{grid-template-columns:1fr}
  .catalog-card-image{height:220px}

  .tour-gallery{padding:1.75rem 1rem 1.5rem}
  .tour-gallery-header{margin-bottom:1rem}
  .tour-gallery-header .sec-title{font-size:clamp(1.65rem,6vw,2rem)}
  .tour-gallery-lead{margin-top:0.4rem;font-size:14px;line-height:1.65}
  .tour-gallery-carousel{position:relative}
  .tour-gallery-carousel-track{
    gap:0.65rem;
    padding:0;
    scroll-padding-inline:0;
  }
  .tour-gallery-carousel-slide{
    flex:0 0 100%;
    width:100%;
    max-width:100%;
    height:clamp(220px,56vw,280px);
    aspect-ratio:unset;
    border-radius:14px;
    scroll-snap-align:center;
    scroll-snap-stop:always;
  }
  .tour-gallery-carousel-slide img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
  }
  .tour-gallery-carousel-counter{
    display:block;
    margin-top:0.65rem;
    text-align:center;
    font-size:11px;
    font-weight:600;
    letter-spacing:0.16em;
    text-transform:uppercase;
    color:var(--muted);
  }
}


/* Upgraded WhatsApp Widget Styles */
.wa-widget-container {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

.wa-float {
  position: relative;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #25D366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s ease;
  text-decoration: none;
  cursor: pointer;
}

.wa-float:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(37, 211, 102, 0.6);
}

.wa-float svg {
  width: 32px;
  height: 32px;
  z-index: 2;
}

/* Pulsing Outer Ring */
.wa-float-ring {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #25D366;
  opacity: 0.4;
  z-index: 1;
  animation: wa-glow-pulse 2s infinite;
  pointer-events: none;
}

@keyframes wa-glow-pulse {
  0% {
    transform: scale(1);
    opacity: 0.4;
  }
  50% {
    transform: scale(1.4);
    opacity: 0;
  }
  100% {
    transform: scale(1.4);
    opacity: 0;
  }
}

/* Chat Greeting Bubble */
.wa-bubble {
  position: absolute;
  bottom: 76px;
  right: 0;
  width: 300px;
  background: #ffffff;
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12), 0 1px 3px rgba(0, 0, 0, 0.06);
  border: 1px solid rgba(0, 0, 0, 0.06);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  opacity: 0;
  transform: translateY(20px) scale(0.95);
  pointer-events: none;
  transition: opacity 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  z-index: 999;
}

.wa-bubble.is-active {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

/* Bubble Header */
.wa-bubble-header {
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
}

.wa-bubble-avatar {
  position: relative;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #f0f2f5;
  color: #0e3348;
  display: flex;
  align-items: center;
  justify-content: center;
}

.wa-bubble-avatar svg {
  width: 24px;
  height: 24px;
  opacity: 0.8;
}

.wa-bubble-status-dot {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #25D366;
  border: 2px solid #ffffff;
  animation: wa-status-pulse 1.5s infinite;
}

@keyframes wa-status-pulse {
  0% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.2); opacity: 0.7; }
  100% { transform: scale(1); opacity: 1; }
}

.wa-bubble-meta {
  display: flex;
  flex-direction: column;
  line-height: 1.3;
}

.wa-bubble-name {
  font-weight: 600;
  font-size: 14px;
  color: #0e3348;
}

.wa-bubble-title {
  font-size: 11px;
  color: #667085;
  font-weight: 500;
}

/* Close Button */
.wa-bubble-close {
  position: absolute;
  top: 8px;
  right: 8px;
  background: none;
  border: none;
  font-size: 20px;
  color: #98a2b3;
  cursor: pointer;
  padding: 4px;
  line-height: 1;
  transition: color 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.wa-bubble-close:hover {
  color: #475467;
}

/* Bubble Body */
.wa-bubble-body {
  font-size: 13px;
  color: #344054;
  line-height: 1.45;
  margin: 0;
}

.wa-bubble-body p {
  margin: 0;
}

/* Bubble Footer / Button */
.wa-bubble-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #25D366;
  color: #ffffff !important;
  text-decoration: none;
  font-weight: 600;
  font-size: 13px;
  padding: 8px 16px;
  border-radius: 20px;
  transition: background 0.2s ease, transform 0.2s ease;
  box-shadow: 0 2px 8px rgba(37, 211, 102, 0.25);
  text-align: center;
}

.wa-bubble-btn:hover {
  background: #20ba59;
  transform: translateY(-1px);
}

/* Responsive adjustments */
@media (max-width: 720px) {
  .wa-widget-container {
    bottom: 1rem;
    right: 1rem;
  }
  .wa-float {
    width: 52px;
    height: 52px;
  }
  .wa-float svg {
    width: 27px;
    height: 27px;
  }
  .wa-bubble {
    width: 270px;
    bottom: 64px;
    padding: 12px;
  }
}

.reviews-platform{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px}
.reviews-platform-badge{font-size:13px;font-weight:600;color:#00AA6C;letter-spacing:0.02em}
.review-footer{display:flex;align-items:baseline;justify-content:space-between;margin-top:auto;padding-top:10px}
.review-location{font-size:12px;color:var(--muted)}
.reviews-cta{text-align:center;margin-top:1.5rem;max-width:1200px;margin-left:auto;margin-right:auto}
.reviews-ta-btn{display:inline-block;padding:0.6rem 1.6rem;border:2px solid #00AA6C;border-radius:40px;color:#00AA6C;font-size:13px;font-weight:600;text-decoration:none;transition:background .25s,color .25s}
.reviews-ta-btn:hover{background:#00AA6C;color:#fff}

.faq-sec{background:var(--BG)}
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid rgba(200,169,106,0.18)}
.faq-q{width:100%;background:none;border:none;padding:1.15rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:15px;font-weight:600;color:var(--P);cursor:pointer;text-align:left}
.faq-q:hover{color:var(--gold,#C8A96A)}
.faq-icon{font-size:20px;font-weight:400;flex-shrink:0;transition:transform .3s ease}
.faq-q[aria-expanded="true"] .faq-icon{transform:rotate(45deg)}
.faq-a{padding:0 0 1.15rem}
.faq-a p{font-size:14px;line-height:1.8;color:var(--muted);margin:0}

.season-banner{display:flex;align-items:flex-start;gap:12px;background:#FFF8E6;border:1.5px solid #F5B800;border-radius:12px;padding:1rem 1.25rem;margin:0 0 2rem}
.season-banner-icon{font-size:20px;flex-shrink:0;line-height:1.4}
.season-banner-body{font-size:13.5px;line-height:1.7;color:#5a4200}
.season-banner-body strong{display:block;margin-bottom:3px;color:#3d2d00}

/* Surin luxury package selector */
.pkg-select{background:linear-gradient(180deg,var(--BG) 0%,#F5F0E6 100%);padding:3.25rem 1.5rem 3.5rem;border-bottom:1px solid rgba(200,169,106,0.12)}
.pkg-select-header{text-align:center;max-width:560px;margin:0 auto 2.25rem}
.pkg-select-lead{font-size:14px;line-height:1.75;color:var(--muted);margin-top:0.65rem}
.pkg-select-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.15rem;max-width:1080px;margin:0 auto}
.pkg-card{
  position:relative;display:flex;flex-direction:column;align-items:flex-start;text-align:left;
  padding:1.65rem 1.45rem 1.5rem;background:rgba(255,253,248,0.82);
  border:1px solid rgba(14,51,72,0.09);border-radius:16px;cursor:pointer;
  transition:border-color .42s ease,box-shadow .42s ease,transform .42s ease,background .42s ease;
  font-family:inherit;color:inherit;width:100%;
}
.pkg-card:hover{border-color:rgba(200,169,106,0.38);background:rgba(255,253,248,0.96);transform:translateY(-2px)}
.pkg-card.is-active{
  border-color:rgba(200,169,106,0.72);
  background:var(--white);
  box-shadow:0 14px 42px rgba(200,169,106,0.16),0 0 0 1px rgba(200,169,106,0.22),0 0 28px rgba(200,169,106,0.08);
  transform:translateY(-5px);
}
.pkg-card-tier{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--A);margin-bottom:0.55rem}
.pkg-card-name{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:700;color:var(--P);line-height:1.1;margin-bottom:0.35rem}
.pkg-card-duration{font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.pkg-card-from{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;color:var(--P);margin-bottom:0.65rem}
.pkg-card-from span{font-size:12px;font-family:'DM Sans',sans-serif;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);margin-right:0.35rem}
.pkg-card-detail{font-size:12px;line-height:1.55;color:#5A7280;margin-top:auto;padding-top:0.85rem;border-top:1px solid rgba(14,51,72,0.06);width:100%}
.pkg-card-mark{position:absolute;top:1rem;right:1rem;width:8px;height:8px;border-radius:50%;background:transparent;border:1.5px solid rgba(200,169,106,0.35);transition:background .35s ease,border-color .35s ease,box-shadow .35s ease}
.pkg-card.is-active .pkg-card-mark{background:var(--A);border-color:var(--A);box-shadow:0 0 10px rgba(200,169,106,0.55)}
.pkg-content{max-width:1200px;margin:0 auto;width:100%}
.pkg-content-inner{transition:opacity .32s ease}
.pkg-content-inner.is-fading{opacity:0;pointer-events:none}
.pkg-tour-main{max-width:760px;margin:0 auto;padding:0}
.pkg-gallery{padding-left:1.25rem;padding-right:1.25rem}
.pkg-faq{padding-top:2rem}
.tour-day-group{margin-bottom:1.75rem}
.tour-day-group:last-child{margin-bottom:0}
.tour-day-label{font-family:var(--font-body);font-size:15px;font-weight:600;letter-spacing:0.05em;color:var(--P);margin-bottom:0.35rem}
.pkg-cta{padding:0 1.25rem 4rem}
.pkg-cta-panel{
  display:grid;grid-template-columns:1fr auto;gap:2.5rem;align-items:center;
  max-width:1200px;margin:0 auto;padding:2.5rem 2.75rem;
  background:linear-gradient(135deg,#0B2A3D 0%,var(--P) 52%,#164E63 100%);
  border-radius:20px;border:1px solid rgba(200,169,106,0.18);
  box-shadow:0 24px 60px rgba(15,40,71,0.14);
}
.pkg-cta-panel .sec-eyebrow{color:rgba(200,169,106,0.88)}
.pkg-cta-panel .sec-title{color:#F8F4EC;margin-bottom:0.65rem}
.pkg-cta-lead{font-size:14px;line-height:1.75;color:rgba(248,244,236,0.62);margin-bottom:1.25rem;max-width:480px}
.pkg-cta-pricing{display:grid;gap:0.2rem}
.pkg-cta-row{display:flex;justify-content:space-between;gap:1rem;font-size:12px;color:rgba(248,244,236,0.78);padding:0.3rem 0}
.pkg-cta-row strong{font-size:13px;color:#F8F4EC;font-weight:600}
.pkg-cta-row--sub{font-size:11px;color:rgba(248,244,236,0.48);padding-bottom:0.45rem;border-bottom:1px solid rgba(248,244,236,0.08)}
.pkg-cta-note{font-size:11px;line-height:1.55;color:rgba(248,244,236,0.42);margin:0.65rem 0 0}
.pkg-cta-action{text-align:center;min-width:200px}
.pkg-cta-from{font-size:11px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:rgba(248,244,236,0.5);margin-bottom:0.85rem}
.pkg-cta-from span{display:block;font-family:var(--font-body);font-size:36px;font-weight:700;letter-spacing:0;color:#F8F4EC;margin-top:0.25rem;text-transform:none;font-variant-numeric:lining-nums tabular-nums}
.pkg-cta-btn{width:100%;justify-content:center;min-width:200px}
.pkg-cta-hint{font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:rgba(248,244,236,0.38);margin:0.85rem 0 0}
.surin-page .tour-page{padding-top:2.5rem}
.surin-page .tour-related-grid{grid-template-columns:repeat(auto-fit,minmax(155px,1fr))}
@media (max-width:960px){
  .pkg-select-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:0.85rem;padding:0.15rem 0 0.35rem;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .pkg-select-grid::-webkit-scrollbar{display:none}
  .pkg-card{flex:0 0 min(78vw,300px);scroll-snap-align:center}
  .pkg-cta-panel{grid-template-columns:1fr;text-align:center;padding:2rem 1.5rem}
  .pkg-cta-lead{margin-left:auto;margin-right:auto}
  .pkg-cta-action{margin:0 auto}
}
@media (max-width:560px){
  .pkg-select{padding:2.25rem 1rem 2.5rem}
  .pkg-card-name{font-size:24px}
  .pkg-cta-from span{font-size:30px}
}

.lux-fleet{background:#08152A;padding:5rem 1.5rem 5.5rem;position:relative;overflow:hidden}
.lux-fleet::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(200,169,106,0.6),transparent)}
.lux-fleet-header{text-align:center;max-width:640px;margin:0 auto 4rem}
.lux-fleet-eyebrow{font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:rgba(200,169,106,0.85);margin-bottom:14px}
.lux-fleet-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4vw,2.9rem);font-weight:600;color:#F8F4EC;line-height:1.2;margin-bottom:14px}
.lux-fleet-sub{font-size:14px;line-height:1.8;color:rgba(248,244,236,0.55)}

.lux-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1140px;margin:0 auto;align-items:start}
.lux-grid--fleet-types{grid-template-columns:repeat(3,minmax(0,1fr));max-width:1140px}

.lux-card{position:relative;background:rgba(255,255,255,0.04);border:1px solid rgba(200,169,106,0.18);border-radius:24px;padding:0 0 1.75rem;overflow:hidden;transition:transform .4s cubic-bezier(.25,.46,.45,.94),border-color .4s,box-shadow .4s;box-shadow:0 8px 32px rgba(0,0,0,0.4);transform-style:preserve-3d;will-change:transform}
.lux-card:hover{border-color:rgba(200,169,106,0.45);box-shadow:0 24px 64px rgba(0,0,0,0.55),0 0 0 1px rgba(200,169,106,0.2);transform:scale(1.03)}

.lux-card--featured{background:rgba(200,169,106,0.07);border-color:rgba(200,169,106,0.4)}
.lux-card--featured:hover{border-color:rgba(200,169,106,0.75)}

.lux-tier{position:absolute;top:16px;left:16px;z-index:3;font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;padding:4px 14px;border-radius:20px;background:rgba(255,255,255,0.08);color:rgba(248,244,236,0.75);border:1px solid rgba(255,255,255,0.18)}
.lux-tier--vip{background:rgba(200,169,106,0.18);color:#C8A96A;border-color:rgba(200,169,106,0.55)}
.lux-vehicles{font-size:10px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:rgba(200,169,106,0.55);margin-bottom:0.45rem}

.lux-img-wrap{position:relative;width:100%;height:220px;overflow:hidden;border-radius:24px 24px 0 0}
.lux-shadow-ground{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:70%;height:28px;background:rgba(0,0,0,0.55);filter:blur(18px);border-radius:50%;z-index:2;transition:width .4s,filter .4s,opacity .4s}
.lux-card:hover .lux-shadow-ground{width:80%;filter:blur(26px);opacity:0.75}
.lux-img{width:100%;height:100%;object-fit:cover;object-position:center 55%;display:block;transition:transform .55s cubic-bezier(.25,.46,.45,.94)}
.lux-card:hover .lux-img{transform:translateY(-12px) scale(1.04)}

.lux-body{padding:1.5rem 1.5rem 0}
.lux-name{font-family:'Cormorant Garamond',serif;font-size:1.55rem;font-weight:600;color:#F8F4EC;margin-bottom:8px}
.lux-desc{font-size:13px;line-height:1.75;color:rgba(248,244,236,0.55);margin-bottom:1.25rem}

.lux-specs{display:flex;flex-direction:column;gap:8px;margin-bottom:1.5rem;padding:1rem 1.1rem;background:rgba(255,255,255,0.04);border-radius:12px;border:1px solid rgba(200,169,106,0.12)}
.lux-spec{display:flex;align-items:center;gap:9px;font-size:12.5px;color:rgba(248,244,236,0.65)}
.lux-spec svg{width:15px;height:15px;flex-shrink:0;color:rgba(200,169,106,0.8)}

.lux-btn{display:block;text-align:center;padding:0.75rem 1.25rem;border-radius:40px;font-size:13px;font-weight:600;letter-spacing:0.04em;text-decoration:none;border:1.5px solid rgba(248,244,236,0.3);color:rgba(248,244,236,0.85);transition:background .3s,border-color .3s,color .3s}
.lux-btn:hover{background:rgba(248,244,236,0.1);border-color:rgba(248,244,236,0.7)}
.lux-btn--gold{border-color:rgba(200,169,106,0.7);color:#C8A96A}
.lux-btn--gold:hover{background:rgba(200,169,106,0.15);border-color:#C8A96A}

/* ── Fleet Showroom (luxury vehicle gallery) ───────────────────── */
fleet-showroom{display:block}
.fs-inner{
  background:#08152A;
  padding:5rem 1.5rem 5.5rem;
  position:relative;
  overflow:hidden
}
.transfers-page fleet-showroom .fs-inner{
  padding-top:3rem;
  border-top:1px solid rgba(200,169,106,0.14)
}
.fs-inner::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(200,169,106,0.55),transparent)
}
.fs-eyebrow{
  font-size:11px;
  font-weight:600;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:rgba(200,169,106,0.88);
  text-align:center;
  margin:0 0 2.25rem
}
.fs-tabs{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:0.5rem;
  max-width:960px;
  margin:0 auto 2.75rem;
  padding:0 0.5rem
}
.fs-tab{
  appearance:none;
  border:1px solid rgba(200,169,106,0.22);
  background:rgba(255,255,255,0.03);
  color:rgba(248,244,236,0.58);
  font-size:10px;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  padding:0.58rem 0.95rem;
  border-radius:999px;
  cursor:pointer;
  white-space:nowrap;
  transition:color .38s ease,border-color .38s ease,background .38s ease,box-shadow .38s ease
}
.fs-tab:hover{
  color:rgba(248,244,236,0.88);
  border-color:rgba(200,169,106,0.42);
  background:rgba(255,255,255,0.06)
}
.fs-tab[aria-selected="true"]{
  color:#C8A96A;
  border-color:rgba(200,169,106,0.62);
  background:rgba(200,169,106,0.1);
  box-shadow:0 0 0 1px rgba(200,169,106,0.12),0 8px 28px rgba(0,0,0,0.28)
}
.fs-tab:focus-visible{
  outline:2px solid rgba(200,169,106,0.75);
  outline-offset:3px
}
.fs-panel{
  max-width:980px;
  margin:0 auto;
  outline:none
}
.fs-panel:focus-visible{
  outline:none
}
.fs-stage{
  display:grid;
  grid-template-columns:1fr;
  align-items:center;
  max-width:980px;
  margin:0 auto
}
.fs-viewport{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  max-height:min(52vh,520px);
  border-radius:4px;
  overflow:hidden;
  background:radial-gradient(ellipse 80% 70% at 50% 58%,#132a45 0%,#08152A 72%,#050d18 100%);
  touch-action:pan-y pinch-zoom;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  user-select:none
}
.fs-spotlight{
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 55% 45% at 50% 62%,rgba(200,169,106,0.11) 0%,rgba(120,165,235,0.04) 42%,transparent 72%);
  pointer-events:none;
  z-index:1
}
.fs-layers{
  position:absolute;
  inset:0;
  z-index:2
}
.fs-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center 72%;
  opacity:0;
  visibility:hidden;
  transform:translateX(0) scale(0.985);
  transition:opacity .42s cubic-bezier(.4,0,.2,1),transform .42s cubic-bezier(.4,0,.2,1),visibility 0s linear .42s;
  filter:drop-shadow(0 22px 38px rgba(0,0,0,0.55));
  will-change:transform,opacity;
  pointer-events:none;
  user-select:none;
  -webkit-user-drag:none;
  z-index:1
}
.fs-layers.is-dragging .fs-img{
  transition:none
}
.fs-layers.is-transitioning .fs-img.is-entering,
.fs-layers.is-transitioning .fs-img.is-exiting,
.fs-img.is-active{
  visibility:visible;
  transition:opacity .42s cubic-bezier(.4,0,.2,1),transform .42s cubic-bezier(.4,0,.2,1),visibility 0s linear 0s;
  z-index:2
}
.fs-layers.is-transitioning .fs-img.is-entering{
  z-index:3
}
.fs-img.is-from-right{
  opacity:0;
  transform:translateX(12%) scale(0.985)
}
.fs-img.is-from-left{
  opacity:0;
  transform:translateX(-12%) scale(0.985)
}
.fs-img.is-to-left{
  opacity:0;
  transform:translateX(-12%) scale(0.985)
}
.fs-img.is-to-right{
  opacity:0;
  transform:translateX(12%) scale(0.985)
}
.fs-img.is-active{
  opacity:1;
  transform:translateX(0) scale(1)
}
.fs-arrow{display:none!important}
.fs-floor{
  position:absolute;
  bottom:8%;
  left:50%;
  transform:translateX(-50%);
  width:62%;
  height:18px;
  background:rgba(0,0,0,0.45);
  border-radius:50%;
  filter:blur(18px);
  z-index:1;
  pointer-events:none
}
.fs-arrow{
  appearance:none;
  flex-shrink:0;
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid rgba(200,169,106,0.28);
  background:rgba(255,255,255,0.04);
  color:rgba(248,244,236,0.72);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:background .32s ease,border-color .32s ease,color .32s ease,transform .32s ease;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px)
}
.fs-arrow svg{width:20px;height:20px}
.fs-arrow:hover:not(:disabled){
  background:rgba(200,169,106,0.12);
  border-color:rgba(200,169,106,0.55);
  color:#C8A96A;
  transform:scale(1.04)
}
.fs-arrow:focus-visible{
  outline:2px solid rgba(200,169,106,0.75);
  outline-offset:3px
}
.fs-arrow:disabled,.fs-arrow[hidden]{opacity:0;pointer-events:none;visibility:hidden}
.fs-name{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.55rem,3.2vw,2.15rem);
  font-weight:500;
  letter-spacing:0.04em;
  color:#F8F4EC;
  text-align:center;
  margin:1.85rem 0 0;
  min-height:1.4em;
  transition:opacity .35s ease
}
.fs-name.is-changing{opacity:0.35}
.fs-swipe-hint{
  display:none;
  text-align:center;
  font-size:9px;
  font-weight:700;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(200,169,106,0.42);
  margin:0.55rem 0 0;
  padding:0 1rem
}
fleet-showroom.fs-has-multi .fs-swipe-hint{display:block}
@media(max-width:900px){
  .fs-inner{padding:3.5rem 1.25rem 4rem}
  .fs-viewport{max-height:min(44vh,400px)}
}
@media(max-width:640px){
  .fs-inner{padding:2.25rem 0 2rem}
  .fs-eyebrow{margin-bottom:1.35rem;font-size:10px}
  .fs-tabs{
    flex-wrap:nowrap;
    justify-content:flex-start;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    gap:0.45rem;
    margin-bottom:1.5rem;
    padding:0 1rem 0.15rem
  }
  .fs-tabs::-webkit-scrollbar{display:none}
  .fs-tab{
    flex:0 0 auto;
    scroll-snap-align:center;
    font-size:10px;
    padding:0.55rem 0.95rem
  }
  .fs-stage{
    grid-template-columns:1fr;
    gap:0
  }
  .fs-panel{position:relative;padding:0 1rem}
  .fs-viewport{
    aspect-ratio:4/3;
    max-height:none;
    border-radius:2px
  }
  .fs-name{
    margin-top:1.25rem;
    font-size:1.45rem
  }
}
@media (prefers-reduced-motion:reduce){
  .fs-img{transition:none;transform:none}
  .fs-img.is-active{transform:none}
  .fs-name{transition:none}
}

@media(max-width:900px){
  .lux-grid{grid-template-columns:1fr;max-width:480px}
  .lux-fleet{padding:3.5rem 1.25rem 4rem}
}
@media(max-width:540px){
  .lux-img-wrap{height:190px}
  .lux-fleet-title{font-size:1.75rem}
}

/* ── Vehicle Viewer Component ───────────────────────────────────── */
vehicle-viewer{display:block}
.vv-wrap{
  position:relative;
  width:100%;
  height:290px;
  background:radial-gradient(ellipse at 50% 52%,#112238 0%,#070F1C 68%);
  border-radius:24px 24px 0 0;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  cursor:grab
}
.vv-wrap:active{cursor:grabbing}
.vv-spotlight{
  position:absolute;
  width:340px;
  height:340px;
  background:radial-gradient(ellipse at center,rgba(200,169,106,0.14) 0%,rgba(120,165,235,0.07) 44%,transparent 70%);
  border-radius:50%;
  top:48%;
  left:50%;
  transform:translate(-50%,-50%);
  transition:transform 0.15s ease;
  pointer-events:none;
  z-index:1
}
.vv-vehicle{
  position:relative;
  z-index:2;
  width:92%;
  max-width:520px;
  height:auto;
  margin-bottom:16px;
  transform:perspective(900px) translateY(-8px);
  filter:drop-shadow(0 18px 28px rgba(0,0,0,0.65));
  will-change:transform
}
.vv-ground{
  position:absolute;
  bottom:8px;
  left:50%;
  transform:translateX(-50%);
  width:72%;
  height:22px;
  background:rgba(0,0,0,0.55);
  border-radius:50%;
  filter:blur(16px);
  z-index:1;
  transition:width .4s,filter .4s;
  pointer-events:none
}
.lux-card:hover .vv-ground{width:82%;filter:blur(22px)}
/* ── Services Section (3-card premium layout) ───────────────────── */
.svc-header{max-width:680px;margin:0 auto 2rem;text-align:center}
.svc-headline{font-family:'Cormorant Garamond',serif;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:600;color:#F5F2EC;line-height:1.18;margin-bottom:0.75rem}
.svc-lead{font-size:13px;line-height:1.75;color:rgba(245,242,236,0.50)}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;margin:0 auto;width:100%;min-width:0;align-items:stretch}

.svc-card{display:flex;flex-direction:column;height:100%;min-width:0;padding:1.8rem 1.6rem 1.6rem;background:rgba(255,255,255,0.04);border:1px solid rgba(200,169,106,0.14);border-radius:18px;text-decoration:none;color:inherit;transition:transform .38s cubic-bezier(.25,.46,.45,.94),border-color .38s,box-shadow .38s,background .38s}
.svc-card:hover{transform:translateY(-5px);border-color:rgba(200,169,106,0.38);box-shadow:0 22px 52px rgba(0,0,0,0.38);background:rgba(255,255,255,0.07)}
.svc-card--vip{border-color:rgba(200,169,106,0.22)}
.svc-card--vip:hover{border-color:rgba(200,169,106,0.55);box-shadow:0 22px 52px rgba(0,0,0,0.42),0 0 0 1px rgba(200,169,106,0.18)}

.svc-icon-wrap{width:46px;height:46px;border-radius:12px;background:rgba(200,169,106,0.09);border:1px solid rgba(200,169,106,0.20);display:flex;align-items:center;justify-content:center;color:rgba(200,169,106,0.75);margin-bottom:1.6rem;flex-shrink:0;transition:background .38s,border-color .38s}
.svc-card:hover .svc-icon-wrap{background:rgba(200,169,106,0.17);border-color:rgba(200,169,106,0.45)}
.svc-icon-wrap--vip{background:rgba(200,169,106,0.14);border-color:rgba(200,169,106,0.35);color:#C8A96A}
.svc-card--vip:hover .svc-icon-wrap--vip{background:rgba(200,169,106,0.24);border-color:rgba(200,169,106,0.6)}

.svc-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:#F0EDE6;line-height:1.2;margin-bottom:0.55rem}
.svc-title::after{content:'';display:block;width:26px;height:1px;background:rgba(200,169,106,0.40);margin-top:0.65rem}

.svc-desc{font-size:13px;line-height:1.75;color:rgba(245,242,236,0.46);margin:1rem 0 1.4rem;flex:1}

.svc-includes{list-style:none;padding:0;margin:0 0 1.75rem;display:flex;flex-direction:column;gap:0.5rem}
.svc-includes li{font-size:12px;letter-spacing:0.03em;color:rgba(245,242,236,0.60);padding-left:1.1rem;position:relative}
.svc-includes li::before{content:'·';position:absolute;left:0;color:rgba(200,169,106,0.65);font-size:18px;line-height:0.85;top:2px}

.svc-cta{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:rgba(200,169,106,0.72);border-bottom:1px solid rgba(200,169,106,0.28);padding-bottom:2px;width:fit-content;transition:color .3s,border-color .3s;margin-top:auto}
.svc-card:hover .svc-cta{color:#C8A96A;border-color:rgba(200,169,106,0.62)}

/* Services grid — container-aware (iframe preview + real devices) */
@container catalog (max-width:767px){
  .svc-grid{grid-template-columns:1fr;gap:1.15rem;max-width:100%}
  .svc-header{margin-bottom:2.25rem;padding:0 0.15rem}
  .svc-headline{font-size:clamp(1.65rem,6vw,2rem)}
  .svc-lead{font-size:13.5px;line-height:1.7;padding:0 0.25rem}
  .svc-card{padding:1.65rem 1.45rem 1.45rem;border-radius:18px}
  .svc-card:hover{transform:none}
  .svc-icon-wrap{width:44px;height:44px;margin-bottom:1.15rem}
  .svc-title{font-size:1.45rem}
  .svc-desc{font-size:14px;line-height:1.62;color:rgba(245,242,236,0.58);margin:0.75rem 0 1rem}
  .svc-includes{margin-bottom:1.15rem;gap:0.35rem}
  .svc-includes li{font-size:12.5px;line-height:1.45}
  .catalog-page{padding:3rem 1.15rem 3.5rem}
}
@container catalog (min-width:768px) and (max-width:1023px){
  .svc-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}
  .svc-card{padding:2rem 1.65rem 1.75rem}
  .svc-card:last-child{grid-column:1/-1;max-width:520px;justify-self:center;width:100%}
}
@container catalog (min-width:1024px){
  .svc-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem}
}

/* Viewport fallback when container queries unsupported */
@media (max-width:1023px){
  .svc-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}
  .svc-card:last-child{grid-column:1/-1;max-width:520px;justify-self:center;width:100%}
}
@media (max-width:767px){
  .svc-grid{grid-template-columns:1fr;gap:1.15rem;max-width:100%}
  .svc-header{margin-bottom:2.25rem}
  .svc-card{padding:1.65rem 1.45rem 1.45rem;border-radius:18px}
  .svc-card:hover{transform:none}
  .svc-card:last-child{grid-column:auto;max-width:none;justify-self:stretch}
  .svc-desc{font-size:14px;line-height:1.62;margin:0.75rem 0 1rem}
  .catalog-page{padding:3rem 1.15rem 3.5rem}
}
@media (min-width:1024px){
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .svc-card:last-child{grid-column:auto;max-width:none;justify-self:stretch}
}
/* ── Fleet Image Carousel ─────────────────────────────────────── */
fleet-carousel{display:block;width:100%}
.fc-wrap{position:relative;width:100%;height:290px;background:linear-gradient(180deg,#0A1828 0%,#070F1C 100%);border-radius:24px 24px 0 0;overflow:hidden;cursor:default;-webkit-user-select:none;user-select:none}
.fc-track{position:relative;width:100%;height:100%}
.fc-slide{position:absolute;inset:0;opacity:0;transition:opacity 2.5s ease-in-out;pointer-events:none;display:flex;align-items:center;justify-content:center}
.fc-slide.is-active{opacity:1;pointer-events:auto}
.fc-img{width:100%;height:100%;object-fit:contain;display:block;padding:14px 18px;box-sizing:border-box;transition:transform 0.55s ease}
.fc-slide.is-active .fc-img{transform:scale(1)}
.fc-wrap:hover .fc-slide.is-active .fc-img{transform:scale(1.04)}
.fc-label{position:absolute;bottom:10px;left:0;right:0;text-align:center;font-size:10px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgba(200,169,106,0.6);pointer-events:none}
.fc-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:32px;height:32px;background:rgba(7,15,28,0.72);border:1px solid rgba(200,169,106,0.20);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(200,169,106,0.72);padding:0;opacity:0;transition:opacity 0.25s,background 0.25s,border-color 0.25s,color 0.25s;flex-shrink:0}
.fc-wrap:hover .fc-arrow{opacity:1}
.fc-arrow:hover{background:rgba(200,169,106,0.16);border-color:rgba(200,169,106,0.50);color:#C8A96A}
.fc-arrow:focus-visible{outline:2px solid rgba(200,169,106,0.55);outline-offset:2px;opacity:1}
.fc-arrow--prev{left:10px}
.fc-arrow--next{right:10px}
.fc-arrow svg{width:14px;height:14px;flex-shrink:0;display:block}
.fc-counter{position:absolute;top:12px;right:13px;font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:0.10em;color:rgba(200,169,106,0.50);line-height:1;pointer-events:none;font-variant-numeric:lining-nums tabular-nums}
.fc-counter-sep{margin:0 1px;opacity:0.6}
@media(prefers-reduced-motion:reduce){.fc-slide{transition:opacity 0.2s}.fc-img{transition:none}}

/* Live Status Banner Styles */
.live-status-banner-container {
  max-width: 1200px;
  margin: 1.5rem auto 0 auto;
  padding: 0 1.5rem;
  width: 100%;
  box-sizing: border-box;
}

.live-status-banner {
  display: flex;
  align-items: center;
  gap: 16px;
  background: rgba(255, 253, 248, 0.95);
  border: 1px solid rgba(200, 169, 106, 0.3);
  border-radius: 12px;
  padding: 14px 20px;
  box-shadow: 0 4px 20px rgba(14, 51, 72, 0.04);
  font-family: 'DM Sans', sans-serif;
  color: #0e3348;
}

.live-status-icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(37, 211, 102, 0.12);
  color: #25d366;
  flex-shrink: 0;
}

.live-status-icon-wrap.warning {
  background: rgba(212, 154, 0, 0.12);
  color: #d49a00;
}

.live-status-content {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.live-status-title {
  font-weight: 700;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: #0e3348;
  letter-spacing: 0.02em;
}

.live-status-badge {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 20px;
  letter-spacing: 0.05em;
}

.live-status-badge.open {
  background: #e6f9ed;
  color: #1f9d55;
}

.live-status-badge.notice {
  background: #fff8e6;
  color: #b37d00;
}

.live-status-desc {
  font-size: 13px;
  color: #5A7280;
  line-height: 1.45;
  margin: 0;
}

.live-status-desc strong {
  color: #0e3348;
}

@media (max-width: 768px) {
  .live-status-banner-container {
    margin-top: 1rem;
    padding: 0 1.15rem;
  }
  .live-status-banner {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 16px;
  }
  .live-status-icon-wrap {
    width: 36px;
    height: 36px;
  }
}

/* 7-Day Weather Widget Styles */
.weather-widget-container {
  max-width: 1200px;
  margin: 1.5rem auto 0 auto;
  padding: 0 1.5rem;
  width: 100%;
  box-sizing: border-box;
}

.weather-widget {
  background: rgba(255, 253, 248, 0.95);
  border: 1px solid rgba(200, 169, 106, 0.3);
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 4px 20px rgba(14, 51, 72, 0.04);
  color: #0e3348;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
}

.weather-widget.is-loading {
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  color: #5A7280;
  gap: 12px;
}

.weather-loading-spinner {
  width: 28px;
  height: 28px;
  border: 3px solid rgba(200, 169, 106, 0.2);
  border-top-color: var(--A, #c8a96a);
  border-radius: 50%;
  animation: weather-spin 1s linear infinite;
}

@keyframes weather-spin {
  to { transform: rotate(360deg); }
}

.weather-widget.is-error {
  align-items: center;
  justify-content: center;
  padding: 30px 20px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  color: #d43f3f;
  gap: 10px;
}

.weather-retry-btn {
  background: #0e3348;
  color: #ffffff;
  border: none;
  padding: 6px 14px;
  border-radius: 20px;
  font-weight: 700;
  font-size: 11px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: background 0.2s;
}

.weather-retry-btn:hover {
  background: #092230;
}

.weather-widget-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.weather-widget-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 700;
  margin: 0;
  color: #0e3348;
  letter-spacing: 0.01em;
}

.weather-location-toggle {
  display: flex;
  background: rgba(14, 51, 72, 0.05);
  padding: 3px;
  border-radius: 30px;
  border: 1px solid rgba(14, 51, 72, 0.02);
}

.weather-toggle-btn {
  border: none;
  background: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 14px;
  border-radius: 20px;
  cursor: pointer;
  transition: all 0.25s ease;
  color: #5A7280;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.weather-toggle-btn.is-active {
  background: #0e3348;
  color: #ffffff;
  box-shadow: 0 2px 8px rgba(14, 51, 72, 0.15);
}

.weather-forecast-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.weather-day-card {
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(14, 51, 72, 0.04);
  border-radius: 12px;
  padding: 12px 6px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
  transition: transform 0.25s cubic-bezier(0.165, 0.84, 0.44, 1), background 0.25s ease, border-color 0.25s ease;
}

.weather-day-card:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.95);
  border-color: rgba(200, 169, 106, 0.35);
  box-shadow: 0 4px 12px rgba(14, 51, 72, 0.03);
}

.weather-day-name {
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: #0e3348;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.weather-day-icon {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 2px 0;
}

.weather-svg {
  width: 100%;
  height: 100%;
}

/* Weather SVG specific colors */
.sunny-color { color: #f5b800; }
.cloudy-sun-color { color: #d49a00; }
.cloudy-color { color: #8fa3b0; }
.rainy-color { color: #3182ce; }
.storm-color { color: #4a5568; }
.windy-color { color: #718096; }

.weather-day-label {
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  font-weight: 600;
  color: #5A7280;
  line-height: 1.2;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.weather-day-temp {
  font-family: 'DM Sans', sans-serif;
  display: flex;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
}

.temp-max {
  color: #0e3348;
}

.temp-min {
  color: #98a2b3;
}

.weather-widget-footer {
  font-family: 'DM Sans', sans-serif;
  font-size: 9px;
  color: #98a2b3;
  text-align: center;
  border-top: 1px solid rgba(14, 51, 72, 0.06);
  padding-top: 10px;
  margin-top: 2px;
  letter-spacing: 0.02em;
}

/* Mobile swipe scroll for weather cards */
@media (max-width: 900px) {
  .weather-forecast-grid {
    display: flex;
    overflow-x: auto;
    gap: 8px;
    padding-bottom: 8px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  
  .weather-forecast-grid::-webkit-scrollbar {
    height: 4px;
  }
  
  .weather-forecast-grid::-webkit-scrollbar-track {
    background: transparent;
  }
  
  .weather-forecast-grid::-webkit-scrollbar-thumb {
    background: rgba(200, 169, 106, 0.25);
    border-radius: 4px;
  }
  
  .weather-day-card {
    flex: 0 0 92px;
    scroll-snap-align: start;
    padding: 10px 4px;
  }
  
  .weather-widget-header {
    flex-direction: row;
    align-items: center;
  }
}

@media (max-width: 768px) {
  .weather-widget-container {
    margin-top: 1rem;
    padding: 0 1.15rem;
  }
  .weather-widget {
    padding: 14px;
    gap: 12px;
  }
}

/* Weather Widget Hero Overlay Style Modifications */
.hero, .tour-hero {
  position: relative;
}

.weather-widget-hero-overlay {
  position: absolute;
  bottom: 2rem;
  right: 2rem;
  z-index: 10;
  max-width: 380px;
  width: auto;
  margin: 0;
  padding: 0;
}

.weather-widget-hero-overlay .weather-widget {
  background: rgba(7, 15, 28, 0.45);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
  color: #ffffff;
  gap: 10px;
}

.weather-widget-hero-overlay .weather-widget-title {
  color: #ffffff;
  font-size: 16px;
}

.weather-widget-hero-overlay .weather-location-toggle {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.04);
}

.weather-widget-hero-overlay .weather-toggle-btn {
  color: rgba(255, 255, 255, 0.7);
  padding: 4px 10px;
  font-size: 10px;
}

.weather-widget-hero-overlay .weather-toggle-btn.is-active {
  background: #ffffff;
  color: #070f1c;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.weather-widget-hero-overlay .weather-forecast-grid {
  gap: 4px;
}

.weather-widget-hero-overlay .weather-day-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  padding: 8px 2px;
  border-radius: 8px;
  box-sizing: border-box;
}

.weather-widget-hero-overlay .weather-day-card:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-1px);
}

.weather-widget-hero-overlay .weather-day-name {
  color: rgba(255, 255, 255, 0.9);
  font-size: 9px;
}

.weather-widget-hero-overlay .weather-day-icon {
  width: 28px;
  height: 28px;
  margin: 1px 0 2px;
}

.weather-widget-hero-overlay .weather-svg {
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 1px 3px rgba(0, 0, 0, 0.35));
}

.weather-widget-hero-overlay .weather-svg.sunny-color {
  color: #ffd95a;
}

.weather-widget-hero-overlay .weather-svg.cloudy-sun-color {
  color: #ffe08a;
}

.weather-widget-hero-overlay .weather-svg.cloudy-color {
  color: #e8f2fa;
}

.weather-widget-hero-overlay .weather-svg.rainy-color {
  color: #7ec8ff;
}

.weather-widget-hero-overlay .weather-svg.storm-color {
  color: #ffe566;
}

.weather-widget-hero-overlay .weather-svg.windy-color {
  color: #c5e3ff;
}

.weather-widget-hero-overlay .weather-day-label {
  display: none;
}

.weather-widget-hero-overlay .weather-day-temp {
  font-size: 11px;
}

.weather-widget-hero-overlay .temp-max {
  color: #ffffff;
}

.weather-widget-hero-overlay .temp-min {
  color: rgba(255, 255, 255, 0.5);
}

.weather-widget-hero-overlay .weather-widget-footer {
  font-size: 8px;
  color: rgba(255, 255, 255, 0.4);
  border-top-color: rgba(255, 255, 255, 0.08);
  padding-top: 6px;
}

/* Adjustments for loading & error states inside overlay */
.weather-widget-hero-overlay .weather-widget.is-loading,
.weather-widget-hero-overlay .weather-widget.is-error {
  background: rgba(7, 15, 28, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #ffffff;
  padding: 20px;
}

/* Mobile responsive overlay placement */
@media (max-width: 900px) {
  .hero {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: stretch;
    height: auto;
    min-height: min(78vh, 680px);
    max-height: none;
    padding-bottom: 0;
  }

  .hero-inner {
    position: relative;
    z-index: 3;
    padding: 0 1.25rem 0.65rem;
    max-width: 100%;
    flex-shrink: 0;
  }

  .hero-inner .hero-sub {
    margin-bottom: 0.85rem;
  }

  .weather-widget-hero-overlay {
    position: relative;
    bottom: auto;
    left: auto;
    right: auto;
    z-index: 4;
    margin: 0 1rem 0.45rem;
    max-width: none;
    width: auto;
  }

  .weather-widget-hero-overlay .weather-widget {
    padding: 8px 10px;
    gap: 7px;
    border-radius: 12px;
  }

  .weather-widget-hero-overlay .weather-widget-title {
    font-size: 13px;
    line-height: 1.1;
  }

  .weather-widget-hero-overlay .weather-widget-header {
    gap: 8px;
    align-items: center;
  }

  .weather-widget-hero-overlay .weather-toggle-btn {
    padding: 3px 8px;
    font-size: 9px;
  }

  .weather-widget-hero-overlay .weather-forecast-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px;
    overflow: visible;
    padding-bottom: 0;
  }

  .weather-widget-hero-overlay .weather-day-card {
    flex: unset;
    min-width: 0;
    padding: 6px 2px;
    gap: 4px;
    border-radius: 8px;
  }

  .weather-widget-hero-overlay .weather-day-name {
    font-size: 8px;
    letter-spacing: 0.06em;
  }

  .weather-widget-hero-overlay .weather-day-icon {
    width: 26px;
    height: 26px;
  }

  .weather-widget-hero-overlay .weather-day-temp {
    font-size: 10px;
    line-height: 1.15;
  }

  .weather-widget-hero-overlay .weather-widget-footer {
    display: none;
  }

  .hero-dots {
    position: relative;
    right: auto;
    bottom: auto;
    z-index: 4;
    margin: 0 1.25rem 0.75rem;
    align-self: flex-end;
  }
}

@media (max-width: 560px) {
  .hero {
    min-height: min(74vh, 640px);
  }

  .hero-inner {
    padding: 2rem 1.15rem 0.5rem;
  }

  .hero h1 {
    font-size: clamp(1.85rem, 8.5vw, 2.35rem);
    line-height: 1.06;
    margin-bottom: 0.55rem;
  }

  .hero-inner .hero-sub {
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 0.7rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .hero-btns .btn-p {
    padding: 10px 20px;
  }

  .weather-widget-hero-overlay {
    margin: 0 0.85rem 0.35rem;
  }

  .weather-widget-hero-overlay .weather-widget {
    padding: 7px 9px;
    gap: 6px;
  }

  .hero-dots {
    margin: 0 1.15rem 0.65rem;
  }
}

@media (max-width: 480px) {
  .hero-dots {
    bottom: auto !important;
  }
}

/* 🧮 Interactive Transfer Calculator Styles (Premium Warm Gold & Navy Theme) */
.trans-calc-overlap-section {
  position: relative;
  z-index: 15;
  margin: 0 auto 4rem auto; /* Margin-top set to 0 to prevent margin-collapse; spacing handled by parent padding */
  padding: 0 1.5rem;
  box-sizing: border-box;
  width: 100%;
  animation: calcFadeUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes calcFadeUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 768px) {
  .trans-calc-overlap-section {
    margin: 2rem auto !important; /* Reset overlap on mobile */
  }
}

/* 🌟 Premium Two-Column Hero Layout */
.tour-hero--two-col {
  background: #0e3348;
  min-height: 480px;
  padding: 7rem 0 4rem 0;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
}

@media (max-width: 991px) {
  .tour-hero--two-col {
    padding-top: 6rem !important;
    padding-bottom: 3rem !important;
    min-height: auto !important;
  }
  .tour-hero--two-col .container {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  .hero-image-col {
    display: flex;
    justify-content: center;
    width: 100% !important;
  }
}

.trans-calc-widget {
  background: #ffffff; /* Clean white background */
  border: 1px solid rgba(200, 169, 106, 0.25); /* Elegant gold border */
  border-radius: 20px; /* Large rounded corners */
  padding: 28px 32px; /* Plenty of spacing */
  box-shadow: 0 20px 50px rgba(14, 51, 72, 0.12), 0 2px 8px rgba(200, 169, 106, 0.04); /* Soft shadow */
  font-family: 'DM Sans', sans-serif;
  color: #0e3348; /* Signature navy blue */
  width: 100%;
  box-sizing: border-box;
}

.trans-calc-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 6px 0;
  color: #0e3348;
  text-align: center;
  letter-spacing: 0.01em;
}

.trans-calc-subtitle {
  font-size: 13px;
  color: #5A7280;
  margin: 0 0 16px 0;
  text-align: center;
  font-weight: 500;
}

.trans-calc-form {
  display: flex;
  flex-direction: column;
  gap: 10px; /* Tighter gap between rows */
}

.trans-calc-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.trans-calc-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.trans-calc-field > label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  color: #5A7280;
  letter-spacing: 0.05em;
}

.calc-select {
  padding: 10px 12px; /* Flatter padding */
  border-radius: 8px;
  border: 1px solid rgba(200, 169, 106, 0.25); /* Warm gold-tinted border */
  background: #ffffff;
  font-family: inherit;
  font-size: 13px;
  color: #0e3348;
  outline: none;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  width: 100%;
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%230e3348' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'></polyline></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 14px;
  padding-right: 32px;
}

.calc-select option {
  background-color: #ffffff;
  color: #0e3348;
}

.calc-select:focus {
  border-color: #C8A96A; /* Gold focus */
  box-shadow: 0 0 0 3px rgba(200, 169, 106, 0.12);
}

.calc-vehicle-selector {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
  gap: 8px;
}

.calc-vehicle-card {
  border: 1px solid rgba(200, 169, 106, 0.15);
  background: #ffffff;
  border-radius: 10px;
  padding: 10px 12px; /* Flatter card padding */
  text-align: left;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  outline: none;
  font-family: inherit;
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 100%;
  box-sizing: border-box;
  color: #0e3348;
}

.calc-vehicle-card:hover {
  transform: translateY(-2px);
  border-color: rgba(200, 169, 106, 0.4);
  background: #fffdfc;
  box-shadow: 0 4px 12px rgba(200, 169, 106, 0.06);
}

.calc-vehicle-card.is-active {
  border-color: #C8A96A; /* Signature gold border for active vehicle */
  background: rgba(200, 169, 106, 0.06); /* Soft gold background tint */
  box-shadow: 0 0 0 1px #C8A96A, 0 6px 16px rgba(200, 169, 106, 0.1);
}

.calc-vehicle-name {
  font-weight: 700;
  font-size: 13.5px;
  color: #0e3348;
}

.calc-vehicle-desc {
  font-size: 11px;
  color: #5A7280;
  line-height: 1.35;
}

.calc-vehicle-specs {
  display: flex;
  gap: 6px;
  margin-top: auto;
  padding-top: 6px;
}

.calc-vehicle-specs span {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 20px;
  background: #f1f5f9;
  color: #475569;
  letter-spacing: 0.02em;
}

.calc-vehicle-card.is-active .calc-vehicle-specs span {
  background: rgba(200, 169, 106, 0.15);
  color: #9c7b3c;
}

.calc-addons-row {
  display: flex;
  align-items: center;
  margin: 0; /* Removed margin to pull closer */
}

.calc-toggle-label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  position: relative;
  user-select: none;
}

.calc-checkbox {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.calc-toggle-custom {
  position: relative;
  width: 40px; /* Slightly smaller toggle */
  height: 22px;
  background: #e2e8f0;
  border-radius: 34px;
  transition: background 0.25s ease;
  flex-shrink: 0;
}

.calc-toggle-custom::before {
  content: "";
  position: absolute;
  height: 16px;
  width: 16px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  border-radius: 50%;
  transition: transform 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.calc-checkbox:checked + .calc-toggle-custom {
  background-color: #C8A96A; /* Gold active toggle */
}

.calc-checkbox:checked + .calc-toggle-custom::before {
  transform: translateX(18px);
}

.calc-toggle-text {
  font-size: 12.5px;
  font-weight: 700;
  color: #5A7280;
  transition: color 0.2s ease;
}

.calc-checkbox:checked ~ .calc-toggle-text {
  color: #0e3348;
}

.calc-result-box {
  background: #fdfaf4; /* Warm ivory box inside */
  border: 1px solid rgba(200, 169, 106, 0.25);
  border-radius: 12px;
  padding: 10px 18px; /* Tighter padding for flatter design */
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  color: #0e3348;
  margin-top: 2px; /* Moved closer to the vehicle selector */
  box-shadow: none;
}

.calc-price-wrap {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.calc-price-label {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  color: #5A7280;
  letter-spacing: 0.08em;
}

.calc-price-value {
  font-family: 'DM Sans', sans-serif;
  font-size: 28px; /* Slightly smaller for flatter profile */
  font-weight: 700;
  color: #C8A96A; /* Gold color for pricing */
  line-height: 1;
}

.calc-book-btn {
  background: #0e3348; /* Elegant signature navy button */
  color: #ffffff !important;
  border: none;
  padding: 10px 22px; /* Flatter button padding */
  border-radius: 30px;
  font-family: inherit;
  font-size: 13.5px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 4px 14px rgba(14, 51, 72, 0.15);
  text-decoration: none;
}

.calc-book-btn:hover {
  background: #17435d;
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(14, 51, 72, 0.25);
}

.calc-book-btn:active {
  transform: translateY(0);
}

.calc-book-btn svg {
  flex-shrink: 0;
}

/* 📱 Mobile Responsiveness for Calculator */
@media (max-width: 768px) {
  .trans-calc-widget {
    padding: 20px;
    border-radius: 16px;
  }
  
  .trans-calc-title {
    font-size: 24px;
  }
  
  .trans-calc-row {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  
  .calc-vehicle-selector {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  
  .calc-vehicle-card {
    padding: 14px;
  }
  
  .calc-result-box {
    flex-direction: column;
    text-align: center;
    padding: 18px 20px;
    gap: 16px;
  }
  
  .calc-book-btn {
    width: 100%;
  }
}

/* Compact luxury transfer quote card */
.trans-calc-overlap-section {
  margin-bottom: 2.25rem;
}

.trans-calc-widget {
  max-width: 920px;
  margin: 0 auto;
  padding: 20px 24px;
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(248, 242, 232, 0.96));
  border: 1px solid rgba(155, 106, 37, 0.22);
  box-shadow:
    0 18px 44px rgba(8, 21, 42, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.trans-calc-head {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  align-items: center;
  gap: 18px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(14, 51, 72, 0.08);
}

.trans-calc-kicker {
  color: var(--A-ink);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 3px;
}

.trans-calc-title {
  font-size: clamp(24px, 3vw, 32px);
  margin: 0;
  text-align: left;
  color: var(--P);
  letter-spacing: 0;
}

.trans-calc-subtitle {
  margin: 3px 0 0;
  text-align: left;
  font-size: 13px;
  line-height: 1.45;
  color: #5A7280;
  font-style: normal;
}

.calc-trust-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  max-width: 360px;
}

.calc-trust-badges span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(200, 169, 106, 0.11);
  border: 1px solid rgba(200, 169, 106, 0.24);
  color: var(--A-ink);
  font-size: 10.5px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.calc-trust-badges svg {
  width: 12px;
  height: 12px;
}

.trans-calc-form {
  gap: 8px;
}

.trans-calc-row {
  gap: 10px;
}

.trans-calc-field {
  gap: 3px;
}

.trans-calc-field > label {
  font-size: 9px;
  color: rgba(14, 51, 72, 0.62);
  letter-spacing: 0.12em;
}

.calc-select {
  min-height: 42px;
  padding: 9px 34px 9px 12px;
  border-color: rgba(14, 51, 72, 0.1);
  border-radius: 10px;
  background-color: rgba(255, 253, 248, 0.82);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.calc-vehicle-selector {
  gap: 8px;
}

.calc-vehicle-card {
  min-height: 78px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 253, 248, 0.74);
  border-color: rgba(14, 51, 72, 0.09);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.calc-vehicle-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(14, 51, 72, 0.06);
}

.calc-vehicle-card.is-active {
  background: linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(200, 169, 106, 0.12));
  border-color: rgba(155, 106, 37, 0.58);
  box-shadow: inset 0 0 0 1px rgba(155, 106, 37, 0.12), 0 10px 24px rgba(14, 51, 72, 0.06);
}

.calc-vehicle-name {
  font-size: 13px;
}

.calc-vehicle-desc {
  font-size: 10.5px;
}

.calc-vehicle-specs {
  gap: 5px;
  padding-top: 4px;
}

.calc-vehicle-specs span {
  padding: 2px 7px;
  font-size: 8px;
  background: rgba(14, 51, 72, 0.055);
}

.calc-bottom-row {
  display: grid;
  grid-template-columns: minmax(220px, 0.85fr) minmax(360px, 1.15fr);
  gap: 10px;
  align-items: stretch;
}

.calc-addons-row {
  min-height: 56px;
  padding: 10px 12px;
  border: 1px solid rgba(14, 51, 72, 0.08);
  border-radius: 12px;
  background: rgba(255, 253, 248, 0.62);
}

.calc-toggle-text {
  font-size: 12px;
  color: var(--P);
}

.calc-result-box {
  min-height: 56px;
  margin-top: 0;
  padding: 9px 12px 9px 16px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(14, 51, 72, 0.045), rgba(200, 169, 106, 0.11));
}

.calc-price-label {
  font-size: 8.5px;
  color: rgba(14, 51, 72, 0.62);
}

.calc-price-value {
  color: var(--A-ink);
  font-size: clamp(22px, 2.6vw, 30px);
}

.calc-book-btn {
  padding: 10px 20px;
  min-height: 42px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0E3348, #09243A);
  box-shadow: 0 10px 24px rgba(14, 51, 72, 0.18);
}

@media (max-width: 900px) {
  .trans-calc-widget {
    padding: 18px;
  }

  .trans-calc-head,
  .calc-bottom-row {
    grid-template-columns: 1fr;
  }

  .calc-trust-badges {
    justify-content: flex-start;
    max-width: none;
  }
}

@media (max-width: 768px) {
  .calc-vehicle-card {
    min-height: auto;
  }

  .calc-result-box {
    align-items: stretch;
  }
}

/* 🔍 Interactive Tour Search & Filter Bar Styles */
.tour-filter-bar {
  background: rgba(255, 253, 248, 0.96);
  border: 1px solid rgba(200, 169, 106, 0.3);
  border-radius: 16px;
  padding: 20px 24px;
  box-shadow: 0 10px 40px rgba(14, 51, 72, 0.05);
  margin: 0 auto 2.5rem auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
  font-family: 'DM Sans', sans-serif;
  color: #0e3348;
  box-sizing: border-box;
  width: 100%;
  max-width: 960px;
}

.tour-search-wrap {
  position: relative;
  width: 100%;
}

.tour-search-input {
  width: 100%;
  padding: 12px 16px 12px 44px;
  border-radius: 10px;
  border: 1px solid rgba(14, 51, 72, 0.12);
  background: #ffffff;
  font-family: inherit;
  font-size: 13px;
  color: #0e3348;
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.tour-search-input:focus {
  border-color: rgba(200, 169, 106, 0.6);
  box-shadow: 0 0 0 3px rgba(200, 169, 106, 0.1);
}

.tour-search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #98a2b3;
  pointer-events: none;
}

.tour-filters-group {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}

.tour-filter-col {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tour-filter-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  color: #98a2b3;
  letter-spacing: 0.06em;
}

.tour-filter-buttons {
  display: flex;
  gap: 6px;
  background: rgba(14, 51, 72, 0.04);
  padding: 3px;
  border-radius: 30px;
  border: 1px solid rgba(14, 51, 72, 0.02);
}

.tour-filter-btn {
  border: none;
  background: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 14px;
  border-radius: 20px;
  cursor: pointer;
  transition: all 0.25s ease;
  color: #5A7280;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  outline: none;
}

.tour-filter-btn:hover {
  color: #0e3348;
}

.tour-filter-btn.is-active {
  background: #0e3348;
  color: #ffffff;
  box-shadow: 0 2px 8px rgba(14, 51, 72, 0.15);
}

/* Catalog Card transitions for smooth filtering */
.catalog-card {
  transition: opacity 0.35s cubic-bezier(0.165, 0.84, 0.44, 1), transform 0.35s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.35s ease !important;
}

.catalog-card.is-filtered-out {
  opacity: 0;
  transform: scale(0.94);
  pointer-events: none;
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  margin: 0;
  padding: 0;
  border: none;
  box-shadow: none;
}

/* No Results Found Warning */
.tour-no-results {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 50px 20px;
  width: 100%;
  grid-column: 1 / -1;
  color: #98a2b3;
  gap: 12px;
  font-family: 'DM Sans', sans-serif;
}

.tour-no-results p {
  font-size: 14px;
  font-weight: 600;
  color: #5A7280;
  margin: 0;
}

.tour-no-results svg {
  opacity: 0.65;
  color: #5A7280;
}

/* 📱 Mobile Adjustments */
@media (max-width: 768px) {
  .tour-filter-bar {
    padding: 16px;
    margin-bottom: 2rem;
  }
  .tour-filters-group {
    gap: 14px;
    flex-direction: column;
  }
  .tour-filter-buttons {
    width: 100%;
    display: flex;
    justify-content: space-between;
  }
  .tour-filter-btn {
    flex: 1;
    text-align: center;
    padding: 5px 6px;
    font-size: 10px;
  }
}

/* 🌟 Premium Landing Page Custom Styles */
.tour-hero--fullscreen {
  height: 85vh;
  min-height: 640px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  padding-bottom: 4rem;
}

.hero-trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 253, 248, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 6px 14px;
  border-radius: 30px;
  font-size: 11px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.95);
  margin-bottom: 1.25rem;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  text-shadow: none;
}

.hero-trust-badge .stars {
  color: #C8A96A;
  font-size: 12px;
}

/* Scroll Down Indicator Anim */
.hero-scroll-indicator {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: rgba(255, 255, 255, 0.5);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  text-decoration: none;
  transition: color 0.3s;
}

.hero-scroll-indicator:hover {
  color: var(--A);
}

.hero-scroll-indicator-mouse {
  width: 20px;
  height: 32px;
  border: 2px solid currentColor;
  border-radius: 12px;
  position: relative;
}

.hero-scroll-indicator-wheel {
  width: 4px;
  height: 8px;
  background: currentColor;
  border-radius: 2px;
  position: absolute;
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
  animation: hero-scroll-dot-anim 1.6s infinite;
}

@keyframes hero-scroll-dot-anim {
  0% { top: 6px; opacity: 1; }
  50% { top: 14px; opacity: 0; }
  100% { top: 6px; opacity: 1; }
}

/* ── Luxury Fleet Cards for Landing Page ────────────────────────── */
.lux-fleet-section {
  background: #FFFDF8;
  padding: 5rem 1.5rem;
}

.lux-fleet-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  max-width: 1140px;
  margin: 0 auto;
}

.lux-fleet-card {
  background: #ffffff;
  border: 1px solid rgba(200, 169, 106, 0.2);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(14, 51, 72, 0.03);
  transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.lux-fleet-card:hover {
  transform: translateY(-4px);
  border-color: rgba(200, 169, 106, 0.45);
  box-shadow: 0 20px 40px rgba(14, 51, 72, 0.08);
}

.lux-fleet-img-wrap {
  position: relative;
  height: 200px;
  background: radial-gradient(ellipse at center, #112238 0%, #070F1C 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
}

.lux-fleet-img {
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
  filter: drop-shadow(0 10px 15px rgba(0,0,0,0.5));
}

.lux-fleet-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 4px 10px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.9);
  color: #0e3348;
  border: 1px solid rgba(14, 51, 72, 0.1);
}

.lux-fleet-badge.vip {
  background: rgba(200, 169, 106, 0.15);
  color: #9c7b3c;
  border-color: rgba(200, 169, 106, 0.35);
}

.lux-fleet-body {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.lux-fleet-title-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
}

.lux-fleet-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 700;
  color: #0e3348;
}

.lux-fleet-price {
  font-size: 16px;
  font-weight: 700;
  color: #C8A96A;
}

.lux-fleet-price span {
  font-size: 11px;
  color: #5A7280;
  font-weight: 500;
}

.lux-fleet-desc {
  font-size: 12.5px;
  color: #5A7280;
  line-height: 1.6;
  margin-bottom: 1.25rem;
}

.lux-fleet-specs {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 1.5rem;
  padding: 12px;
  background: #fdfaf4;
  border-radius: 10px;
  border: 1px solid rgba(200, 169, 106, 0.12);
}

.lux-fleet-spec {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: #0e3348;
  font-weight: 600;
}

.lux-fleet-spec svg {
  width: 14px;
  height: 14px;
  color: #C8A96A;
}

.lux-fleet-btn {
  display: block;
  text-align: center;
  background: #0e3348;
  color: #ffffff !important;
  border: none;
  padding: 10px 20px;
  border-radius: 30px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: background 0.2s;
}

.lux-fleet-btn:hover {
  background: #17435d;
}

.lux-fleet-btn.vip-btn {
  background: #C8A96A;
}

.lux-fleet-btn.vip-btn:hover {
  background: #bca061;
}

/* 📱 Sticky Mobile Booking CTA */
.sticky-mobile-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #ffffff;
  border-top: 1px solid rgba(14, 51, 72, 0.08);
  padding: 10px 16px;
  display: none;
  z-index: 999;
  box-shadow: 0 -4px 20px rgba(14, 51, 72, 0.08);
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .sticky-mobile-cta {
    display: flex;
  }
  .lux-fleet-grid {
    grid-template-columns: 1fr;
    max-width: 440px;
  }
}

.sticky-cta-info {
  display: flex;
  flex-direction: column;
  line-height: 1.3;
}

.sticky-cta-label {
  font-size: 9px;
  color: #5A7280;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.sticky-cta-stars {
  color: #C8A96A;
  font-size: 10px;
  margin-top: 2px;
}

.sticky-cta-btn {
  background: #0e3348;
  color: #ffffff !important;
  border: none;
  padding: 10px 20px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 6px;
  box-shadow: 0 4px 10px rgba(14, 51, 72, 0.15);
}

.sticky-cta-btn svg {
  flex-shrink: 0;
}


/* PLAN MY TRIP - Quiz Modal (Phase 3) */
body.tp-open { overflow: hidden; }
.tp-overlay {
  position: fixed; inset: 0; z-index: 9900;
  background: rgba(8, 28, 44, 0.82);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px; animation: tp-fade-in 0.25s ease both;
}
@keyframes tp-fade-in { from { opacity: 0; } to { opacity: 1; } }
.tp-modal {
  background: #fff; border-radius: 24px; width: 100%; max-width: 680px;
  max-height: 92vh; overflow-y: auto; position: relative; padding: 40px 40px 32px;
  box-shadow: 0 32px 80px rgba(8,28,44,0.35), 0 0 0 1px rgba(200,169,106,0.15);
  animation: tp-slide-up 0.32s cubic-bezier(0.22,1,0.36,1) both;
  font-family: 'DM Sans', sans-serif;
  scrollbar-width: thin; scrollbar-color: rgba(200,169,106,0.3) transparent;
}
@keyframes tp-slide-up {
  from { opacity: 0; transform: translateY(28px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.tp-close {
  position: absolute; top: 16px; right: 16px; background: rgba(14,51,72,0.06);
  border: none; border-radius: 50%; width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: #0e3348; transition: background 0.18s ease, transform 0.18s ease;
  z-index: 10; padding: 0;
}
.tp-close:hover { background: rgba(14,51,72,0.12); transform: rotate(90deg); }
.tp-header { text-align: center; margin-bottom: 24px; }
.tp-logo-tag { display: inline-block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: #c8a96a; margin-bottom: 10px; }
.tp-title { font-size: 26px; font-weight: 800; color: #0e3348; margin: 0 0 8px; line-height: 1.2; }
.tp-subtitle { font-size: 14px; color: #5A7280; margin: 0; line-height: 1.5; }
.tp-progress-bar { display: flex; align-items: center; gap: 12px; margin-bottom: 28px; }
.tp-progress-track { flex: 1; height: 4px; background: rgba(14,51,72,0.08); border-radius: 99px; overflow: hidden; }
.tp-progress-fill { height: 100%; background: linear-gradient(90deg, #c8a96a, #e8c97a); border-radius: 99px; transition: width 0.4s cubic-bezier(0.22,1,0.36,1); width: 20%; }
.tp-progress-label { font-size: 12px; font-weight: 600; color: #98a2b3; white-space: nowrap; }
.tp-steps-wrap { position: relative; min-height: 280px; overflow: hidden; }
.tp-step { width: 100%; }
.tp-step--enter-right { animation: tp-enter-right 0.28s cubic-bezier(0.22,1,0.36,1) both; }
.tp-step--enter-left  { animation: tp-enter-left  0.28s cubic-bezier(0.22,1,0.36,1) both; }
.tp-step--exit-left   { animation: tp-exit-left   0.25s ease both; position: absolute; top:0;left:0;right:0; }
.tp-step--exit-right  { animation: tp-exit-right  0.25s ease both; position: absolute; top:0;left:0;right:0; }
@keyframes tp-enter-right { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
@keyframes tp-enter-left  { from{opacity:0;transform:translateX(-40px)} to{opacity:1;transform:translateX(0)} }
@keyframes tp-exit-left   { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(-40px)} }
@keyframes tp-exit-right  { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(40px)} }
.tp-step-question { font-size: 17px; font-weight: 700; color: #0e3348; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; line-height: 1.3; }
.tp-step-icon { font-size: 22px; }
.tp-optional-tag { font-size: 11px; font-weight: 600; color: #98a2b3; text-transform: uppercase; letter-spacing: 0.05em; display: block; width: 100%; margin-top: 2px; }
.tp-options { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.tp-options--multi { grid-template-columns: 1fr 1fr; }
.tp-option-card { display: flex; align-items: center; gap: 12px; background: rgba(14,51,72,0.03); border: 1.5px solid rgba(14,51,72,0.1); border-radius: 14px; padding: 14px; cursor: pointer; transition: border-color 0.18s ease, background 0.18s ease, transform 0.15s ease, box-shadow 0.18s ease; text-align: left; position: relative; font-family: inherit; }
.tp-option-card:hover { border-color: rgba(200,169,106,0.5); background: rgba(200,169,106,0.04); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(14,51,72,0.06); }
.tp-option-card.is-selected { border-color: #c8a96a; background: rgba(200,169,106,0.08); box-shadow: 0 0 0 3px rgba(200,169,106,0.15); }
.tp-option-emoji { font-size: 24px; flex-shrink: 0; line-height: 1; }
.tp-option-text { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.tp-option-label { font-size: 13px; font-weight: 700; color: #0e3348; line-height: 1.2; }
.tp-option-desc { font-size: 11px; color: #7a8fa0; line-height: 1.3; }
.tp-option-check { width: 20px; height: 20px; border-radius: 50%; background: #c8a96a; color: #fff; font-size: 11px; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; opacity: 0; transform: scale(0.5); transition: opacity 0.18s ease, transform 0.18s ease; }
.tp-option-card.is-selected .tp-option-check { opacity: 1; transform: scale(1); }
.tp-nav { display: flex; align-items: center; justify-content: flex-end; gap: 12px; margin-top: 24px; padding-top: 20px; border-top: 1px solid rgba(14,51,72,0.07); }
.tp-btn-back { background: none; border: none; font-size: 13px; font-weight: 600; color: #7a8fa0; cursor: pointer; padding: 10px 16px; border-radius: 10px; transition: color 0.18s ease, background 0.18s ease; font-family: inherit; }
.tp-btn-back:hover { color: #0e3348; background: rgba(14,51,72,0.05); }
.tp-btn-next { background: linear-gradient(135deg, #0e3348, #1a4a6b); color: #fff; border: none; border-radius: 12px; padding: 13px 28px; font-size: 14px; font-weight: 700; cursor: pointer; transition: opacity 0.18s, transform 0.15s, box-shadow 0.18s; font-family: inherit; box-shadow: 0 4px 16px rgba(14,51,72,0.2); }
.tp-btn-next:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 8px 24px rgba(14,51,72,0.28); }
.tp-btn-next:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: none; }
.tp-result-overlay { z-index: 9950; }
.tp-result-modal { max-width: 640px; }
.tp-result-header { text-align: center; margin-bottom: 24px; }
.tp-result-icon { font-size: 42px; margin-bottom: 10px; line-height: 1; }
.tp-result-title { font-size: 24px; font-weight: 800; color: #0e3348; margin: 0 0 8px; }
.tp-result-sub { font-size: 14px; color: #5A7280; margin: 0; }
.tp-result-tours { display: flex; flex-direction: column; gap: 10px; margin-bottom: 18px; }
.tp-result-tour { display: flex; align-items: center; gap: 14px; background: linear-gradient(135deg, rgba(14,51,72,0.03), rgba(200,169,106,0.04)); border: 1px solid rgba(200,169,106,0.2); border-radius: 14px; padding: 14px 16px; }
.tp-result-tour-num { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, #c8a96a, #e8c97a); color: #fff; font-size: 13px; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.tp-result-tour-info { flex: 1; min-width: 0; }
.tp-result-tour-name { font-size: 14px; font-weight: 700; color: #0e3348; margin-bottom: 2px; }
.tp-result-tour-desc { font-size: 12px; color: #7a8fa0; line-height: 1.3; }
.tp-result-tour-link { font-size: 12px; font-weight: 700; color: #c8a96a; text-decoration: none; white-space: nowrap; padding: 4px 8px; border-radius: 6px; transition: background 0.18s; }
.tp-result-tour-link:hover { background: rgba(200,169,106,0.1); }
.tp-result-summary { margin-bottom: 20px; }
.tp-summary-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.tp-chip { background: rgba(14,51,72,0.05); border: 1px solid rgba(14,51,72,0.08); border-radius: 99px; padding: 5px 14px; font-size: 12px; font-weight: 600; color: #0e3348; }
.tp-result-actions { display: flex; flex-direction: column; gap: 10px; align-items: center; }
.tp-wa-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; background: linear-gradient(135deg, #25D366, #1ebe59); color: #fff; text-decoration: none; border-radius: 14px; padding: 16px 24px; font-size: 15px; font-weight: 800; transition: transform 0.18s, box-shadow 0.18s; box-shadow: 0 6px 24px rgba(37,211,102,0.3); font-family: inherit; }
.tp-wa-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 32px rgba(37,211,102,0.4); }
.tp-restart-btn { background: none; border: 1.5px solid rgba(14,51,72,0.12); border-radius: 10px; padding: 9px 20px; font-size: 13px; font-weight: 600; color: #7a8fa0; cursor: pointer; transition: color 0.18s, border-color 0.18s; font-family: inherit; }
.tp-restart-btn:hover { color: #0e3348; border-color: rgba(14,51,72,0.25); }
.tp-result-note { text-align: center; font-size: 12px; color: #98a2b3; margin: 16px 0 0; line-height: 1.5; }
@media (max-width: 600px) {
  .tp-modal { padding: 28px 20px 24px; border-radius: 20px; max-height: 95vh; }
  .tp-title { font-size: 21px; }
  .tp-options, .tp-options--multi { grid-template-columns: 1fr; }
  .tp-option-card { padding: 12px; }
  .tp-steps-wrap { min-height: 240px; }
  .tp-step-question { font-size: 15px; }
  .tp-wa-btn { font-size: 14px; padding: 14px 18px; }
  .tp-result-title { font-size: 20px; }
  .tp-result-modal { padding: 28px 20px 24px; }
}

/* Improve small luxury section labels on light backgrounds */
.sec-eyebrow,
.why-bar-label,
.founder-kicker,
.lux-fleet-eyebrow,
.catalog-intro .sec-eyebrow,
.pkg-card-tier,
.tp-logo-tag {
  color: var(--A-ink);
  font-weight: 800;
  letter-spacing: 0.2em;
  text-shadow: 0 1px 0 rgba(255, 253, 248, 0.72);
}

.why-bar--compact .why-bar-label {
  letter-spacing: 0.18em;
}

.weather-widget-hero-overlay .weather-widget-title,
.why-bar--on-dark .why-bar-label,
.pkg-cta-panel .sec-eyebrow,
.tour-hero-tag,
.tour-hero--catalog .tour-hero-tag--eyebrow {
  color: var(--A-light);
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

/* Fix: override display:flex when element has hidden attribute */
.tp-overlay[hidden] { display: none !important; }

/* ── Transfers page — compact mobile luxury layout ─────────────── */
.transfers-page .trans-calc-section--transfers {
  background: #08152A;
  padding: 1.25rem 0 2.25rem;
  position: relative;
  z-index: 10;
}

.transfers-page .trans-calc-overlap-section--transfers {
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}

.transfers-page .transfer-calculator-mount {
  max-width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

.transfers-page .catalog-page--transfers {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.transfers-page .svc-header--transfers {
  margin-bottom: 2rem;
}

.transfers-page .lux-fleet-scroll-hint {
  display: none;
}

@media (max-width: 900px) {
  .transfers-page .tour-hero--transfers {
    min-height: unset;
    height: auto;
    max-height: none;
    padding: calc(var(--logo-h) + 1.6rem) 1.15rem 1.25rem;
  }

  .transfers-page .tour-hero--transfers h1 {
    font-size: clamp(1.75rem, 6.5vw, 2.15rem);
    line-height: 1.08;
    margin-bottom: 0.4rem;
  }

  .transfers-page .tour-hero--transfers .tour-hero-sub {
    font-size: 14px;
    line-height: 1.55;
    margin-bottom: 0.6rem;
  }

  .transfers-page .tour-hero--transfers .tour-hero-meta {
    margin-bottom: 0;
    gap: 0.65rem 1rem;
    font-size: 9px;
  }
}

@media (max-width: 767px) {
  .transfers-page .tour-hero--transfers {
    padding: calc(var(--logo-h) + 1.35rem) 1rem 1rem;
  }

  .transfers-page .tour-hero--transfers .tour-hero-tag {
    font-size: 9px;
    letter-spacing: 0.22em;
    margin-bottom: 0.4rem;
  }

  .transfers-page .tour-hero--transfers h1 {
    font-size: clamp(1.55rem, 7.2vw, 1.85rem);
  }

  .transfers-page .tour-hero--transfers .tour-hero-sub {
    font-size: 12.5px;
    line-height: 1.48;
    margin-bottom: 0.55rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .transfers-page .tour-hero--transfers .tour-hero-meta {
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    gap: 0;
    font-size: 8.5px;
    letter-spacing: 0.11em;
    -webkit-overflow-scrolling: touch;
  }

  .transfers-page .tour-hero--transfers .tour-hero-meta::-webkit-scrollbar {
    display: none;
  }

  .transfers-page .tour-hero--transfers .tour-hero-meta span {
    flex-shrink: 0;
  }

  .transfers-page .tour-hero--transfers .tour-hero-meta span + span::before {
    content: '·';
    margin: 0 0.4rem;
    opacity: 0.55;
  }

  .transfers-page .tour-hero-cta {
    display: none;
  }

  .transfers-page .trans-calc-section--transfers {
    padding: 0.35rem 0 1.35rem;
  }

  .transfers-page .trans-calc-overlap-section--transfers {
    margin: 0 auto !important;
    padding: 0 0.7rem;
  }

  .transfers-page .trans-calc-widget {
    padding: 13px 13px 11px;
    border-radius: 15px;
    box-shadow:
      0 12px 32px rgba(8, 21, 42, 0.16),
      inset 0 1px 0 rgba(255, 255, 255, 0.92);
  }

  .transfers-page .trans-calc-head {
    margin-bottom: 8px;
    padding-bottom: 7px;
    gap: 0;
  }

  .transfers-page .calc-trust-badges {
    display: none;
  }

  .transfers-page .trans-calc-kicker {
    font-size: 8.5px;
    letter-spacing: 0.16em;
    margin-bottom: 1px;
  }

  .transfers-page .trans-calc-title {
    font-size: 1.28rem;
    line-height: 1.15;
  }

  .transfers-page .trans-calc-subtitle {
    display: none;
  }

  .transfers-page .trans-calc-row {
    grid-template-columns: 1fr 1fr;
    gap: 7px;
  }

  .transfers-page .trans-calc-field > label {
    font-size: 8px;
    letter-spacing: 0.1em;
  }

  .transfers-page .calc-select {
    min-height: 36px;
    padding: 6px 26px 6px 9px;
    font-size: 11.5px;
    border-radius: 8px;
  }

  .transfers-page .calc-vehicle-selector {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 7px;
    padding-bottom: 2px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    grid-template-columns: unset;
  }

  .transfers-page .calc-vehicle-selector::-webkit-scrollbar {
    display: none;
  }

  .transfers-page .calc-vehicle-card {
    flex: 0 0 min(62vw, 176px);
    scroll-snap-align: start;
    min-height: auto;
    padding: 9px 10px;
  }

  .transfers-page .calc-vehicle-desc {
    display: none;
  }

  .transfers-page .calc-vehicle-name {
    font-size: 12px;
  }

  .transfers-page .calc-bottom-row {
    gap: 7px;
  }

  .transfers-page .calc-addons-row {
    min-height: auto;
    padding: 7px 9px;
  }

  .transfers-page .calc-toggle-custom {
    width: 36px;
    height: 20px;
  }

  .transfers-page .calc-toggle-custom::before {
    width: 14px;
    height: 14px;
  }

  .transfers-page .calc-checkbox:checked + .calc-toggle-custom::before {
    transform: translateX(16px);
  }

  .transfers-page .calc-toggle-text {
    font-size: 10.5px;
    line-height: 1.25;
  }

  .transfers-page .calc-result-box {
    flex-direction: row;
    align-items: center;
    text-align: left;
    padding: 7px 9px;
    gap: 8px;
  }

  .transfers-page .calc-price-value {
    font-size: 1.25rem;
  }

  .transfers-page .calc-book-btn {
    width: auto;
    flex: 1;
    min-width: 0;
    padding: 8px 10px;
    font-size: 11.5px;
    gap: 5px;
  }

  .transfers-page .calc-book-btn svg {
    width: 15px;
    height: 15px;
  }

  .transfers-page .lux-fleet {
    padding: 2rem 0 1.75rem;
  }

  .transfers-page .lux-fleet-header {
    margin-bottom: 1.1rem;
    padding: 0 1rem;
  }

  .transfers-page .lux-fleet-eyebrow {
    font-size: 9px;
    margin-bottom: 8px;
  }

  .transfers-page .lux-fleet-title {
    font-size: 1.45rem;
    margin-bottom: 5px;
  }

  .transfers-page .lux-fleet-sub {
    font-size: 11.5px;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .transfers-page .lux-grid--fleet-types {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 0.75rem;
    padding: 0 1rem 0.25rem;
    max-width: none;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .transfers-page .lux-grid--fleet-types::-webkit-scrollbar {
    display: none;
  }

  .transfers-page .lux-card {
    flex: 0 0 min(80vw, 288px);
    scroll-snap-align: center;
    border-radius: 18px;
    padding-bottom: 1.15rem;
    transform: none !important;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.35);
  }

  .transfers-page .lux-card:hover {
    transform: none;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.42);
  }

  .transfers-page .fc-wrap {
    height: 150px;
    border-radius: 18px 18px 0 0;
  }

  .transfers-page .lux-tier {
    top: 10px;
    left: 10px;
    font-size: 8.5px;
    padding: 3px 10px;
  }

  .transfers-page .lux-body {
    padding: 0.85rem 1rem 0;
  }

  .transfers-page .lux-vehicles {
    font-size: 9px;
    margin-bottom: 0.3rem;
  }

  .transfers-page .lux-name {
    font-size: 1.12rem;
    margin-bottom: 3px;
    line-height: 1.15;
  }

  .transfers-page .lux-desc {
    font-size: 11px;
    line-height: 1.45;
    margin-bottom: 0.65rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .transfers-page .lux-specs {
    padding: 0.55rem 0.65rem;
    margin-bottom: 0.7rem;
    gap: 4px;
    border-radius: 10px;
  }

  .transfers-page .lux-spec {
    font-size: 10.5px;
    gap: 7px;
  }

  .transfers-page .lux-spec svg {
    width: 13px;
    height: 13px;
  }

  .transfers-page .lux-spec:nth-child(n+3) {
    display: none;
  }

  .transfers-page .lux-btn {
    padding: 0.55rem 0.85rem;
    font-size: 11.5px;
    border-radius: 999px;
  }

  .transfers-page .lux-fleet-scroll-hint {
    display: block;
    text-align: center;
    font-size: 8.5px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(200, 169, 106, 0.42);
    margin: 0.65rem 0 0;
    padding: 0 1rem;
  }

  .transfers-page fleet-showroom .fs-inner {
    padding: 2rem 0 1.75rem;
  }

  .transfers-page fleet-showroom .fs-eyebrow {
    font-size: 9px;
    margin-bottom: 1rem;
    padding: 0 1rem;
  }

  .transfers-page fleet-showroom .fs-tabs {
    margin-bottom: 1.15rem;
  }

  .transfers-page fleet-showroom .fs-viewport {
    aspect-ratio: 4 / 3.2;
  }

  .transfers-page fleet-showroom .fs-name {
    font-size: 1.35rem;
    margin-top: 1rem;
  }

  .transfers-page .catalog-page--transfers {
    padding: 1.5rem 0.85rem 1.75rem;
  }

  .transfers-page .svc-header--transfers {
    margin-bottom: 1rem;
    padding: 0 0.15rem;
  }

  .transfers-page .catalog-page--transfers .sec-eyebrow {
    font-size: 9px;
    margin-bottom: 0.45rem;
  }

  .transfers-page .catalog-page--transfers .svc-headline {
    font-size: 1.35rem;
    margin-bottom: 0.4rem;
  }

  .transfers-page .catalog-page--transfers .svc-lead {
    font-size: 11.5px;
    line-height: 1.55;
  }

  .transfers-page .catalog-page--transfers .svc-grid {
    gap: 0.85rem;
  }

  .transfers-page .catalog-page--transfers .svc-card {
    padding: 1.05rem 1rem 0.95rem;
    border-radius: 14px;
  }

  .transfers-page .catalog-page--transfers .svc-icon-wrap {
    width: 36px;
    height: 36px;
    margin-bottom: 0.7rem;
    border-radius: 10px;
  }

  .transfers-page .catalog-page--transfers .svc-title {
    font-size: 1.2rem;
  }

  .transfers-page .catalog-page--transfers .svc-desc {
    font-size: 12px;
    line-height: 1.5;
    margin: 0.45rem 0 0.55rem;
  }

  .transfers-page .catalog-page--transfers .svc-includes {
    margin-bottom: 0.6rem;
    gap: 0.2rem;
  }

  .transfers-page .catalog-page--transfers .svc-includes li {
    font-size: 11px;
  }

  .transfers-page .why-bar--compact.page-sec {
    padding-top: 0.75rem;
    padding-bottom: 0.85rem;
  }

  .transfers-page .why-bar--compact .why-item {
    padding: 0.65rem 0.55rem;
  }

  .transfers-page .why-bar--compact .why-title {
    font-size: 15px;
  }

  .transfers-page .why-bar--compact .why-desc {
    font-size: 11px;
    line-height: 1.45;
  }
}
