/* -----------------------------
   Design tokens
------------------------------ */
:root{
  --bg:#ffffff;
  --surface:#ffffff;
  --surface-2:#f4f6f8;
  --ink:#1f2933;
  --ink-2:rgba(31,41,51,.72);
  --ink-3:rgba(31,41,51,.55);
  --line:rgba(31,41,51,.12);
  --shadow:0 18px 60px rgba(16,24,40,.12);

  --blue:#c89b1f;
  --blue-2:#8f6911;
  --blue-soft:rgba(200,155,31,.12);

  --good:#0ea5e9;
  --warn:#f59e0b;
  --bad:#ef4444;

  --radius:18px;
  --radius-sm:14px;
}

/* -----------------------------
   Base
------------------------------ */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial;
  color:var(--ink);
  background:var(--bg);
  padding-top:90px; /* fixed header row */
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto}
a{color:inherit}
.wrap{width:80%;max-width:none;margin:0 auto;padding:0}
@media (max-width:1100px){.wrap{width:88%;}}
@media (max-width:768px){.wrap{width:94%;}}
section{scroll-margin-top:110px}

/* -----------------------------
   Buttons
------------------------------ */
.btn{
  border:1px solid transparent;
  border-radius:999px;
  padding:10px 14px;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  background:transparent;
  color:var(--ink);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btnPrimary{
  background:linear-gradient(180deg, var(--blue), var(--blue-2));
  color:#fff;
  box-shadow:0 14px 30px rgba(200,155,31,.24);
}
.btnPrimary:hover{box-shadow:0 18px 38px rgba(200,155,31,.28); transform:translateY(-1px)}
.btnOutline{
  border-color:rgba(200,155,31,.38);
  color:var(--blue-2);
  background:rgba(200,155,31,.08);
}
.btnOutline:hover{background:rgba(200,155,31,.12); transform:translateY(-1px)}
.btnSecondary{
  background:transparent;
  border:2px solid #fff;
  color:#fff;
}
.btnSecondary:hover{background:#fff;color:#000}

/* -----------------------------
   Header / Nav
------------------------------ */
/* Fixed header offsets */
body{ padding-top:100px; }
section{ scroll-margin-top:110px; }

.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
}

/* HEADER GRID (desktop: nav row + social row) */
.bar.headerGrid{
  min-height:90px;
  padding:10px 0 0 10px;
  display:grid;
  grid-template-columns:auto 1fr auto; /* logo | right stack | hamburger */
  grid-template-rows:auto auto;        /* nav row + socials row */
  align-items:center;
  column-gap:14px;
  position:relative;
}

/* Place items */
.brand{
  grid-column:1;
  grid-row:1 / span 2;
  display:flex;
  align-items:center;
  gap:10px;
}
.primary-nav{
  grid-column:2;
  grid-row:1;
  justify-self:end;
  display:flex;
  align-items:center;
}
.socialBar{
  grid-column:2;
  grid-row:2;
  justify-self:end;
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:-6px; /* pulls closer to nav like your screenshot */
}
.ctaRow{
  grid-column:3;
  grid-row:1;
  justify-self:end;
  display:flex;
  align-items:center;
}

/* Logo */
/* Logo (allow overhang without breaking nav layout) */
.logoLink{
  display:block;
  position:relative;
  z-index:3;
  text-decoration:none;
  line-height:0;
}

.brand{
  position:relative;
  overflow:visible;
}

.siteLogo,
.logoWrap img,
.custom-logo,
.custom-logo-link img{
  height:120px !important;
  width:auto !important;
  max-width:none;
  display:block;
  transform:translateY(18px); /* slight overhang into hero */
}

/* ensure header allows the overhang */
.site-header{
  overflow:visible;
}

/* Social icons (desktop + mobile) */
.socialIcon{
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  text-decoration:none;
  box-shadow:0 10px 25px rgba(16,24,40,.04);
  transition:transform .15s ease, background .15s ease, box-shadow .15s ease;
	margin-top: 0px;
}
.socialIcon svg{ width:14px; height:14px; }
.socialIcon:hover{
  background:rgba(31,41,51,.06);
  transform:translateY(-1px);
}

/* WP menu reset + horizontal layout */
.primary-nav ul,
.primary-nav ul.menu,
.primary-nav ul.sub-menu{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}
.primary-nav li{
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
}
.primary-nav li::marker{ content:"" !important; }
.primary-nav li::before{ content:none !important; display:none !important; }

.primary-nav > ul{
  display:flex;
  gap:6px;
  align-items:center;
  flex-wrap:wrap;
}

.primary-nav a{
  text-decoration:none;
  color:var(--ink-2);
  font-size:12px;
  padding:10px 10px;
  border-radius:999px;
  display:inline-flex;
}
.primary-nav a:hover{ background:rgba(31,41,51,.06); color:var(--ink); }

/* Hamburger */
.hamb{
  width:40px;height:40px;border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  display:none;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.hamb i, .hamb i::before, .hamb i::after{
  content:"";
  display:block;
  width:16px;height:2px;
  background:var(--ink);
  border-radius:2px;
  position:relative;
}
.hamb i::before{ position:absolute; top:-6px; left:0; }
.hamb i::after{ position:absolute; top:6px; left:0; }

/* MOBILE */
@media (max-width:920px){
  .primary-nav{ display:none; }
  .hamb{ display:flex; }

  .bar.headerGrid{
    height:auto;
    padding:10px 10px 12px;
    grid-template-columns:1fr auto;
    grid-template-rows:auto auto;
    align-items:start;
  }

  .brand{
    grid-column:1;
    grid-row:1;
  }

  .ctaRow{
    grid-column:2;
    grid-row:1;
  }

  .socialBar{
    grid-column:1 / -1;
    grid-row:2;
    justify-self:center;
    margin-top:8px;
  }
	.socialIcon{
		margin-top: 0px;
	}
  /* update offsets because header is taller on mobile */
  body{ padding-top:140px; }
  section{ scroll-margin-top:150px; }

  /* slightly smaller icons on mobile */
  .socialIcon{ width:28px; height:28px; }
  .socialIcon svg{ width:14px; height:14px; }
	  .siteLogo,
  .logoWrap img,
  .custom-logo,
  .custom-logo-link img{
    height:80px !important;
    transform:translateY(6px);
  }
}

/* Mobile nav */
.mobile-nav{
  display:none;
  border-top:1px solid var(--line);
  padding:10px 0 16px;
}
.mobile-nav.is-open{ display:block; }
.mobile-nav a{
  display:block;
  padding:10px 12px;
  border-radius:14px;
  text-decoration:none;
  color:var(--ink-2);
  font-weight:700;
  font-size:13px;
}
.mobile-nav a:hover{ background:rgba(31,41,51,.06); color:var(--ink); }

/* -----------------------------
   Hero
------------------------------ */
.hero{
  position:relative;
  min-height:600px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  overflow:hidden;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("../images/hero-desktop.png");
  background-size:cover;
  background-position:center;
  z-index:0;
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.38) 0%, rgba(0,0,0,.18) 45%, rgba(0,0,0,.10) 100%),
    linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.28) 100%);
  z-index:1;
}

.heroInner{
  position:relative;
  z-index:2;   /* THIS keeps buttons full colour */
}
.heroGrid{
  display:grid;
  grid-template-columns:1fr;
  text-align:center;
  justify-items:center;
  gap:22px;
  align-items:end;
}
.hero h1{margin:0;font-size:clamp(38px,4.5vw,64px);letter-spacing:-.03em;line-height:1.03}
.hero .lead{margin-top:16px;max-width:800px;color:rgba(255,255,255,.92);font-size:clamp(22px,2.5vw,36px);line-height:1.4;font-weight:600}
.heroActions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px;justify-content:center}
@media (max-width:920px){.hero{min-height:520px}}
@media (max-width:820px){
  .hero::before{background-image:url("../images/hero-mobile.png")!important}
  .hero{min-height:72vh}
}

/* -----------------------------
   Sections / Layout
------------------------------ */
main{padding:28px 0 72px}
.section{padding:26px 0}
.sectionAlt{background:var(--surface-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}

.sectionHead{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
  gap:10px !important;
  margin-bottom:18px;
}
.sectionHead > div{
  width:100% !important;
  max-width:none !important;
  flex:0 0 100% !important;
}
.sectionHead h2{margin:0;font-size:20px;letter-spacing:-.02em}
.sectionHead p{margin:0;color:var(--ink-2);font-size:13px;max-width:none;line-height:1.65}
.sectionIntro p{margin:0;color:var(--ink-2);font-size:13px;line-height:1.7;max-width:none}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:980px){.cards{grid-template-columns:1fr}}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 12px 35px rgba(16,24,40,.08);overflow:hidden}
.cardPad{padding:16px}
.subtle{color:var(--ink-2);font-size:12px;line-height:1.6}

/* Tabs */
.tabs{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:14px}
.tabBtn{
  border:1px solid rgba(31,41,51,.14);
  background:#fff;
  color:var(--ink-2);
  padding:10px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease, color .12s ease;
  white-space:nowrap;
  box-shadow:0 10px 25px rgba(16,24,40,.04);
}
.tabBtn:hover{transform:translateY(-1px);color:var(--ink);border-color:rgba(31,41,51,.18)}
.tabBtn.active{
  border-color:rgba(200,155,31,.38);
  background:rgba(200,155,31,.12);
  color:var(--blue-2);
  box-shadow:0 16px 32px rgba(200,155,31,.12);
}
.tabCount{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:22px;padding:0 7px;border-radius:999px;
  margin-left:8px;font-size:11px;font-weight:900;
  background:rgba(31,41,51,.06);color:var(--ink-2);
}
.tabBtn.active .tabCount{background:rgba(200,155,31,.14);color:var(--blue-2)}
.emptyState{
  display:none;
  padding:18px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:0 12px 35px rgba(16,24,40,.06);
  color:var(--ink-2);
  font-size:13px;
  line-height:1.6;
  text-align:center;
}

/* Trip cards */
.tripList{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
@media (max-width:1100px){.tripList{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.tripList{grid-template-columns:1fr}}

.trip{
  display:flex;flex-direction:column;justify-content:space-between;
  padding:18px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 18px 40px rgba(16,24,40,.08);
  min-height:260px;
  transition:transform .18s ease, box-shadow .18s ease;
  will-change:transform;
}
.trip:hover{transform:translateY(-6px);box-shadow:0 26px 60px rgba(16,24,40,.14)}
.trip b{display:block;font-size:13px;letter-spacing:-.01em}
.trip small{display:block;color:var(--ink-2);margin-top:5px;font-size:12px;line-height:1.5}
.price{font-weight:900;font-size:16px;letter-spacing:-.02em}

.badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:7px 10px;border-radius:999px;font-size:11px;font-weight:900;
  border:1px solid rgba(31,41,51,.12);
  background:rgba(31,41,51,.05);
  color:var(--ink);
  width:max-content;
}
.badge.warn{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.28);color:#92400e}
.badge.bad{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.28);color:#7f1d1d}
.badge.good{background:rgba(14,165,233,.12);border-color:rgba(14,165,233,.28);color:#0c4a6e}

.tripImg{
  width:100%;
  aspect-ratio:1 / 1;
  border-radius:16px;
  background-size:cover;
  background-position:center;
  border:1px solid rgba(31,41,51,.10);
  box-shadow:0 12px 28px rgba(16,24,40,.08);
  position:relative;
  overflow:hidden;
  transition:transform .22s ease;
  transform:scale(1);
}
.tripImg::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.32) 100%);
}
.trip:hover .tripImg{transform:scale(1.05)}
.viewAllWrap,.sectionButtonWrap{display:flex;justify-content:center;margin-top:26px}

/* Why section */
.whySection{
  max-width:none;
  margin:26px 0 0;
  padding:22px;
  background:rgba(200,155,31,.08);
  border:1px solid rgba(200,155,31,.16);
  border-radius:var(--radius);
}
.whyHeader{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  gap:8px;
  margin-bottom:14px;
}
.whyHeader b{font-size:14px;letter-spacing:-.01em}
.whyHeader span{color:var(--ink-2);font-size:12px;line-height:1.6;max-width:none;width:100%}
.whyGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:980px){.whyGrid{grid-template-columns:1fr}}
.whyTile{
  background:#fff;border:1px solid rgba(31,41,51,.12);
  border-radius:var(--radius);
  box-shadow:0 12px 35px rgba(16,24,40,.06);
  padding:14px;display:flex;gap:12px;align-items:flex-start;
}
.whyIcon{
  width:34px;height:34px;border-radius:12px;
  background:rgba(200,155,31,.12);
  border:1px solid rgba(200,155,31,.24);
  display:grid;place-items:center;color:var(--blue-2);
  font-weight:900;flex:0 0 auto;
}
.whyTile b{display:block;font-size:12px;letter-spacing:-.01em}
.whyTile small{display:block;margin-top:6px;color:var(--ink-2);line-height:1.55;font-size:12px}

/* Page content */
.entry{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 12px 35px rgba(16,24,40,.06);
  padding:18px;
}
.entry h1{margin:0 0 12px;font-size:28px;letter-spacing:-.02em}
.entry h2{margin:22px 0 10px;font-size:18px;letter-spacing:-.01em}
.entry p{color:var(--ink-2);line-height:1.75}

/* Footer */
.site-footer{background:#000;color:rgba(255,255,255,.86);padding:26px 0;border-top:1px solid rgba(255,255,255,.10)}
.site-footer a{color:#fff}
.footGrid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr;
  gap:20px;
  align-items:start;
}

@media (max-width:980px){
  .footGrid{
    grid-template-columns:1fr;
  }
}
.footTitle{font-weight:900;letter-spacing:-.02em;color:#fff}
.footSmall{color:rgba(255,255,255,.72);font-size:12px;line-height:1.7;margin-top:8px}
.footerPolicyMenu{
  list-style:none;
  margin:10px 0 0;
  padding:0;
}

.footerPolicyMenu li{
  margin:0 0 8px;
}

.footerPolicyMenu a{
  color:rgba(255,255,255,.86);
  text-decoration:none;
  font-size:12px;
  line-height:1.6;
}

.footerPolicyMenu a:hover{
  color:#fff;
  text-decoration:underline;
}
.footerMenuList{
  display:grid;
  gap:8px;
}

.footerMenuList a{
  color:rgba(255,255,255,.86);
  text-decoration:none;
  font-size:12px;
  line-height:1.6;
}

.footerMenuList a:hover{
  color:#fff;
  text-decoration:underline;
}
/* Utility */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* -----------------------------
   Trip filter drawer (homepage)
------------------------------ */
.tripToolbar{display:flex;align-items:center;gap:12px;margin:10px 0 18px}
.filterBtn{
  border:1px solid rgba(31,41,51,.14);
  background:#fff;
  color:var(--ink);
  padding:10px 14px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 25px rgba(16,24,40,.04);
}
.activeFilters{display:flex;flex-wrap:wrap;gap:8px}
.filterChip{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;border-radius:999px;
  background:rgba(31,41,51,.06);
  color:var(--ink);
  font-size:12px;font-weight:800;
}
.filterChip button{border:0;background:transparent;cursor:pointer;font-weight:900;line-height:1}

.tripFilterPanel{
  position:fixed;left:0;right:0;bottom:0;
  background:#fff;z-index:120;
  border-radius:20px 20px 0 0;
  box-shadow:0 -20px 50px rgba(0,0,0,.2);
  transform:translateY(110%);
  transition:transform .28s ease;
  padding:18px 18px 16px;
  max-height:80vh;
  overflow:auto;
}
.tripFilterPanel.open{transform:translateY(0)}
.filterHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.filterClose{width:38px;height:38px;border-radius:999px;border:1px solid var(--line);background:#fff;cursor:pointer}
.filterGroup{margin:16px 0}
.filterGroup h4{margin:0 0 10px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.filterOpt{display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:14px;cursor:pointer}
.filterOpt:hover{background:rgba(31,41,51,.05)}
.filterFooter{display:flex;gap:10px;padding-top:10px;position:sticky;bottom:0;background:#fff}
.filterFooter .btn{flex:1}

/* -----------------------------
   Shop filters (dropdown row)
------------------------------ */
.tripShopFilters{margin:10px 0 18px}
.tripShopFilters__row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.tripShopFilters select{
  border:1px solid rgba(31,41,51,.14);
  border-radius:999px;
  padding:10px 12px;
  background:#fff;
  font:inherit;
  min-width:180px;
}
.tripShopFilters select:disabled{opacity:.55}
@media (max-width:700px){
  .tripShopFilters select{min-width:100%}
  .tripShopFilters__row .btn{width:100%; justify-content:center}
}

/* -----------------------------
   Single product route selector
------------------------------ */
.woocommerce.single-product select.graysRouteNativeSelect{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}
.graysRoutePanel{
  border:1px solid rgba(31,41,51,.12);
  border-radius:24px;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  box-shadow:0 18px 45px rgba(31,41,51,.08);
  padding:14px;
  margin:8px 0 16px;
}
.graysRoutePanel__intro{
  display:grid;
  gap:3px;
  padding:4px 4px 12px;
  color:var(--ink);
}
.graysRoutePanel__intro strong{font-size:18px;line-height:1.15}
.graysRoutePanel__intro small{color:rgba(31,41,51,.68);font-weight:650}
.graysRoutePanel__eyebrow{
  width:max-content;
  border-radius:999px;
  background:rgba(255,193,7,.18);
  color:#6b4b00;
  font-size:12px;
  line-height:1;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:7px 9px;
}
.graysRouteChoices{
  display:grid;
  gap:10px;
}
.graysRouteChoice{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  width:100%;
  text-align:left;
  border:1px solid rgba(31,41,51,.13);
  border-radius:20px;
  background:#fff;
  color:var(--ink);
  padding:14px;
  font:inherit;
  cursor:pointer;
  transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease,background .16s ease;
}
.graysRouteChoice:hover{
  transform:translateY(-2px);
  border-color:rgba(31,41,51,.26);
  box-shadow:0 16px 34px rgba(31,41,51,.11);
}
.graysRouteChoice:focus-visible{outline:3px solid rgba(255,193,7,.55);outline-offset:3px}
.graysRouteChoice.is-selected{
  background:linear-gradient(135deg,var(--ink) 0%,#111827 100%);
  border-color:var(--ink);
  color:#fff;
  box-shadow:0 18px 38px rgba(31,41,51,.22);
}
.graysRouteChoice.is-disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.graysRouteChoice__content{display:grid;gap:6px;min-width:0}
.graysRouteChoice__badge{
  width:max-content;
  border-radius:999px;
  background:rgba(31,41,51,.07);
  color:rgba(31,41,51,.72);
  font-size:12px;
  font-weight:900;
  padding:5px 8px;
}
.graysRouteChoice.is-selected .graysRouteChoice__badge{background:rgba(255,255,255,.16);color:#ffd24a}
.graysRouteChoice__title{font-size:17px;font-weight:950;line-height:1.2}
.graysRouteChoice__meta{font-size:13px;font-weight:800;color:rgba(31,41,51,.62)}
.graysRouteChoice.is-selected .graysRouteChoice__meta{color:rgba(255,255,255,.72)}
.graysRouteChoice__path{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:2px}
.graysRouteChoice__stop{
  border-radius:999px;
  background:rgba(31,41,51,.055);
  padding:5px 8px;
  font-size:12px;
  font-weight:800;
  color:rgba(31,41,51,.78);
}
.graysRouteChoice.is-selected .graysRouteChoice__stop{background:rgba(255,255,255,.13);color:rgba(255,255,255,.9)}
.graysRouteChoice__arrow{font-size:12px;font-weight:900;color:rgba(31,41,51,.42)}
.graysRouteChoice.is-selected .graysRouteChoice__arrow{color:rgba(255,255,255,.48)}
.graysRouteChoice__more{font-size:12px;font-weight:900;color:#6b4b00;background:rgba(255,193,7,.22);border-radius:999px;padding:5px 8px}
.graysRouteChoice__tick{
  flex:0 0 auto;
  width:30px;
  height:30px;
  border-radius:999px;
  border:2px solid currentColor;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  line-height:1;
  font-weight:950;
}
.graysRouteChoice:not(.is-selected) .graysRouteChoice__tick{color:transparent;border-color:rgba(31,41,51,.18)}
.woocommerce.single-product form.variations_form .reset_variations{
  display:inline-flex !important;
  margin-top:4px;
}
@media (max-width:700px){
  .graysRoutePanel{border-radius:20px;padding:12px;margin-top:10px}
  .graysRouteChoice{align-items:flex-start;padding:13px;border-radius:18px}
  .graysRouteChoice__title{font-size:16px}
  .graysRouteChoice__tick{width:28px;height:28px}
}

/* =========================================================
   WooCommerce (Classic) – keep tidy + match theme
========================================================= */
input,select,textarea{font-family:inherit}
.woocommerce input.input-text,
.woocommerce textarea.input-text,
.woocommerce select{
  border:1px solid rgba(31,41,51,.14);
  border-radius:14px;
  padding:10px 12px;
}

/* Hide ordering UI */
.woocommerce-result-count,
.woocommerce-ordering{display:none}

/* Notices (kill WC green, keep theme) */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error{
  background:#f3f6fb !important;
  color:var(--ink) !important;
  border-left:0 !important;
  border-right:0 !important;
  border-bottom:0 !important;
}
.woocommerce-message,
.woocommerce-info{border-top:3px solid var(--blue) !important}
.woocommerce-error{border-top:3px solid var(--bad) !important}
.woocommerce-message::before,
.woocommerce-info::before{color:var(--blue) !important}
.woocommerce-error::before{color:var(--bad) !important}

/* Scope WC link colours to MAIN only so header/nav never changes */
/* WooCommerce text links only — not buttons */
.woocommerce-page main a:not(.button):not(.btn):not(.wp-block-button__link):not(.added_to_cart):not(.single_add_to_cart_button) {
  color: var(--blue-2);
}

.woocommerce-page main a:not(.button):not(.btn):not(.wp-block-button__link):not(.added_to_cart):not(.single_add_to_cart_button):hover {
  color: var(--blue);
}
/* Keep button text readable */
.woocommerce-page main a.button,
.woocommerce-page main .button,
.woocommerce-page main a.btn,
.woocommerce-page main .btn,
.woocommerce-page main .wp-block-button__link,
.woocommerce-page main a.added_to_cart,
.woocommerce-page main .single_add_to_cart_button {
  color: #fff !important;
}
/* Reset any accidental earlier overrides */
.woocommerce a,
.woocommerce a:hover{color:inherit}

/* Prices */
.woocommerce ul.products li.product .price,
.woocommerce div.product .price{
  color:var(--ink) !important;
  font-weight:900;
}

/* =========================================================
   WooCommerce Product Grid – force CSS grid
========================================================= */
.woocommerce ul.products{
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:18px !important;
  margin:18px 0 0 !important;
  padding:0 !important;
  list-style:none !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after{
  content:none !important;
  display:none !important;
}
.woocommerce ul.products li.product{
  float:none !important;
  width:auto !important;
  margin:0 !important;
  clear:none !important;

  display:flex !important;
  flex-direction:column !important;
  height:100%;

  padding:18px !important;
  background:#fff !important;
  border:1px solid var(--line) !important;
  border-radius:var(--radius) !important;
  box-shadow:0 18px 40px rgba(16,24,40,.08) !important;
}
.woocommerce ul.products li.product img{border-radius:16px !important}
.woocommerce ul.products li.product a{display:block}
.woocommerce ul.products li.product .button{display:none !important}

@media (max-width:1100px){
  .woocommerce ul.products{grid-template-columns:repeat(2, minmax(0, 1fr)) !important}
}
@media (max-width:700px){
  .woocommerce ul.products{grid-template-columns:1fr !important}
}

/* =========================================================
   WooCommerce Blocks (Cart/Checkout + Empty cart + Grid)
========================================================= */

/* Blocks Buttons */
.woocommerce .wc-block-components-button,
.woocommerce-page .wc-block-components-button,
.woocommerce .wc-block-components-button:not(.is-link),
.woocommerce-page .wc-block-components-button:not(.is-link),
.woocommerce .wc-block-components-button.wc-block-components-button--contained,
.woocommerce .wc-block-components-checkout-place-order-button,
.woocommerce button.wc-block-components-checkout-place-order-button,
.woocommerce a.wc-block-components-checkout-place-order-button{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:999px !important;
  padding:12px 16px !important;
  font-weight:900 !important;
  text-decoration:none !important;
  border:1px solid transparent !important;
  cursor:pointer !important;

  background:linear-gradient(180deg, var(--blue), var(--blue-2)) !important;
  color:#fff !important;
  box-shadow:0 14px 30px rgba(200,155,31,.24) !important;
}
.woocommerce .wc-block-components-button__text{color:inherit !important;font-weight:inherit !important}
.woocommerce .wc-block-components-button.is-link{
  background:transparent !important;
  box-shadow:none !important;
  color:var(--blue-2) !important;
  padding:10px 12px !important;
}
.woocommerce .wc-block-components-checkout-place-order-button:hover,
.woocommerce .wc-block-components-button.wc-block-components-button--contained:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 38px rgba(200,155,31,.28) !important;
}

/* Make key CTAs full-width */
.woocommerce .wc-block-cart__submit-container .wc-block-components-button,
.woocommerce .wc-block-checkout__actions .wc-block-components-button{
  width:100% !important;
}

/* Empty cart container */
.woocommerce .wc-block-cart-empty,
.woocommerce .wp-block-woocommerce-cart{
  background:var(--surface) !important;
  border:1px solid var(--line) !important;
  border-radius:var(--radius) !important;
  box-shadow:0 12px 35px rgba(16,24,40,.06) !important;
  padding:22px !important;
}
.woocommerce .wc-block-cart-empty{text-align:center}
.woocommerce .wc-block-cart-empty__title,
.woocommerce .wc-block-cart-empty h2{
  margin:0 0 8px !important;
  font-size:24px !important;
  font-weight:900 !important;
  letter-spacing:-.02em;
}
.woocommerce .wc-block-cart-empty p,
.woocommerce .wc-block-cart-empty .wc-block-cart-empty__description{
  color:var(--ink-2) !important;
  line-height:1.7 !important;
  max-width:60ch;
  margin-left:auto !important;
  margin-right:auto !important;
}

/* Blocks “New in store” grid -> theme grid */
.woocommerce .wc-block-grid__products{
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:18px !important;
  margin:18px 0 0 !important;
  padding:0 !important;
  list-style:none !important;
  justify-items:stretch !important;
  align-items:stretch !important;
}
@media (max-width:900px){
  .woocommerce .wc-block-grid__products{grid-template-columns:repeat(2, minmax(0, 1fr)) !important}
}
@media (max-width:650px){
  .woocommerce .wc-block-grid__products{grid-template-columns:1fr !important}
}

/* Card */
.woocommerce .wc-block-grid__product{
  width:100% !important;
  max-width:none !important;
  margin:0 !important;

  display:flex !important;
  flex-direction:column !important;
  justify-content:space-between !important;

  padding:18px !important;
  background:#fff !important;
  border:1px solid var(--line) !important;
  border-radius:var(--radius) !important;
  box-shadow:0 18px 40px rgba(16,24,40,.08) !important;

  transition:transform .18s ease, box-shadow .18s ease !important;
}
.woocommerce .wc-block-grid__product:hover{
  transform:translateY(-6px) !important;
  box-shadow:0 26px 60px rgba(16,24,40,.14) !important;
}

/* Image wrapper */
.woocommerce .wc-block-grid__product-image{
  width:100% !important;
  border-radius:16px !important;
  overflow:hidden !important;
  border:1px solid rgba(31,41,51,.10) !important;
  box-shadow:0 12px 28px rgba(16,24,40,.08) !important;
}
.woocommerce .wc-block-grid__product-image img{
  width:100% !important;
  height:auto !important;
  display:block !important;
  transform:scale(1) !important;
  transition:transform .22s ease !important;
}
.woocommerce .wc-block-grid__product:hover .wc-block-grid__product-image img{
  transform:scale(1.05) !important;
}

/* Title + price */
.woocommerce .wc-block-grid__product-title{
  display:block !important;
  width:100% !important;
  max-width:none !important;
  margin:12px 0 0 !important;
  font-size:13px !important;
  font-weight:800 !important;
  letter-spacing:-.01em !important;
  line-height:1.35 !important;
  white-space:normal !important;
  word-break:normal !important;
  overflow-wrap:anywhere !important;
  color:var(--ink) !important;
}
.woocommerce .wc-block-grid__product-price{
  margin-top:10px !important;
  font-weight:900 !important;
  font-size:16px !important;
  letter-spacing:-.02em !important;
  color:var(--ink) !important;
}

/* Add to basket CTA */
.woocommerce .wc-block-grid__product-add-to-cart{
  margin-top:14px !important;
  width:100% !important;
}
.woocommerce .wc-block-grid__product-add-to-cart .wp-block-button{
  width:100% !important;
}
.woocommerce .wc-block-grid__product-add-to-cart .wp-block-button__link{
  width:100% !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:12px 16px !important;
  border-radius:999px !important;
  background:linear-gradient(180deg, var(--blue), var(--blue-2)) !important;
  color:#fff !important;
  font-weight:900 !important;
  text-decoration:none !important;
  border:1px solid transparent !important;
  box-shadow:0 14px 30px rgba(200,155,31,.24) !important;
  white-space:nowrap !important;
  font-size:13px !important;
}
.woocommerce .wc-block-grid__product-add-to-cart .wp-block-button__link:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 38px rgba(200,155,31,.28) !important;
  color:#fff !important;
}

/* =========================================================
   Single product: Add to basket button (classic Woo)
========================================================= */
.woocommerce.single-product button.single_add_to_cart_button.button.alt,
.woocommerce.single-product .single_add_to_cart_button.button.alt{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:linear-gradient(180deg, var(--blue), var(--blue-2)) !important;
  color:#fff !important;
  border:1px solid transparent !important;
  border-radius:999px !important;
  padding:12px 16px !important;
  font-weight:900 !important;
  text-decoration:none !important;
  box-shadow:0 14px 30px rgba(200,155,31,.24) !important;
}
.woocommerce.single-product button.single_add_to_cart_button.button.alt:hover,
.woocommerce.single-product .single_add_to_cart_button.button.alt:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 38px rgba(200,155,31,.28) !important;
  color:#fff !important;
}
.woocommerce.single-product button.single_add_to_cart_button.button.alt:active{
  transform:translateY(1px);
}

/* Added-to-basket notice: View basket button */
.woocommerce-message a.button.wc-forward,
.woocommerce-message a.wc-forward.button{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:linear-gradient(180deg, var(--blue), var(--blue-2)) !important;
  color:#fff !important;
  border:1px solid transparent !important;
  border-radius:999px !important;
  padding:10px 14px !important;
  font-weight:900 !important;
  text-decoration:none !important;
  box-shadow:0 14px 30px rgba(200,155,31,.24) !important;
}
.woocommerce-message a.button.wc-forward:hover{
  color:#fff !important;
  transform:translateY(-1px);
  box-shadow:0 18px 38px rgba(200,155,31,.28) !important;
}

/* -----------------------------
   Contact Form 7 – theme styling
------------------------------ */
#contact .wpcf7 form{margin:0}

#contact .graysForm label{
  display:block;
  font-weight:700;
  margin:0 0 6px;
}
#contact .graysFormRow{margin:0 0 14px}

#contact .graysInput,
#contact .graysTextarea{
  width:100%;
  border:1px solid rgba(0,0,0,.12);
  border-radius:14px;
  padding:12px 14px;
  background:#fff;
  font:inherit;
  outline:none;
}
#contact .graysTextarea{min-height:130px;resize:vertical}

#contact .graysInput:focus,
#contact .graysTextarea:focus{
  border-color:rgba(0,0,0,.25);
  box-shadow:0 0 0 3px rgba(0,0,0,.06);
}

#contact .graysFormActions{margin-top:10px}

#contact .wpcf7-not-valid-tip{
  margin-top:6px;
  font-size:.9em;
}
#contact .wpcf7-response-output{
  margin:12px 0 0;
  border-radius:14px;
}

/* Contact left column phone row */
.contactPhoneRow{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
/* Fix quantity box alignment inside booking card */
.woocommerce div.product form.cart .quantity {
  width: 100%;
  margin-bottom: 12px;
}

.woocommerce div.product form.cart .quantity input.qty {
  width: 100%;
  max-width: 80px; /* keep it small but aligned */
}
.woocommerce div.product form.cart {
  display: flex;
  flex-direction: column;
}

.woocommerce div.product form.cart > * {
  width: 100%;
}
/* Make quantity feel like part of the form */
.woocommerce div.product form.cart .quantity {
  padding: 10px;
  border-radius: 12px;
  background: rgba(31,41,51,.04);
  border: 1px solid rgba(31,41,51,.08);
}
.contactWhatsappBtn{white-space:nowrap}
/* =========================================================
   Basket page tidy-up
========================================================= */

/* Main empty basket wrapper */
.woocommerce-cart .wc-block-cart-empty,
.woocommerce-cart .wp-block-woocommerce-cart {
  width: 80%;
  max-width: none;
  margin: 0 auto;
  background: var(--surface) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 12px 35px rgba(16,24,40,.06) !important;
  padding: 32px !important;
}
@media (max-width:1100px){
  .woocommerce-cart .wc-block-cart-empty,
  .woocommerce-cart .wp-block-woocommerce-cart {
    width: 88%;
  }
}

@media (max-width:768px){
  .woocommerce-cart .wc-block-cart-empty,
  .woocommerce-cart .wp-block-woocommerce-cart {
    width: 94%;
    padding: 22px !important;
  }
}


/* Empty basket heading / text */
.woocommerce-cart .wc-block-cart-empty__title,
.woocommerce-cart .wc-block-cart-empty h2 {
  font-size: 28px !important;
  font-weight: 900 !important;
  letter-spacing: -.02em;
  color: var(--ink) !important;
}

.woocommerce-cart .wc-block-cart-empty p,
.woocommerce-cart .wc-block-cart-empty .wc-block-cart-empty__description {
  color: var(--ink-2) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

/* "New in store" heading */
.woocommerce-cart .wc-block-cart__cross-sells h2,
.woocommerce-cart .wc-block-grid h2,
.woocommerce-cart .wp-block-heading {
  font-size: 20px !important;
  font-weight: 900 !important;
  letter-spacing: -.02em;
  color: var(--ink) !important;
  text-align: center;
  margin: 24px 0 18px !important;
}

/* Product title links in basket recommendations */
.woocommerce-cart .wc-block-grid__product-title,
.woocommerce-cart .wc-block-grid__product-title a,
.woocommerce-cart .wc-block-grid__product-link {
  color: var(--ink) !important;
  text-decoration: none !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.4 !important;
}

.woocommerce-cart .wc-block-grid__product-title a:hover,
.woocommerce-cart .wc-block-grid__product-link:hover {
  color: var(--blue-2) !important;
}

/* Keep recommendation cards aligned with your theme */
.woocommerce-cart .wc-block-grid__product {
  text-align: center;
}

/* =========================================================
   Basket recommendations -> make them match trip cards
========================================================= */

.woocommerce-cart .wc-block-grid__products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
  margin: 18px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  align-items: stretch !important;
}

@media (max-width: 1100px) {
  .woocommerce-cart .wc-block-grid__products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px) {
  .woocommerce-cart .wc-block-grid__products {
    grid-template-columns: 1fr !important;
  }
}

.woocommerce-cart .wc-block-grid__product {
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 18px !important;
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 18px 40px rgba(16,24,40,.08) !important;
  text-align: left !important;
}

.woocommerce-cart .wc-block-grid__product:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 26px 60px rgba(16,24,40,.14) !important;
}

/* image area */
.woocommerce-cart .wc-block-grid__product-image,
.woocommerce-cart .wc-block-grid__product-link {
  display: block !important;
  width: 100% !important;
}

.woocommerce-cart .wc-block-grid__product-image img,
.woocommerce-cart .wc-block-grid__product-link img {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  border-radius: 16px !important;
  border: 1px solid rgba(31,41,51,.10) !important;
  box-shadow: 0 12px 28px rgba(16,24,40,.08) !important;
  display: block !important;
}

/* title */
.woocommerce-cart .wc-block-grid__product-title,
.woocommerce-cart .wc-block-grid__product-title a,
.woocommerce-cart .wc-block-grid__product-link {
  color: var(--ink) !important;
  text-decoration: none !important;
}

.woocommerce-cart .wc-block-grid__product-title {
  margin: 12px 0 0 !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
  letter-spacing: -.01em !important;
  text-align: left !important;
}

/* price */
.woocommerce-cart .wc-block-grid__product-price {
  margin-top: 10px !important;
  font-weight: 900 !important;
  font-size: 16px !important;
  color: var(--ink) !important;
  text-align: left !important;
}

/* button row */
.woocommerce-cart .wc-block-grid__product-add-to-cart {
  width: 100% !important;
  margin-top: 14px !important;
}

.woocommerce-cart .wc-block-grid__product-add-to-cart .wp-block-button {
  width: 100% !important;
}

.woocommerce-cart .wc-block-grid__product-add-to-cart .wp-block-button__link {
  width: 100% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 16px !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, var(--blue), var(--blue-2)) !important;
  color: #fff !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  border: 1px solid transparent !important;
  box-shadow: 0 14px 30px rgba(200,155,31,.24) !important;
  font-size: 13px !important;
  white-space: nowrap !important;
}

/* Make the CTA look like your other buttons */
.woocommerce-cart .wc-block-grid__product-add-to-cart .wp-block-button__link,
.woocommerce-cart .wc-block-grid__product-add-to-cart a,
.woocommerce-cart .wc-block-grid__product-add-to-cart .button {
  background: linear-gradient(180deg, var(--blue), var(--blue-2)) !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 12px 16px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  box-shadow: 0 14px 30px rgba(200,155,31,.24) !important;
  font-size:12px;
}

/* Extra spacing under recommendations */
.woocommerce-cart .wc-block-grid {
  margin-top: 12px !important;
}
/* Basket recommendations grid */
.tripList--basket{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:18px;
}

@media (max-width:1100px){
  .tripList--basket{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:700px){
  .tripList--basket{
    grid-template-columns:1fr;
  }
}

/* -----------------------------
   Single product passenger form containment
   Keeps pickup dropdowns inside passenger cards on narrow/2-column layouts
------------------------------ */
.woocommerce.single-product form.cart,
.woocommerce.single-product form.cart *{
  box-sizing:border-box;
}
.woocommerce.single-product form.cart select:not(.graysRouteNativeSelect),
.woocommerce.single-product form.cart input:not([type="checkbox"]):not([type="radio"]),
.woocommerce.single-product form.cart textarea{
  width:100%;
  max-width:100%;
}
.woocommerce.single-product form.cart select:not(.graysRouteNativeSelect){
  display:block;
  min-width:0;
  text-overflow:ellipsis;
}
.woocommerce.single-product form.cart p,
.woocommerce.single-product form.cart .form-row,
.woocommerce.single-product form.cart fieldset,
.woocommerce.single-product form.cart [class*="passenger"],
.woocommerce.single-product form.cart [class*="Passenger"]{
  min-width:0;
  max-width:100%;
}
.woocommerce.single-product form.cart [class*="passenger"] select,
.woocommerce.single-product form.cart [class*="Passenger"] select{
  min-width:0;
}
@media (max-width:900px){
  .woocommerce.single-product form.cart [class*="passenger"],
  .woocommerce.single-product form.cart [class*="Passenger"]{
    width:100%;
  }
}
