/* Surrey Link Transport
   Quote page only
   Loaded after style.css
*/
/* =========================
   MOBILE SCROLL FIX
   Quote page only
   ========================= */

@media (max-width: 991.98px){

  .slt-quote .slt-veh-panel{
    position: fixed !important;
    inset: 0 !important;
    z-index: 15000 !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    border: 0 !important;
    border-radius: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    opacity: 0;
    transform: translateY(18px);
    pointer-events: none;
  }

  .slt-quote .slt-veh-panel.is-open{
    opacity: 1 !important;
    transform: translateY(0) !important;
    pointer-events: auto !important;
  }

  .slt-quote .slt-veh-panel__head{
    position: sticky !important;
    top: 0 !important;
    z-index: 2 !important;
    background: #fff !important;
    padding-top: calc(16px + env(safe-area-inset-top));
  }

  .slt-quote .slt-vehicles{
    flex: 1 1 auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: auto !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    touch-action: pan-y !important;
    padding-bottom: 12px !important;
  }

  .slt-quote .slt-veh-panel__footer{
    position: sticky !important;
    bottom: 0 !important;
    z-index: 2 !important;
    background: #fff !important;
    padding-bottom: calc(14px + env(safe-area-inset-bottom));
  }

  body.slt-veh-mobile-open .slt-routebar{
    display: none !important;
  }

  .slt-quote .slt-routebar{
    position: relative !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 0 12px !important;
  }

  .slt-quote .slt-routebar__items{
    grid-template-columns: 1fr !important;
  }

  .slt-quote .slt-mapwrap--right{
    height: auto !important;
    min-height: 48dvh !important;
    padding: 12px !important;
  }

  .slt-quote .slt-map--panel{
    height: 48dvh !important;
    min-height: 320px !important;
  }
}

@supports not (height: 100dvh){
  @media (max-width: 991.98px){
    .slt-quote .slt-veh-panel{
      height: 100vh !important;
      max-height: 100vh !important;
    }

    .slt-quote .slt-mapwrap--right{
      min-height: 48vh !important;
    }

    .slt-quote .slt-map--panel{
      height: 48vh !important;
    }
  }
}
/* =========================
   QUOTE PAGE – mobile spacing tidy-up
   Add at the very end of style.css
   ========================= */
@media (max-width: 575.98px){
  .slt-quote .slt-qpanel{
    padding:14px 14px 18px;
  }

  .slt-quote .slt-booking-intro{
    margin-bottom:12px;
    padding:12px 14px 10px;
    border-radius:16px;
  }

  .slt-quote .slt-booking-intro__eyebrow{
    min-height:26px;
    padding:0 9px;
    font-size:0.72rem;
  }

  .slt-quote .slt-booking-intro__title{
    margin:6px 0 0;
    font-size:1.18rem;
    line-height:1.08;
  }

  .slt-quote .slt-qtabs{
    margin-bottom:12px;
    padding:4px;
    border-radius:16px;
    gap:8px;
  }

  .slt-quote .slt-qtab{
    min-height:46px;
    font-size:0.9rem;
    padding:0 10px;
  }

  .slt-quote .form-check.form-switch{
    margin-top:0 !important;
    margin-bottom:12px !important;
    padding:10px 12px 8px 2.45rem;
    border-radius:16px;
  }

  .slt-quote .form-check-label{
    font-size:0.94rem;
  }

  .slt-quote #returnHint{
    margin-top:4px !important;
    font-size:0.8rem !important;
    line-height:1.4;
  }

  .slt-quote .slt-qfield{
    margin-bottom:12px;
  }

  .slt-quote .slt-qrowhead{
    margin-bottom:6px;
  }

  .slt-quote .slt-qinput{
    min-height:48px;
    padding:12px 14px;
    border-radius:14px;
    font-size:0.95rem;
  }

  .slt-quote .slt-vias{
    gap:10px;
    margin-bottom:10px;
  }

  .slt-quote .slt-qtime{
    margin:14px 0 10px;
    padding:12px 14px;
    border-radius:16px;
  }

  .slt-quote .slt-qtime__value{
    font-size:0.96rem;
  }

  .slt-quote .slt-qtime__tz{
    margin-top:8px;
    font-size:0.8rem;
  }

  .slt-quote .slt-status{
    margin:8px 0 10px;
    font-size:0.88rem;
    line-height:1.42;
  }  .slt-quote .slt-continue{
    min-height:52px;
    margin-top:2px;
    border-radius:16px;
    font-size:0.96rem;
  }
}

/* =========================
   Quote intro payment logos - compact clean layout
   ========================= */
.slt-quote .slt-booking-intro{
  display:block;
  padding:16px 18px 15px;
  border-radius:22px;
}

.slt-quote .slt-booking-intro__eyebrow{
  display:inline-flex;
  width:auto;
  max-width:100%;
  min-height:32px;
  padding:0 14px;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(126,186,29,0.14);
  border:1px solid rgba(126,186,29,0.22);
  color:#36560d;
  font-size:0.78rem;
  font-weight:900;
  letter-spacing:.055em;
  text-transform:uppercase;
  line-height:1.15;
}



.slt-quote .slt-paylogo{
  width:34px;
  height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:#fff;
  border:1px solid rgba(31,36,40,0.12);
  color:#1f2428;
  box-shadow:0 5px 12px rgba(17,24,39,0.05);
}

.slt-quote .slt-paylogo i{
  font-size:1.05rem;
  line-height:1;
}

.slt-quote .slt-booking-intro__title{
  margin:14px 0 0;
  font-size:clamp(2rem, 4.2vw, 2.55rem);
  line-height:1;
  letter-spacing:-0.055em;
  white-space:nowrap;
}

/* Mobile */
@media (max-width:575.98px){
  .slt-quote .slt-booking-intro{
    padding:14px 14px 13px;
    border-radius:18px;
    margin-bottom:12px;
  }

  .slt-quote .slt-booking-intro__eyebrow{
    min-height:30px;
    padding:0 11px;
    font-size:0.70rem;
    letter-spacing:.045em;
  }

  

  .slt-quote .slt-paylogo{
    width:31px;
    height:25px;
    border-radius:7px;
  }

  .slt-quote .slt-paylogo i{
    font-size:0.95rem;
  }

  .slt-quote .slt-booking-intro__title{
    margin-top:12px;
    font-size:1.9rem;
    white-space:nowrap;
  }
}

@media (max-width:380px){
  .slt-quote .slt-booking-intro__title{
    font-size:1.65rem;
  }

  .slt-quote .slt-paylogo{
    width:30px;
    height:24px;
  }
}
/* =========================
   Quote map visual polish
   ========================= */
.slt-quote .slt-map--panel{
  overflow:hidden;
  border-radius:22px !important;
  border:1px solid rgba(31,36,40,0.12) !important;
  box-shadow:
    0 22px 55px rgba(17,24,39,0.13),
    inset 0 1px 0 rgba(255,255,255,0.75) !important;
}

.slt-quote .slt-mapwrap--right{
  background:
    radial-gradient(circle at top right, rgba(126,186,29,0.16), transparent 28%),
    linear-gradient(180deg, #f8fbf4 0%, #eef4ea 100%) !important;
}
/* =========================
   Quote page top UX refresh
   ========================= */

/* Top intro card */
.slt-quote .slt-booking-intro{
  padding:18px 20px 18px !important;
  border-radius:24px !important;
  background:
    radial-gradient(circle at top right, rgba(126,186,29,0.16), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, #f8fbf5 100%) !important;
  border:1px solid rgba(126,186,29,0.18) !important;
  box-shadow:0 18px 45px rgba(17,24,39,0.07) !important;
}

.slt-quote .slt-booking-intro__eyebrow{
  background:rgba(126,186,29,0.13) !important;
  border-color:rgba(126,186,29,0.28) !important;
  color:#263018 !important;
  letter-spacing:.08em;
}



.slt-quote .slt-booking-intro__title{
  margin:16px 0 0 !important;
  font-size:clamp(2rem, 4vw, 3rem) !important;
  letter-spacing:-0.06em;
}

/* Better journey option buttons */
.slt-quote .slt-qtabs--journey{
  display:grid !important;
  grid-template-columns:1fr 1fr;
  gap:12px !important;
  padding:0 !important;
  margin:18px 0 16px !important;
  background:transparent !important;
  border:0 !important;
}

.slt-quote .slt-qtabs--journey .slt-qtab{
  min-height:66px;
  padding:12px 14px !important;
  border-radius:20px !important;
  border:1px solid rgba(88,88,88,0.16) !important;
  background:#fff !important;
  color:#3f474e !important;
  box-shadow:0 10px 24px rgba(17,24,39,0.05);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-weight:900;
  transition:
    transform .16s ease,
    box-shadow .16s ease,
    border-color .16s ease,
    background-color .16s ease;
}

.slt-quote .slt-qtabs--journey .slt-qtab:hover{
  transform:translateY(-1px);
  border-color:rgba(126,186,29,0.35) !important;
  box-shadow:0 16px 34px rgba(17,24,39,0.08);
}

.slt-quote .slt-qtabs--journey .slt-qtab.is-active{
  background:#111 !important;
  color:#fff !important;
  border-color:#111 !important;
  box-shadow:0 18px 38px rgba(17,24,39,0.16);
}

.slt-quote .slt-qtab__icon{
  width:36px;
  height:36px;
  border-radius:13px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(126,186,29,0.13);
  color:#41640f;
  flex:0 0 36px;
}

.slt-quote .slt-qtab.is-active .slt-qtab__icon{
  background:rgba(126,186,29,0.22);
  color:#bdf26a;
}

/* Return journey toggle - no outer box */
.slt-quote .slt-return-toggle{
  margin:4px 0 18px !important;
  padding:0 !important;
  min-height:44px;
  display:flex;
  align-items:center;
  gap:12px;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  border-radius:0 !important;
}

.slt-quote .form-switch.slt-return-toggle .form-check-input{
  float:none !important;
  margin:0 !important;
  width:58px;
  height:32px;
  border-radius:999px;
  cursor:pointer;
  border:1px solid rgba(88,88,88,0.22);
  background-color:#e9ecef;
  box-shadow:none;
}

.slt-quote .form-switch.slt-return-toggle .form-check-input:checked{
  background-color:#7EBA1D;
  border-color:#7EBA1D;
}

.slt-quote .form-switch.slt-return-toggle .form-check-input:focus{
  box-shadow:0 0 0 4px rgba(126,186,29,0.18);
  border-color:#7EBA1D;
}

.slt-quote .slt-return-toggle .form-check-label{
  margin:0;
  cursor:pointer;
}

.slt-quote .slt-return-toggle__title{
  display:block;
  color:#20252a;
  font-weight:900;
  font-size:1rem;
  line-height:1.2;
}

/* Mobile tidy */
@media (max-width:575.98px){
  .slt-quote .slt-booking-intro{
    padding:14px 15px 15px !important;
    border-radius:20px !important;
  }

  

  .slt-quote .slt-booking-intro__title{
    margin-top:12px !important;
    font-size:2rem !important;
  }

  .slt-quote .slt-qtabs--journey{
    gap:10px !important;
    margin:14px 0 14px !important;
  }

  .slt-quote .slt-qtabs--journey .slt-qtab{
    min-height:58px;
    border-radius:17px !important;
    font-size:0.92rem;
    gap:8px;
  }

  .slt-quote .slt-qtab__icon{
    width:32px;
    height:32px;
    border-radius:11px;
    flex-basis:32px;
  }

  .slt-quote .slt-return-toggle{
    margin-bottom:16px !important;
  }
}
/* =========================
   Quote page header Home button
   ========================= */
.slt-quote .slt-header-home-link{
  min-height:42px;
  padding:0 15px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  color:#fff;
  font-weight:800;
  font-size:0.82rem;
  letter-spacing:.04em;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.08);
  transition:background-color .16s ease, transform .16s ease, border-color .16s ease;
}

.slt-quote .slt-header-home-link:hover{
  color:#fff;
  background:rgba(255,255,255,0.14);
  border-color:rgba(255,255,255,0.24);
  transform:translateY(-1px);
}

.slt-quote .slt-header-home-link i{
  font-size:0.9rem;
}

@media (max-width:575.98px){
  .slt-quote .slt-header-home-link{
    width:40px;
    min-width:40px;
    height:40px;
    padding:0;
    border-radius:14px;
  }

  .slt-quote .slt-header-home-link span{
    display:none;
  }
}

/* stripe */
.slt-expressbox{
  margin:10px 0 14px;
}

.slt-wallet-title{
  font-weight:900;
  color:#111;
  margin-bottom:8px;
}

.slt-or-divider{
  display:flex;
  align-items:center;
  gap:10px;
  margin:14px 0 4px;
  color:rgba(88,88,88,.72);
  font-size:.86rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.slt-or-divider::before,
.slt-or-divider::after{
  content:"";
  height:1px;
  flex:1;
  background:rgba(88,88,88,.14);
}
/* =========================
   QUOTE UX REFRESH – left-panel flow
   Payment icons moved to CTA area; route stats moved off the map
   ========================= */

.slt-quote .slt-qpanel{
  background:#f7f9fb;
}

.slt-quote .slt-booking-intro{
  margin-bottom:14px;
  padding:14px 16px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(88,88,88,0.10);
  box-shadow:0 14px 34px rgba(17,24,39,0.06);
}

.slt-quote .slt-booking-intro__title{
  margin:12px 0 0;
  font-size:clamp(1.75rem, 3.6vw, 2.35rem);
}

.slt-quote .slt-qtabs--journey{
  padding:5px;
  border-radius:18px;
  background:#eef2f5;
  border:1px solid rgba(88,88,88,0.10);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.80);
}

.slt-quote .slt-qtab{
  min-height:52px;
  border:0;
  border-radius:14px;
  background:transparent;
  color:#42484e;
  font-weight:900;
  box-shadow:none;
}

.slt-quote .slt-qtab.is-active{
  background:linear-gradient(135deg, #7EBA1D 0%, #A8D94E 100%);
  color:#111;
  border-color:transparent;
  box-shadow:0 12px 26px rgba(126,186,29,0.28);
}

.slt-quote .slt-qtab__icon{
  width:30px;
  height:30px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.48);
}

.slt-quote .slt-return-toggle{
  margin:0 0 14px !important;
  padding:0 0 0 2.7rem;
  border:0;
  background:transparent;
  box-shadow:none;
}

.slt-quote .slt-return-toggle .form-check-input{
  width:2.25rem;
  height:1.25rem;
  margin-left:-2.7rem;
  border-color:rgba(88,88,88,0.24);
  cursor:pointer;
}

.slt-quote .slt-return-toggle .form-check-input:checked{
  background-color:#7EBA1D;
  border-color:#7EBA1D;
}

.slt-quote .slt-return-toggle__title{
  color:#222629;
  font-weight:900;
}

.slt-quote .slt-qinput{
  background:#fff;
  border-color:rgba(88,88,88,0.14);
  box-shadow:0 10px 24px rgba(17,24,39,0.055);
}

.slt-quote .slt-qinput:focus{
  border-color:rgba(126,186,29,0.78);
  box-shadow:0 0 0 4px rgba(126,186,29,0.15), 0 12px 26px rgba(17,24,39,0.08);
}

.slt-quote .slt-iconmini{
  background:#fff;
  box-shadow:0 8px 18px rgba(17,24,39,0.055);
}

.slt-quote .slt-trip-stats[hidden]{
  display:none !important;
}

.slt-quote .slt-trip-stats{
  margin:2px 0 14px;
  padding:10px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(126,186,29,0.22);
  box-shadow:0 14px 32px rgba(17,24,39,0.07);
}

.slt-quote .slt-trip-stats__items{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:8px;
  align-items:stretch;
}

.slt-quote .slt-trip-stats .slt-rstat{
  min-width:0;
  padding:10px 8px;
  border-radius:14px;
  background:linear-gradient(180deg, #fbfcfd 0%, #f4f7f9 100%);
  border:1px solid rgba(88,88,88,0.08);
  display:flex;
  align-items:center;
  gap:8px;
}

.slt-quote .slt-trip-stats .slt-rstat__icon{
  width:34px;
  height:34px;
  border-radius:12px;
  flex:0 0 34px;
  color:#111;
  background:rgba(126,186,29,0.18);
  display:flex;
  align-items:center;
  justify-content:center;
}

.slt-quote .slt-trip-stats .slt-rstat__label{
  display:block;
  font-size:0.68rem;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(88,88,88,0.65);
}

.slt-quote .slt-trip-stats .slt-rstat__value{
  margin-top:2px;
  color:#111;
  font-size:0.93rem;
  font-weight:900;
  line-height:1.15;
  white-space:nowrap;
}

.slt-quote .slt-trip-stats .slt-rbadge{
  grid-column:1 / -1;
  justify-self:start;
  margin-top:2px;
}

.slt-quote .slt-qtime{
  position:relative;
  margin:14px 0 12px;
  padding:13px 14px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(88,88,88,0.14);
  box-shadow:0 10px 24px rgba(17,24,39,0.055);
}

.slt-quote .slt-qtime__label::before{
  content:"\f133";
  font-family:"Font Awesome 6 Free";
  font-weight:900;
  margin-right:8px;
  color:#7EBA1D;
}

.slt-quote .slt-qtime__top .slt-btn{
  background:#222629;
  color:#fff;
  border-radius:12px;
}

.slt-quote .slt-qtime__tz{
  display:none;
}

.slt-quote .slt-status{
  min-height:22px;
  color:rgba(88,88,88,0.78);
}

.slt-quote .slt-continue{
  min-height:56px;
  border-radius:18px;
  font-size:1rem;
  font-weight:950;
  letter-spacing:.02em;
  text-transform:uppercase;
  transition:transform .16s ease, box-shadow .16s ease, filter .16s ease, background .16s ease;
}

.slt-quote .slt-continue.is-ready{
  background:linear-gradient(135deg, #7EBA1D 0%, #A8D94E 100%);
  color:#111;
  box-shadow:0 18px 36px rgba(126,186,29,0.30);
}

.slt-quote .slt-continue.is-ready:hover{
  transform:translateY(-1px);
  filter:brightness(1.03);
}

/* =========================
   Compact secure checkout logos
   ========================= */
.slt-quote .slt-paytrust{
  margin-top:10px;
  padding:10px 12px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(88,88,88,0.10);
  box-shadow:0 8px 20px rgba(17,24,39,0.04);
}

.slt-quote .slt-paytrust__text{
  display:flex;
  align-items:center;
  gap:7px;
  color:#36560d;
  font-size:0.72rem;
  font-weight:950;
  letter-spacing:.075em;
  text-transform:uppercase;
}

.slt-quote .slt-paytrust__logos{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  margin-top:8px;
}

.slt-quote .slt-paytrust .slt-paylogo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.slt-quote .slt-paytrust .slt-paylogo--img{
  width:54px;
  height:34px;
  padding:5px 7px;
  border-radius:10px;
  background:#fff;
  border:1px solid rgba(31,36,40,0.10);
  box-shadow:0 5px 12px rgba(17,24,39,0.045);
}

.slt-quote .slt-paytrust .slt-paylogo--img img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  display:block;
}

@media (max-width:575.98px){
  .slt-quote .slt-paytrust{
    padding:9px 10px;
  }

  .slt-quote .slt-paytrust__text{
    font-size:0.68rem;
  }

  .slt-quote .slt-paytrust__logos{
    gap:5px;
    margin-top:7px;
  }

  .slt-quote .slt-paytrust .slt-paylogo--img{
    width:48px;
    height:30px;
    padding:4px 6px;
    border-radius:9px;
  }
}
.slt-quote .slt-mapwrap--right{
  overflow:hidden;
}

.slt-quote .slt-mapwrap--right > .slt-routebar{
  display:none !important;
}

@media (max-width:575.98px){
  .slt-quote .slt-trip-stats__items{
    grid-template-columns:1fr 1fr 1fr;
    gap:6px;
  }

  .slt-quote .slt-trip-stats .slt-rstat{
    flex-direction:column;
    align-items:flex-start;
    padding:9px 8px;
  }

  .slt-quote .slt-trip-stats .slt-rstat__icon{
    width:30px;
    height:30px;
    flex-basis:30px;
  }

  .slt-quote .slt-trip-stats .slt-rstat__label{
    font-size:0.62rem;
  }

  .slt-quote .slt-trip-stats .slt-rstat__value{
    font-size:0.82rem;
    white-space:normal;
  }

  .slt-quote .slt-paytrust__logos{
    gap:6px;
  }
}
/* =========================
   Booking progress indicator
   Route → Vehicle → Confirm
   ========================= */

.slt-quote .slt-booking-progress{
  display:grid;
  grid-template-columns:auto 1fr auto 1fr auto;
  align-items:center;
  gap:8px;
  margin:0 0 14px;
  padding:10px 12px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(88,88,88,0.10);
  box-shadow:0 10px 26px rgba(17,24,39,0.045);
}

.slt-quote .slt-booking-progress__step{
  display:flex;
  align-items:center;
  gap:7px;
  color:rgba(88,88,88,0.72);
  font-size:0.78rem;
  font-weight:900;
  white-space:nowrap;
}

.slt-quote .slt-booking-progress__step span{
  width:26px;
  height:26px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#eef2f5;
  color:#5d656b;
  font-size:0.78rem;
  font-weight:950;
  border:1px solid rgba(88,88,88,0.10);
}

.slt-quote .slt-booking-progress__step strong{
  font-weight:950;
}

.slt-quote .slt-booking-progress__step.is-active{
  color:#152004;
}

.slt-quote .slt-booking-progress__step.is-active span{
  background:linear-gradient(135deg, #7EBA1D 0%, #A8D94E 100%);
  color:#111;
  border-color:rgba(126,186,29,0.45);
  box-shadow:0 8px 18px rgba(126,186,29,0.24);
}

.slt-quote .slt-booking-progress__step.is-complete{
  color:#36560d;
}

.slt-quote .slt-booking-progress__step.is-complete span{
  background:rgba(126,186,29,0.16);
  color:#36560d;
  border-color:rgba(126,186,29,0.24);
}

.slt-quote .slt-booking-progress__line{
  height:3px;
  min-width:18px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(126,186,29,0.28), rgba(88,88,88,0.10));
}

@media (max-width:575.98px){
  .slt-quote .slt-booking-progress{
    gap:6px;
    padding:9px 10px;
    border-radius:16px;
  }

  .slt-quote .slt-booking-progress__step{
    gap:5px;
    font-size:0.68rem;
  }

  .slt-quote .slt-booking-progress__step span{
    width:24px;
    height:24px;
    font-size:0.72rem;
  }

  .slt-quote .slt-booking-progress__line{
    min-width:12px;
  }
}

/* =========================
   Booking terms / cancellation mini policy
   ========================= */
.slt-quote .slt-terms-accept{
  margin:16px 0 14px;
  padding:14px;
  border-radius:18px;
  background:rgba(126,186,29,0.07);
  border:1px solid rgba(126,186,29,0.20);
}

.slt-quote .slt-check--terms{
  margin:0;
  align-items:flex-start;
  gap:10px;
  color:#1f2428;
  font-weight:800;
  line-height:1.5;
}

.slt-quote .slt-check--terms input{
  margin-top:4px;
}

.slt-quote .slt-check--terms a{
  color:#1f2428;
  text-decoration:underline;
  text-underline-offset:3px;
}

.slt-quote .slt-cancel-policy-mini{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid rgba(126,186,29,0.18);
}

.slt-quote .slt-cancel-policy-mini summary{
  cursor:pointer;
  font-weight:900;
  color:#36560d;
}

.slt-quote .slt-cancel-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px 12px;
  margin-top:10px;
  padding:12px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(31,36,40,0.08);
  font-size:0.92rem;
}

.slt-quote .slt-cancel-grid strong{
  color:#111;
  white-space:nowrap;
}

.slt-quote .slt-cancel-policy-mini p{
  margin:9px 0 0;
  color:rgba(88,88,88,0.82);
  font-size:0.88rem;
  line-height:1.5;
  font-weight:600;
}
/* =========================
   Quote trust cards - logo/icon upgrade
   ========================= */

.slt-quote .slt-google-review-card__top{
  align-items:center;
}

.slt-quote .slt-trust-logo{
  width:52px;
  height:52px;
  flex:0 0 52px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  border:1px solid rgba(31,36,40,0.10);
  box-shadow:0 10px 24px rgba(17,24,39,0.08);
  overflow:hidden;
}

.slt-quote .slt-trust-logo i{
  font-size:1.45rem;
  line-height:1;
}

.slt-quote .slt-trust-logo--google i{
  color:#4285F4;
}

.slt-quote .slt-trust-logo--council{
  background:#fff;
}

.slt-quote .slt-trust-logo--council img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:7px;
}

.slt-quote .slt-trust-logo--council i{
  color:#36560d;
}

.slt-quote .slt-trust-logo--communication{
  background:rgba(126,186,29,0.14);
  color:#36560d;
}

.slt-quote .slt-trust-logo--secure{
  background:rgba(66,133,244,0.10);
  color:#1d4ed8;
}

.slt-quote .slt-trust-proof{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.slt-quote .slt-trust-proof__icon{
  display:none;
}

.slt-quote .slt-trust-proof .slt-trust-logo{
  margin-bottom:16px;
}

.slt-quote .slt-google-stars{
  margin-top:20px;
  color:#ffce31;
  font-size:1.15rem;
  letter-spacing:.08em;
}

@media (max-width:575.98px){
  .slt-quote .slt-trust-logo{
    width:48px;
    height:48px;
    flex-basis:48px;
    border-radius:15px;
  }

  .slt-quote .slt-trust-logo i{
    font-size:1.3rem;
  }
}
/* =========================
   Final fix: compact secure checkout logos
   ========================= */
.slt-quote .slt-paytrust{
  margin-top:10px !important;
  padding:9px 10px !important;
  border-radius:14px !important;
}

.slt-quote .slt-paytrust__text{
  font-size:0.68rem !important;
  gap:6px !important;
}

.slt-quote .slt-paytrust__logos{
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  gap:5px !important;
  flex-wrap:wrap !important;
  margin-top:7px !important;
}

.slt-quote .slt-paytrust .slt-paylogo--img{
  width:46px !important;
  height:29px !important;
  padding:4px 6px !important;
  border-radius:9px !important;
}

.slt-quote .slt-paytrust .slt-paylogo--img img{
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:100% !important;
  object-fit:contain !important;
  display:block !important;
}
/* =========================
   Desktop quote/map height balance
   Fixes bottom gap between form and map
   ========================= */
@media (min-width: 992px){

  .slt-quote #quoteStage.slt-quote-split{
    height:calc(100dvh - var(--slt-header-h)) !important;
    min-height:calc(100dvh - var(--slt-header-h)) !important;
    align-items:stretch !important;
    overflow:hidden !important;
  }

  .slt-quote .slt-qpanel--left,
  .slt-quote .slt-veh-panel,
  .slt-quote .slt-mapwrap--right{
    height:100% !important;
    min-height:0 !important;
  }

  .slt-quote .slt-qpanel--left{
    overflow-y:auto !important;
    overscroll-behavior:contain;
  }

  .slt-quote .slt-mapwrap--right{
    padding:0 !important;
    background:#eef4ea !important;
    overflow:hidden !important;
  }

  .slt-quote .slt-mapwrap--right::before{
    display:none !important;
  }

  .slt-quote .slt-map--panel{
    width:100% !important;
    height:100% !important;
    min-height:0 !important;
    border:0 !important;
    border-radius:0 !important;
    box-shadow:none !important;
    clip-path:none !important;
  }

  .slt-quote .slt-map--panel::after{
    display:none !important;
  }

  .slt-quote .slt-map--panel .gm-style{
    border-radius:0 !important;
  }
}