/* Single tour — layout, gallery, lightbox, sidebar, mobile CTA */

/* ── Page head & quick facts ───────────────────────────────────────── */
.st-page-head{padding:20px 0 8px}
.st-title{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:800;color:#000;margin:0 0 10px;line-height:1.2;letter-spacing:-.02em}
.st-dest-rating-row{
  display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:10px 14px;
  margin:0 0 16px;min-width:0;
}
.st-dest-line{
  margin:0;min-width:0;flex:0 1 auto;max-width:100%;font-size:15px;color:#6b7280;
  display:flex;flex-wrap:nowrap;align-items:center;gap:6px;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
}
.st-dest-line .st-dest-link{
  flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  color:#00AA6C;font-weight:600;text-decoration:none;
}
.st-dest-link{color:#00AA6C;font-weight:600;text-decoration:none}
.st-dest-link:hover{text-decoration:underline;color:#007A50}
.st-dest-sep{color:#d1d5db;flex-shrink:0}
.st-dest-label{color:#9ca3af;flex-shrink:0}

.st-rating-inline{display:flex;flex-wrap:nowrap;align-items:center;gap:4px 8px;flex-shrink:0}
.st-rating-inline .st-stars{flex-shrink:0}

.st-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;font-size:14px;color:#6b7280;margin:0 0 20px}
.st-badge{background:#e6f7f0;color:#00AA6C;font-weight:700;font-size:11px;padding:4px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}
/* Match tour card (.tc-dots): green filled dots + gray empty */
.st-stars{display:inline-flex;gap:2px;align-items:center}
.st-stars svg{width:13px;height:13px;display:block}
.st-stars .on{fill:#00AA6C}
.st-stars .off{fill:#d1d5db}
.st-rating-num{font-weight:700;color:#000}
.st-reviews-count{color:#6b7280}
.st-divider{color:#e5e7eb}
.st-provider{color:#6b7280}
.st-provider strong{color:#000;font-weight:600}

.st-quick-facts{
  list-style:none;margin:0 0 8px;padding:0;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:10px;
}
.st-fact{
  background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:12px 14px;
  display:flex;flex-direction:row;align-items:center;gap:12px;min-height:56px;box-sizing:border-box;
  overflow:visible;
}
.st-fact--accent{background:#f0fdf4;border-color:#bbf7d0}
.st-fact__icon{
  flex-shrink:0;width:24px;height:24px;min-width:24px;min-height:24px;
  display:flex;align-items:center;justify-content:center;color:#6b7280;
  overflow:visible;
}
/* Root SVG defaults to overflow:hidden — strokes at viewBox edge get clipped when scaled down */
.st-fact__icon svg{width:100%;height:100%;display:block;overflow:visible}
.st-fact--accent .st-fact__icon{color:#00AA6C}
.st-fact__value{font-size:15px;font-weight:600;color:#000;line-height:1.3;flex:1;min-width:0}
.st-fact--accent .st-fact__value{color:#007A50}

/* ── Gallery mosaic ─────────────────────────────────────────────────── */
.st-gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:4px;border-radius:14px;overflow:hidden;height:min(420px,52vw);margin-bottom:28px}
.st-gallery-item{position:relative;overflow:hidden;cursor:pointer}
.st-gallery-item:focus{outline:2px solid #00AA6C;outline-offset:2px}
.st-gallery-item:first-child{grid-row:1/3}
.st-gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.st-gallery-item:hover img{transform:scale(1.04)}
.st-gallery-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;gap:8px;color:#fff;font-weight:600;font-size:14px;
  transition:background .25s;cursor:pointer;
}
.st-gallery-overlay:hover{background:rgba(0,0,0,.65)}
.st-gallery-overlay svg{width:20px;height:20px}
/* Shown only ≤1023px on hero image — extra mosaic cells / desktop overlay are hidden on small screens */
.st-gallery-overlay--all-mobile{display:none!important}
@media(max-width:1023px){
  .st-gallery-overlay--all-mobile{
    display:flex!important;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:6px;
    inset:auto 10px 10px 10px;
    top:auto;
    height:auto;
    min-height:0;
    padding:10px 12px;
    border-radius:10px;
    font-size:13px;
    font-weight:700;
    line-height:1.2;
    text-align:center;
    background:rgba(0,0,0,.58);
    pointer-events:auto;
  }
  .st-gallery-overlay--all-mobile__text{display:block;max-width:100%}
  .st-gallery-item:first-child .st-gallery-overlay--all-mobile svg{width:22px;height:22px;flex-shrink:0}
}

/* ── Two column ───────────────────────────────────────────────────── */
.st-layout{display:grid;grid-template-columns:1fr;gap:28px 40px;margin-bottom:48px;align-items:start}
.st-content{min-width:0}
.st-aside{min-width:0}

.st-section{margin-bottom:36px}
.st-section--compact{margin-bottom:28px}
.st-section__title{font-size:1.25rem;font-weight:700;color:#000;margin:0 0 14px;line-height:1.25;letter-spacing:-.02em}
.st-content > .st-section .st-section__title{
  padding-bottom:0;margin-bottom:18px;border-bottom:none;
}
/* شريط أخضر فاقع تحت العنوان (محاذي لبداية النص) */
.st-content > .st-section .st-section__title::after{
  content:"";display:block;width:3rem;height:4px;margin-top:10px;
  background:#00AA6C;border-radius:999px;
  box-shadow:0 1px 0 rgba(0,122,80,.25);
}
.st-content > .st-section.st-section--compact .st-section__title{margin-bottom:14px}
.st-content > .st-section.st-section--compact .st-section__title::after{margin-top:8px;height:3px;width:2.5rem}
.st-section--compact .st-section__title{font-size:1.1rem}

.st-proof{display:flex;align-items:flex-start;gap:14px;border:1px solid #e5e7eb;border-radius:12px;padding:16px 18px;margin-bottom:24px;background:#fff}
.st-proof-icon{width:44px;height:44px;border-radius:50%;background:#e6f7f0;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.st-proof-icon svg{width:22px;height:22px;color:#00AA6C;stroke:#00AA6C;fill:none}
.st-proof strong{display:block;color:#000;font-size:15px;margin-bottom:4px}
.st-proof-stat{color:#6b7280;font-size:14px;line-height:1.5}

.st-excerpt{font-size:17px;color:#374151;line-height:1.65;margin:0}

.st-flexibility-lede{font-size:15px;color:#4b5563;line-height:1.65;margin:0 0 10px}
.st-inline-link{display:inline-flex;align-items:center;gap:4px;font-size:14px;font-weight:600;color:#00AA6C;text-decoration:none}
.st-inline-link:hover{text-decoration:underline;color:#007A50}

.st-prose,.st-prose--preline{color:#374151;line-height:1.75;font-size:16px}
.st-prose--preline{white-space:pre-line}
.st-prose p:first-child{margin-top:0}
.st-prose p:last-child{margin-bottom:0}

.st-itin-box{border:1px solid #e5e7eb;border-radius:12px;padding:22px 24px;color:#374151;line-height:1.75;white-space:pre-line;background:#fafafa}

.st-itin-steps{
  list-style:none;margin:0;padding:0;counter-reset:st-itin;
  border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#fafafa;
}
.st-itin-step{
  counter-increment:st-itin;margin:0;padding:14px 18px 14px 52px;border-bottom:1px solid #e5e7eb;
  position:relative;font-size:15px;line-height:1.55;color:#374151;
}
.st-itin-step:last-child{border-bottom:none}
.st-itin-step::before{
  content:counter(st-itin);
  position:absolute;left:16px;top:50%;transform:translateY(-50%);
  width:26px;height:26px;border-radius:50%;background:#00AA6C;color:#fff;
  font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;
}

/* Itinerary — GYG-style timeline (single pin icon per step) */
.st-itin-timeline{margin-top:4px}
.st-itin-tl-wrap{
  position:relative;
  transition:max-height .35s ease;
}
.st-itin-tl-wrap--collapsed{
  max-height:22rem;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(to bottom,#000 58%,transparent 100%);
  mask-image:linear-gradient(to bottom,#000 58%,transparent 100%);
}
.st-itin-tl-list{list-style:none;margin:0;padding:0}
.st-itin-tl-item{
  display:flex;gap:16px;align-items:flex-start;margin:0;
}
.st-itin-tl-rail{
  flex-shrink:0;width:40px;display:flex;flex-direction:column;align-items:center;
}
.st-itin-tl-node{
  width:32px;height:32px;border-radius:50%;background:#fff;border:1px solid #e5e7eb;
  box-shadow:0 1px 4px rgba(0,0,0,.08);
  display:flex;align-items:center;justify-content:center;color:#6b7280;
}
.st-itin-tl-node-svg{width:15px;height:15px;display:block}
.st-itin-tl-dots{
  display:flex;flex-direction:column;gap:5px;padding:10px 0;align-items:center;flex-shrink:0;
}
.st-itin-tl-dot{width:5px;height:5px;border-radius:50%;background:#00AA6C}
.st-itin-tl-tail{
  width:3px;min-height:36px;margin-top:6px;border-radius:2px;
  background:linear-gradient(to bottom,#00AA6C,rgba(0,170,108,.18),transparent);
  flex-shrink:0;
}
.st-itin-tl-body{flex:1;min-width:0;padding-bottom:18px}
.st-itin-tl-item:last-child .st-itin-tl-body{padding-bottom:0}
.st-itin-tl-title{
  margin:0 0 4px;font-size:15px;font-weight:700;color:#1C1C2E;line-height:1.35;
}
.st-itin-tl-sub{margin:0;font-size:14px;color:#6b7280;line-height:1.45}
.st-itin-tl-more{
  margin-top:14px;padding:0;background:none;border:none;font:inherit;
  font-weight:700;font-size:15px;color:#1C1C2E;text-decoration:underline;cursor:pointer;
  text-align:left;
}
.st-itin-tl-more:hover,.st-itin-tl-more:focus-visible{color:#00AA6C;outline:none}

/* Experience: long post content — same collapse pattern as itinerary */
.st-exp-wrap{position:relative;transition:max-height .35s ease}
.st-exp-wrap--collapsed{
  max-height:22rem;overflow:hidden;
  -webkit-mask-image:linear-gradient(to bottom,#000 58%,transparent 100%);
  mask-image:linear-gradient(to bottom,#000 58%,transparent 100%);
}
.st-exp-more{
  margin-top:14px;padding:0;background:none;border:none;font:inherit;
  font-weight:700;font-size:15px;color:#1C1C2E;text-decoration:underline;cursor:pointer;
  text-align:left;
}
.st-exp-more:hover,.st-exp-more:focus-visible{color:#00AA6C;outline:none}

/* Itinerary + map: stacked by default; two columns from 1024px (desktop) */
.st-itin-map-layout__aside{margin-top:20px}
.st-itin-map-frame{
  border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#e5e7eb;
  aspect-ratio:4/3;max-height:420px;
}
.st-itin-map-frame__iframe{display:block;width:100%;height:100%;min-height:240px;border:0}

.st-inc-grid{display:grid;grid-template-columns:1fr;gap:28px}
.st-inc-col__title{font-size:15px;font-weight:700;color:#000;margin:0 0 12px}
.st-list-row{display:flex;gap:10px;margin-bottom:10px;font-size:15px;color:#374151;align-items:flex-start}
.st-list-row:last-child{margin-bottom:0}
.st-list-row svg{width:20px;height:20px;flex-shrink:0;margin-top:2px}
.st-list-row .inc{stroke:#00AA6C;fill:none}
.st-list-row .exc{stroke:#ef4444;fill:none}

.st-box{border:1px solid #e5e7eb;border-radius:12px;padding:20px;background:#fff}
.st-meeting-box{display:flex;gap:14px;align-items:flex-start}
.st-meeting-icon{width:24px;height:24px;flex-shrink:0;stroke:#00AA6C;fill:none}
.st-meeting-text{margin:0;color:#374151;font-size:15px;line-height:1.6}

.st-full-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.st-full-gallery__link{display:block;border-radius:12px;overflow:hidden;border:1px solid #e5e7eb;cursor:pointer;transition:box-shadow .2s}
.st-full-gallery__link:hover{box-shadow:0 4px 14px rgba(0,0,0,.08)}
.st-full-gallery__link:focus{outline:2px solid #00AA6C;outline-offset:2px}
.st-full-gallery img{width:100%;height:160px;object-fit:cover;display:block;transition:transform .35s}
.st-full-gallery__link:hover img{transform:scale(1.04)}

/* ── Sidebar & mobile booking drawer ─────────────────────────────── */
.st-booking-drawer-backdrop{display:none}
.st-booking-drawer-header{display:none}
.st-booking-drawer-panel{display:block}
/* Inner sticky removed on desktop — .st-aside is sticky so the whole column follows scroll */
.st-sidebar{position:relative}

/* Booking card — sidebar / drawer: stronger contrast & readable sizes */
.st-booking-card{
  border:1px solid #e5e7eb;border-radius:12px;padding:24px;background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.06);
}
.st-booking-card__price-old{
  font-size:14px;color:#6b7280;text-decoration:line-through;margin:0 0 4px;font-weight:500;
}
.st-booking-card__price-now{
  font-size:28px;font-weight:700;color:var(--te-price-color,#c72a3d);line-height:1.2;letter-spacing:-.02em;
}
.st-booking-card__price-per{
  font-size:13px;font-weight:500;color:#4b5563;margin:6px 0 20px;line-height:1.45;
}
.st-booking-card__offer{
  margin:0 0 12px;font-size:13px;font-weight:600;color:#b45309;line-height:1.45;
}
.st-booking-card__icon{
  flex-shrink:0;display:block;color:#00AA6C;
}
.st-booking-card__icon--row{width:18px;height:18px}
.st-booking-card__icon--micro{width:16px;height:16px}
.st-booking-card__icon--footnote{width:14px;height:14px;margin-top:2px;opacity:.95;color:#6b7280}
.st-booking-card__icon--check{width:17px;height:17px;margin-top:1px}
.st-booking-card__label-wrap{
  display:flex;align-items:center;gap:8px;min-width:0;flex:1 1 auto;max-width:min(100%,58%);
}
.st-booking-card__meta{
  margin-bottom:20px;padding:12px 14px;background:#f9fafb;border-radius:10px;border:1px solid #eef0f3;
}
.st-booking-card__row{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:10px 0;border-bottom:1px solid #e5e7eb;font-size:13px;
}
.st-booking-card__row:first-child{padding-top:2px}
.st-booking-card__row--last{border-bottom:none;padding-bottom:2px}
.st-booking-card__label{color:#374151;font-weight:600;min-width:0}
.st-booking-card__value{color:#111827;font-weight:700;text-align:right}
.st-booking-card__value--ok{color:#00AA6C}
.st-booking-card__cta{
  width:100%;padding:14px 16px;background:#FF6B35;color:#fff;border-radius:8px;
  text-decoration:none;font-weight:600;font-size:15px;margin-bottom:12px;box-sizing:border-box;
}
.st-booking-card__micro{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 14px;
  font-size:13px;font-weight:500;color:#4b5563;line-height:1.55;margin-bottom:16px;
}
.st-booking-card__micro-item{display:inline-flex;align-items:center;gap:6px}
.st-booking-card__micro-dot{color:#9ca3af;font-weight:600}
.st-booking-card__widget{margin-top:16px;border-top:1px solid #e5e7eb;padding-top:16px}
.st-booking-card__widget-title{
  font-size:13px;font-weight:600;color:#374151;margin:0 0 10px;text-align:center;line-height:1.4;
}
.st-booking-card__footnote{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:6px;
  text-align:center;margin:12px 0 0;font-size:12px;font-weight:500;color:#6b7280;line-height:1.5;
}
.st-booking-card__footnote span{max-width:100%}
.st-booking-card .st-policies{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}
.st-booking-card .st-trust .t-sub{font-size:13px;color:#4b5563;line-height:1.5}
.st-booking-card__features{
  margin-top:16px;font-size:13px;font-weight:500;color:#374151;line-height:1.55;
}
.st-booking-card__feature-line{
  display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;
}
.st-booking-card__feature-line:last-child{margin-bottom:0}
.st-booking-card__feature-line span{min-width:0}

.st-price-card{border:1px solid #e5e7eb;border-radius:14px;padding:22px 20px;margin-bottom:16px;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.st-price-old{font-size:14px;color:#9ca3af;text-decoration:line-through;margin:0 0 4px}
.st-price-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.st-price-now{font-size:clamp(1.75rem,3vw,2rem);font-weight:800;color:var(--te-price-color,#c72a3d)}
.st-price-per{font-size:14px;color:#6b7280}
.st-offer{font-size:12px;color:#ea580c;font-weight:600;margin:0 0 14px;line-height:1.4}
.st-cta{
  display:block;width:100%;box-sizing:border-box;background:#00AA6C;color:#fff;font-weight:700;font-size:16px;text-align:center;
  padding:14px 16px;border-radius:12px;text-decoration:none;transition:background .2s;border:none;cursor:pointer;margin-bottom:16px;
}
.st-cta:hover{background:#007A50;color:#fff}
.st-policies{padding-top:4px;border-top:1px solid #f3f4f6;margin-top:4px}
.st-trust{display:flex;gap:10px;margin-bottom:14px;font-size:14px}
.st-trust:last-child{margin-bottom:0}
.st-trust svg{width:20px;height:20px;flex-shrink:0;stroke:#00AA6C;fill:none;margin-top:2px}
.st-trust .t-title{font-weight:600;color:#000;margin:0;font-size:14px}
.st-trust .t-sub{font-size:12px;color:#6b7280;margin:4px 0 0;line-height:1.45}

/* ── Lightbox ─────────────────────────────────────────────────────── */
.lb-overlay{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);align-items:center;justify-content:center;flex-direction:column}
.lb-overlay.active{display:flex}
.lb-close{position:absolute;top:16px;right:20px;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:28px;cursor:pointer;z-index:10;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s;line-height:1}
.lb-close:hover{background:rgba(255,255,255,.2)}
.lb-counter{position:absolute;top:22px;left:20px;color:#fff;font-size:14px;font-weight:600}
.lb-img-wrap{max-width:92vw;max-height:78vh;display:flex;align-items:center;justify-content:center;padding:0 56px}
.lb-img-wrap img{max-width:100%;max-height:78vh;object-fit:contain;border-radius:8px;display:block}
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;font-size:28px;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lb-arrow:hover{background:rgba(255,255,255,.25)}
.lb-prev{left:12px}
.lb-next{right:12px}
.lb-thumbs{display:flex;gap:8px;margin-top:16px;overflow-x:auto;max-width:92vw;padding:6px 0 12px}
.lb-thumbs img{width:68px;height:52px;object-fit:cover;border-radius:8px;cursor:pointer;border:2px solid transparent;opacity:.55;transition:opacity .2s,border-color .2s;flex-shrink:0}
.lb-thumbs img.active{border-color:#00AA6C;opacity:1}
.lb-thumbs img:hover{opacity:1}

/* ── Mobile sticky CTA ────────────────────────────────────────────── */
.st-mobile-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:40;
  background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -4px 20px rgba(0,0,0,.06);
  padding:10px 0;box-sizing:border-box;padding-bottom:max(10px,env(safe-area-inset-bottom));
}
a.st-mobile-cta--bar-link{
  text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent;
  cursor:pointer;
}
a.st-mobile-cta--bar-link:visited{color:inherit}
a.st-mobile-cta--bar-link:focus-visible{outline:2px solid #00AA6C;outline-offset:2px}
.st-mobile-cta__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%}
.st-mobile-cta__price{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px}
.st-mobile-cta__label{font-size:12px;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em}
.st-mobile-cta__amount{font-size:20px;font-weight:800;color:#000}
.st-mobile-cta__unit{font-size:12px;color:#6b7280}
.st-mobile-cta__btn{
  flex-shrink:0;background:#00AA6C;color:#fff;font-weight:700;font-size:15px;padding:12px 22px;border-radius:12px;text-decoration:none;
  transition:background .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-sizing:border-box;
}
a.st-mobile-cta--bar-link:hover .st-mobile-cta__btn{background:#007A50;color:#fff}
.st-mobile-cta__btn:hover{background:#007A50;color:#fff}
.st-mobile-cta__btn--gyg{
  font-size:11px;
  line-height:1.25;
  padding:10px 10px;
  max-width:62%;
  text-align:left;
  white-space:normal;
  justify-content:flex-start;
}
.st-gyg-main-cta{transition:background .2s}
.st-gyg-main-cta:hover{background:#ff8248!important}

/* ── Responsive ───────────────────────────────────────────────────── */
@media(min-width:768px){
  .st-inc-grid{grid-template-columns:1fr 1fr}
  .st-full-gallery{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:1024px){
  .st-itin-map-layout{
    display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,380px);
    gap:32px 40px;align-items:start;
  }
  .st-itin-map-layout__aside{margin-top:0}
  .st-itin-map-frame{
    position:sticky;top:88px;max-height:min(420px,calc(100vh - 120px));
  }
  .st-layout{grid-template-columns:minmax(0,1fr) minmax(280px,380px)}
  .st-page-head{padding-top:8px}
  /* Whole booking column sticks under header while main content scrolls */
  .st-aside{
    position:sticky;
    top:88px;
    align-self:start;
  }
}
@media(max-width:1023px){
  .st-layout{display:block}
  /* Keep 2×2 mosaic: two explicit rows so the large cell gets real height */
  .st-gallery{
    height:min(300px,48vw);
    grid-template-columns:1fr 1fr;
    grid-template-rows:1fr 1fr;
  }
  .st-gallery-item:first-child{grid-row:1/3}
  .st-gallery-item:nth-child(n+4){display:none}
  .st-aside{
    position:fixed;inset:0;z-index:55;pointer-events:none;
  }
  .st-aside.st-booking-open{pointer-events:auto}
  .st-booking-drawer-backdrop{
    display:block;position:absolute;inset:0;background:rgba(0,0,0,.45);
    opacity:0;transition:opacity .25s ease;pointer-events:none;
  }
  .st-aside.st-booking-open .st-booking-drawer-backdrop{
    opacity:1;pointer-events:auto;
  }
  .st-booking-drawer-panel{
    position:absolute;top:0;right:0;bottom:0;width:min(100%,420px);max-width:100%;
    background:#fff;box-shadow:-8px 0 32px rgba(0,0,0,.12);
    display:flex;flex-direction:column;overflow:hidden;
    transform:translateX(100%);transition:transform .28s ease;
  }
  .st-aside.st-booking-open .st-booking-drawer-panel{transform:translateX(0)}
  .st-booking-drawer-header{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    flex-shrink:0;padding:14px 16px;padding-top:max(14px,env(safe-area-inset-top));
    border-bottom:1px solid #e5e7eb;background:#fff;
  }
  .st-booking-drawer-title{font-size:17px;font-weight:700;color:#000}
  .st-booking-drawer-close{
    flex-shrink:0;width:44px;height:44px;border:none;border-radius:10px;
    background:#f3f4f6;color:#374151;font-size:26px;line-height:1;cursor:pointer;
    display:flex;align-items:center;justify-content:center;padding:0;
    transition:background .2s;
  }
  .st-booking-drawer-close:hover{background:#e5e7eb}
  .st-booking-drawer-panel .st-sidebar{
    position:static;top:auto;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;
    padding:0 16px 24px;padding-bottom:max(24px,env(safe-area-inset-bottom));
  }
  /* Sticky bar already shows price + Book — hide duplicate block; keep policies + form in drawer */
  .st-booking-drawer-panel .st-price-card-top{display:none}
  .st-booking-drawer-panel .st-price-card:not(:has(.st-trust)){display:none}
  .st-mobile-cta{display:block}
  #st-tour-main{padding-bottom:72px}
}
@media(max-width:1023px) and (prefers-reduced-motion:reduce){
  .st-booking-drawer-backdrop,.st-booking-drawer-panel{transition:none}
}
@media(max-width:640px){
  .st-dest-rating-row{gap:6px;margin-bottom:14px}
  .st-dest-line{font-size:14px}
  .st-rating-inline{gap:3px 6px}
  .st-rating-inline .st-stars svg{width:11px;height:11px}
  .st-rating-inline .st-rating-num{font-size:14px}
  .st-rating-inline .st-reviews-count{font-size:11px;white-space:nowrap}
  /*
   * Single-column hero: must use ONE grid row. Two 1fr rows + only one item
   * leaves a phantom row and collapses the image cell (img height:100% → 0).
   */
  .st-gallery{
    height:min(240px,62vw);
    min-height:200px;
    grid-template-columns:1fr;
    grid-template-rows:1fr;
  }
  .st-gallery-item:first-child{
    grid-row:1 / -1;
    min-height:0;
    align-self:stretch;
    position:relative;
  }
  .st-gallery-item:nth-child(n+2){display:none}
  /* Absolute fill — iOS/Safari often fails img{height:100%} inside grid auto rows */
  .st-gallery-item:first-child img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  .st-quick-facts{grid-template-columns:repeat(2,1fr);gap:6px}
  .st-fact{padding:8px 10px;min-height:0;gap:8px;border-radius:8px}
  /* 14px box + default svg overflow clipped strokes; keep modest size but readable */
  .st-fact__icon{width:20px;height:20px;min-width:20px;min-height:20px}
  .st-fact__value{font-size:12px;line-height:1.25;font-weight:600}
}
