:root{--dark:#020814;--navy:#06152b;--blue:#14b8d4;--blue2:#1296db;--text:#07111f;--muted:#4c6382;--line:#d7e4ef;--soft:#eef8ff}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:#f7fbff;color:var(--text);font-family:Arial,Helvetica,sans-serif}a{color:inherit}.hs-header{background:var(--dark);color:#fff;padding:18px 20px}.hs-header-inner,.hs-container{max-width:1120px;margin:0 auto}.hs-header-inner{display:flex;justify-content:space-between;gap:16px;align-items:center}.hs-logo{color:#fff;text-decoration:none;font-size:24px;font-weight:950;letter-spacing:-.06em}.hs-logo span{color:var(--blue)}.hs-nav{display:flex;gap:14px;align-items:center;flex-wrap:wrap}.hs-nav a,.hs-link-button{color:#fff;background:none;border:0;cursor:pointer;text-decoration:none;font-weight:850;font-size:14px;font-family:inherit}.hs-container{padding:38px 20px 90px}.hs-narrow{max-width:620px}.hs-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;padding:34px;border-radius:34px;background:radial-gradient(circle at 85% 20%,rgba(20,184,212,.25),transparent 30%),linear-gradient(135deg,#06152b,#020814);color:#fff;box-shadow:0 24px 70px rgba(7,17,31,.18)}.hs-hero h1{margin:0;font-size:clamp(42px,7vw,78px);line-height:.9;letter-spacing:-.075em}.hs-hero h1 span{color:var(--blue)}.hs-hero p{color:#dceeff;font-size:18px;line-height:1.65;font-weight:750}.hs-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 18px 44px rgba(7,17,31,.08)}.hs-dark-card{color:#fff;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16)}.hs-grid{display:grid;gap:18px}.hs-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.hs-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.hs-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}.hs-btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:14px 22px;border-radius:999px;border:0;background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;font-weight:950;text-decoration:none;cursor:pointer;font-family:inherit}.hs-btn-secondary{background:#fff;color:var(--text);border:1px solid var(--line)}.hs-form{display:grid;gap:14px}.hs-field{display:grid;gap:7px}.hs-field label{color:var(--muted);font-size:13px;font-weight:950}.hs-input,.hs-textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:13px 14px;font:inherit;background:#fff}.hs-textarea{min-height:96px;resize:vertical}.hs-kicker{color:var(--blue);font-weight:950;text-transform:uppercase;letter-spacing:.12em;font-size:12px}.hs-title{margin:10px 0 18px;font-size:clamp(32px,5vw,52px);line-height:.95;letter-spacing:-.06em}.hs-muted{color:var(--muted);line-height:1.6;font-weight:750}.hs-price{font-size:24px;color:var(--blue2);font-weight:950}.hs-service-card{text-align:left;cursor:pointer;transition:.2s}.hs-service-card:hover,.hs-service-card.selected{transform:translateY(-2px);border-color:var(--blue);box-shadow:0 0 0 3px rgba(20,184,212,.14)}.hs-step{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--blue);color:#fff;font-weight:950;margin-right:8px}.hs-summary-row{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line);padding:10px 0}.hs-summary-row strong{text-align:right}.hs-error,.hs-success,.hs-warning{border-radius:16px;padding:14px;margin-top:14px;font-weight:850}.hs-error{background:#fff1f2;color:#be123c}.hs-success{background:#ecfdf5;color:#047857}.hs-warning{background:#fffbeb;color:#92400e}.hs-scroll-target{scroll-margin-top:24px}.hs-booking-summary-sticky{position:sticky;top:18px;align-self:start}.hs-mini-item{padding:12px 0;border-bottom:1px solid var(--line)}.hs-mini-item:last-child{border-bottom:0}.hs-calendar{border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff}.hs-calendar-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;background:#f8fbff;border-bottom:1px solid var(--line)}.hs-calendar-title{font-weight:950;font-size:18px;letter-spacing:-.03em}.hs-calendar-nav{display:flex;gap:8px}.hs-calendar-nav button{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--text);font-size:22px;font-weight:950;cursor:pointer}.hs-calendar-days,.hs-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.hs-calendar-day-name{padding:11px 6px;text-align:center;color:var(--muted);font-size:12px;font-weight:950;text-transform:uppercase;border-bottom:1px solid var(--line)}.hs-calendar-date{min-height:70px;border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;color:var(--text);cursor:pointer;display:grid;align-content:center;justify-items:center;gap:5px;font-weight:950}.hs-calendar-date:nth-child(7n){border-right:0}.hs-calendar-date.is-empty{cursor:default;background:#f8fbff}.hs-calendar-date.is-unavailable{color:#b4c2d3;background:#f8fbff;cursor:not-allowed}.hs-calendar-date.is-available:hover{background:#ecfeff}.hs-calendar-date.is-selected{background:var(--blue);color:#fff}.hs-calendar-date-number{font-size:17px}.hs-calendar-slot-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:20px;padding:0 7px;border-radius:999px;background:#e7faff;color:var(--blue2);font-size:11px;font-weight:950}.hs-calendar-date.is-selected .hs-calendar-slot-count{background:rgba(255,255,255,.22);color:#fff}.hs-time-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px}.hs-time-btn{min-height:46px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--text);font-weight:950;cursor:pointer}.hs-time-btn:hover,.hs-time-btn.is-selected{background:var(--blue);color:#fff;border-color:var(--blue)}@media(max-width:860px){.hs-hero,.hs-grid-2,.hs-grid-3{grid-template-columns:1fr}.hs-header-inner{align-items:flex-start;flex-direction:column}.hs-booking-summary-sticky{position:static}}@media(max-width:640px){.hs-calendar-date{min-height:54px}.hs-calendar-slot-count{display:none}.hs-time-list{grid-template-columns:repeat(2,minmax(0,1fr))}}


.hs-vehicle-found {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  background: #f8fbff;
  display: none;
}
.hs-vehicle-found.visible { display: block; }
.hs-size-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 7px 11px;
  background: #ecfeff;
  color: #007c95;
  font-size: 12px;
  font-weight: 950;
  margin-top: 8px;
}


/* Vehicle lookup UI */
.hs-reg-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}

.hs-reg-input {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 950;
}

.hs-reg-btn {
  white-space: nowrap;
}

.hs-vehicle-card-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.hs-vehicle-card-top h3 {
  margin: 6px 0 4px;
}

@media (max-width: 640px) {
  .hs-reg-row {
    grid-template-columns: 1fr;
  }

  .hs-reg-btn {
    width: 100%;
  }

  .hs-vehicle-card-top {
    flex-direction: column;
  }
}


/* Vehicle lookup flow v3 */
.hs-reg-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}

.hs-reg-input {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 950;
}

.hs-reg-btn {
  white-space: nowrap;
}

.hs-vehicle-found,
.hs-saved-vehicle {
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 18px;
  background: #f8fbff;
  margin-top: 16px;
}

.hs-saved-vehicle {
  background: #ecfeff;
  border-color: rgba(20,184,212,.35);
  margin-bottom: 18px;
}

.hs-saved-vehicle p {
  margin: 8px 0 14px;
}

.hs-vehicle-card-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.hs-vehicle-card-top h3 {
  margin: 6px 0 4px;
}

.hs-size-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--blue), var(--blue2));
  color: #fff;
  font-size: 13px;
  font-weight: 950;
  white-space: nowrap;
}

.hs-vehicle-message {
  margin-top: 14px;
}

@media (max-width: 640px) {
  .hs-reg-row {
    grid-template-columns: 1fr;
  }

  .hs-reg-btn {
    width: 100%;
  }

  .hs-vehicle-card-top {
    flex-direction: column;
  }
}


.hs-mini-item strong {
  color: var(--text);
}

.hs-mini-item span {
  color: var(--muted);
  font-weight: 750;
  line-height: 1.5;
}


/* Hydro Shine-style customer portal dashboard */
.hs-portal-body {
  background: #f6f5f8;
}

.hs-portal-sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 46px;
  background: #e7f5ff;
  border-right: 1px solid #cbe5f7;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px 7px;
  gap: 18px;
  z-index: 20;
}

.hs-portal-icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border: 0;
  background: transparent;
  border-radius: 8px;
  text-decoration: none;
  font-size: 19px;
  cursor: pointer;
}

.hs-portal-icon.active,
.hs-portal-icon:hover {
  background: #ffffff;
  box-shadow: 0 2px 8px rgba(7,17,31,.08);
}

.hs-portal-logout {
  margin-top: auto;
}

.hs-portal-main {
  margin-left: 46px;
  padding: 24px 28px 80px;
  max-width: 1480px;
}

.hs-portal-topbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 14px;
}

.hs-portal-greeting {
  margin: 0;
  color: #4f5870;
  font-size: 20px;
}

.hs-portal-topbar h1 {
  margin: 5px 0 0;
  color: #111827;
  letter-spacing: -0.04em;
}

.hs-portal-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.hs-orbisx-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 22px;
  align-items: start;
}

.hs-orbisx-card {
  background: #fff;
  border-radius: 5px;
  box-shadow: 0 4px 20px rgba(27, 35, 70, .08);
  padding: 24px;
}

.hs-orbisx-large {
  min-height: 390px;
}

.hs-orbisx-card-title {
  border: 1px solid #d4dbe5;
  background: linear-gradient(#fff,#f8fafc);
  border-radius: 3px;
  padding: 12px 16px;
  color: #0b84dc;
  font-size: 20px;
  font-weight: 800;
  margin-bottom: 16px;
}

.hs-statement-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px 22px;
}

.hs-statement-box {
  min-height: 118px;
  color: #fff;
  text-align: center;
  border-radius: 2px;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.08);
  padding: 12px 10px;
}

.hs-statement-box strong {
  display: block;
  font-size: 16px;
  border-bottom: 1px solid rgba(0,0,0,.12);
  padding-bottom: 8px;
}

.hs-statement-box span {
  display: block;
  font-size: 30px;
  margin: 12px 0 4px;
}

.hs-statement-box small {
  display: block;
  font-size: 13px;
  line-height: 1.4;
}

.hs-statement-box.blue { background: linear-gradient(135deg,#439de8,#227dd1); }
.hs-statement-box.teal { background: linear-gradient(135deg,#67c8d9,#0ba0c2); }
.hs-statement-box.green { background: linear-gradient(135deg,#7fdb72,#34bf31); }
.hs-statement-box.yellow { background: linear-gradient(135deg,#ffe760,#ffc900); }

.hs-review-box {
  margin-top: 20px;
}

.hs-review-box h3 {
  color: #0879d8;
  margin-bottom: 8px;
}

.hs-green-btn {
  display: inline-flex;
  border: 0;
  background: #16c05b;
  color: #fff;
  text-decoration: none;
  border-radius: 4px;
  padding: 10px 14px;
  font-weight: 800;
  cursor: pointer;
}

.hs-orbisx-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-top: 26px;
}

.hs-orbisx-mini-card {
  background: #fff;
  border-radius: 5px;
  box-shadow: 0 4px 20px rgba(27, 35, 70, .08);
  padding: 22px 24px;
  display: flex;
  gap: 18px;
  justify-content: space-between;
  align-items: center;
}

.hs-orbisx-mini-card h3 {
  margin: 0;
  color: #374151;
}

.hs-outline-btn {
  border: 1px solid #d9e2ef;
  border-radius: 4px;
  background: #f9fbff;
  color: #2467b8;
  font-weight: 750;
  padding: 10px 16px;
  text-decoration: none;
  box-shadow: 0 3px 8px rgba(7,17,31,.08);
}

.hs-full-width {
  margin-top: 26px;
}

.hs-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}

.hs-detail-grid div {
  border: 1px solid #e0e7f0;
  background: #fbfdff;
  padding: 12px;
  border-radius: 4px;
}

.hs-detail-grid span {
  display: block;
  color: #667085;
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 5px;
}

.hs-detail-grid strong {
  color: #111827;
  overflow-wrap: anywhere;
}

.hs-table-wrap {
  overflow-x: auto;
}

.hs-portal-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
}

.hs-portal-table th {
  text-align: left;
  background: #f7fafc;
  color: #4b5563;
  border-bottom: 1px solid #dbe5ef;
  padding: 12px;
  font-size: 13px;
}

.hs-portal-table td {
  border-bottom: 1px solid #eef2f7;
  padding: 12px;
  color: #1f2937;
  font-weight: 650;
}

@media (max-width: 1100px) {
  .hs-orbisx-grid,
  .hs-orbisx-strip,
  .hs-detail-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .hs-portal-sidebar {
    position: static;
    width: auto;
    height: auto;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
  }

  .hs-portal-main {
    margin-left: 0;
    padding: 20px;
  }

  .hs-portal-topbar,
  .hs-orbisx-mini-card {
    flex-direction: column;
    align-items: stretch;
  }

  .hs-statement-grid {
    grid-template-columns: 1fr;
  }
}



/* Dashboard centred card layout */
.hs-portal-main {
  max-width: 1320px;
  margin-left: 46px;
  margin-right: auto;
}

.hs-orbisx-grid,
.hs-orbisx-strip {
  justify-content: center;
}

.hs-orbisx-grid {
  grid-template-columns: minmax(320px, 420px) minmax(320px, 420px) minmax(320px, 420px);
}

.hs-orbisx-card,
.hs-orbisx-mini-card {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.hs-full-width {
  max-width: 1290px;
  margin-left: auto;
  margin-right: auto;
}

.hs-orbisx-strip {
  grid-template-columns: minmax(320px, 620px) minmax(320px, 620px);
}

@media (max-width: 1100px) {
  .hs-portal-main {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
  }

  .hs-orbisx-grid,
  .hs-orbisx-strip {
    grid-template-columns: minmax(280px, 680px);
  }

  .hs-full-width {
    max-width: 680px;
  }
}

@media (max-width: 720px) {
  .hs-portal-main {
    margin-left: 0;
    max-width: 100%;
  }

  .hs-orbisx-grid,
  .hs-orbisx-strip {
    grid-template-columns: 1fr;
  }

  .hs-full-width {
    max-width: 100%;
  }
}



/* Hover expanding customer portal sidebar */
.hs-portal-sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 46px;
  background: #e7f5ff;
  border-right: 1px solid #cbe5f7;
  box-shadow: 5px 0 18px rgba(7, 17, 31, .10);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 12px 7px;
  gap: 8px;
  overflow-x: hidden;
  overflow-y: auto;
  z-index: 100;
  transition: width .22s ease;
}

.hs-portal-sidebar:hover {
  width: 205px;
}

.hs-portal-nav-item {
  width: 100%;
  min-height: 38px;
  border: 0;
  background: transparent;
  color: #1476d4;
  border-radius: 9px;
  display: grid;
  grid-template-columns: 30px 1fr;
  align-items: center;
  gap: 4px;
  text-decoration: none;
  font: inherit;
  font-weight: 750;
  cursor: pointer;
  padding: 3px 8px 3px 0;
  white-space: nowrap;
  text-align: left;
}

.hs-portal-nav-item:hover,
.hs-portal-nav-item.active {
  background: rgba(255,255,255,.78);
  box-shadow: 0 2px 8px rgba(7,17,31,.07);
}

.hs-portal-nav-icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  font-size: 18px;
  flex: 0 0 auto;
}

.hs-portal-nav-label {
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity .16s ease, transform .16s ease;
  overflow: hidden;
  font-size: 16px;
}

.hs-portal-sidebar:hover .hs-portal-nav-label {
  opacity: 1;
  transform: translateX(0);
}

.hs-portal-logout {
  margin-top: auto;
}

/* Hide the old icon button styling if older markup remains cached */
.hs-portal-icon {
  width: 30px;
  height: 30px;
}

/* Keep main content clear of the collapsed sidebar */
.hs-portal-main {
  margin-left: 46px;
  transition: margin-left .22s ease;
}

/* Optional: when sidebar opens, keep content stable rather than pushing it */
.hs-portal-sidebar:hover + .hs-portal-main {
  margin-left: 46px;
}

@media (max-width: 720px) {
  .hs-portal-sidebar {
    position: sticky;
    top: 0;
    width: 100%;
    height: auto;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 8px;
  }

  .hs-portal-sidebar:hover {
    width: 100%;
  }

  .hs-portal-nav-item {
    width: auto;
    min-width: 38px;
    grid-template-columns: 30px;
    padding: 3px 4px;
  }

  .hs-portal-nav-label {
    display: none;
  }

  .hs-portal-logout {
    margin-top: 0;
    margin-left: auto;
  }

  .hs-portal-main,
  .hs-portal-sidebar:hover + .hs-portal-main {
    margin-left: 0;
  }
}


/* Booking vehicle flow fix */
.hs-saved-vehicle,
.hs-vehicle-found {
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 18px;
  background: #f8fbff;
  margin-top: 16px;
}

.hs-saved-vehicle {
  background: #ecfeff;
  border-color: rgba(20,184,212,.35);
  margin-bottom: 18px;
}

.hs-saved-vehicle-list {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.hs-saved-vehicle-choice {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 14px;
  cursor: pointer;
}

.hs-saved-vehicle-choice:hover {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(20,184,212,.12);
}

.hs-saved-vehicle-choice strong,
.hs-saved-vehicle-choice small {
  display: block;
}

.hs-saved-vehicle-choice small {
  color: var(--muted);
  font-weight: 750;
  margin-top: 3px;
}

.hs-reg-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}

.hs-reg-input {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 950;
}

.hs-reg-btn {
  white-space: nowrap;
}

.hs-vehicle-card-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.hs-vehicle-card-top h3 {
  margin: 6px 0 4px;
}

.hs-size-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--blue), var(--blue2));
  color: #fff;
  font-size: 13px;
  font-weight: 950;
  white-space: nowrap;
}

.hs-vehicle-message {
  margin-top: 14px;
}

@media (max-width: 640px) {
  .hs-reg-row {
    grid-template-columns: 1fr;
  }

  .hs-reg-btn {
    width: 100%;
  }

  .hs-vehicle-card-top {
    flex-direction: column;
  }
}


/* Dashboard vehicles card */
.hs-section-title-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}

.hs-add-link {
  color: #4b5563;
  font-size: 17px;
  font-weight: 750;
  text-decoration: none;
}

.hs-add-link:hover {
  color: var(--blue2);
}

.hs-vehicle-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(240px, 1fr));
  gap: 18px;
}


.hs-empty-vehicles-card {
  border: 1px dashed #cbd5e1;
  background: #f8fafc;
  min-height: 170px;
  border-radius: 8px;
  padding: 22px;
  text-align: center;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
}

.hs-empty-vehicles-icon {
  font-size: 30px;
  line-height: 1;
}

.hs-empty-vehicles-card h3 {
  margin: 4px 0 0;
  color: #1f2937;
  font-size: 20px;
  font-weight: 800;
}

.hs-empty-vehicles-card p {
  margin: 0 0 8px;
}

.hs-dashboard-vehicle-card {
  border: 1px solid #dbe5ef;
  background: #fff;
  min-height: 190px;
  border-radius: 3px;
  padding: 18px;
  text-align: center;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
}

.hs-dashboard-vehicle-star {
  font-size: 30px;
  line-height: 1;
}

.hs-dashboard-vehicle-card h3 {
  margin: 4px 0 0;
  color: #4b5563;
  font-size: 20px;
  font-weight: 500;
}

.hs-dashboard-vehicle-card p {
  margin: 0;
}

.hs-dashboard-vehicle-card small {
  display: block;
  color: #9ca3af;
  margin-top: 8px;
}

.hs-blue-small-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: #328fe8;
  color: #fff;
  border-radius: 4px;
  padding: 8px 12px;
  font-weight: 750;
  cursor: pointer;
  box-shadow: 0 3px 8px rgba(7,17,31,.15);
}

.hs-blue-small-btn:hover {
  filter: brightness(.96);
}

@media (max-width: 900px) {
  .hs-vehicle-dashboard-grid {
    grid-template-columns: 1fr;
  }
}


/* Menu booking/vehicles link fix */
.hs-portal-nav-item[title="Booking"] .hs-portal-nav-icon {
  font-size: 18px;
}

.hs-portal-nav-item[title="Vehicles"] .hs-portal-nav-icon {
  font-size: 18px;
}


/* Profile edit + locked booking details */
.hs-readonly-input {
  background: #f4f7fb !important;
  color: #475467 !important;
  cursor: not-allowed;
}

.hs-profile-edit-form {
  margin-top: 18px;
  border: 1px solid #dbe5ef;
  border-radius: 14px;
  padding: 18px;
  background: #fbfdff;
}

.hs-inline-button {
  border: 0;
  background: transparent;
  cursor: pointer;
}

.hs-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}

#customerDetailsLockedNotice {
  margin-top: 16px;
}


/* Animated loading spinner */
.hs-loading-row {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--muted);
  font-weight: 850;
  padding: 10px 0;
}

.hs-spinner {
  width: 24px;
  height: 24px;
  border: 3px solid rgba(20, 184, 212, .22);
  border-top-color: var(--blue);
  border-radius: 999px;
  animation: hs-spin .75s linear infinite;
  flex: 0 0 auto;
}

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


/* Saved vehicle locked fields */
.hs-readonly-input {
  background: #f4f7fb !important;
  color: #475467 !important;
  cursor: not-allowed !important;
}

#savedVehicleLockedNotice {
  margin: 14px 0;
}

/* Hydro Shine PWA install banner */
.hs-pwa-install-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 620px;
  margin: 0 auto;
  padding: 12px 14px;
  border: 1px solid rgba(5, 171, 217, 0.22);
  border-radius: 18px;
  background: rgba(255,255,255,0.98);
  box-shadow: 0 18px 45px rgba(15, 32, 61, 0.18);
  backdrop-filter: blur(14px);
}

.hs-pwa-install-icon img {
  width: 46px;
  height: 46px;
  border-radius: 13px;
  display: block;
}

.hs-pwa-install-copy {
  flex: 1;
  min-width: 0;
  color: #17314f;
  line-height: 1.25;
}

.hs-pwa-install-copy strong,
.hs-pwa-install-copy span {
  display: block;
}

.hs-pwa-install-copy span {
  margin-top: 2px;
  color: #61728a;
  font-size: 13px;
}

.hs-pwa-install-btn {
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  background: #05abd9;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  white-space: nowrap;
}

.hs-pwa-install-close {
  border: 0;
  background: transparent;
  color: #61728a;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  padding: 4px 2px;
}

@media (max-width: 560px) {
  .hs-pwa-install-banner {
    left: 10px;
    right: 10px;
    bottom: 10px;
    align-items: flex-start;
  }

  .hs-pwa-install-btn {
    padding: 9px 11px;
    font-size: 12px;
  }
}


/* Mobile hamburger slide-out portal menu */
.hs-mobile-menu-toggle,
.hs-mobile-menu-backdrop {
  display: none;
}

@media (max-width: 720px) {
  .hs-portal-body {
    padding-top: 58px;
  }

  .hs-mobile-menu-toggle {
    position: fixed;
    top: 12px;
    left: 12px;
    z-index: 260;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(5, 171, 217, .28);
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(7, 17, 31, .16);
    display: grid;
    place-content: center;
    gap: 5px;
    cursor: pointer;
  }

  .hs-mobile-menu-toggle span {
    width: 21px;
    height: 2px;
    display: block;
    border-radius: 999px;
    background: #0f7ed8;
    transition: transform .2s ease, opacity .2s ease;
  }

  body.hs-mobile-menu-open .hs-mobile-menu-toggle span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  body.hs-mobile-menu-open .hs-mobile-menu-toggle span:nth-child(2) {
    opacity: 0;
  }

  body.hs-mobile-menu-open .hs-mobile-menu-toggle span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  .hs-mobile-menu-backdrop {
    position: fixed;
    inset: 0;
    z-index: 210;
    display: block;
    background: rgba(7, 17, 31, .42);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .2s ease, visibility .2s ease;
  }

  body.hs-mobile-menu-open .hs-mobile-menu-backdrop {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .hs-portal-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: min(82vw, 310px);
    max-width: 310px;
    height: 100vh;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    gap: 8px;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 72px 14px 18px;
    z-index: 240;
    transform: translateX(-106%);
    transition: transform .24s ease;
    box-shadow: 18px 0 38px rgba(7, 17, 31, .22);
  }

  body.hs-mobile-menu-open .hs-portal-sidebar {
    transform: translateX(0);
  }

  .hs-portal-sidebar:hover {
    width: min(82vw, 310px);
  }

  .hs-portal-nav-item {
    width: 100%;
    min-width: 0;
    min-height: 44px;
    grid-template-columns: 34px 1fr;
    padding: 5px 10px 5px 2px;
  }

  .hs-portal-nav-icon {
    width: 34px;
    height: 34px;
  }

  .hs-portal-nav-label {
    display: block;
    opacity: 1;
    transform: none;
    font-size: 16px;
  }

  .hs-portal-logout {
    margin-top: auto;
    margin-left: 0;
  }

  .hs-portal-main,
  .hs-portal-sidebar:hover + .hs-portal-main {
    margin-left: 0;
    padding-top: 10px;
  }

  body.hs-mobile-menu-open {
    overflow: hidden;
  }
}

/* Google Places address autocomplete */
.pac-container {
  z-index: 99999 !important;
  border-radius: 14px;
  margin-top: 6px;
  box-shadow: 0 18px 45px rgba(6, 31, 68, 0.18);
  border: 1px solid rgba(0, 174, 239, 0.16);
  font-family: inherit;
}
.pac-item {
  padding: 10px 12px;
  font-size: 14px;
  cursor: pointer;
}
.pac-item-query {
  font-size: 14px;
}
input[data-hs-address-autocomplete] {
  background-image: linear-gradient(90deg, rgba(20,180,216,.08), rgba(255,255,255,0));
}


/* Release-ready Hydro Shine index page */
.hs-home-body {
  background:
    radial-gradient(circle at 8% 8%, rgba(20,184,212,.16), transparent 28%),
    radial-gradient(circle at 94% 18%, rgba(18,150,219,.14), transparent 26%),
    #f7fbff;
}

.hs-home-header {
  position: sticky;
  top: 0;
  z-index: 40;
  box-shadow: 0 10px 30px rgba(2,8,20,.18);
}

.hs-home-container {
  padding-top: 28px;
}

.hs-home-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 86% 18%, rgba(20,184,212,.36), transparent 31%),
    radial-gradient(circle at 10% 90%, rgba(18,150,219,.2), transparent 28%),
    linear-gradient(135deg,#06152b,#020814);
}

.hs-home-hero::after {
  content: "";
  position: absolute;
  width: 260px;
  height: 260px;
  right: -90px;
  bottom: -110px;
  border-radius: 999px;
  border: 34px solid rgba(255,255,255,.06);
  pointer-events: none;
}

.hs-home-hero-copy,
.hs-home-app-card {
  position: relative;
  z-index: 1;
}

.hs-home-app-card {
  text-align: center;
}

.hs-home-app-icon {
  width: 112px;
  height: 112px;
  border-radius: 24px;
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
  margin-bottom: 14px;
}

.hs-home-app-card h2,
.hs-home-section h2,
.hs-home-cta h2,
.hs-home-services-card h2 {
  margin: 8px 0 10px;
  letter-spacing: -.055em;
  line-height: 1;
}

.hs-home-check-list {
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
  display: grid;
  gap: 10px;
  text-align: left;
}

.hs-home-check-list li {
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.1);
  font-weight: 900;
}

.hs-home-check-list li::before {
  content: "✓";
  color: var(--blue);
  margin-right: 8px;
  font-weight: 950;
}

.hs-home-section {
  margin-top: 34px;
}

.hs-home-section-head {
  max-width: 760px;
  margin-bottom: 18px;
}

.hs-home-section-head h2 {
  font-size: clamp(30px, 4.6vw, 50px);
}

.hs-home-section-head p,
.hs-home-feature-card p,
.hs-home-services-card p,
.hs-home-steps p,
.hs-home-cta p {
  color: var(--muted);
  line-height: 1.65;
  font-weight: 750;
}

.hs-home-feature-card h3,
.hs-home-steps h3 {
  margin: 10px 0 8px;
  letter-spacing: -.03em;
}

.hs-home-feature-icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: #ecfeff;
  font-size: 24px;
}

.hs-home-services-card {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 20px;
  align-items: center;
  background: linear-gradient(135deg,#ffffff,#f0fbff);
}

.hs-home-service-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.hs-home-service-list span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 13px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
  color: var(--text);
  font-weight: 900;
  box-shadow: 0 10px 26px rgba(7,17,31,.06);
}

.hs-home-cta {
  margin-top: 34px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  background: #06152b;
  color: #fff;
}

.hs-home-cta p {
  color: #dceeff;
}

.hs-home-footer {
  padding: 24px 20px;
  background: #020814;
  color: #fff;
}

.hs-home-footer .hs-header-inner {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.hs-home-footer span {
  color: #dceeff;
  font-weight: 750;
}

@media (max-width: 860px) {
  .hs-home-services-card,
  .hs-home-cta {
    grid-template-columns: 1fr;
    display: grid;
  }

  .hs-home-cta .hs-actions {
    margin-top: 0;
  }
}

@media (max-width: 640px) {
  .hs-home-container {
    padding: 18px 14px 82px;
  }

  .hs-home-hero {
    padding: 26px 20px;
    border-radius: 26px;
  }

  .hs-home-hero h1 {
    font-size: clamp(40px, 13vw, 58px);
  }

  .hs-home-app-icon {
    width: 92px;
    height: 92px;
  }

  .hs-home-section,
  .hs-home-cta {
    margin-top: 24px;
  }
}

/* Release booking checkout note */
.hs-payment-note{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:14px 16px;
  border-radius:16px;
  background:#ecfeff;
  border:1px solid rgba(6,182,212,.22);
  color:#315070;
  font-size:14px;
  line-height:1.45;
}
.hs-payment-note strong{
  color:#075985;
  font-size:15px;
}

/* Desktop dashboard centring fix
   Centres the customer dashboard content within the available screen area,
   while keeping it clear of the collapsed sidebar. */
@media (min-width: 1101px) {
  .hs-portal-main,
  .hs-portal-sidebar:hover + .hs-portal-main {
    width: min(calc(100vw - 46px), 1320px);
    max-width: 1320px;
    margin-left: calc(46px + max(28px, (100vw - 46px - 1320px) / 2));
    margin-right: auto;
    padding-left: 28px;
    padding-right: 28px;
  }

  .hs-portal-topbar,
  .hs-orbisx-grid,
  .hs-orbisx-strip,
  .hs-full-width {
    width: 100%;
  }

  .hs-orbisx-grid,
  .hs-orbisx-strip,
  .hs-vehicle-dashboard-grid {
    justify-content: center;
  }
}


/* Maintenance scheme announcement */
.hs-announcement-card {
  border: 1px solid rgba(5, 171, 217, 0.22);
  border-radius: 16px;
  padding: 16px;
  background: #f7fcff;
  box-shadow: 0 10px 24px rgba(10, 35, 66, 0.06);
}

.hs-announcement-card strong {
  display: block;
  color: #004f7a;
  font-size: 1.02rem;
  line-height: 1.35;
  margin-bottom: 8px;
}

.hs-announcement-card p {
  margin: 0 0 10px;
  color: #24425f;
  line-height: 1.45;
}

.hs-announcement-card p:last-child {
  margin-bottom: 0;
}

.hs-maintenance-eligible {
  background: linear-gradient(135deg, #eafff5 0%, #eefaff 100%);
  border-color: rgba(14, 183, 113, 0.32);
}

.hs-maintenance-eligible .hs-outline-btn {
  margin-top: 4px;
  display: inline-flex;
  width: auto;
}

.hs-upcoming-appointment {
  border-left: 4px solid #0ea5e9;
}


/* Completed appointments */

.hs-announcement-card.hs-maintenance-eligible {
  border-left: 4px solid #10b981;
}

.hs-announcement-card.hs-upcoming-appointment {
  border-left: 4px solid #05abd9;
}

/* Completed appointments Book Again action */
.hs-book-again-btn {
  white-space: nowrap;
  padding: 8px 14px;
  border-radius: 999px;
}

@media (max-width: 720px) {
  .hs-book-again-btn {
    width: 100%;
    margin-top: 4px;
  }
}

/* Service add-ons / optional extras */
.hs-addons-list{display:grid;gap:12px;margin-top:14px}.hs-addon-card{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;border:1px solid var(--line);border-radius:18px;padding:14px 16px;background:#fff;cursor:pointer;transition:.2s}.hs-addon-card:hover{border-color:var(--blue);box-shadow:0 0 0 3px rgba(20,184,212,.12)}.hs-addon-card input{width:20px;height:20px;accent-color:var(--blue)}.hs-addon-main{display:grid;gap:4px}.hs-addon-main strong{font-weight:950}.hs-addon-main small{color:var(--muted);font-weight:750;line-height:1.4}.hs-addon-price{font-weight:950;color:var(--blue2);white-space:nowrap}.hs-info-box{display:grid;gap:5px;border:1px solid var(--line);border-radius:18px;padding:16px;background:#f8fbff}.hs-info-box span{color:var(--muted);font-weight:750;line-height:1.5}@media(max-width:640px){.hs-addon-card{grid-template-columns:auto 1fr}.hs-addon-price{grid-column:2}}


/* Hydro Shine actual logo in header bars */
.hs-logo-image-link{display:flex;align-items:center;text-decoration:none;line-height:1;min-width:0;flex:0 0 auto}
.hs-header-logo-img{display:block;height:54px;width:auto;max-width:300px;object-fit:contain}
.hs-home-header .hs-header-logo-img{height:58px;max-width:340px}
@media(max-width:860px){.hs-header-logo-img{height:46px;max-width:260px}.hs-home-header .hs-header-logo-img{height:50px;max-width:280px}}
@media(max-width:520px){.hs-header-logo-img{height:40px;max-width:220px}.hs-home-header .hs-header-logo-img{height:44px;max-width:240px}}
