/* Sote Theme — original variables + logo fix */
:root {
  --cityride-font: "Plus Jakarta Sans", "Manrope", Arial, sans-serif;
  --cityride-heading-font: "Plus Jakarta Sans", "Manrope", Arial, sans-serif;
  --cityride-special-font: "Plus Jakarta Sans", "Manrope", Arial, sans-serif;
  --cityride-font-two: "Plus Jakarta Sans", "Manrope", Arial, sans-serif;
  --cityride-base: #f89c10;
  --cityride-base-rgb: 248, 156, 16;
  --cityride-black: #141414;
  --cityride-black-rgb: 20, 20, 20;
  --cityride-black2: #000000;
  --cityride-black2-rgb: 0, 0, 0;
  --cityride-white: #ffffff;
  --cityride-white-rgb: 255, 255, 255;
  --cityride-white2: #F4F1EA;
  --cityride-white2-rgb: 244, 241, 234;
  --cityride-text: #838383;
  --cityride-text-rgb: 131, 131, 131;
  --cityride-gray: #DFDFDF;
  --cityride-gray-rgb: 223, 223, 223;
  --cityride-gray2: #717880;
  --cityride-gray2-rgb: 113, 120, 128;
  --cityride-gray3: #CFD7E0;
  --cityride-gray3-rgb: 207, 215, 224;
  --cityride-border-color: #DFDFDF;
  --cityride-border-color-rgb: 223, 223, 223;
  --cityride-letter-space: -0.03em;
  --section-space: 120px;
  --section-space2: 118px;
}

/* ─────────────────────────────────────────────
   LOGO — transparent, consistent 60px height
   ─────────────────────────────────────────────*/

/* Target every possible logo selector with max specificity */
html body .main-header__logo img,
html body .main-header__logo .sote-site-logo,
html body .main-header__logo .sote-brand__image,
html body .main-header__logo img[src*="sote-logo"],
html body .sote-brand .sote-brand__image,
html body .sote-brand__image,
html body .sote-site-logo,
html body .logo-box img,
html body .logo-retina img,
html body .sidebar-one__logo img,
html body .mobile-nav__content img[src*="sote-logo"],
html body .mobile-nav__content .sote-site-logo {
  display: block !important;
  height: 74px !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  filter: none !important;
  -webkit-filter: none !important;
  object-fit: contain !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

/* Footer logo — same size */
html body .main-footer.sote-footer .sote-footer__logo,
html body .main-footer .sote-footer__logo,
html body .sote-footer .sote-footer__logo,
html body .footer-widget__logo img {
  display: block !important;
  height: 60px !important;
  width: auto !important;
  max-width: none !important;
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  filter: none !important;
  -webkit-filter: none !important;
  object-fit: contain !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

/* Logo link wrappers — purely transparent */
html body .sote-brand,
html body .sote-brand--light,
html body .main-header__logo a,
html body .sote-footer__logo-link,
html body .main-footer.sote-footer .sote-footer__logo-link,
html body .logo-box a,
html body .logo-retina a {
  display: inline-flex !important;
  align-items: center !important;
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

@media (max-width: 767px) {
  html body .main-header__logo img,
  html body .sote-brand__image,
  html body .sote-site-logo {
    height: 46px !important;
  }
  html body .main-footer.sote-footer .sote-footer__logo {
    height: 46px !important;
  }
}

/* Site-wide SOTE optimization: black, orange and white clean UI */
:root {
  --sote-black: #0b0b0b;
  --sote-ink: #17120d;
  --sote-orange: #f89c10;
  --sote-orange-deep: #db7600;
  --sote-white: #ffffff;
  --sote-surface: #fffdf8;
  --sote-soft: #f7f1e8;
  --sote-line: rgba(23, 18, 13, 0.1);
  --sote-soft-shadow: 0 18px 48px rgba(23, 18, 13, 0.08);
  --sote-font: "Plus Jakarta Sans", "Manrope", Arial, sans-serif;
  --cityride-font: var(--sote-font);
  --cityride-heading-font: var(--sote-font);
  --cityride-special-font: var(--sote-font);
  --cityride-font-two: var(--sote-font);
  --cityride-base: var(--sote-orange);
  --cityride-base-rgb: 248, 156, 16;
  --cityride-black: var(--sote-black);
  --cityride-black-rgb: 11, 11, 11;
  --cityride-white: var(--sote-white);
  --cityride-text: #52565a;
  --cityride-letter-space: 0;
}

html body {
  font-family: var(--sote-font) !important;
  background: var(--sote-white) !important;
  color: #3f4246;
  font-size: 16px;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

html body h1,
html body h2,
html body h3,
html body h4,
html body h5,
html body h6 {
  font-family: var(--sote-font) !important;
  font-weight: 800;
  letter-spacing: 0 !important;
}

html body p,
html body li,
html body a,
html body button,
html body input,
html body select,
html body textarea {
  font-family: var(--sote-font) !important;
  letter-spacing: 0 !important;
}

html body a {
  text-decoration: none;
}

html body a:hover {
  color: var(--sote-orange-deep);
}

/* Header cleanup */
html body .main-header,
html body .sticky-header--cloned,
html body .sote-header {
  background: rgba(255, 255, 255, 0.96) !important;
  border-bottom: 1px solid var(--sote-line) !important;
  box-shadow: 0 8px 28px rgba(23, 18, 13, 0.05);
  backdrop-filter: blur(14px);
}

html body .main-menu .main-menu__list > li > a {
  color: var(--sote-ink) !important;
  letter-spacing: 0.02em !important;
}

html body .main-menu .main-menu__list > li:hover > a,
html body .main-menu .main-menu__list > li.current > a {
  color: var(--sote-orange-deep) !important;
}

html body .main-menu .main-menu__list ul {
  border: 1px solid var(--sote-line) !important;
  border-radius: 8px !important;
  background: var(--sote-white) !important;
  box-shadow: 0 20px 52px rgba(23, 18, 13, 0.12) !important;
}

html body .main-menu .main-menu__list ul li a {
  color: var(--sote-ink) !important;
}

html body .main-menu .main-menu__list ul li a:hover {
  color: var(--sote-orange-deep) !important;
  background: rgba(248, 156, 16, 0.1) !important;
}

html body .main-header__cart {
  display: none !important;
}

/* Buttons and app CTAs */
html body .cityride-btn,
html body .cityride-btn--primary,
html body .cityride-btn--secondary,
html body .main-header__btn,
html body .sote-header__cta,
html body .sote-footer__app-actions a,
html body .sote-store-btn {
  min-height: 46px;
  border-radius: 999px !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

html body .cityride-btn,
html body .cityride-btn--primary,
html body .main-header__btn {
  background: var(--sote-orange) !important;
  color: var(--sote-black) !important;
  border-color: var(--sote-orange) !important;
}

html body .cityride-btn:hover,
html body .cityride-btn--primary:hover,
html body .main-header__btn:hover {
  background: var(--sote-black) !important;
  color: var(--sote-white) !important;
  border-color: var(--sote-black) !important;
}

html body .cityride-btn--secondary,
html body .cityride-btn--white {
  background: var(--sote-white) !important;
  color: var(--sote-black) !important;
  border: 1px solid var(--sote-line) !important;
}

html body .cityride-btn--secondary:hover,
html body .cityride-btn--white:hover {
  background: var(--sote-black) !important;
  color: var(--sote-white) !important;
  border-color: var(--sote-black) !important;
}

html body .cityride-btn--black {
  background: var(--sote-black) !important;
  color: var(--sote-white) !important;
  border-color: var(--sote-black) !important;
}

html body .cityride-btn--black:hover {
  background: var(--sote-orange) !important;
  color: var(--sote-black) !important;
  border-color: var(--sote-orange) !important;
}

/* Clean section rhythm */
html body .page-wrapper {
  background: var(--sote-white);
}

html body .page-header {
  background: var(--sote-black) !important;
}

html body .page-header__bg::before {
  background: linear-gradient(90deg, rgba(11, 11, 11, 0.86) 0%, rgba(11, 11, 11, 0.56) 100%) !important;
}

html body .sote-section,
html body .sote-v2-section,
html body .sote-about-section,
html body .sote-services-section,
html body .sote-contact-main section,
html body .sote-faq-main section,
html body .sote-blog-main section,
html body .sote-news-main section,
html body .sote-article-main section,
html body .sote-airport-main section,
html body .sote-cities-main section {
  scroll-margin-top: 112px;
}

/* Cards: consistent, cleaner than the old template */
html body .sote-v2-overview__card,
html body .sote-v2-service-card,
html body .sote-city-card,
html body .sote-v2-city-card,
html body .sote-about-value,
html body .sote-services-card,
html body .sote-service-card,
html body .sote-contact-info-card,
html body .sote-contact-channel,
html body .sote-faq-category-card,
html body .sote-faq-panel,
html body .sote-blog-card,
html body .sote-news-card,
html body .sote-article-card,
html body .sote-airport-quick-grid article,
html body .sote-airport-step-grid article,
html body .sote-airport-info-grid article,
html body .sote-cities-search-card,
html body .sote-cities-country,
html body .sote-cities-support article,
html body .sote-legal-card,
html body .sote-fleet-card,
html body .sote-driver-card {
  border-radius: 8px !important;
  background: var(--sote-white) !important;
  border: 1px solid var(--sote-line) !important;
  box-shadow: var(--sote-soft-shadow) !important;
}

html body .sote-v2-overview__card:hover,
html body .sote-v2-service-card:hover,
html body .sote-city-card:hover,
html body .sote-v2-city-card:hover,
html body .sote-services-card:hover,
html body .sote-contact-info-card:hover,
html body .sote-faq-category-card:hover,
html body .sote-blog-card:hover,
html body .sote-news-card:hover {
  border-color: rgba(248, 156, 16, 0.32) !important;
  box-shadow: 0 24px 62px rgba(23, 18, 13, 0.12) !important;
}

html body .sote-v2-overview__icon,
html body .sote-v2-service-card__icon,
html body .sote-services-card__icon,
html body .sote-contact-hero__chips span,
html body .sote-faq-hero__chips span,
html body .sote-airport-quick-grid i,
html body .sote-cities-search i {
  background: rgba(248, 156, 16, 0.14) !important;
  color: var(--sote-orange-deep) !important;
}

/* Hero consistency */
html body .sote-hero,
html body .sote-v2-hero,
html body .sote-city-hero,
html body .sote-cities-hero,
html body .sote-services-hero,
html body .sote-about-hero,
html body .sote-contact-hero,
html body .sote-faq-hero,
html body .sote-blog-hero,
html body .sote-news-hero,
html body .sote-article-hero {
  background-color: var(--sote-black) !important;
}

html body .sote-eyebrow,
html body .sote-v2-eyebrow {
  letter-spacing: 0.08em !important;
  border-radius: 999px !important;
}

/* Forms */
html body input,
html body select,
html body textarea,
html body .form-control {
  border-radius: 8px !important;
}

html body input:focus,
html body select:focus,
html body textarea:focus,
html body .form-control:focus {
  border-color: var(--sote-orange) !important;
  box-shadow: 0 0 0 4px rgba(248, 156, 16, 0.14) !important;
}

/* Footer */
html body .main-footer,
html body .sote-footer {
  background: #080808 !important;
}

html body .sote-footer__heading,
html body .main-footer h3 {
  color: var(--sote-white) !important;
}

html body .sote-footer a:hover,
html body .main-footer a:hover {
  color: var(--sote-orange) !important;
}

@media (max-width: 767px) {
  html body .main-header__search {
    display: none !important;
  }

  html body .cityride-btn,
  html body .cityride-btn--primary,
  html body .cityride-btn--secondary,
  html body .cityride-btn--black,
  html body .cityride-btn--white {
    width: 100%;
    justify-content: center;
  }
}

/* Directory pages: cities and airports */
html body.sote-cities-page .sote-cities-main {
  background: var(--sote-white) !important;
  padding-bottom: 68px !important;
}

html body.sote-cities-page .sote-cities-hero {
  position: relative;
  min-height: 580px;
  padding: 112px 0 96px !important;
  background:
    linear-gradient(90deg, rgba(8, 8, 8, 0.78) 0%, rgba(8, 8, 8, 0.58) 44%, rgba(8, 8, 8, 0.22) 100%),
    url("../images/resources/sote-taxi-banner.png") center center/cover no-repeat !important;
}

html body.sote-airports-page .sote-airports-hero {
  min-height: 620px;
  background:
    linear-gradient(90deg, rgba(8, 8, 8, 0.8) 0%, rgba(8, 8, 8, 0.56) 42%, rgba(8, 8, 8, 0.18) 72%, rgba(8, 8, 8, 0.36) 100%),
    url("../images/resources/sote-airports-image.png") center center/cover no-repeat !important;
}

html body.sote-cities-page .sote-cities-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 7px;
  background: var(--sote-orange);
}

html body.sote-cities-page .sote-cities-hero > .container {
  position: relative;
  z-index: 1;
}

html body.sote-cities-page .sote-cities-hero__content {
  max-width: 780px;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  text-shadow: 0 3px 18px rgba(0, 0, 0, 0.44);
}

html body.sote-cities-page .sote-cities-hero__content h1 {
  color: var(--sote-white) !important;
  font-size: clamp(40px, 5.8vw, 72px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  text-shadow: 0 4px 26px rgba(0, 0, 0, 0.58);
}

html body.sote-cities-page .sote-cities-hero__content p {
  max-width: 680px;
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 17px;
  line-height: 1.75;
  text-shadow: 0 3px 18px rgba(0, 0, 0, 0.52);
}

html body.sote-cities-page .sote-cities-hero .sote-eyebrow {
  background: rgba(255, 255, 255, 0.16) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
  color: var(--sote-white) !important;
}

html body.sote-cities-page .sote-cities-search-card {
  border-top: 5px solid var(--sote-orange) !important;
  padding: 26px !important;
}

html body.sote-cities-page .sote-cities-search {
  min-height: 56px;
  border-radius: 8px !important;
  background: #fff8ec !important;
}

html body.sote-cities-page .sote-cities-mode__item {
  border-radius: 8px !important;
  background: rgba(11, 11, 11, 0.06) !important;
}

html body.sote-cities-page .sote-cities-mode__item--active,
html body.sote-cities-page .sote-cities-mode__item:hover {
  background: var(--sote-black) !important;
  color: var(--sote-white) !important;
}

html body.sote-cities-page .sote-cities-stats--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

html body.sote-cities-page .sote-cities-stats div {
  border-radius: 8px !important;
  background: var(--sote-black) !important;
}

html body.sote-cities-page .sote-cities-stats strong {
  color: var(--sote-white) !important;
  letter-spacing: 0 !important;
}

html body.sote-cities-page .sote-cities-stats span {
  color: rgba(255, 255, 255, 0.72) !important;
  letter-spacing: 0.06em !important;
}

html body.sote-cities-page .sote-cities-map-band {
  margin-top: -42px;
}

html body.sote-cities-page .sote-cities-map-band__inner {
  grid-template-columns: minmax(96px, 150px) minmax(0, 1fr) auto;
  border-radius: 8px !important;
  background: var(--sote-black) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  box-shadow: 0 24px 70px rgba(11, 11, 11, 0.18) !important;
}

html body.sote-cities-page .sote-cities-map-band__inner img {
  max-height: 112px;
  padding: 10px;
  border-radius: 8px;
  background: var(--sote-white);
}

html body.sote-cities-page .sote-cities-map-band__inner h2,
html body.sote-cities-page .sote-cities-map-band__inner p {
  color: var(--sote-white) !important;
  letter-spacing: 0 !important;
}

html body.sote-cities-page .sote-cities-map-band__inner p {
  color: rgba(255, 255, 255, 0.78) !important;
}

html body.sote-cities-page .sote-directory-app-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

html body.sote-cities-page .sote-directory-app-actions .cityride-btn {
  min-width: 132px;
}

html body.sote-cities-page .sote-cities-locations {
  padding: 86px 0 42px !important;
}

html body.sote-cities-page .sote-cities-section-head h2,
html body.sote-cities-page .sote-cities-support h3,
html body.sote-cities-page .sote-seo-faq__head h2,
html body.sote-cities-page .sote-city-cta__inner h2 {
  letter-spacing: 0 !important;
}

html body.sote-cities-page .sote-cities-country-tabs a {
  border-radius: 8px !important;
  background: #fff1d6 !important;
  border: 1px solid rgba(248, 156, 16, 0.22);
}

html body.sote-cities-page .sote-cities-country-tabs a:hover {
  background: var(--sote-orange) !important;
  color: var(--sote-black) !important;
}

html body.sote-cities-page .sote-cities-country {
  grid-template-columns: minmax(180px, 0.28fr) minmax(0, 1fr);
  gap: 18px;
  padding: 18px !important;
}

html body.sote-cities-page .sote-cities-country__head {
  border-radius: 8px !important;
  background: var(--sote-black) !important;
  border-left: 6px solid var(--sote-orange);
}

html body.sote-cities-page .sote-cities-country__head span {
  color: var(--sote-white) !important;
  letter-spacing: 0 !important;
}

html body.sote-cities-page .sote-cities-country__head strong {
  color: var(--sote-orange) !important;
  letter-spacing: 0.06em !important;
}

html body.sote-cities-page .sote-cities-country__links {
  gap: 12px;
}

html body.sote-cities-page .sote-cities-country__links a {
  min-height: 98px;
  border-radius: 8px !important;
  background: var(--sote-white) !important;
  box-shadow: none !important;
}

html body.sote-airports-page .sote-cities-country__links a {
  min-height: 112px;
}

html body.sote-cities-page .sote-cities-country__links a:hover {
  border-color: rgba(248, 156, 16, 0.62) !important;
  box-shadow: 0 14px 34px rgba(11, 11, 11, 0.1) !important;
}

html body.sote-cities-page .sote-cities-country__links span {
  color: var(--sote-black) !important;
  font-size: 21px;
  letter-spacing: 0 !important;
  overflow-wrap: anywhere;
}

html body.sote-cities-page .sote-cities-country__links small {
  color: #555b60 !important;
  font-weight: 700;
}

html body.sote-cities-page .sote-cities-country__links i,
html body.sote-cities-page .sote-cities-support__icon {
  border-radius: 8px !important;
  background: rgba(248, 156, 16, 0.16) !important;
  color: var(--sote-orange-deep) !important;
}

html body.sote-cities-page .sote-cities-support {
  padding: 8px 0 36px !important;
}

html body.sote-cities-page .sote-cities-support article {
  padding: 26px !important;
}

html body.sote-cities-page .sote-city-cta__inner {
  border-radius: 8px !important;
  background: var(--sote-black) !important;
  border-top: 6px solid var(--sote-orange) !important;
  box-shadow: 0 28px 70px rgba(11, 11, 11, 0.16) !important;
}

html body.sote-cities-page .sote-city-cta__inner h2,
html body.sote-cities-page .sote-city-cta__inner p {
  color: var(--sote-white) !important;
}

html body.sote-airports-page .sote-seo-faq {
  background: var(--sote-white) !important;
}

html body.sote-airports-page .sote-seo-faq__item {
  border-radius: 8px !important;
  box-shadow: var(--sote-soft-shadow) !important;
}

@media (max-width: 1199px) {
  html body.sote-cities-page .sote-cities-map-band__inner {
    grid-template-columns: minmax(96px, 140px) minmax(0, 1fr);
  }

  html body.sote-cities-page .sote-directory-app-actions {
    grid-column: 2;
    justify-content: flex-start;
  }
}

@media (max-width: 991px) {
  html body.sote-cities-page .sote-cities-hero,
  html body.sote-airports-page .sote-airports-hero {
    min-height: auto;
    padding: 88px 0 74px !important;
  }

  html body.sote-cities-page .sote-cities-search-card {
    margin-top: 10px;
  }

  html body.sote-cities-page .sote-cities-country {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  html body.sote-cities-page .sote-cities-hero {
    padding: 74px 0 60px !important;
  }

  html body.sote-cities-page .sote-cities-hero__content h1 {
    font-size: clamp(34px, 10vw, 46px) !important;
  }

  html body.sote-cities-page .sote-cities-search-card {
    padding: 20px !important;
  }

  html body.sote-cities-page .sote-cities-stats--three {
    grid-template-columns: 1fr;
  }

  html body.sote-cities-page .sote-cities-map-band {
    margin-top: -22px;
  }

  html body.sote-cities-page .sote-cities-map-band__inner {
    grid-template-columns: 1fr;
    padding: 22px !important;
  }

  html body.sote-cities-page .sote-directory-app-actions {
    grid-column: auto;
    justify-content: stretch;
    width: 100%;
  }

  html body.sote-cities-page .sote-directory-app-actions .cityride-btn {
    min-width: 0;
  }

  html body.sote-cities-page .sote-cities-country__links {
    grid-template-columns: 1fr;
  }

  html body.sote-cities-page .sote-cities-country__links a {
    min-height: auto;
  }
}

/* Full-width dashcam safety banner */
html body .sote-dashcam-banner {
  width: 100%;
  margin: 0;
  padding: 0;
  background: #0b0b0b;
  overflow: hidden;
}

html body .sote-dashcam-banner img {
  display: block;
  width: 100%;
  height: clamp(320px, 46vw, 680px);
  object-fit: cover;
  object-position: center center;
}

@media (max-width: 767px) {
  html body .sote-dashcam-banner img {
    height: 300px;
    object-position: center center;
  }
}

/* Cleaner app-first hero for rider and driver pages */
html body.sote-booking-page .sote-booking-shell,
html body.sote-driver-page .sote-booking-shell {
  min-height: auto !important;
  padding: clamp(76px, 8vw, 112px) 0 !important;
}

html body.sote-driver-page .sote-driver-booking-main .sote-booking-shell {
  min-height: calc(100vh - 96px) !important;
  display: flex !important;
  align-items: center !important;
  background-size: cover !important;
  background-position: center center !important;
  padding: clamp(112px, 12vw, 172px) 0 !important;
}

html body.sote-booking-page .sote-booking-hero-grid,
html body.sote-driver-page .sote-booking-hero-grid {
  grid-template-columns: minmax(0, 720px) !important;
  align-items: center !important;
  justify-content: start !important;
  gap: 0 !important;
}

html body.sote-booking-page .sote-booking-copy,
html body.sote-driver-page .sote-booking-copy {
  max-width: 660px !important;
  padding-left: clamp(18px, 2vw, 26px) !important;
  border-left: 5px solid var(--sote-orange) !important;
}

html body.sote-booking-page .sote-booking-copy h1,
html body.sote-driver-page .sote-booking-copy h1 {
  max-width: 620px !important;
  margin-top: 20px !important;
  font-size: clamp(42px, 5vw, 68px) !important;
  line-height: 1.02 !important;
  letter-spacing: 0 !important;
}

html body.sote-booking-page .sote-booking-copy p,
html body.sote-driver-page .sote-booking-copy p {
  max-width: 600px !important;
  margin-top: 18px !important;
  font-size: 17px !important;
  line-height: 1.7 !important;
}

/* Match rider app mockups to driver page card style */
html body.sote-booking-page .sote-booking-steps__grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 20px !important;
}

html body.sote-booking-page .sote-booking-step-card {
  padding: 24px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(23, 18, 13, 0.08) !important;
  background: #ffffff !important;
  box-shadow: 0 18px 44px rgba(23, 18, 13, 0.06) !important;
}

html body.sote-booking-page .sote-booking-step-card__phone {
  min-height: 260px !important;
  padding: 22px 16px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(23, 18, 13, 0.08) !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(244, 180, 0, 0.14), transparent 44%),
    linear-gradient(180deg, #fff8ea 0%, #f4efe6 100%) !important;
}

html body.sote-booking-page .sote-booking-step-card__phone img {
  max-width: 220px !important;
  filter: drop-shadow(0 20px 28px rgba(23, 18, 13, 0.14)) !important;
}

html body.sote-booking-page .sote-booking-step-card__content {
  margin-top: 20px !important;
}

html body .sote-simple-app-card {
  width: min(100%, 420px) !important;
  justify-self: end !important;
  padding: 28px !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, 0.96) !important;
  border: 1px solid rgba(255, 255, 255, 0.72) !important;
  border-top: 6px solid var(--sote-orange) !important;
  box-shadow: 0 26px 70px rgba(11, 11, 11, 0.22) !important;
}

html body .sote-simple-app-card::before {
  display: none !important;
}

html body .sote-simple-app-card__eyebrow {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  color: #8b5e00;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

html body .sote-simple-app-card h2 {
  margin: 10px 0 0;
  color: var(--sote-black) !important;
  font-family: var(--cityride-heading-font, "Lexend", sans-serif);
  font-size: clamp(25px, 2.4vw, 32px);
  line-height: 1.12;
  letter-spacing: 0 !important;
}

html body .sote-simple-app-card p {
  margin: 12px 0 0;
  color: #555b60 !important;
  font-size: 15px;
  line-height: 1.65;
}

html body .sote-simple-app-card__list {
  display: grid;
  gap: 10px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

html body .sote-simple-app-card__list li {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--sote-black);
  font-size: 14px;
  font-weight: 800;
}

html body .sote-simple-app-card__list li::before {
  content: "";
  width: 9px;
  height: 9px;
  flex: 0 0 9px;
  border-radius: 50%;
  background: var(--sote-orange);
}

html body .sote-simple-app-card__actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 24px;
}

html body .sote-simple-app-card__actions .cityride-btn {
  width: 100%;
  justify-content: center;
  min-height: 54px;
}

/* App dropdowns in the header */
html body .sote-header__cta-menu--mega {
  width: min(640px, calc(100vw - 28px)) !important;
  padding: 14px !important;
  border-radius: 8px !important;
}

html body .sote-header__app-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 0.95fr) minmax(210px, 0.9fr) !important;
  gap: 14px !important;
  align-items: stretch !important;
}

html body .sote-header__app-qr {
  display: block !important;
}

html body .sote-header__app-panel {
  padding: 16px !important;
  border: 1px solid rgba(23, 18, 13, 0.08) !important;
  box-shadow: none !important;
  background: #ffffff !important;
  border-radius: 8px !important;
}

html body .sote-header__app-eyebrow {
  color: #8b5e00 !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: 0.08em !important;
}

html body .sote-header__app-headline {
  margin: 8px 0 0 !important;
  color: var(--sote-black) !important;
  font-size: 21px !important;
  line-height: 1.2 !important;
}

html body .sote-header__app-desc {
  margin-top: 8px !important;
  color: #555b60 !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
}

html body .sote-header__link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 38px !important;
  padding: 9px 12px !important;
  margin: 10px 8px 0 0 !important;
  border-radius: 999px !important;
  background: rgba(244, 180, 0, 0.12) !important;
  color: var(--sote-black) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  line-height: 1.2 !important;
}

html body .sote-header__link:hover {
  background: var(--sote-orange) !important;
  color: var(--sote-black) !important;
}

html body .sote-header__link-list {
  display: grid !important;
  gap: 10px !important;
  margin-top: 18px !important;
}

html body .sote-header__link-list .sote-header__link {
  width: 100% !important;
  justify-content: flex-start !important;
  min-height: 42px !important;
  margin: 0 !important;
  padding: 11px 14px !important;
  border-radius: 8px !important;
}

html body .sote-header__app-buttons {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  margin-top: 16px !important;
}

html body .sote-header__app-buttons a {
  min-height: 44px !important;
  padding: 10px 12px !important;
  border-radius: 999px !important;
  text-align: center !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

html body .sote-header__app-qr .sote-header__app-buttons {
  margin-top: 14px !important;
}

html body .sote-header__app-qr .sote-header__qr-cards {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

html body .sote-header__qr-card {
  min-height: 100% !important;
  padding: 12px !important;
  border-radius: 8px !important;
  color: var(--sote-black) !important;
}

html body .sote-header__qr-card img {
  width: min(112px, 100%) !important;
  border-radius: 6px !important;
}

html body .sote-header__qr-label {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  margin-top: 8px !important;
}

html body .sote-header__qr-label i {
  color: #8b5e00 !important;
  font-size: 14px !important;
}

html body .sote-header__qr-card strong {
  margin-top: 4px !important;
  color: var(--sote-black) !important;
  font-size: 12px !important;
}

html body .sote-simple-app-card__links {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-top: 16px !important;
}

html body .sote-simple-app-card__links a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 38px !important;
  padding: 9px 14px !important;
  border-radius: 999px !important;
  background: rgba(244, 180, 0, 0.12) !important;
  color: var(--sote-black) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}

html body .sote-simple-app-card__links a:hover {
  background: var(--sote-orange) !important;
  color: var(--sote-black) !important;
}

@media (max-width: 991px) {
  html body.sote-booking-page .sote-booking-hero-grid,
  html body.sote-driver-page .sote-booking-hero-grid {
    grid-template-columns: 1fr !important;
  }

  html body.sote-booking-page .sote-booking-steps__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  html body .sote-simple-app-card {
    justify-self: start !important;
  }

  html body .sote-header__cta-menu--mega {
    width: min(390px, calc(100vw - 28px)) !important;
  }

  html body .sote-header__app-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 767px) {
  html body.sote-booking-page .sote-booking-shell,
  html body.sote-driver-page .sote-booking-shell {
    padding: 58px 0 52px !important;
  }

  html body.sote-driver-page .sote-driver-booking-main .sote-booking-shell {
    min-height: calc(100svh - 72px) !important;
    padding: 82px 0 72px !important;
  }

  html body.sote-booking-page .sote-booking-steps__grid {
    grid-template-columns: 1fr !important;
  }

  html body.sote-booking-page .sote-booking-step-card__phone {
    min-height: 300px !important;
    padding: 20px 14px !important;
  }

  html body.sote-booking-page .sote-booking-step-card__phone img {
    max-width: 200px !important;
  }

  html body.sote-booking-page .sote-booking-copy h1,
  html body.sote-driver-page .sote-booking-copy h1 {
    font-size: clamp(34px, 10vw, 44px) !important;
  }

  html body.sote-booking-page .sote-booking-copy p,
  html body.sote-driver-page .sote-booking-copy p {
    font-size: 15px !important;
  }

  html body .sote-simple-app-card {
    width: 100% !important;
    padding: 22px !important;
  }
}
