/* =========================================================
   LIVEABOARD TYPOGRAPHY – MAIN CONTENT ONLY
   Sidebar is excluded by design
   ========================================================= */

#page_wrapper.liveaboard-page #main{
  font-size:16px;
  line-height:1.7;
  color:#1f2d3d;
}

#page_wrapper.liveaboard-page #main p,
#page_wrapper.liveaboard-page #main li{
  font-size:16px;
  line-height:1.7;
}

#page_wrapper.liveaboard-page #main h1{
  font-size:28px;
  font-weight:900;
}

#page_wrapper.liveaboard-page #main h2{
  font-size:23px;
  font-weight:800;
}

#page_wrapper.liveaboard-page #main h3{
  font-size:19px;
  font-weight:800;
}

#page_wrapper.liveaboard-page #main h4{
  font-size:17px;
  font-weight:700;
}

/* =========================================================
   LIVEABOARD PAGES – Resort-style styling (CLEAN SINGLE FILE)
   Scope: #page_wrapper.liveaboard-page
   ========================================================= */

/* =========================================================
   Variables
   ========================================================= */
#page_wrapper.liveaboard-page{
  --card-radius: 18px;
  --card-border: 1px solid #e6e9ef;
  --card-shadow: 0 10px 30px rgba(17,24,39,0.08);

  --text: #1f2d3d;
  --muted: #566173;
  --blue: #1b4dd7;
  --orange: #f0ad4e;
}

/* =========================================================
   Typography (ONLY inside #content so header/breadcrumbs stay theme)
   ========================================================= */
#page_wrapper.liveaboard-page #content{
  font-size:16px;
  line-height:1.65;
  color:var(--text);
}

#page_wrapper.liveaboard-page #content p,
#page_wrapper.liveaboard-page #content li,
#page_wrapper.liveaboard-page #content .description,
#page_wrapper.liveaboard-page #content .tab-pane{
  font-size:16px !important;
  line-height:1.7 !important;
  color:var(--text);
  font-weight:400 !important;
}

#page_wrapper.liveaboard-page #content h1{ font-size:28px !important; line-height:1.25; font-weight:900 !important; color:#1a2b3c; }
#page_wrapper.liveaboard-page #content h2{ font-size:23px !important; line-height:1.3;  font-weight:800 !important; color:#1a2b3c; }
#page_wrapper.liveaboard-page #content h3{ font-size:19px !important; font-weight:800 !important; color:#1a2b3c; }
#page_wrapper.liveaboard-page #content h4{ font-size:17px !important; font-weight:700 !important; color:#1a2b3c; }

/* =========================================================
   Layout: main + sidebar like resort
   ========================================================= */
#page_wrapper.liveaboard-page #content > .container > .row{
  display:flex !important;
  align-items:flex-start !important;
  gap:24px !important;
}

#page_wrapper.liveaboard-page #content > .container > .row > #main{
  flex:0 0 75% !important;
  max-width:75% !important;
  float:none !important;
}

#page_wrapper.liveaboard-page #content > .container > .row > .sidebar{
  flex:0 0 25% !important;
  max-width:25% !important;
  float:none !important;
}

@media (max-width: 991px){
  #page_wrapper.liveaboard-page #content > .container > .row{
    display:block !important;
  }
  #page_wrapper.liveaboard-page #content > .container > .row > #main,
  #page_wrapper.liveaboard-page #content > .container > .row > .sidebar{
    max-width:100% !important;
    width:100% !important;
  }
}

/* =========================================================
   Gallery: remove square panel behind rounded image
   ========================================================= */
#page_wrapper.liveaboard-page #hotel-main-content,
#page_wrapper.liveaboard-page #hotel-main-content .photo-gallery,
#page_wrapper.liveaboard-page #hotel-main-content .image-carousel{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}

#page_wrapper.liveaboard-page #hotel-main-content .photo-gallery{
  border-radius: var(--card-radius) !important;
  overflow:hidden !important;
}

#page_wrapper.liveaboard-page #hotel-main-content .photo-gallery img{
  border-radius:0 !important; /* container handles rounding */
  display:block !important;
}

#page_wrapper.liveaboard-page #hotel-main-content .image-carousel{
  margin-top:12px !important;
}

#page_wrapper.liveaboard-page #hotel-main-content .image-carousel img{
  border-radius:12px !important;
}

/* =========================================================
   Tabs: resort style
   ========================================================= */
#page_wrapper.liveaboard-page #hotel-features.tab-container{
  margin-top:14px;
}

#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:14px !important;
  border-bottom:1px solid #e6e9ef !important;
  padding:0 0 10px !important;
  margin:0 0 18px !important;
}

#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li{
  float:none !important;
  margin:0 !important;
}

#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li > a{
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  padding:10px 0 !important;
  font-size:15px !important;
  font-weight:700 !important;
  text-transform:none !important;
  color:var(--text) !important;
  position:relative;
}

#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li.active > a,
#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li > a:hover{
  color:var(--blue) !important;
}

#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li.active > a:after{
  content:"";
  position:absolute;
  left:0;
  bottom:-11px;
  width:100%;
  height:2px;
  background:var(--blue);
  border-radius:2px;
}

/* Availability tab: orange like resort "Prices" (NO pill) */
#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li > a[href="#availability"]{
  font-weight:900 !important;
  color:var(--orange) !important;
}

#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li.active > a[href="#availability"]{
  color:var(--orange) !important;
}

#page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li.active > a[href="#availability"]:after{
  background:var(--orange) !important;
}

/* Mobile tabs */
@media (max-width: 767px){
  #page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs{
    gap:10px !important;
    padding-bottom:12px !important;
  }
  #page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li > a{
    padding:10px 12px !important;
    font-size:13px !important;
    line-height:1.2 !important;
  }
  #page_wrapper.liveaboard-page #hotel-features.tab-container > ul.tabs > li > a[href="#availability"]{
    width:100% !important;
    text-align:center !important;
  }
}

/* =========================================================
   Description: rounded card (long description)
   ========================================================= */
#page_wrapper.liveaboard-page #hotel-description .long-description{
  background:#fff !important;
  border: var(--card-border) !important;
  border-radius: var(--card-radius) !important;
  box-shadow: var(--card-shadow) !important;
  padding:22px !important;
}

#page_wrapper.liveaboard-page #hotel-description .long-description h1,
#page_wrapper.liveaboard-page #hotel-description .long-description h2{
  margin-top:0 !important;
}

/* =========================================================
   Sidebar: rounded cards + desktop type smaller
   ========================================================= */
#page_wrapper.liveaboard-page .sidebar article.detailed-logo,
#page_wrapper.liveaboard-page .sidebar .travelo-box,
#page_wrapper.liveaboard-page .sidebar .book-with-us-box{
  background:#fff !important;
  border: var(--card-border) !important;
  border-radius: var(--card-radius) !important;
  box-shadow: var(--card-shadow) !important;
  overflow:hidden !important;
  margin-bottom:16px !important;
}

/* Sidebar main image: rounded corners by clipping the FIGURE */
#page_wrapper.liveaboard-page .sidebar article.detailed-logo figure{
  margin:0 !important;
  border-radius: var(--card-radius) var(--card-radius) 0 0 !important;
  overflow:hidden !important;
  padding:0 !important;
}

#page_wrapper.liveaboard-page .sidebar article.detailed-logo img{
  width:100% !important;
  height:auto !important;
  border-radius:0 !important; /* figure handles rounding */
  display:block !important;
}

#page_wrapper.liveaboard-page .sidebar a.button,
#page_wrapper.liveaboard-page .sidebar a.btn-small.button,
#page_wrapper.liveaboard-page .sidebar .btn-large,
#page_wrapper.liveaboard-page .sidebar button.full-width{
  border-radius:14px !important;
  font-weight:800 !important;
}

/* Desktop sidebar typography smaller (mobile stays theme-ish) */
@media (min-width: 992px){
  #page_wrapper.liveaboard-page .sidebar{ font-size:14px !important; line-height:1.55 !important; }
  #page_wrapper.liveaboard-page .sidebar p,
  #page_wrapper.liveaboard-page .sidebar li{ font-size:13.5px !important; line-height:1.55 !important; }
  #page_wrapper.liveaboard-page .sidebar h2{ font-size:18px !important; font-weight:800 !important; }
  #page_wrapper.liveaboard-page .sidebar h3,
  #page_wrapper.liveaboard-page .sidebar h4{ font-size:14.5px !important; font-weight:800 !important; }
  #page_wrapper.liveaboard-page .sidebar .price,
  #page_wrapper.liveaboard-page .sidebar .trip-price,
  #page_wrapper.liveaboard-page .sidebar .amount{
    font-size:22px !important;
    font-weight:900 !important;
  }
}

/* =========================================================
   Rounded images inside tab panes
   ========================================================= */
#page_wrapper.liveaboard-page #hotel-features .tab-content img,
#page_wrapper.liveaboard-page .travel-story-container img,
#page_wrapper.liveaboard-page .my-trip img,
#page_wrapper.liveaboard-page .guest-review img{
  border-radius:12px !important;
}

#page_wrapper.liveaboard-page #hotel-features .tab-content .travel-story-container,
#page_wrapper.liveaboard-page #hotel-features .tab-content .travel-story-content,
#page_wrapper.liveaboard-page #hotel-features .tab-content .my-trip{
  overflow:visible !important;
}

/* =========================================================
   KSP BLOCK (single card + 2-col grid + proper icons)
   ========================================================= */
#page_wrapper.liveaboard-page .liveaboard-ksp-card{
  background:#fff !important;
  border: var(--card-border) !important;
  border-radius: var(--card-radius) !important;
  box-shadow: var(--card-shadow) !important;
  padding:22px 22px 12px !important;
  margin:0 0 18px !important;
}

#page_wrapper.liveaboard-page .liveaboard-ksp-title{
  margin:0 0 14px !important;
  font-size:22px !important;
  line-height:1.25 !important;
  font-weight:900 !important;
  color:var(--text) !important;
  letter-spacing:-0.2px;
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  gap:16px 24px !important;
}

@media (max-width: 767px){
  #page_wrapper.liveaboard-page .liveaboard-ksp-list{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list > li{
  display:flex !important;
  align-items:flex-start !important;
  gap:14px !important;
  margin:0 !important;
  padding:0 !important;
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list > li > i{
  flex:0 0 28px;
  width:28px;
  height:28px;
  display:inline-block;
  margin-top:2px;
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list > li > i:before{
  content:"";
  display:block;
  width:28px;
  height:28px;
  background-repeat:no-repeat;
  background-position:center;
  background-size:28px 28px;
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list strong{
  display:block;
  font-weight:900;
  font-size:18px;
  line-height:1.25;
  margin:0 0 6px;
  color:var(--text);
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list span{
  display:block;
  font-size:16px;
  line-height:1.6;
  color:var(--muted);
}

/* --- KSP Icons (blue outline, consistent stroke) --- */
#page_wrapper.liveaboard-page .liveaboard-ksp-list i.ksp-boat:before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231b4dd7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 14l2-5h10l6 2.5-6 2.5H3z'/%3E%3Cpath d='M9 9V6h5l2 2v1'/%3E%3Cpath d='M4 17c2 1 4 1 6 0s4-1 6 0 4 1 6 0'/%3E%3Ccircle cx='10' cy='12.2' r='0.6'/%3E%3Ccircle cx='12' cy='12.2' r='0.6'/%3E%3Ccircle cx='14' cy='12.2' r='0.6'/%3E%3C/svg%3E");
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list i.ksp-diver:before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231b4dd7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7.5 10c1.8-1.8 3.2-2.5 4.5-2.5S14.7 8.2 16.5 10'/%3E%3Cpath d='M6.8 12.8c2.2 2 4 2.8 5.2 2.8s3-.8 5.2-2.8'/%3E%3Cpath d='M9.3 10v2'/%3E%3Cpath d='M14.7 10v2'/%3E%3Ccircle cx='19' cy='7' r='1'/%3E%3Ccircle cx='21' cy='9' r='0.9'/%3E%3C/svg%3E");
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list i.ksp-food:before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231b4dd7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='5'/%3E%3Cpath d='M5 7v10'/%3E%3Cpath d='M3.5 7h3'/%3E%3Cpath d='M18 7v10'/%3E%3Cpath d='M20.5 7h-3'/%3E%3Cpath d='M19.5 7v4'/%3E%3C/svg%3E");
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list i.ksp-safety:before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231b4dd7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='8'/%3E%3Ccircle cx='12' cy='12' r='2'/%3E%3Cpath d='M12 2v3'/%3E%3Cpath d='M12 19v3'/%3E%3Cpath d='M2 12h3'/%3E%3Cpath d='M19 12h3'/%3E%3C/svg%3E");
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list i.ksp-crew:before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231b4dd7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 12c0-3 2.5-5 5-5s5 2 5 5'/%3E%3Cpath d='M6 12h12'/%3E%3Cpath d='M7.5 12v2.2c0 1 1 1.8 2.2 1.8h4.6c1.2 0 2.2-.8 2.2-1.8V12'/%3E%3Cpath d='M9 9.5l1.5 1'/%3E%3Cpath d='M15 9.5l-1.5 1'/%3E%3C/svg%3E");
}

#page_wrapper.liveaboard-page .liveaboard-ksp-list i.ksp-bed:before{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231b4dd7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 11V9a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v2'/%3E%3Cpath d='M3 14h18'/%3E%3Cpath d='M4 14v4'/%3E%3Cpath d='M20 14v4'/%3E%3Cpath d='M7 11h5'/%3E%3C/svg%3E");
}

/* =========================================================
   Header/Breadcrumb bar – keep theme sizing/weight
   ========================================================= */
#page_wrapper.liveaboard-page .page-title-container{
  font-size:14px !important;
  line-height:1.2 !important;
}

#page_wrapper.liveaboard-page .page-title-container .page-title .entry-title,
#page_wrapper.liveaboard-page .page-title-container .page-title h2,
#page_wrapper.liveaboard-page .page-title-container .page-title .entry-title a{
  font-size:22px !important;
  font-weight:700 !important;
  letter-spacing:0 !important;
  margin:0 !important;
}

#page_wrapper.liveaboard-page .page-title-container .breadcrumbs,
#page_wrapper.liveaboard-page .page-title-container .breadcrumbs li,
#page_wrapper.liveaboard-page .page-title-container .breadcrumbs a{
  font-size:12px !important;
  font-weight:400 !important;
  text-transform:none !important;
  letter-spacing:0 !important;
}

/* =========================================================
   Sidebar: Includes / Excludes block + italic description
   ========================================================= */
#page_wrapper.liveaboard-page .sidebar .holiday-inclusions{
  font-size:14px;
  line-height:1.45;
}

#page_wrapper.liveaboard-page .sidebar .holiday-inclusions p,
#page_wrapper.liveaboard-page .sidebar .holiday-inclusions li{
  font-size:inherit;
  line-height:inherit;
}

#page_wrapper.liveaboard-page .sidebar .holiday-inclusions h4{
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  margin:12px 0 6px;
}

#page_wrapper.liveaboard-page .sidebar .holiday-inclusions ul.check.features{
  margin:0 0 12px;
}

#page_wrapper.liveaboard-page .sidebar .holiday-inclusions ul.check.features li{
  margin-bottom:6px;
}

/* Web description styling (separate from inclusions so it doesn’t look like “Excludes”) */
#page_wrapper.liveaboard-page .sidebar p.description{
  font-size:14px;
  line-height:1.5;
  color:#555;
  font-style:italic;
  padding-left:12px;
  border-left:3px solid #f0c14b;
  margin-top:16px;
}

/* =========================================================
   Availability tab – Ghazala Explorer card styles (SCOPED)
   ========================================================= */

/* ================
   FULL trips: keep visible but make smaller (hide description panel)
   ================ */
#page_wrapper.liveaboard-page #availability .st-trip-card.full{
  opacity:.55;
  filter:grayscale(.1);
  pointer-events:auto; /* IMPORTANT: so waitlist button is clickable */
}

/* Hide description block on full trips to reduce height */
#page_wrapper.liveaboard-page #availability .st-trip-card.full .st-trip-description{
  display:none !important;
}

/* Tighten padding a touch on full trips */
#page_wrapper.liveaboard-page #availability .st-trip-card.full .st-trip-details{
  padding-top:10px;
  padding-bottom:10px;
}

/* Buttons */
#page_wrapper.liveaboard-page #availability .st-emailtrip-btn,
#page_wrapper.liveaboard-page #availability .st-waitlist-btn{
  display:inline-block;
  padding:8px 14px;
  border-radius:9999px;
  text-decoration:none;
  font-weight:800;
  line-height:1;
}

/* Available email button */
#page_wrapper.liveaboard-page #availability .st-emailtrip-btn{
  background:#0066cc;
  color:#fff;
}
#page_wrapper.liveaboard-page #availability .st-emailtrip-btn:hover{
  background:#004fa3;
}

/* Waitlist button (full trips) */
#page_wrapper.liveaboard-page #availability .st-waitlist-btn{
  background:#f0ad4e;
  color:#1a1a1a;
}
#page_wrapper.liveaboard-page #availability .st-waitlist-btn:hover{
  filter:brightness(.95);
}
/* Keep filters clickable above cards/overlays */
#page_wrapper.liveaboard-page #availability .st-toolbar,
#page_wrapper.liveaboard-page #availability #month-filter{
  position:relative;
  z-index:50;
}

#page_wrapper.liveaboard-page #availability select,
#page_wrapper.liveaboard-page #availability option{
  position:relative;
  z-index:60;
}
/* Grid of cards */
#page_wrapper.liveaboard-page #availability .st-results{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin:10px 0 40px;
}
@media (min-width:900px){
  #page_wrapper.liveaboard-page #availability .st-results{ grid-template-columns:1fr; }
}

/* Card container */
#page_wrapper.liveaboard-page #availability .st-trip-card{
  display:flex; position:relative; cursor:pointer;
  background:#fff; border-radius:16px; overflow:hidden;
  border:1px solid #eef0f4;
  box-shadow:0 6px 14px rgba(12,38,77,.06);
  transition:transform .2s, box-shadow .2s;
}
#page_wrapper.liveaboard-page #availability .st-trip-card:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 26px rgba(12,38,77,.12);
}
#page_wrapper.liveaboard-page #availability .st-trip-card.full{
  opacity:.55; filter:grayscale(.1); pointer-events:none;
}

/* Whole-card link */
#page_wrapper.liveaboard-page #availability .st-card-link{
  position:absolute; inset:0; z-index:1; text-indent:-9999px; overflow:hidden;
}
#page_wrapper.liveaboard-page #availability .st-trip-image,
#page_wrapper.liveaboard-page #availability .st-trip-content{
  position:relative; z-index:2;
}
#page_wrapper.liveaboard-page #availability .st-card-link:focus-visible{
  outline:2px solid #004fa3; outline-offset:3px; border-radius:16px;
}

/* Image column (fixed size) */
#page_wrapper.liveaboard-page #availability .st-trip-image{
  flex:0 0 260px; max-width:260px; height:200px;
  margin:8px 0 8px 8px;
  overflow:hidden; background:#f5f7fb;
  border-radius:12px; display:flex; align-items:stretch;
}
#page_wrapper.liveaboard-page #availability .st-trip-image img{
  display:block; width:100%; height:100%; object-fit:cover;
  border-radius:12px; transition:transform .3s;
}

/* When the image is wrapped in a link, make the link fill the box */
#page_wrapper.liveaboard-page #availability .st-trip-image a{
  display:block;
  width:100%;
  height:100%;
  border-radius:12px;
  overflow:hidden;
}

/* Ensure the img still covers fully inside the link */
#page_wrapper.liveaboard-page #availability .st-trip-image a img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:12px;
}

#page_wrapper.liveaboard-page #availability .st-trip-card:hover .st-trip-image img{
  transform:scale(1.05);
}

/* Content column */
#page_wrapper.liveaboard-page #availability .st-trip-content{
  flex:1; min-height:200px;
  display:flex; flex-direction:column; justify-content:space-between;
  gap:6px; padding:12px 18px; color:#3b3b3b;
}

/* Header split: left title/location, right dates+price+inc flights */
#page_wrapper.liveaboard-page #availability .st-trip-header{
  display:flex; justify-content:space-between; align-items:flex-start; gap:14px;
}
#page_wrapper.liveaboard-page #availability .st-head-left{ flex:1; }
#page_wrapper.liveaboard-page #availability .st-trip-title{
  margin:0 0 4px; font-size:1.15rem; font-weight:700; color:#0d3b66;
}
#page_wrapper.liveaboard-page #availability .st-trip-location{
  margin:0; font-size:.9rem; color:#5a6b7b;
}

/* Right column (stacked) */
#page_wrapper.liveaboard-page #availability .st-head-right{
  display:flex; flex-direction:column; align-items:flex-end; gap:4px; text-align:right;
}
#page_wrapper.liveaboard-page #availability .st-trip-dates{
  background:#f2f5fb; color:#3b587a;
  border-radius:9999px; padding:4px 10px;
  font-weight:600; font-size:.9rem; white-space:nowrap; line-height:1;
}
#page_wrapper.liveaboard-page #availability .st-trip-price{
  font-size:1.2rem; font-weight:800; color:#0b9660; line-height:1.2;
}
#page_wrapper.liveaboard-page #availability .st-incflts{
  font-size:.9rem; color:#566; line-height:1.2;
}

/* Details panel */
#page_wrapper.liveaboard-page #availability .st-trip-details{
  background:#f9fafc;
  border-radius:8px;
  padding:16px;
  margin:12px 0;
}

#page_wrapper.liveaboard-page #availability .st-trip-description{
  font-size:.95rem;
  line-height:1.6;
  color:#333;
}

/* Expand/collapse */
#page_wrapper.liveaboard-page #availability .desc-full{ white-space:pre-wrap; }
#page_wrapper.liveaboard-page #availability .desc-toggle-link{
  color:#0b63d1; cursor:pointer; text-decoration:underline; display:inline-block; margin-top:4px;
}
#page_wrapper.liveaboard-page #availability .desc-toggle-link:hover{ text-decoration:none; }

/* Footer: status + CTA */
#page_wrapper.liveaboard-page #availability .st-trip-footer{
  display:flex; justify-content:flex-end; align-items:center; gap:12px; margin-top:auto;
}
#page_wrapper.liveaboard-page #availability .st-status{ font-size:.95rem; font-weight:700; }
#page_wrapper.liveaboard-page #availability .st-status.limited{ color:#b71c1c; }
#page_wrapper.liveaboard-page #availability .st-status.available{ color:#2e7d32; }

/* CTA pill */
#page_wrapper.liveaboard-page #availability .st-pill-btn{
  display:inline-block; background:#0066cc; color:#fff; padding:8px 14px;
  border-radius:9999px; text-decoration:none; font-weight:700;
}
#page_wrapper.liveaboard-page #availability .st-pill-btn:hover{ background:#004fa3; }
#page_wrapper.liveaboard-page #availability .st-pill-btn:focus{ outline:2px solid #004fa3; outline-offset:2px; }

/* Filters */
#page_wrapper.liveaboard-page #availability #month-filter{
  display:flex; gap:12px; align-items:center; flex-wrap:wrap; margin:10px 0 20px;
}
#page_wrapper.liveaboard-page #availability #month-filter label{
  margin-right:6px; color:#334; font-weight:600;
}
#page_wrapper.liveaboard-page #availability #month-select,
#page_wrapper.liveaboard-page #availability #itinerary-select{
  padding:8px 10px; border:1px solid #d7dde3; border-radius:10px; background:#fff; color:#223; min-width:180px;
}

/* Toolbar container */
#page_wrapper.liveaboard-page #availability .st-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 16px;
  border:1px solid #e7ebf2;
  border-radius:12px;
  background:#f9fafc;
  margin:10px 0 20px;
}

/* Left filters area */
#page_wrapper.liveaboard-page #availability .st-filter{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 14px;
}
#page_wrapper.liveaboard-page #availability .st-filter label{
  font-weight:700;
  color:#1e2430;
}
#page_wrapper.liveaboard-page #availability #month-select,
#page_wrapper.liveaboard-page #availability #itinerary-select{
  padding:8px 10px;
  border:1px solid #d7dde3;
  border-radius:10px;
  background:#fff;
  color:#223;
  min-width:180px;
}

/* Sort pills (right side) */
#page_wrapper.liveaboard-page #availability .st-sort{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
#page_wrapper.liveaboard-page #availability .st-sort-label{
  color:#3a4050;
  font-weight:700;
}
#page_wrapper.liveaboard-page #availability .st-sort-pill{
  display:inline-block;
  padding:8px 14px;
  border-radius:9999px;
  background:#eef2f8;
  color:#223;
  text-decoration:none;
  font-weight:700;
  line-height:1;
  border:1px solid transparent;
}
#page_wrapper.liveaboard-page #availability .st-sort-pill:hover{ background:#e2e8f5; }
#page_wrapper.liveaboard-page #availability .st-sort-pill.active{
  background:#0b63d1;
  color:#fff;
  border-color:#0b63d1;
}

/* Mobile */
@media (max-width:768px){
  #page_wrapper.liveaboard-page #availability .st-trip-card{ flex-direction:column; }
  #page_wrapper.liveaboard-page #availability .st-trip-image{
    max-width:none; width:calc(100% - 16px); height:220px; margin:8px auto 0 auto;
  }
  #page_wrapper.liveaboard-page #availability .st-trip-content{ min-height:auto; padding:12px 16px; }
  #page_wrapper.liveaboard-page #availability .st-trip-header{ flex-direction:column; align-items:flex-start; }
  #page_wrapper.liveaboard-page #availability .st-head-right{
    flex-direction:row; flex-wrap:wrap; align-items:center; gap:8px; text-align:left;
  }
  #page_wrapper.liveaboard-page #availability .st-toolbar{ flex-direction:column; align-items:stretch; }
  #page_wrapper.liveaboard-page #availability .st-sort{ justify-content:flex-start; }
}

/* “Stretch image to full card height” refinements (kept, scoped) */
#page_wrapper.liveaboard-page #availability .st-trip-card{ align-items:stretch; }
#page_wrapper.liveaboard-page #availability .st-trip-image{
  flex:0 0 320px;
  max-width:320px;
  height:auto;
  align-self:stretch;
  margin:16px 0 16px 16px;
  border-radius:12px;
  overflow:hidden;
}
#page_wrapper.liveaboard-page #availability .st-trip-image a,
#page_wrapper.liveaboard-page #availability .st-trip-image img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:12px;
}

/* Pull content up and reduce grey area heaviness */
#page_wrapper.liveaboard-page #availability .st-trip-content{
  min-height:auto;
  padding:12px 18px;
  gap:8px;
}

#page_wrapper.liveaboard-page #availability .st-trip-title{ margin:0 0 6px; }
#page_wrapper.liveaboard-page #availability .st-trip-location{ margin:0; }

#page_wrapper.liveaboard-page #availability .st-trip-details{
  background:#f6f8fb;
  border-radius:12px;
  padding:12px 16px;
  margin-top:8px;
}

#page_wrapper.liveaboard-page #availability .st-trip-description{ margin:0 0 10px; }

#page_wrapper.liveaboard-page #availability .st-trip-footer{
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:12px;
}

/* Small screen tweak: image fixed height when stacked */
@media (max-width: 768px){
  #page_wrapper.liveaboard-page #availability .st-trip-image{
    max-width:none;
    width:calc(100% - 16px);
    height:220px;
    align-self:auto;
    margin:8px auto 0 auto;
  }
  #page_wrapper.liveaboard-page #availability .st-trip-content{ padding:12px 16px; }
}
/* FIX: prevent image stretching when description expands */
#page_wrapper.liveaboard-page #availability .st-trip-card{
  align-items:flex-start !important;   /* stop stretching */
}

#page_wrapper.liveaboard-page #availability .st-trip-image{
  flex:0 0 260px !important;
  max-width:260px !important;
  height:200px !important;             /* fixed height = no stretch */
  align-self:flex-start !important;
  margin:8px 0 8px 8px !important;
}

#page_wrapper.liveaboard-page #availability .st-trip-image a,
#page_wrapper.liveaboard-page #availability .st-trip-image img{
  height:100% !important;
  width:100% !important;
  object-fit:cover !important;
}

/* ==========================
   MOBILE: Availability toolbar + cards
   ========================== */
@media (max-width: 767px){

  /* FILTER BAR: stack cleanly */
  #page_wrapper.liveaboard-page #availability #month-filter{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }

  /* Make labels readable + keep spacing tight */
  #page_wrapper.liveaboard-page #availability #month-filter label{
    margin:0;
    font-size:14px;
  }

  /* Dropdowns full width on mobile */
  #page_wrapper.liveaboard-page #availability #month-select,
  #page_wrapper.liveaboard-page #availability #itinerary-select{
    width:100%;
    min-width:0;
  }

  /* "Show only available" toggle: full width row */
  #page_wrapper.liveaboard-page #availability #st-only-available-wrap{
    margin-left:0 !important;
    width:100%;
    justify-content:flex-start;
  }

  /* CARD: image height controlled so it doesn't take over */
  #page_wrapper.liveaboard-page #availability .st-trip-image{
    height:200px;        /* adjust: 180–220 is a good range */
    width:calc(100% - 16px);
    margin:8px auto 0 auto;
    border-radius:12px;
    overflow:hidden;
  }
  #page_wrapper.liveaboard-page #availability .st-trip-image img{
    width:100%;
    height:100%;
    object-fit:cover;
  }

  /* CARD footer: buttons wrap nicely */
  #page_wrapper.liveaboard-page #availability .st-trip-footer{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    justify-content:flex-start;
    align-items:stretch;
  }

  /* Make both buttons equal width on mobile */
  #page_wrapper.liveaboard-page #availability .st-trip-footer a.st-emailtrip-btn,
  #page_wrapper.liveaboard-page #availability .st-trip-footer a.st-pill-btn{
    flex:1 1 calc(50% - 10px);
    min-width:140px;
    text-align:center;
  }

  /* Status sits on its own line (prevents squish) */
  #page_wrapper.liveaboard-page #availability .st-trip-footer .st-status{
    flex:1 1 100%;
    margin-top:2px;
  }
}