
.sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

    /* --- css/head-foot.css --- */
    /* -- TOKENS -- */
    :root {
      --red: #D90008;
      --black: #111111;
      --ink: #222222;
      --body: #444444;
      --muted: #888888;
      --rule: #e0e0e0;
      --bg-off: #f5f5f5;
      --bg-dark: #111111;
    }

    *,
    *::before,
    *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0
    }

    html {
      scroll-behavior: smooth;
      overflow-x: hidden
    }

    body {
      font-family: 'Barlow', sans-serif;
      background: #fff;
      color: #111;
      overflow-x: hidden;
      line-height: 1.6;
      font-size: 18px;
      /* SOP: 18px for Body Text */
    }

    a {
      text-decoration: none;
      color: inherit
    }

    img {
      display: block;
      max-width: 100%;
      height: auto;
    }
    figure {
      margin: 0;
    }

    picture {
      display: block;
    }

    .figcaption-visually-hidden {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

    .content-figure {
      margin: 0;
      position: relative;
    }

    .fimg-track figure {
      flex: 0 0 100%;
      width: 100%;
      height: 100%;
      margin: 0;
      position: relative;
    }

    .fimg-track figure picture {
      width: 100%;
      height: 100%;
    }

    .fimg-track figure img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .img-half picture {
      width: 100%;
      height: 100%;
    }

    .srv-figure {
      margin: 0;
      height: 55%;
      overflow: hidden;
    }

    .srv-figure picture {
      width: 100%;
      height: 100%;
    }

    .srv-figure .srv-bg {
      height: 100%;
    }

    .srv-card:hover .srv-figure,
    .srv-card:active .srv-figure,
    .srv-card:focus-within .srv-figure {
      height: 100%;
    }


    /* -- TYPOGRAPHY OVERRIDES (SOP) -- */
    h1,
    .hero-h1 {
      font-size: 42px !important;
      line-height: 1.1;
      margin-bottom: 16px;
    }

    h2,
    .about-h,
    .sec-title,
    .why-h {
      font-size: 36px !important;
      line-height: 1.1;
      margin-bottom: 12px;
    }

    h3,
    .srv-title,
    .step-title,
    .fcap,
    .fname {
      font-size: 32px !important;
    }

    h4 {
      font-size: 28px !important;
    }

    h5 {
      font-size: 24px !important;
    }

    h6 {
      font-size: 20px !important;
    }

    p,
    .fa p,
    .areas-desc,
    .step-text,
    .why-p,
    .sec-head-note,
    .mq-text,
    .am-desc {
      font-size: 18px !important;
      line-height: 1.6;
      margin-bottom: 15px;
    }

    .rich-text > :first-child {
      margin-top: 0;
    }

    .rich-text > :last-child,
    .rich-text li > :last-child,
    .rich-text li:last-child {
      margin-bottom: 0;
    }

    .rich-text p,
    .rich-text ul,
    .rich-text ol {
      margin: 0 0 18px;
    }

    .rich-text ul,
    .rich-text ol {
      padding-left: 1.25em;
      list-style-position: outside;
    }

    .rich-text ul {
      list-style-type: disc;
    }

    .rich-text ol {
      list-style-type: decimal;
    }

    .rich-text li {
      margin-bottom: 10px;
    }

    .rich-text li::marker {
      color: var(--red);
    }

    .rich-text ul ul,
    .rich-text ul ol,
    .rich-text ol ul,
    .rich-text ol ol {
      margin: 10px 0 0;
    }

    .rich-text br + br {
      display: block;
      margin-top: 0.75em;
    }

    .rich-text a {
      font-weight: 700;
      text-decoration: underline;
    }
    /* -- UTILS -- */
    .container {
      max-width: 1240px;
      margin: 0 auto;
      padding: 0 32px
    }

    #hero > .container {
      width: 100%;
      min-width: 0;
    }

    .sec {
      padding: 96px 0
    }

    .sec-alt {
      background: var(--bg-off)
    }
    @supports (content-visibility: auto) {
      body > section:not(:first-of-type),
      body > aside[id] {
        content-visibility: auto;
        contain-intrinsic-size: 1px 960px;
      }
    }


    .eyebrow {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 600;
      font-size: 14px;
      letter-spacing: .3em;
      text-transform: uppercase;
      color: var(--red);
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 12px;
    }

    .eyebrow::before {
      content: '';
      width: 24px;
      height: 2px;
      background: var(--red);
      transform: skewX(-20deg);
      flex-shrink: 0
    }

    .sec-title {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      text-transform: uppercase;
      color: var(--black);
    }

    .sec-head {
      display: block;
      margin-bottom: 52px;
      text-align: left;
    }

    .sec-head-note {
      max-width: 900px;
      color: var(--body);
      margin-top: 16px;
    }

    /* -- BUTTONS -- */
    .btn-red-lg,
    .btn-black-lg {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 800;
      font-size: 20px;
      /* Adjusted from 27px (approx 26px) to match closer to SOP h6/body scale, keeping 20px for consistency */
      letter-spacing: .1em;
      text-transform: uppercase;
      color: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 24px 56px;
      clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
      transition: background .2s, transform .2s;
      text-decoration: none;
      border: none;
      cursor: pointer;
    }

    .btn-red-lg {
      background: var(--red);
    }

    .btn-red-lg:hover {
      background: #A50007;
      transform: translateX(3px);
    }

    .btn-black-lg {
      background: var(--black);
    }

    .btn-black-lg:hover {
      background: #333;
      transform: translateX(3px);
    }

    #hero .btn-black-lg {
      background-color: #fff;
      color: #000;
    }

    #hero .btn-black-lg:hover {
      background: #ccc;
      transform: translateX(3px);
    }

    .btn-ghost {
      background: transparent;
      color: var(--black);
      border: 2px solid var(--black);
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 800;
      font-size: 16px;
      text-transform: uppercase;
      padding: 16px 36px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      transition: background .2s, color .2s;
    }

    .btn-ghost:hover {
      background: var(--black);
      color: #fff
    }

    /* -- NAV -- */
    #nav {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 200;
      background: rgba(255, 255, 255, .97);
      border-bottom: 3px solid var(--red);
      backdrop-filter: blur(8px);
    }

    .nav-wrap {
      max-width: 1340px;
      margin: 0 auto;
      padding: 0 16px;
      height: 64px;
      display: flex;
      align-items: center;
      justify-content: space-between
    }

    .logo {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      font-size: 20px;
      text-transform: uppercase;
      color: var(--black);
      letter-spacing: .03em;
      line-height: 1
    }

    @media(max-width:599px) {
    .logo {
    font-size:17px;
    }
    }

    .logo em {
      color: var(--red);
      font-style: normal
    }

    .logo small {
      display: block;
      font-size: 10px;
      letter-spacing: .22em;
      color: var(--muted);
      font-style: normal;
      font-weight: 600;
      text-transform: uppercase;
      margin-top: 2px
    }

    .nav-links {
      display: flex;
      list-style: none;
      height: 100%;
    }

    .nav-item {
      position: relative;
      display: flex;
      align-items: center;
      height: 100%;
    }

    .nav-links button.nav-main-link {
      appearance: none;
      -webkit-appearance: none;
      background: transparent;
      border: 0;
      cursor: pointer;
      font: inherit;
    }

    .nav-links :is(a, button).nav-main-link {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 16px;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--ink);
      padding: 0 8px;
      height: 64px;
      display: flex;
      align-items: center;
      border-right: 1px solid var(--rule);
      transition: color .2s;
      position: relative;
      white-space: nowrap;
    }

    .nav-links :is(a, button).nav-main-link::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 3px;
      background: var(--red);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform .3s
    }

    .nav-links :is(a, button).nav-main-link:hover {
      color: var(--red)
    }

    .nav-links :is(a, button).nav-main-link:hover::after {
      transform: scaleX(1)
    }

    .nav-dropdown {
      display: none;
      position: absolute;
      top: 64px;
      left: 0;
      background: #fff;
      flex-direction: column;
      min-width: 240px;
      border-top: 3px solid var(--red);
      box-shadow: 0 8px 24px rgba(0, 0, 0, .08);
      max-height: 70vh;
      overflow-y: auto;
    }

    .nav-item:hover .nav-dropdown {
      display: flex;
    }

    .nav-dropdown a {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 600;
      font-size: 15px;
      letter-spacing: .08em;
      text-transform: uppercase;
      padding: 16px 20px;
      color: var(--ink);
      border-bottom: 1px solid var(--rule);
      transition: background .2s, color .2s;
    }

    .nav-dropdown a:last-child {
      border-bottom: none;
    }

    .nav-dropdown a:hover {
      background: var(--bg-off);
      color: var(--red);
    }

    .nav-cta {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 800;
      font-size: 14px;
      letter-spacing: .08em;
      text-transform: uppercase;
      background: var(--red);
      color: #fff;
      padding: 0 12px;
      height: 64px;
      display: flex;
      align-items: center;
      transition: background .2s;
      white-space: nowrap;
    }

    .nav-cta:hover {
      background: #A50007
    }

    .hbg {
      display: none;
      background: none;
      border: none;
      cursor: pointer;
      padding: 4px
    }

    .hbg span {
      display: block;
      width: 22px;
      height: 2px;
      background: var(--black);
      margin: 5px 0
    }

    #mmenu {
      display: none;
      position: fixed;
      top: 64px;
      left: 0;
      right: 0;
      bottom: 0;
      background: #fff;
      border-top: 3px solid var(--red);
      z-index: 199;
      padding: 8px 0;
      overflow-y: auto;
    }

    #mmenu a.m-top {
      display: block;
      padding: 16px 28px;
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 17px;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--ink);
      border-bottom: 1px solid var(--rule);
      transition: color .2s
    }

    #mmenu a.m-sub {
      display: block;
      padding: 12px 28px 12px 48px;
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 600;
      font-size: 15px;
      letter-spacing: .05em;
      text-transform: uppercase;
      color: var(--body);
      border-bottom: 1px solid var(--rule);
      background: var(--bg-off);
    }

    #mmenu a:hover,
    #mmenu a.cta {
      color: var(--red)
    }

    /* -- FOOTER -- */
    footer {
      background: var(--black);
      color: #fff;
      padding: 64px 0 28px
    }

    .ft-grid {
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 1fr;
      gap: 40px;
      margin-bottom: 44px
    }

    .ft-logo {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      font-size: 22px;
      text-transform: uppercase;
      margin-bottom: 12px
    }

    .ft-logo em {
      color: var(--red);
      font-style: normal
    }

    .ft-h {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 14px;
      letter-spacing: .25em;
      text-transform: uppercase;
      color: var(--red);
      margin-bottom: 14px
    }

    .ft-ul {
      list-style: none
    }

    .ft-ul li {
      margin-bottom: 8px
    }

    .ft-ul a {
      font-size: 14px;
      color: #fff;
    }

    .ft-contact {
      color: #fff;
      font-size: 14px;
      margin-bottom: 16px;
      display: block;
    }

    .ft-copy {
      border-top: 1px solid #222;
      padding-top: 28px;
      display: flex;
      justify-content: space-between;
      color: #555;
      font-size: 13px;
      text-transform: uppercase;
      letter-spacing: .1em
    }

    .mobile-nav-tel {
      display: none;
    }

    @media (max-width: 1024px) {
      .nav-wrap {
        padding: 0 20px;
      }

      .nav-links,
      .nav-cta {
        display: none;
      }

      .hbg {
        display: block;
        margin-left: 12px;
      }

      .mobile-nav-tel {
        display: flex;
        align-items: center;
        background: var(--red);
        color: #fff !important;
        font-family: 'Barlow Condensed', sans-serif;
        font-weight: 700;
        font-size: 15px;
        letter-spacing: 0.05em;
        text-transform: uppercase;
        padding: 8px 16px;
        border-radius: 4px;
        text-decoration: none;
        margin-left: auto;
      }

      .container {
        padding: 0 24px;
      }
    }

    @media (max-width: 768px) {

      h1,
      .hero-h1 {
        font-size: 32px !important;
      }

      h2,
      .about-h,
      .sec-title,
      .why-h {
        font-size: 34px !important;
      }

      .sec {
        padding: 64px 0;
      }

      .ft-grid {
        grid-template-columns: 1fr;
        gap: 32px;
      }

      .ft-copy {
        flex-direction: column;
        gap: 12px;
        text-align: center;
      }
    }

/* --- css/homepage.css --- */
    /* -- HERO -- */
    #hero {
      min-height: 100vh; min-height: 100dvh;
      padding-top: 64px;
      display: flex;
      align-items: center;
      background: linear-gradient(rgba(17, 17, 17, 0.7), rgba(17, 17, 17, 0.85)), url('/assets/site-images/party-bus-inside.avif') center/cover no-repeat;
      position: relative;
    }

    .hero-body {
      position: relative;
      z-index: 1;
      padding: 80px 0;
      max-width: 800px;
      margin: 0 auto;
      text-align: center;
      display: flex;
      flex-direction: column;
      align-items: center;
    }

    .hero-eyebrow {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 14px;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: #fff;
      background: var(--red);
      padding: 6px 16px;
      margin-bottom: 24px;
      display: inline-block;
    }

    .hero-h1 {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      text-transform: uppercase;
      color: #fff;
    }

    .hero-h1 em {
      color: var(--red);
      font-style: normal;
    }

    .hero-sub {
      color: rgba(255, 255, 255, .9);
      max-width: 600px;
      margin: 0 0 36px;
      font-weight: 400;
    }

    .hero-stats {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 22px 24px;
      margin-top: 56px;
      padding-top: 32px;
      border-top: 1px solid rgba(255, 255, 255, .15);
      width: 100%;
    }

    @media (max-width: 768px) {
      .hero-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    .hstat-n {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      font-size: clamp(28px, 6vw, 42px);
      line-height: 1;
      color: #fff;
    }

    .hstat-n em {
      color: var(--red);
      font-style: normal;
    }

    .hstat-l {
      font-size: 13px;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, .6);
      margin-top: 6px;
    }

    /* -- MARQUEE -- */
    #proof {
      background: var(--black);
      padding: 40px 0 30px;
      overflow: hidden;
      border-top: none;
    }

    .mq-text {
      text-align: center !important;
      color: rgba(255, 255, 255, 0.8);
      margin-bottom: 28px;
    }

    .mq {
      display: flex;
      align-items: center;
      gap: 44px;
      animation: mq 28s linear infinite;
      white-space: nowrap;
      width: max-content
    }

    .mq:hover {
      animation-play-state: paused
    }

    @keyframes mq {
      from {
        transform: translateX(0)
      }

      to {
        transform: translateX(-50%)
      }
    }

    .mq-label {
      font-family: 'Barlow Condensed', sans-serif;
      font-size: 12px;
      letter-spacing: .28em;
      text-transform: uppercase;
      color: #777;
      flex-shrink: 0
    }

    .mq-item {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 15px;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, .45);
      flex-shrink: 0;
      transition: color .3s;
      cursor: default
    }

    .mq-item:hover {
      color: #fff
    }

    .mq-dot {
      width: 6px;
      height: 6px;
      background: var(--red);
      transform: rotate(45deg);
      flex-shrink: 0
    }

    /* -- ABOUT -- */
    #about {
      background: #fff
    }

    .about-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center
    }

    .about-h {
      font-style: italic;
      font-weight: 900;
      text-transform: uppercase;
      color: var(--black);
    }

    .about-h em {
      color: var(--red);
      font-style: normal
    }

    .stat-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
    }

    .stat-box {
      background: var(--bg-off);
      padding: 32px 24px;
      border-left: 4px solid var(--red);
      transition: background .25s;
    }

    .stat-box:hover {
      background: #ebebeb
    }

    .stat-n {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      font-size: 42px;
      line-height: 1.1;
      color: var(--black);
      margin-bottom: 4px
    }

    .stat-n em {
      color: var(--red);
      font-style: normal
    }

    .stat-l {
      font-size: 13px;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: var(--muted)
    }

    /* -- FLEET (Image Carousels) -- */
    #fleet {
      background: var(--bg-off)
    }

    .fleet-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 24px;
    }

    .fcard {
      background: #fff;
      padding: 26px;
      border-top: 4px solid transparent;
      box-shadow: 0 4px 12px rgba(0, 0, 0, .04);
      display: flex;
      flex-direction: column;
      min-width: 0; /* MDN: lets grid items shrink below min-content */
    }

    .fname-link {
      color: var(--black);
      transition: color 0.2s;
      display: inline-block;
      margin-bottom: 12px;
    }

    .fname-link:hover {
      color: var(--red);
    }

    .fname {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 800;
      font-size: 26px;
      /* SOP 32px? Keeping custom but check SOP */
      text-transform: uppercase;
    }

    /* Mini Image Carousel Inside Card */
    .fimg-carousel {
      position: relative;
      width: 100%;
      height: 300px;
      margin-bottom: 14px;
      overflow: hidden;
      border-radius: 4px;
      background: #eee;
    }

    .fimg-track {
      display: flex;
      transition: transform 0.4s ease;
      height: 100%;
    }

    .fimg-track img {
      flex: 0 0 100%;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .fimg-nav {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      background: rgba(0, 0, 0, 0.6);
      color: #fff;
      border: none;
      padding: 12px 14px;
      cursor: pointer;
      font-size: 16px;
      z-index: 2;
      transition: background 0.2s;
    }

    .fimg-nav:hover {
      background: var(--red);
    }

    .fimg-prev {
      left: 0;
    }

    .fimg-next {
      right: 0;
    }

    .fcap {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 16px;
      color: var(--red);
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-bottom: 16px;
    }

    .famenities {
      list-style: none;
      margin-bottom: 20px;
      flex-grow: 1;
    }

    .famenities li {
      font-size: 18px;
      /* SOP Body */
      color: var(--body);
      margin-bottom: 8px;
      padding-left: 24px;
      position: relative;
      line-height: 1.4;
    }

    .famenities li::before {
      content: '\2713';
      position: absolute;
      left: 0;
      color: var(--red);
      font-weight: bold;
    }

    .fprice {
      font-family: 'Barlow Condensed', sans-serif;
      font-size: 20px;
      font-weight: 700;
      color: var(--black);
      margin-bottom: 24px;
      padding-top: 16px;
      border-top: 1px solid var(--rule);
    }

    .fprice span {
      color: var(--red);
      font-weight: 900;
      font-size: 26px;
      font-style: italic;
    }

    /* -- AMENITIES SECTION -- */
    #amenities {
      background: var(--black);
      color: #fff;
    }

    .amenities-layout {
      display: grid;
      grid-template-columns: 1fr;
      gap: 48px;
      text-align: center;
    }

    .am-content {
      margin: 0 auto;
      max-width: 800px;
    }

    .am-title {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      font-size: clamp(40px, 5vw, 64px) !important;
      text-transform: uppercase;
      line-height: 0.95 !important;
      margin-bottom: 24px;
      color: #fff;
    }

    .am-desc {
      color: #ddd;
      margin-bottom: 36px;
    }

    .am-list {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
    }

    .am-item {
      background: #1a1a1a;
      padding: 24px 20px;
      border-radius: 6px;
      border-bottom: 3px solid var(--red);
      transition: transform 0.2s;
      display: flex;
      gap: 16px;
      align-items: center;
    }

    .am-item:hover {
      transform: translateY(-4px);
    }

    .am-icon {
      color: var(--red);
      display: flex;
      align-items: center;
      width: 32px;
      height: 32px;
      flex-shrink: 0;
    }

    .am-icon svg {
      display: block;
      width: 100%;
      height: 100%;
    }

    .am-item-title-wrap {
      display: flex;
      flex-direction: column;
    }

    .am-item-title {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 800;
      font-size: 24px;
      /* SOP H5? */
      text-transform: uppercase;
      color: #fff;
      line-height: 1.2;
      margin: 0;
    }

    .am-item-desc {
      font-size: 17px !important;
      color: #aaa;
      line-height: 1.6;
    }

    /* -- PRICING -- */
    #pricing {
      background: #fff
    }

    .ptable {
      border: 1px solid var(--rule);
      border-radius: 4px;
      overflow: hidden;
    }

    .phead {
      background: var(--black);
      color: #fff;
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      letter-spacing: .05em;
      text-transform: uppercase;
    }

    .pname {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 22px;
      text-transform: uppercase;
      color: inherit
    }

    .pval {
      font-size: 24px;
      color: inherit;
      font-weight: 500;
    }

    .table-intro {
      color: var(--body);
      margin-bottom: 20px;
    }

    .ptable {
      width: 100%;
      border-collapse: separate;
      border-spacing: 0;
      table-layout: fixed;
      background: #fff;
    }

    .ptable caption {
      text-align: left;
      padding: 20px 24px;
      background: var(--bg-off);
      color: var(--body);
      font-size: 16px;
      border-bottom: 1px solid var(--rule);
    }

    .ptable thead th {
      background: var(--black);
      color: #fff;
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      letter-spacing: .05em;
      text-transform: uppercase;
      text-align: left;
      padding: 20px 24px;
    }

    .ptable thead th:first-child,
    .ptable tbody th {
      width: 40%;
    }

    .ptable thead th:not(:first-child),
    .ptable tbody td {
      width: 20%;
    }

    .ptable tbody th,
    .ptable tbody td,
    .ptable tfoot td {
      padding: 20px 24px;
      border-bottom: 1px solid var(--rule);
      text-align: left;
      vertical-align: top;
    }

    .ptable tbody tr:nth-child(even) {
      background: var(--bg-off);
    }

    .ptable tbody th {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 22px;
      text-transform: uppercase;
      color: inherit;
    }

    .ptable tbody td {
      font-size: 24px;
      color: inherit;
      font-weight: 500;
    }

    .ptable tfoot td {
      background: var(--bg-off);
      color: var(--body);
      font-size: 16px;
      border-bottom: none;
    }
    /* -- WHY CHOOSE US -- */
    #why {
      background: var(--bg-off)
    }

    .why-layout {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center
    }

    .why-h {
      font-style: italic;
      font-weight: 900;
      text-transform: uppercase;
      color: var(--black);
    }

    .why-img {
      width: 100%;
      max-width: 600px;
      aspect-ratio: 3 / 2;
      height: auto;
      border-radius: 8px;
      object-fit: cover;
      box-shadow: 0 12px 40px rgba(0, 0, 0, .15);
      display: block;
      margin: 0 auto;
    }

    /* -- AREAS SECTION -- */
    .areas-layout {
      display: flex;
      justify-content: center;
    }

    .areas-content {
      background: #fff;
      padding: 0;
      border-radius: 8px;
      box-shadow: 0 12px 40px rgba(0, 0, 0, .08);
      width: 100%;
      max-width: 1100px;
      text-align: left;
      display: grid;
      grid-template-columns: 1fr 1fr;
      align-items: stretch;
      overflow: hidden;
    }

    .areas-text {
      padding: 60px 48px;
      position: relative;
    }

    .areas-text::before {
      content: '';
      position: absolute;
      top: 36px;
      left: 48px;
      width: 24px;
      height: 3px;
      background: var(--red);
    }

    .areas-text::after {
      content: 'COVERAGE AREA';
      position: absolute;
      top: 26px;
      left: 84px;
      font-family: "Barlow Condensed", sans-serif;
      font-size: 16px;
      font-weight: 700;
      letter-spacing: 0.1em;
      color: var(--red);
      text-transform: uppercase;
    }

    /* -- SCROLLING CAROUSEL COMPONENT (SERVICES / DESTINATIONS) -- */
    .carousel-sec {
      background: #fff;
      padding-bottom: 96px;
    }

    .srv-cw {
      overflow: hidden;
      cursor: grab;
      user-select: none;
      border-top: 3px solid var(--red);
      padding: 40px 0;
      background: #111;
    }

    .srv-cw:active {
      cursor: grabbing;
    }

    .srv-ct {
      display: flex;
      gap: 24px;
      transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      padding: 0 32px;
    }

    .srv-card {
      flex: 0 0 420px;
      height: 500px;
      position: relative;
      overflow: hidden;
      background: #151515;
    }

    .srv-bg {
      width: 100%;
      height: 55%;
      object-fit: cover;
      transition: opacity 0.4s ease, height 0.4s ease;
    }

    .srv-content {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 45%;
      background: #151515;
      padding: 32px 24px;
      transition: height 0.4s ease, background 0.4s ease;
      display: flex;
      flex-direction: column;
    }

    .srv-card:hover .srv-content {
      height: 100%;
      background: rgba(17, 17, 17, 0.95);
    }

    .srv-card:hover .srv-bg {
      opacity: 0.2;
      height: 100%;
    }

    .srv-title-link {
      text-decoration: none;
      color: #fff;
      display: inline-block;
    }

    .srv-title {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 900;
      font-size: 35px;
      text-transform: uppercase;
      font-style: italic;
      margin-bottom: 12px;
      line-height: 1;
      transition: color 0.2s;
      color: #fff;
    }

    .srv-title-link:hover .srv-title {
      color: var(--red);
    }

    .dest-title {
      color: #fff;
    }

    .srv-line {
      width: 100%;
      height: 3px;
      background: var(--red);
      margin-bottom: 20px;
      flex-shrink: 0;
    }

    .srv-desc {
      font-size: 18px;
      /* SOP Body */
      color: #ddd;
      line-height: 1.5;
      overflow: hidden;
      max-height: 52px;
      transition: max-height 0.4s ease;
    }

    .srv-card:hover .srv-desc {
      max-height: 400px;
      overflow-y: auto;
      padding-right: 10px;
    }

    .srv-desc::-webkit-scrollbar {
      width: 6px;
    }

    .srv-desc::-webkit-scrollbar-track {
      background: rgba(255, 255, 255, 0.05);
      border-radius: 4px;
    }

    .srv-desc::-webkit-scrollbar-thumb {
      background: rgba(255, 255, 255, 0.2);
      border-radius: 4px;
    }

    .srv-desc::-webkit-scrollbar-thumb:hover {
      background: var(--red);
    }

    .srv-link {
      margin-top: auto;
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 800;
      font-size: 21px;
      color: #fff;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      padding-top: 16px;
      transition: color 0.2s;
    }

    .srv-link:hover {
      color: var(--red);
    }

    .cnav {
      display: flex;
      align-items: center;
      gap: 14px;
      padding: 24px 0 0;
      justify-content: center;
    }

    .cbtn {
      width: 52px;
      height: 52px;
      background: #fff;
      border: 2px solid var(--rule);
      color: var(--black);
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 20px;
      font-weight: 700;
      transition: background .2s, border-color .2s, color .2s;
    }

    .cbtn:hover {
      background: var(--red);
      border-color: var(--red);
      color: #fff;
    }

    /* -- REVIEWS COMPONENT -- */
    .review-sec {
      background: var(--bg-off);
      text-align: center;
    }

    .review-container {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 40px;
      max-width: 1000px;
      margin: 0 auto;
    }

    .nav-arrow {
      background: none;
      border: none;
      font-size: 50px;
      cursor: pointer;
      color: #111;
      font-weight: 300;
      transition: color 0.2s;
    }

    .nav-arrow:hover {
      color: var(--red);
    }

    .review-center {
      flex: 1;
      display: flex;
      flex-direction: column;
      align-items: center;
    }

    .quote-icon {
      font-size: 100px;
      color: var(--red);
      font-family: Arial, sans-serif;
      font-style: italic;
      line-height: 0.5;
      -webkit-text-stroke: 2px var(--red);
      color: transparent;
      font-weight: 900;
    }

    .quote-top {
      align-self: center;
      margin-bottom: 10px;
      transform: scaleX(-1);
    }

    .quote-bot {
      align-self: center;
      margin-top: 10px;
    }

    .review-text {
      font-size: 29px !important;
      font-style: italic;
      color: #111;
      margin: 24px 0 !important;
      font-weight: 500;
      letter-spacing: 0.02em;
    }

    .review-author {
      font-size: 21px;
      color: var(--red);
      font-weight: 700;
      font-style: italic;
    }

    .review-dots {
      display: flex;
      justify-content: center;
      gap: 12px;
      margin-top: 40px;
    }

    .rv-dot {
      width: 40px;
      height: 3px;
      background: #ddd;
      cursor: pointer;
      transition: background 0.3s;
    }

    .rv-dot.active {
      background: var(--red);
    }

    /* -- STEPS, AREAS, FAQ -- */
    #steps {
      background: #fff;
    }

    .steps-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 3px;
      margin-top: 52px
    }

    .step {
      background: var(--bg-off);
      padding: 44px 32px;
      position: relative;
      overflow: hidden;
      border: 1px solid var(--rule)
    }

    .step-num {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      font-size: 130px;
      color: rgba(0, 0, 0, .04);
      position: absolute;
      top: -18px;
      right: -8px;
      line-height: 1;
      pointer-events: none
    }

    .step-bar {
      width: 28px;
      height: 3px;
      background: var(--red);
      transform: skewX(-20deg);
      margin-bottom: 20px
    }

    .step-title {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 800;
      font-style: italic;
      font-size: 28px;
      text-transform: uppercase;
      color: var(--black);
      margin-bottom: 12px
    }

    .steps-cta {
      text-align: center;
      margin-top: 44px
    }

    #areas {
      background: var(--bg-off)
    }



    .city-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 3px
    }

    .ctag {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 600;
      font-size: 16px;
      text-transform: uppercase;
      letter-spacing: .05em;
      color: var(--ink);
      background: #fff;
      padding: 14px;
      display: flex;
      align-items: center;
      gap: 6px;
      transition: background .2s, color .2s;
      border: 1px solid var(--rule)
    }

    .ctag::before {
      content: '';
      width: 5px;
      height: 5px;
      background: var(--red);
      transform: rotate(45deg);
      flex-shrink: 0
    }

    .ctag:hover {
      background: var(--red);
      color: #fff
    }

    .ctag:hover::before {
      background: #fff
    }

    .mapbox {
      height: 420px;
      border: 2px solid var(--rule);
      overflow: hidden;
      position: relative
    }

    .mapbox iframe {
      width: 100%;
      height: 100%;
      border: none
    }

    #faq {
      background: #fff
    }

    .faq-list {
      margin-top: 44px
    }

    .fitem {
      border-bottom: 2px solid var(--rule)
    }

    .fq {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 22px 0;
      cursor: pointer;
      gap: 20px
    }

    .fqt {
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      font-size: 22px;
      text-transform: uppercase;
      color: var(--black);
      letter-spacing: .03em;
      transition: color .2s
    }

    .fitem.open .fqt {
      color: var(--red)
    }

    .fic {
      width: 28px;
      height: 28px;
      border: 2px solid var(--rule);
      background: var(--bg-off);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 18px;
      color: var(--muted);
      flex-shrink: 0;
      transition: background .2s, border-color .2s, color .2s, transform .3s;
      font-family: 'Barlow Condensed', sans-serif;
      font-weight: 700;
      line-height: 1
    }

    .fitem.open .fic {
      background: var(--red);
      border-color: var(--red);
      color: #fff;
      transform: rotate(45deg)
    }

    .fa {
      max-height: 0;
      overflow: hidden;
      transition: max-height .4s ease, padding .4s ease
    }

    .fa.open {
      max-height: 360px;
      padding-bottom: 22px
    }

    /* -- CTA -- */
    #cta {
      background: var(--red);
      padding: 88px 0;
      overflow: hidden;
      position: relative
    }

    #cta::before {
      content: 'GO';
      position: absolute;
      right: -10px;
      top: 50%;
      transform: translateY(-50%);
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      font-size: 280px;
      color: rgba(255, 255, 255, .08);
      line-height: 1;
      pointer-events: none
    }

    .cta-in {
      text-align: center;
      position: relative;
      z-index: 1
    }

    .cta-in h2 {
      font-family: 'Barlow Condensed', sans-serif;
      font-style: italic;
      font-weight: 900;
      font-size: clamp(52px, 8vw, 108px);
      text-transform: uppercase;
      line-height: .9;
      color: #fff;
      margin-bottom: 20px
    }

    .cta-btns {
      display: flex;
      justify-content: center;
      gap: 14px;
      flex-wrap: wrap
    }

    @media (max-width: 1024px) {
      .carousel-sec {
        padding-bottom: 80px;
      }

      .srv-card {
        flex: 0 0 340px;
        height: 440px;
      }

      .about-grid,
      .why-layout,
      .amenities-layout,
      .areas-content {
        grid-template-columns: 1fr;
        gap: 48px;
      }

      .steps-grid {
        grid-template-columns: 1fr;
        gap: 40px;
      }

      .step-num {
        font-size: 100px;
        top: -10px;
      }

      .fimg-carousel {
        height: 260px;
      }
    }

    @media (max-width: 768px) {
      #hero {
        min-height: auto !important;
        align-items: flex-start !important;
      }

      .hero-body {
        padding: 20px 0 32px !important;
      }

      .bcrumb {
        margin-bottom: 16px !important;
      }

      .hero-sub {
        padding: 0 20px;
      }

      .stat-grid,
      .fleet-grid,
      .areas-layout,
      .am-list,
      .city-grid {
        grid-template-columns: 1fr !important;
      }

      .ptable {
        overflow-x: hidden;
        display: block;
      }

      .pname {
        font-size: 14px;
      }

      .pval {
        font-size: 13px;
      }

      .table-intro {
        margin-bottom: 16px;
      }

      .ptable caption {
        padding: 16px 12px;
        font-size: 14px;
      }

      .ptable thead th,
      .ptable tbody th,
      .ptable tbody td,
      .ptable tfoot td {
        padding: 12px 10px;
      }

      .ptable tbody th {
        font-size: 14px;
      }

      .ptable thead th,
      .ptable tbody td {
        font-size: 13px;
      }

      .ptable tfoot td {
        font-size: 12px;
      }
      .srv-cw {
        pointer-events: none;
      }

      .cbtn {
        pointer-events: auto;
      }

      .srv-card {
        flex: 0 0 280px;
        height: 400px;
        pointer-events: auto;
      }

      .srv-card:hover .srv-content,
      .srv-card:active .srv-content,
      .srv-card:focus-within .srv-content {
        height: 100%;
        background: rgba(17, 17, 17, 0.95);
      }

      .srv-card:hover .srv-bg,
      .srv-card:active .srv-bg,
      .srv-card:focus-within .srv-bg {
        opacity: 0.2;
        height: 100%;
      }

      .srv-card:hover .srv-desc,
      .srv-card:active .srv-desc,
      .srv-card:focus-within .srv-desc {
        max-height: 400px;
        overflow-y: auto;
        padding-right: 10px;
      }

      .srv-link {
        pointer-events: none;
      }

      .srv-card:hover .srv-link,
      .srv-card:active .srv-link,
      .srv-card:focus-within .srv-link {
        pointer-events: auto;
      }

      .srv-content {
        padding: 16px 20px;
      }

      .srv-title {
        font-size: 27px !important;
        margin-bottom: 24px;
      }

      .srv-desc {
        font-size: 14px !important;
      }

      .btn-red-lg,
      .btn-black-lg {
        padding: 20px 24px;
        font-size: clamp(18px, 5.2vw, 22px);
        margin: 0 auto;
        white-space: nowrap;
      }

      .hero-btns,
      .cta-btns,
      div[style*="display:flex; gap:16px; flex-wrap:wrap;"],
      div[style*="display:flex; flex-direction:column; gap:8px;"] {
        justify-content: center !important;
        align-items: center !important;
        text-align: center;
      }

      .about-grid>div>div:nth-child(3),
      .why-layout>div>div:nth-child(3) {
        margin-bottom: 24px;
      }

      .why-layout.why-layout--text-first>div:first-child {
        order: 2;
      }

      .why-layout.why-layout--text-first>div:last-child {
        order: 1;
      }

      p.am-desc,
      p.sec-head-note,
      p:not(.mq-text):not(.ft-contact) {
        text-align: left !important;
      }

      .fqt {
        font-size: 18px;
        line-height: 1.2;
      }

      .fa.open {
        max-height: none;
      }

      .ft-bot img {
        max-width: 100%;
        height: auto;
      }
    }

    p>a {
      font-weight: bold;
      text-decoration: underline;
    }
  .hero-body p {
    color: #fff;
    text-align:start;
}
footer img {
    max-width: 100% !important;
    width: auto;
    height: auto;
}

  .nav-links .mobile-view-all {
      display: none;
    }

    .mobile-only-item {
      display: none;
    }

    body.nav-open {
      overflow: hidden;
    }

    @media (max-width: 1024px) {
      #nav {
        z-index: 10001;
      }

      .nav-links {
        display: none !important;
        position: fixed;
        top: 64px;
        left: 0;
        right: 0;
        bottom: 0;
        width: 100%;
        margin: 0;
        background: #fff;
        border-top: 3px solid var(--red);
        z-index: 10000;
        padding: 8px 0 calc(env(safe-area-inset-bottom, 0px) + 12px);
        overflow-y: auto;
        overflow-x: hidden;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        height: calc(100dvh - 64px);
        min-height: calc(100vh - 64px);
        list-style: none;
        visibility: hidden;
        opacity: 0;
        pointer-events: none;
      }

      .nav-links.open {
        display: block !important;
        visibility: visible;
        opacity: 1;
        pointer-events: auto;
        height: calc(100dvh - 64px);
        min-height: calc(100vh - 64px);
      }

      .nav-item {
        display: block;
        height: auto;
      }

      .nav-links :is(a, button).nav-main-link {
        display: block;
        padding: 16px 28px;
        height: auto;
        border-right: none;
        border-bottom: 1px solid var(--rule);
        font-size: 17px;
        letter-spacing: .1em;
      }

      .nav-links :is(a, button).nav-main-link[data-nav-toggle="submenu"] {
        cursor: pointer;
      }

      .nav-links :is(a, button).nav-main-link::after {
        display: none;
      }

      .nav-links .nav-dropdown,
      .nav-links .nav-dropdown.mega-menu {
        display: none;
        position: static !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        width: auto !important;
        min-width: 0;
        max-height: none !important;
        overflow: visible !important;
        box-shadow: none !important;
        border-top: none !important;
        border-radius: 0 !important;
        padding: 0 !important;
        margin: 0 !important;
        background: transparent !important;
      }

      .nav-links .nav-dropdown.open,
      .nav-links .nav-dropdown.mega-menu.open {
        display: block !important;
      }

      .nav-links .nav-item.has-submenu > .nav-dropdown:not(.open),
      .nav-links .nav-item.has-submenu:focus-within > .nav-dropdown:not(.open),
      .nav-links .nav-item.has-submenu > .nav-dropdown.mega-menu:not(.open),
      .nav-links .nav-item.has-submenu:focus-within > .nav-dropdown.mega-menu:not(.open) {
        display: none !important;
      }

      .nav-links .nav-dropdown a,
      .nav-links .mega-menu a,
      .nav-links .mobile-view-all {
        display: block;
        padding: 12px 28px 12px 48px !important;
        font-family: 'Barlow Condensed', sans-serif;
        font-weight: 600;
        font-size: 15px;
        letter-spacing: .05em;
        text-transform: uppercase;
        color: var(--body);
        border-bottom: 1px solid var(--rule);
        background: var(--bg-off);
        width: 100%;
      }

      .nav-links .mobile-view-all {
        display: block;
      }

      .nav-links .mega-menu {
        display: none;
        grid-template-columns: 1fr !important;
        gap: 0 !important;
        width: 100% !important;
      }

      .nav-links .mega-col,
      .nav-links .mega-list,
      .nav-links .mega-list li {
        display: block;
        width: 100%;
      }

      .nav-links .mega-h4,
      .nav-links .nav-dropdown style {
        display: none;
      }

      .nav-links .mega-list {
        gap: 0;
      }

      .nav-links .mega-list a,
      .nav-links .nav-dropdown a,
      .nav-links .mobile-view-all {
        position: relative;
        z-index: 2;
        pointer-events: auto;
      }

      .nav-links .mega-list a {
        padding-left: 48px !important;
      }

      .nav-item.open > .nav-main-link,
      .nav-links :is(a, button).nav-main-link:hover,
      .nav-links .nav-dropdown a:hover {
        color: var(--red);
        background: transparent;
      }

      .mobile-only-item {
        display: block;
      }
    }

    @media (min-width: 1025px) {
      .nav-item.has-submenu:focus-within > .nav-dropdown {
        display: flex;
      }

      .nav-item.has-submenu:focus-within > .nav-dropdown.mega-menu {
        display: grid !important;
        grid-template-columns: 1fr 1fr;
        gap: 40px;
      }
    }

    .nav-item.desktop-open > .nav-main-link,
    .nav-item.desktop-open > .nav-main-link:hover,
    .nav-item.open > .nav-main-link {
      color: var(--red);
    }

    .nav-item.desktop-open > .nav-main-link::after {
      transform: scaleX(1);
    }

    .nav-item.has-submenu > .nav-main-link {
      padding-right: 14px;
    }

    .mega-menu {
      width: 800px;
      padding: 32px;
      border-radius: 0 0 8px 8px;
      cursor: default;
    }

    .nav-item:hover .mega-menu {
      display: grid !important;
      grid-template-columns: 1fr 1fr;
      gap: 40px;
    }

    .mega-col .mega-h4 {
      font-family: 'Barlow Condensed', sans-serif;
      font-size: 13px;
      font-weight: 600;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--red);
      border-bottom: 1px solid #eee;
      padding-bottom: 8px;
      margin-bottom: 16px;
    }

    .mega-list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: flex;
      flex-direction: column;
      gap: 4px;
    }

    .mega-list a {
      display: flex;
      align-items: center;
      font-family: 'Barlow Condensed', sans-serif;
      font-size: 13px;
      font-weight: 600;
      letter-spacing: .1em;
      color: var(--ink);
      padding: 8px 0;
      text-transform: uppercase;
      text-decoration: none;
      transition: color .2s, padding-left .2s;
    }

    .mega-list a:hover,
    .mega-list a:focus-visible {
      color: var(--red);
      background: transparent;
      padding-left: 4px;
      outline: none;
    }

    .nav-dropdown.mega-menu a {
      border-bottom: none;
      width: auto;
    }

    .hbg,
    .mobile-nav-tel {
      touch-action: manipulation;
    }

    .nav-dropdown-right {
      left: auto;
      right: 0;
    }

    .mega-h4-spaced {
      margin-top: 32px;
    }
.rich-text {
    margin-bottom: 15px;
}
div#app, div#app2 {
    z-index: 999 !important;
}


/* ====== extracted page-shared blocks ====== */
/* === disable hover-motion animations (added by disable_anims script) === */
.btn-red-lg:hover,
.btn-black-lg:hover,
#hero .btn-black-lg:hover,
.am-item:hover,
.city-card:hover,
.fcard:hover,
.fname-link:hover,
.fcard-btn:hover,
.desktop-cta-btn:hover,
.mobile-cta-btn:hover,
.mobile-cta-btn:active { transform: none !important; }

.city-card:hover {
  box-shadow: none !important;
}

/* amenity items: keep their left-aligned look regardless of the
   `text-align:center` set on .amenities-layout */
.am-list,
.am-list .am-item,
.am-list .am-item-title,
.am-list .am-item-title h3 { text-align: left !important; }

/* nav-mobile-cta-fix */
@media (max-width: 1024px) {
  #primaryNav .nav-item.mobile-only-item {
    display: block !important;
    height: auto !important;
    padding: 0 !important;
    border-bottom: 0 !important;
  }

  #primaryNav .nav-item.mobile-only-item .nav-main-link.quote-trigger,
  #primaryNav .nav-item.mobile-only-item .nav-main-link[href^="tel:"] {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: calc(100% - 32px) !important;
    min-height: 50px !important;
    margin: 12px 16px !important;
    padding: 14px 20px !important;
    border: 0 !important;
    border-radius: 6px !important;
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
    letter-spacing: .08em !important;
    text-align: center !important;
    text-transform: uppercase !important;
    white-space: normal !important;
    box-shadow: none !important;
    cursor: pointer !important;
    appearance: none !important;
    -webkit-appearance: none !important;
  }

  #primaryNav .nav-item.mobile-only-item .nav-main-link.quote-trigger {
    background: var(--red) !important;
    color: #fff !important;
  }

  #primaryNav .nav-item.mobile-only-item .nav-main-link[href^="tel:"] {
    background: var(--black) !important;
    color: #fff !important;
    margin-top: 0 !important;
    text-decoration: none !important;
  }
}

/* vehicle-mobile-cta-fix */
@media (max-width: 1024px) {
  body {
    padding-bottom: calc(136px + env(safe-area-inset-bottom, 0px)) !important;
  }

  body.nav-open,
  body.overflow-hidden {
    padding-bottom: 0 !important;
  }

  body .mobile-cta-widget {
    z-index: 9500 !important;
  }

  body .mobile-cta-widget .mobile-ctas {
    display: block !important;
    width: min(calc(100vw - 20px), 560px) !important;
    max-width: 560px !important;
    box-sizing: border-box !important;
  }

  body .mobile-cta-widget .mobile-cta-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 8px !important;
  }

  body .mobile-cta-widget .mobile-cta-btn {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    overflow: hidden !important;
    text-align: center !important;
  }

  body .mobile-cta-widget .mobile-cta-btn > span {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
  }
}

@media (max-width: 768px) {
  main .hero-btns,
  main .cta-btns,
  main .about-actions,
  main .steps-cta,
  main div:has(> .btn-red-lg),
  main div:has(> .btn-black-lg) {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: center !important;
    gap: 12px !important;
  }

  main .btn-red-lg,
  main .btn-black-lg,
  main a.btn-red-lg,
  main a.btn-black-lg,
  main button.btn-red-lg,
  main button.btn-black-lg {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
    justify-content: center !important;
    text-align: center !important;
    white-space: normal !important;
  }
}

@media (max-width: 420px) {
  body {
    padding-bottom: calc(128px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

/* article-table */
.article-table-wrap {
  width: 100%;
  max-width: 100%;
  margin: 32px 0;
  overflow-x: auto;
  border: 1px solid var(--rule);
  background: #fff;
  -webkit-overflow-scrolling: touch;
}

.article-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
  font-size: 16px;
  line-height: 1.45;
}

.article-table caption {
  padding: 14px 18px;
  background: var(--black);
  color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800;
  font-size: 18px;
  letter-spacing: .12em;
  text-align: left;
  text-transform: uppercase;
}

.article-table th,
.article-table td {
  padding: 14px 16px;
  border: 1px solid var(--rule);
  vertical-align: top;
  text-align: left;
}

.article-table thead th {
  background: var(--bg-off);
  color: var(--black);
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800;
  font-size: 15px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.article-table tbody th {
  color: var(--black);
  font-weight: 800;
}

.article-table tbody tr:nth-child(even) {
  background: #fafafa;
}

/* article-toc-sticky-fix */
#article.article-body,
.article-body {
  content-visibility: visible !important;
  contain: none !important;
  contain-intrinsic-size: auto !important;
}

/* mobile-sticky-article-toc */
.mobile-article-toc {
  display: none;
}

.article-content h2[id],
.article-content h3[id] {
  scroll-margin-top: 132px;
}

@media (max-width: 1024px) {
  body.has-mobile-article-toc .article-toc {
    display: none !important;
  }

  .mobile-article-toc {
    position: sticky;
    top: 64px;
    z-index: 150;
    display: block;
    width: min(1120px, calc(100% - 32px));
    margin: 0 auto 28px;
    border: 1px solid rgba(17, 17, 17, .14);
    border-top: 3px solid var(--red);
    background: rgba(255, 255, 255, .98);
    box-shadow: 0 16px 34px rgba(17, 17, 17, .14);
    backdrop-filter: blur(10px);
  }

  .mobile-article-toc-toggle {
    width: 100%;
    min-height: 54px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    padding: 13px 16px;
    border: 0;
    background: #fff;
    color: var(--black);
    cursor: pointer;
    text-align: left;
  }

  .mobile-article-toc-kicker {
    display: block;
    color: var(--red);
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .18em;
    line-height: 1;
    text-transform: uppercase;
  }

  .mobile-article-toc-current {
    display: block;
    margin-top: 4px;
    overflow: hidden;
    color: var(--black);
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 17px;
    font-weight: 900;
    letter-spacing: .08em;
    line-height: 1.15;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
  }

  .mobile-article-toc-icon {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--black);
    color: #fff;
    font-family: Arial, sans-serif;
    font-size: 18px;
    line-height: 1;
    transition: transform .18s ease;
  }

  .mobile-article-toc.is-open .mobile-article-toc-icon {
    transform: rotate(180deg);
  }

  .mobile-article-toc-panel {
    max-height: min(54vh, 440px);
    overflow-y: auto;
    border-top: 1px solid var(--rule);
    background: #fff;
  }

  .mobile-article-toc-panel[hidden] {
    display: none;
  }

  .mobile-article-toc-list {
    display: grid;
    gap: 0;
    margin: 0;
    padding: 6px 0;
    list-style: none;
  }

  .mobile-article-toc-list a {
    display: block;
    padding: 13px 16px;
    border-left: 4px solid transparent;
    border-bottom: 1px solid var(--rule);
    color: var(--body);
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: .06em;
    line-height: 1.2;
    text-decoration: none;
    text-transform: uppercase;
  }

  .mobile-article-toc-list li:last-child a {
    border-bottom: 0;
  }

  .mobile-article-toc-list a:hover,
  .mobile-article-toc-list a:focus-visible,
  .mobile-article-toc-list a[aria-current="true"] {
    border-left-color: var(--red);
    background: var(--bg-off);
    color: var(--black);
  }
}

@media (max-width: 420px) {
  .mobile-article-toc {
    width: min(100% - 20px, 1120px);
    top: 64px;
  }

  .mobile-article-toc-current {
    font-size: 15px;
  }
}

/* quote-button-color-fix */
.nav-cta-wrap > button.nav-cta.quote-trigger,
button.nav-cta.quote-trigger {
  background: var(--red) !important;
  background-color: var(--red) !important;
  color: #fff !important;
}

.nav-cta-wrap > a.nav-cta[href^="tel:"] {
  background: var(--black) !important;
  background-color: var(--black) !important;
  color: #fff !important;
}

button.desktop-cta-btn-quote,
button.mobile-cta-btn-quote {
  background: var(--red) !important;
  background-color: var(--red) !important;
  color: #fff !important;
}

/* footer-aware-floating-cta */
#desktopCtaWidget.is-footer-hidden,
.desktop-cta-widget.is-footer-hidden {
  opacity: 0 !important;
  transform: translateY(18px) !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

#desktopCtaWidget.is-footer-hidden [data-desktop-cta-reveal],
.desktop-cta-widget.is-footer-hidden [data-desktop-cta-reveal] {
  opacity: 0 !important;
  transform: translateY(18px) !important;
  pointer-events: none !important;
}

.mobile-cta-widget.is-visible.is-footer-hidden,
.mobile-cta-widget.is-footer-hidden {
  opacity: 0 !important;
  transform: translateY(120%) !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* sticky-safe-horizontal-clipping */
html,
body {
  overflow-x: clip !important;
}

@supports not (overflow: clip) {
  html,
  body {
    overflow-x: hidden !important;
  }
}

/* related-post-card-images */
.related-wrap .post-item .pi-media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .78;
  transition: transform .25s ease, opacity .25s ease;
}

.related-wrap .post-item:hover .pi-media img,
.related-wrap .post-item:focus-visible .pi-media img {
  transform: scale(1.025);
  opacity: .62;
}

.related-wrap .post-item .pi-ph {
  position: relative;
  z-index: 1;
}
