﻿@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Public+Sans:ital,wght@0,100..900;1,100..900&display=swap');

/* common css starts here */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
figure,
ol,
ul,
dl,
fieldset,
pre {
    margin: 0;
}

.iti {
    width: 100%;
}

.phoneInput {
    width: 100%;
    padding-left: 40px;
    outline: none;
    border: none;
}


a:hover {
    text-decoration: none;
}

html {
    scroll-behavior: smooth;
}

/* modal css home page  */

.modal-footer.homefooter {
    position: absolute;
    top: 0;
    right: 11px;
    border-top: none;
}
.close-red {
    color: red;
    font-size: 45px
}
.modal_img img {
    width: 100%;
    height: 100%;
}
.modal-body .modal_img img {
    max-width: 100%;
    max-height: 100%;
}
a.modal-link {
    display: block;
    cursor: pointer;
}



/* Serpentine fonts ends here */

.field-error {
    color: red;
    font-size: 14px;
    margin-top: 5px;
}

.error_field {
    border-color: red;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

#notify_message {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 100;
}

input.error_field::placeholder {
    color: red !important;
}

.error_field {
    border-bottom: 1px solid red !important;
}

.req_check {
    border-bottom: 1px solid red !important;
}

.alert {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    text-align: center;
    color: #fff;
    z-index: 5;
    margin-bottom: 0;
    font-size: 18px;
    font-weight: 500;
}

.alert-danger {
    background-color: #bb1b1b;
    text-align: center;
    color: #fff;
    position: fixed;
    bottom: 0;
    width: 100%;
    margin-bottom: 0;
    font-size: 18px;
    font-weight: 500;
    z-index: 5;
}

.alert-success {
    background-color: #109610;
    text-align: center;
    color: #fff;
    position: fixed;
    bottom: 0;
    width: 100%;
    margin-bottom: 0;
    font-size: 18px;
    font-weight: 500;
    z-index: 5;
}

.regularBlackPara {
    color: #000;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.48px;
}

.regularWhitePara {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
}

.headingWrapper {
    margin-bottom: 40px;
}

.mainHeading {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 48px;
    font-style: normal;
    font-weight: 900;
    line-height: 56px;
    letter-spacing: -1.44px;
}

.redBtn {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: normal;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 28px;
    background-color: #B02D27;
    border: none;
    outline: none;
    transition: all 0.3s;
    text-align: center;
}

.redBtn:hover {
    color: #FFF;
    background-color: #8C221E;
}

.secondaryRedBtn {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: normal;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 28px;
    background-color: transparent;
    border: 1px solid #FFFFFF;
    outline: none;
    transition: all 0.3s;
    text-align: center;
}

.secondaryRedBtn:hover {
    color: #FFF;
    background-color: #8C221E;
    border: 1px solid #8C221E;
}


.blueBtn {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: normal;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 28px;
    background-color: transparent;
    border: 1px solid #FFFFFF;
    outline: none;
    transition: all 0.4s;
    text-align: center;
}

.blueBtn:hover {
    color: #FFF;
    background-color: #1C2B4A;
    border: 1px solid #1C2B4A;
}

.btnWrapper {
    margin-top: 40px;
}

.whiteHeading {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 48px;
    font-style: normal;
    font-weight: 900;
    line-height: 56px;
    letter-spacing: -1.44px;
}

.secondaryWhiteHeading {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 32px;
    font-style: normal;
    font-weight: 900;
    line-height: 40px;
    letter-spacing: -0.96px;
}

.secondaryHeading {
    color: #1C2B4A;
    text-align: center;
    font-family: "DM Sans";
    font-size: 32px;
    font-style: normal;
    font-weight: 900;
    line-height: 40px;
    letter-spacing: -0.96px;
}

.smallHeading {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 30px;
    letter-spacing: -0.72px;
}

.boldText {
    color: #000;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
}

.smallBlackHeading {
    color: #000;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: 32px;
}

.regularBluePara {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.smallBlueHeading {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 24px;
    letter-spacing: -0.72px;
}


/* common css ends here */

/* desktop nav css starts here */
.topBar {
    background-color: #B02D27;
    padding: 8px 10% 8px 15px;
    text-align: right;
}

.topBarInnerWrap {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 40px;
}

.topBarItems {
    display: flex;
    align-items: center;
    gap: 5px;
}

.desktopHeader {
    position: sticky;
    left: 0;
    top: 0;
    width: 100%;
    background-color: #1C2B4A;
    padding: 0px 5%;
    margin: 4px 0;
    z-index: 50;
}

.desktopNavInnerWrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.siteLogosWrapper {
    display: flex;
    align-items: center;
    gap: 40px;
}

.siteMainLogoWrap {
    max-width: 181px;
    padding-top: 15px;
    padding-bottom: 15px;
}

.siteMainLogoWrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.topperLogoWrap {
    max-width: 57px;
}

.topperLogoWrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.desktopNavList {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 64px;
    list-style: none;
}
.desktopNavList li{
    padding-bottom: 39px;
    padding-top: 39px;
    position: relative;
}
.desktopNavList li::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  width: 0;
  background: red;
  transition: width 0.3s ease;
}

.desktopNavList li:hover::after {
  width: 100%;
}
.desktopNavLink {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
    line-height: 24px;
}

.desktopNavLink:hover {
    color: #FFF;
}

.resourcesAndContactWrap {
    display: flex;
    align-items: center;
    gap: 80px;
}

.resourcesItem {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 8px;
}

.resourcesItemText {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

/* desktop  css ends here */

/* desktop mega menu css starts here */
.inventoryMegaMenu {
    position: fixed;
    left: 0;
    top: 150px;
    width: 100%;
    background-color: #fff;
    /* padding: 88px 0 72px 0; */
    padding: 50px 0px;
    z-index: 200;
    display: none;
    box-shadow: 0 6px 12px -2px rgba(0, 0, 0, 0.25);
}

.inventoryMegaMenuList {
    list-style: none;
}

.inventoryMegaMenuList li {
    margin-bottom: 16px;
}

.megaMenuLinkText {
    color: #000;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.megaMenuLinkText:hover {
    color: #000;
}

.inventoryMegaMenuCard {
    position: relative;
    padding-top: 119%;
}

.inventoryMegaMenuCard .inventoryMegaMenuCardImage {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.inventoryMegaMenuLogoWrap {
    position: absolute;
    right: 24px;
    bottom: 24px;
    z-index: 2;
    max-width: 200px;
}

.inventoryMegaMenuLogoWrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.activeNavTab {
    /* border-bottom: 4px solid #B02D27; */
    padding-bottom: 24px;
}

.rentalsMegaMenu {
    position: fixed;
    left: 0;
    top: 80px;
    width: 100%;
    background-color: #fff;
    padding: 88px 0 72px 0;
    z-index: 20;
    display: none;
    box-shadow: 0 6px 12px -2px rgba(0, 0, 0, 0.25)
}

.rentalMegaMenuCard {
    padding: 0 12px;
}

.rentalMegaMenuImageWrap {
    position: relative;
    padding-top: 69%;
}

.rentalMegaMenuImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.storageMegaMenu {
    position: fixed;
    left: 0;
    top: 80px;
    width: 100%;
    background-color: #fff;
    padding: 88px 0 72px 0;
    z-index: 20;
    display: none;
    box-shadow: 0 6px 12px -2px rgba(0, 0, 0, 0.25)
}

.serviceMegaMenu {
    position: fixed;
    left: 0;
    top: 80px;
    width: 100%;
    background-color: #fff;
    padding: 88px 0 72px 0;
    z-index: 20;
    display: none;
    box-shadow: 0 6px 12px -2px rgba(0, 0, 0, 0.25)
}

.resourcesMegaMenu {
    position: fixed;
    z-index: 20;
    top: 80px;
    right: 0;
    background-color: #1C2B4A;
    padding: 70px 15px 42px 42px;
    height: calc(100vh);
    min-width: 460px;
    transform: translateX(100%);
    transition: all 0.4s;
}

.showResourcesMegaMenu {
    transform: translateX(0%);
}

.resourcesNavLinkList {
    list-style: none;
}

.resourcesNavLinkText {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
}

.resourcesNavLinkText:hover {
    color: #FFF;
}

.resourcesNavLinkList li {
    margin-bottom: 16px;
}

.resourcesItem {
    transition: all 0.4s;
}

.resourcesItem:hover svg path {
    stroke: #669BBC;
}

.resourcesItem:hover .resourcesItemText {
    color: #669BBC;
}

.activeResourceTab {
    border-bottom: 4px solid #669BBC;
    padding-bottom: 15px;
}

/* desktop mega menu css ends here */

/* mobile nav css starts here */
.mobileHeader {
    display: none;
    background-color: #1C2B4A;
    position: sticky;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 20;
    padding: 12px 24px;
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.1);
}

.mobileHeaderInnerWrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.mobileLogoWrap {
    max-width: 280px;
}

.mobileLogoWrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}


.burgerLine {
    background-color: #fff;
    width: 40px;
    height: 2px;
    margin-bottom: 10px;
    transition: transform 0.4s ease, opacity 0.4s ease;
}

/* the cross effect  */
.cross .lineOne {
    transform: rotate(45deg) translateY(15px);
}

.cross .lineThree {
    transform: rotate(-45deg) translateY(-17px);
}

.cross .lineTwo {
    opacity: 0;
}

/* mobile nav css ends here */

/* mobile mega menu css starts here */
.mobileNavMegaMenu {
    position: sticky;
    left: 0;
    top: 120px;
    width: 100%;
    background-color: #1C2B4A;
    padding: 30px;
    z-index: 20;
    box-shadow: 0 0px 5px -10px rgba(0, 0, 0, 0.2);
    height: 90vh;
    overflow-y: auto;
    display: none;
}

/* close icon */
.mobileMenuCrossIcon {
    max-width: 14px;
    cursor: pointer;
}

/* wrapper */
.menuWrap {
    margin-top: 30px;
}

/* main menu links */
.mainMobileMenuInnerWrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 26px 5%;
    border-radius: 4px;
    border: 2px solid rgba(102, 155, 188, 0.20);
    background: rgba(102, 155, 188, 0.10);
    margin-bottom: 8px;
    max-width: 360px;
    margin: 8px auto;
}

.mainMobileMenuText {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 28px;
    letter-spacing: -0.72px;
}

/* bottom links */
.menuBottomContainer {
    margin-top: 80px;
}

.menuBottomList {
    list-style: none;
    max-width: 360px;
    margin: 0 auto;
}

.menuBottomList li {
    margin-bottom: 16px;
}

.menuBottomLink {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: 24px;
    letter-spacing: -0.48px;
}

.menuBottomLink:hover {
    color: #FFF;
}

/* submenu top bar */
.mobileMenuTopBar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.mainMenuIconWrapper {
    display: flex;
    align-items: center;
    gap: 8px;
}

.mainMenuIconText {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.48px;
    opacity: 0.6;
}

/* submenu */
.subMenuContentWrap {
    margin-top: 46px;
}

.subMenuHeading {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 28px;
    letter-spacing: -0.72px;
}

.subMenuLink {
    padding: 12px 0;
}

.subMenuLinkText {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.subMenuLinkText:hover {
    color: #FFF;
}

.mobileBoatsMenuCard {
    border-radius: 4px;
    border: 2px solid rgba(102, 155, 188, 0.20);
    background: rgba(102, 155, 188, 0.10);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    height: 100%;
}

.mobileBoatsMenuCard img {
    max-width: 140px;
    max-height: 41px;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* brand logos */
.mobileLogoWrapper {
    border-radius: 2px;
    border: 1px solid #EEE;
    background: #FAFAFA;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 5px;
    height: 80px;
}

.mobileLogoInnerWrap {
    max-width: 139px;
}

.mobileLogoInnerWrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* submenus hidden by default */
.submenu-boats,
.submenu-rentals,
.submenu-service,
.submenu-storage,
.submenu-resources {
    display: none;
}


/* mobile mega menu css ends here */


/* footer css starts here */
.grecaptcha-badge {
    display: none;
}

.recaptcha-disclaimer {
    font-size: 16px;
    color: rgba(255, 255, 255, 0.40);
    text-align: center;
    margin-top: 10px;
    padding: 5px 0 10px 0;
    font-family: "DM Sans";
}

.recaptcha-disclaimer a {
    font-size: 16px;
    color: #007bff78;
    text-align: center;
    margin-top: 10px;
    padding: 5px 0 10px 0;
    font-family: "DM Sans";
}

.footerContainer {
    margin-top: 10px;
    border-top: 1px solid #EEEEEE;
}

.joinNewsLetterSection {
    background-color: #B02D27;
    padding: 40px 15px 48px 15px;
    margin-bottom: 10px;
}

.footerLinkMobileHeader {
    padding: 24px 0;
    border-bottom: 1px solid #FFFFFF33;
}

.footerLinksMobileHeading {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

.joinHeading {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: 40px;
    letter-spacing: -0.96px;
}

.joinNewsInputWrapper {
    max-width: 350px;
    margin: 40px auto 40px auto;
    border-radius: 2px;
    border: 1px solid #E6E6E6;
    background: #FFF;
    display: flex;
    align-items: center;
}

.joinNewsInput {
    border: none;
    outline: none;
    width: 95%;
    color: rgba(28, 43, 74, 0.60);
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    padding: 9px 20px;
}

.joinNewsBtn {
    padding: 9px 20px;
    border: none;
    outline: none;
    background-color: #fff;
}

.socialIconsContainer {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
}

.socailIcon {
    background-color: #1C2B4A;
    height: 40px;
    width: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.socailIcon .fa-brands {
    color: #fff;
    font-size: 16px;
}

.mainFooter {
    background-color: #1C2B4A;
    padding: 80px 0 120px 0;
}


.customBorderLeft {
    border-left: 1px solid rgba(255, 255, 255, 0.2);
}

.footerLinksHeading {
    color: #669BBC;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
    letter-spacing: 0.8px;
    text-transform: uppercase;
}

.whiteLink {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
}

.whiteLink:hover {
    color: #FFF
}

.footerLinkList {
    list-style: none;
    margin-top: 26px;
    max-width: 240px;
}

.footerLinks {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

.footerLinks:hover {
    color: #FFF;
}

.barList a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid #FFFFFF33;
    padding: 16px 0;
}

.footerLogoSection {
    max-width: 400px;
    margin: 0 auto;
}

.footerLogoWrapper {
    max-width: 240px;
    margin: 0 auto;
}

.footerLogoWrapper img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.footerLocationsWrap {
    margin: 47px auto 40px auto;
}

.footerPhone {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: -0.72px;
}

.footerPhone:hover {
    color: #FFF;
}

.footerBottom {
    background-color: #121e38;
    padding: 15px 17px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
}

.footerBottomLink {
    color: rgba(255, 255, 255, 0.60);
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

.footerBottomLink:hover {
    color: rgba(255, 255, 255, 0.60);
}

.footerBottomAfterLine {
    position: relative;
}

.footerBottomAfterLine::after {
    content: '';
    position: absolute;
    right: -20px;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 20px;
    background-color: rgba(255, 255, 255, 0.60);
}

.footerLinkInnerList {
    list-style: none;
    margin-top: 10px;
    display: none;
}

.joinNewsInputInnerWrap {
    width: 100%;
}

/* footer css ends here */

/* home page css starts here */
.homeHeaderVideoWrapper {
    position: relative;
    padding-top: 56.6%;
}

.homeHeaderVideoWrapper .headerVideo {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.headerBannerCard {
    position: relative;
    padding-top: 56%;
    margin: 0 2px;
}

.headerBannerCard img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.headerBannerCardContent {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 50%;
    background: linear-gradient(180deg, rgba(28, 43, 74, 0.00) 0%, rgba(28, 43, 74, 0.60) 100%);
    display: flex;
    align-items: flex-end;
    padding-bottom: 10px;
    padding-left: 5%;
}

.headerBannerCardTitle {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 32px;
    font-style: normal;
    font-weight: 900;
    line-height: 48px;
    letter-spacing: -0.96px;
}

.heroSection {
    margin: 64px 0 80px 0;
}

.heroSectionInnerWrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
}

.heroHeaderWrapper {
    max-width: 480px;
}

.colorTag {
    color: #669BBC;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: 24px;
    letter-spacing: 0.8px;
}

.blueBoldTag {
    color: #669BBC;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 32px;
    letter-spacing: -0.72px;
}

.heroParaWrapper {
    max-width: 680px;
}

.socailSection {
    border: 1px solid #E1E1E1;
    background-color: #F7F7F7;
    padding: 110px 0;
}

.socialCarousel {
    position: relative;
}

.socialCarousel .owl-prev {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.socialCarousel .owl-next {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}

.socialCarouselCard {
    position: relative;
    padding-top: 56%;
}

.socialCarouselCard img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.socailTextContainer {
    max-width: 440px;
    margin: 0 auto;
}

.paraWrapper {
    margin: 24px 0 32px 0;
}

.socailSectionIconContainer {
    display: flex;
    align-items: center;
    gap: 8px;
}

.socailSectionIcon {
    background-color: #B02D27;
    height: 40px;
    width: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.socailSectionIcon i {
    color: #fff;
}

.featuredBoatsSection {
    margin: 64px 0 80px 0;
}

.featuredBoatsHeader {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 40px;
}

.featuredBoatsCarousel {
    position: relative;
}

.featuredBoatsCarousel .owl-prev {
    position: absolute;
    left: -48px;
    top: 35%;
}

.featuredBoatsCarousel .owl-next {
    position: absolute;
    right: -48px;
    top: 35%;
}

.featuredBoatTextWrap {
    max-width: 600px;
}

.featuredBoatImageWrap {
    position: relative;
    padding-top: 64%;
}

.featuredBoatImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.featuredBoatCardContetWrap {
    margin-top: 13px;
}

.featuredBoatTitle {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
}

.featuredBoatInfoWrap {
    display: flex;
    align-items: center;
    gap: 30px;
}

.featuredBoatPrice {
    color: #B02D27;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}


.featuredBoatMonthlyPrice {
    color: rgba(0, 0, 0, 0.50);
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    position: relative;
}

.featuredBoatMonthlyPrice::before {
    content: '';
    position: absolute;
    left: -15px;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 15px;
    background-color: #D9D9D9;
}

.homeLocationCard {
    position: relative;
    padding-top: 56%;
    margin: 0 2px;
}

.homeLocationCard img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.homeLocationCardContentWrap {
    position: absolute;
    left: 10%;
    bottom: 10%;
    z-index: 2;
}

.homeLocationCard::after {
    content: "";
    width: 100%;
    height: 50%;
    position: absolute;
    left: 0;
    bottom: 0;
    background: linear-gradient(180deg, rgba(34, 34, 34, 0.00) 0%, rgba(34, 34, 34, 0.80) 100%);
}

.locationWhitePara {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.brandLogosSection {
    background-color: #1C2B4A;
    padding: 47px 15px;
    margin-top: 4px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 80px;
}

.brandLogoWrap {
    max-width: 200px;
}

.brandLogoWrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.liveCamAndEventCard {
    padding: 0 15px;
}

.camAndEventImageWrap {
    position: relative;
    padding-top: 60%;
}

.camAndEventImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.camAndEventTextWrap {
    margin-top: 4px;
}

.camAndEventTitle {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 32px;
    font-style: normal;
    font-weight: 900;
    line-height: 48px;
    letter-spacing: -0.96px;
}

.liveCamAndEventSection {
    margin: 80px 0;
}

.brokerAndFinancingImageWrap {
    max-width: 320px;
    margin: 0 auto;
}

.brokerAndFinancingImageWrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.brokerAndFinancingCard {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    max-width: 680px;
}

.brokerAndFinancingTextWrap {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.brokerAndFinancingTextInnerWrap {
    max-width: 320px;
}

.charlesMillBlogSection {
    margin: 64px 0 80px 0;
}

.charlesMillTextWrap {
    display: flex;
    align-items: center;
    height: 100%;
}

.CharlesMillTextInnerWrap {
    max-width: 640px;
}

.charlesBlogImageWrap {
    max-width: 220px;
}

.charlesBlogImageWrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.charlesBlogCard {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding-bottom: 24px;
    border-bottom: 1px solid #E1E1E1;
    margin-top: 24px;
}

.charlesBlogTextWrap {
    max-width: 640px;
}

.homeBlogPara {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.5;
    max-height: calc(1.5em * 2);
}

.blogColorTag {
    color: #669BBC;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.homeBlogHeading {
    -webkit-line-clamp: 1;
}

/* home page css ends here */

/* service page css starts here */
.bgDarkCustom {
    background-color: #231F20;
}

.tabsWrapper {
    margin: 40px 0px;
}

.infoTab {
    display: flex;
    justify-content: space-between;
    padding: 15px 30px;
    border-radius: 2px;
    border: 1px solid #D9D9D9;
    margin-bottom: 20px;
    background: #FFF;
    cursor: pointer;
}

.infoTabName h4 {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
    letter-spacing: -0.16px;
}

.tabsContent {
    border: 1px solid #E1E1E1;
    background: #F7F7F7;
    padding: 40px 40px 79px 40px;
}

.tabsDetailsHeader {
    margin-bottom: 30px;
    margin-top: 40px;
}

.tabsDetails {
    max-width: 900px;
    margin: 0 auto;
}

.tabsDetailsImg {
    margin-top: 40px;
}

.tabsContentImgContainer img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.tabsContentLogoContainer {
    max-width: 200px;
}

.tabsContentLogoContainer img {
    height: 100%;
    width: 100%;
    object-fit: contain;
}

.tabsDetails {
    display: none;
}

.tabsDetailsContent ul {
    padding-left: 30px;
}

.tabsNote {
    margin-top: 40px;
}

.tabsNote p {
    color: #231F20;
    font-family: "Myriad Pro Regular";
    font-size: 18px;
    font-style: italic;
    font-weight: 400;
    line-height: 25px;
}

.tabsSec {
    margin: 60px auto;
    max-width: 1500px;
}

.headerSection {
    position: relative;
    padding-top: 31%;
    min-height: 400px;
}

.headerSection .headerMedia {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.formSection {
    padding: 56px 0 84px 0;
    border-top: 1px solid #E1E1E1;
    border-bottom: 1px solid #E1E1E1;
    background-color: #F7F7F7;
}

.fomrHeadingWrapper {
    margin-bottom: 60px;
}

.formFieldWrapper {
    margin-bottom: 16px;
}

.formField {
    color: rgba(0, 0, 0, 0.60);
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    width: 100%;
    outline: none;
    border-radius: 2px;
    border: 1px solid rgba(225, 225, 225, 0.87);
    background: #FFF;
    padding: 14px 13px 16px 13px;
}

.mainFormWrapper {
    max-width: 820px;
    margin: 0 auto;
}

.formBtnWrapper {
    margin-top: 25px;
}

#formContainer {
    scroll-margin-top: 80px;
}

.tabsDetailImageWrap {
    position: relative;
    padding-top: 55%;
    margin-top: 40px;
}

.tabsDetailImageWrap img,
iframe {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pageHeroSection {
    margin: 80px auto;
}

.brandHeroTextWrapper {
    max-width: 680px;
}

.pageHeroInnerWrap {
    display: flex;
    justify-content: space-between;
    gap: 30px;
    padding: 0 15px;
    margin: 0 auto;
}

.pageHeroLinkSection {
    max-width: 480px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.pageLinkWrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin-top: 40px;
}

.pageHeroTextWrapper {
    max-width: 1000px;
}

.customCanvasImageWrap {
    position: relative;
    padding-top: 70%;
}

.firstSectionTopMargin{
        margin-top: 60px;
    }

.customCanvasImageWrap img,
iframe {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* service page css ends here */

/* redocking page css starts here */
.redockingMediaWrap {
    position: relative;
    padding-top: 56%;
}

.redockingMediaWrap .redockingMedia {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.redockingWrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

.redockingInnerWrap {
    max-width: 400px;
}

.faqSection {
    margin: 80px 0;
}

.faqWrapper {
    max-width: 900px;
    margin: 0 auto;
}

.faqCard {
    border: 1px solid #E1E1E1;
    background-color: #F7F7F7;
    padding: 18px 24px;
}

.faqQuestionTab {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
    cursor: pointer;
}

.questionText {
    color: #222;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: 24px;
}

.faqCard {
    margin-bottom: 16px;
}

.faqQuestionTab .fa-solid {
    color: #222222;
    font-size: 20px;
}

/* redocking page css ends here */

/* repower page css starts here */
.repowerBannerWrapper {
    position: relative;
    max-width: 1280px;
    margin: 0 auto;
}

.repowerBannerWrapper .repowerBannerMedia {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.repowerBannerSection {
    margin-bottom: 80px;
}

.availabelOutBoardsSection {
    margin: 64px 0;
}

.availableOutBoardCard {
    padding: 0 20px;
    margin-bottom: 40px;
}

.availableOutBoardImageWrap {
    position: relative;
    padding-top: 110%;
}

.availableOutBoardImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.availableOutBoardContent {
    margin-top: 8px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
}

.availableOutBoardTitle {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
}

.horsePowerText {
    color: #1C2B4A;
    text-align: right;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

/* repower page css ends here */

/* storage page css starts here */
.blueBoldText {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 56px;
    letter-spacing: -0.72px;
}

.pricingHeading {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 32px;
    letter-spacing: -0.72px;
}

.storageLocationCard {
    padding: 0 20px;
}

.storageLocationImageWrap {
    position: relative;
    padding-top: 61%;
}

.storageLocationImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.storageLocationCardContent {
    margin-top: 16px;
}

.storageLocationTitle {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 21px;
    font-style: normal;
    font-weight: 900;
    line-height: 32px;
    letter-spacing: -0.63px;
}

.storageLocationSection {
    margin-bottom: 80px;
}

.selectFieldStyle {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background: url("/assets/images/contact/down-arrow.webp") no-repeat right 10px center;
    background-size: 16px 16px;
    padding-right: 40px;
    background-color: #fff;
    cursor: pointer;
}

/* storage page css ends here */

/* contact page css starts here */
.contactHeaderSection {
    position: relative;
    padding-top: 31%;
    min-height: 700px;
    overflow-x: hidden;
}

.contactHeaderSection img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.contactHeaderContent {
    position: absolute;
    left: 10%;
    bottom: 30%;
}

.whiteTag {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: 24px;
    letter-spacing: 0.8px;
    text-transform: uppercase;
}

.contactFormWrapper {
    position: absolute;
    right: 15%;
    bottom: -150px;
    border: 1px solid #E1E1E1;
    background: #F7F7F7;
    padding: 40px 60px;
    min-width: 520px;
}

.contactFormHeading {
    color: #1C2B4A;
    text-align: center;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 32px;
    letter-spacing: -0.72px;
}

.contactLocationSection {
    margin: 100px 0 80px 0;
}

.contactBoldText {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 32px;
    letter-spacing: -0.72px;
}

.contactLocationCard {
    padding: 0 40px;
}

.contactLocationImageWrap {
    position: relative;
    padding-top: 61%;
}

.contactLocationImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.contactHeadingWrapper {
    margin-bottom: 60px;
    margin-left: 30px;
}

.contactLocationContentWrap {
    margin-top: 24px;
}

.contactPhone {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 32px;
}

.contactPhone:hover {
    color: #1C2B4A;
}

.contactAddress {
    color: #000;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 32px;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-thickness: auto;
    text-underline-offset: auto;
    text-underline-position: from-font;
}

/* contact page css ends here */

/* brokerage page css starts here */
.brokerageMediaWrap {
    position: relative;
    padding-top: 45%;
}

.brokerageMediaWrap .brokerageMedia {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.brokerageProcessSection {
    margin: 64px 0 4px 0;
    padding: 64px 15px 76px 15px;
    background-color: #1C2B4A;
}

.brokerageProcessCard {
    padding: 0 40px;
    display: flex;
    gap: 40px;
}

.brokergeStepNumberWrap {
    flex: 0 0 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #fff;
    width: 80px;
}

.brokerageNumber {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 40px;
    font-style: normal;
    font-weight: 300;
    line-height: 24px;
}

.brokerageStepHeading {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 900;
    line-height: 32px;
}

.brokerageProcessCardContainer {
    margin-top: 64px;
}

/* brokerae page css ends here */

/* docking cm page css starts here */
.charlesMillsMapSection {
    max-width: 1280px;
    margin: 0 auto;
}

.charlesMapWrapper {
    position: relative;
    padding-top: 64%;
    border: 1px solid #000;
    margin: 0 15px;
}

.charlesMapWrapper .locationMapDocking {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}


.slipsAndDockingRates {
    margin-top: 64px;
    padding: 64px 15px 88px 15px;
    background-color: #1C2B4A;
}

.slipAndDockingRatesHeader {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
    margin-bottom: 40px;
}

.slipAndDockingRateRow {
    padding: 15px 0;
    border-bottom: 1px solid #FFFFFF33;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 80px;
}

.slipAndDockingClassWrap {
    width: 50%;
    padding-left: 40px;
}

.slipAndDcokingRatesWrap {
    width: 50%;
    padding-right: 40px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}

.whiteBoldText {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
}

.slipRatesAfter {
    position: relative;
}

.slipRatesAfter::after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: -10px;
    background-color: rgba(255, 255, 255, 0.20);
    width: 1px;
    height: 15px;
}

.marinaRulesSection {
    margin: 64px 15px;
}

.marinaRulesHeroParaWrap {
    padding: 0 15px;
    max-width: 960px;
    margin: 0 auto;
}

.rulesWrapper {
    padding: 0 15px;
    margin: 0 auto;
    max-width: 1280px;
}

.rulesWrapper ol li {
    margin-bottom: 4px;
}

.rulesWrapper ol li::marker {
    font-weight: bold;
}

/* docking cm page css ends here */

/* mid ohio page css starts here */
.midOhioFormWrapper {
    max-width: 400px;
    margin: 0 auto;
}

.midOhioformSection {
    background-color: #fff;
    padding: 56px 15px 80px 15px;
    border-top: 1px solid #E1E1E1;
    border-bottom: 1px solid #E1E1E1;
}

.midOhioheaderSection {
    position: relative;
    padding-top: 41%;
    min-height: 400px;
}

.midOhioheaderSection .headerMedia {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.midOhioheaderSection::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    background-color: rgba(0, 0, 0, 0.3);
}

.midOhioHeaderContent {
    position: absolute;
    left: 10%;
    bottom: 94px;
    border: 1px solid #fff;
    padding: 46px 64px 32px 64px;
    z-index: 2;
}

.midOhioHeroSection {
    max-width: 960px;
    margin: 80px auto;
}

#memberShopModal .modal-body {
    padding: 0;
}

.memberShipModalInnerWrap {
    position: relative;
}

.memberShipModalInnerWrap .memberModalCloseBtn {
    position: absolute;
    top: 24px;
    right: 24px;
}

.memberShipModalImageWrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.memberShipModalTextWrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

.memberShipModalTextInnerWrap {
    max-width: 480px;
    margin: 0 auto;
}

.memberBtnWrapper {
    margin: 40px 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
    max-width: 360px;
}

.midOhioTabBar {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap-reverse;
    gap: 40px;
}

.midOhioTabsWrapper {
    display: flex;
    align-items: center;
    border-radius: 4px;
    border: 1px solid #E1E1E1;
    background: #F7F7F7;
    overflow: hidden;
    flex-wrap: wrap;
}

.midOhioTabBar {
    margin-bottom: 40px;
}

.midOhioTab {
    color: #000;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    border: none;
    outline: none;
    display: inline-flex;
    transition: all 0.4s;
    padding: 18px 32px 17px 32px;
}

.midOhioTab:hover {
    background-color: #1C2B4A33;
}

.activeMidOhioTab {
    background-color: #1C2B4A33;
}

.howItWorksCardWrapper {
    background-color: #F7F7F7;
    padding: 64px 15px 112px 15px;
}

.howItWorksCard {
    padding: 0 20px;
}

.howItWorksIconWrap {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px auto;
}

.howItWorksIconWrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    max-width: 73px;
}

.blueBgColor {
    background-color: #1C2B4A;
}

.lightBlueBgColor {
    background-color: #669BBC;
}

.greyBgColor {
    background-color: #E1E1E1;
}

.redBgColor {
    background-color: #B02D27;
}

.howItWorksTextCard {
    padding: 64px 30px 40px 30px;
    height: 430px;
}

.memberShipBenefitsCardWrapper {
    background-color: #F7F7F7;
    padding: 64px 15px 112px 15px;
}

.memberShipCardImageWrap {
    min-height: 180px;
    height: 100%;
}


.memberShipCardImageWrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.memberShipCardTextWrap {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
}

.memberShipTextInnerWrap {
    max-width: 200px;
}

.memberBlueText {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
}

.rentalFleetWrapper {
    background-color: #F7F7F7;
    padding: 64px 15px 112px 15px;
}

.rentalHeroWrapper {
    max-width: 960px;
    margin: 0 auto;
}

.fleetCardWrapper {
    border: 1px solid #E1E1E1;
    background: #FFF;
    padding: 42px 47px 47px 47px;
}

.fleetInnerCardsContainer {
    display: flex;
    gap: 24px;
}

.fleetInnerCard {
    width: 50%;
}

.fleetInnerCardImageWrap {
    position: relative;
    padding-top: 64%;
}

.fleetInnerCardImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fleetInnerCardTextWrap {
    margin-top: 16px;
}

.fleetInnerCardInfoPara {
    color: #1C2B4A;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: 24px;
    letter-spacing: -0.48px;
}

.pricingWrapper {
    background: #F7F7F7;
    padding: 64px 15px 112px 15px;
}

.pricingTextWrapper {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pricingTextInnerWrapper {
    max-width: 400px;
}

.pricingImageWrapper {
    position: relative;
    padding-top: 82%;
}

.pricingImageWrapper img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.midOhioFaqWrapper {
    background: #F7F7F7;
    padding: 64px 15px 112px 15px;
}

.boatClubTabDetail {
    display: none;
}

.boatClubTabDetail.activeMidOhioTabBox {
    display: block;
}

/* mid ohio page css ends here */

/* financing page css starts here */
.main_wrap {
    position: relative;
}

.main_wrap::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    background-color: rgba(0, 0, 0, 0.2);
}

.img_wrap {
    position: relative;
    padding-top: 37%;
}

.img_wrap .financingMedia {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.main_wrap .text_wrap {
    position: absolute;
    left: 50%;
    bottom: 20%;
    transform: translateX(-50%);
    z-index: 5;
}

.financeFormWrapper {
    margin: 40px 0;
    min-height: 600px;
    background-color: #cdcdcd;
}

/* financing page css ends here */

/* 404 page start here */

.commonSection {
    margin-bottom: 80px;
}

.commonSectionInnerWrap {
    display: flex;
    gap: 120px;
    max-width: calc(100% - 15%);
    width: 100%;
    margin: 0 auto;
    padding: 0 15px;
}

.commonSectionTextWrapper {
    width: 50%;
    max-width: 600px;
}

.commonSectionImageWrapper {
    width: 50%;
}

.commonSectionImageWrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.commonSectionHeading {
    color: #1C2B4A;
    text-align: center;
    font-family: "DM Sans";
    font-size: 32px;
    font-style: normal;
    font-weight: 900;
    line-height: 40px;
    letter-spacing: -0.96px;
}

.commonPara {
    color: #000;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    text-align: center;
    line-height: 24px;
    margin-bottom: 40px;
    margin-top: 40px;
}

.commonSectionLinkWrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
}

.featured-btn {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 20px;
    text-transform: uppercase;
    background: #222;
    display: inline-block;
}

.thank-you-content-box {
    width: 50%;
}

.thank-you-inner-box {
    max-width: 480px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: center;
}

/* live cam  page css starts here */
.LiveCamHeadingWrapper {
    margin: 40px 0 40px 0;
}

.headingColorTag {
    color: #669BBC;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: 24px;
    letter-spacing: 0.8px;
    text-transform: uppercase;
}

.liveImageOuterWrap {
    padding: 0 20px;
}

.liveCamImageWrap {
    position: relative;
    padding-top: 50%;
}

.liveCamImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.liveCamImageWrap iframe {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.liveCamImagesSection {
    margin-top: 40px;
}

.liveCamDetailsSection {
    margin: 40px 0;
}

.liveCamTextInnerWrap {
    max-width: 960px;
}

.liveCamLogoWrap {
    border: 1px solid #E1E1E1;
    background: #F7F7F7;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 15px;
    max-width: 400px;
    margin-left: auto;
}

.liveCamLogoInnerWrap {
    max-width: 320px;
}

.liveCamLogoContainer img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.liveCamLogoTextWrap {
    margin-top: 24px;
}

.liveCamPhone {
    color: #B02D27;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
}

.liveCamPhone:hover {
    color: #B02D27;
}

.liveCamBtnWrapper {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 40px;
}

/* live cam  page css ends here */

/* about page css starts here */
.aboutLocationBtnWrapper {
    margin-top: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 24px;
}

.aboutBtnWrapper {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #1C2B4A;
    padding: 20px 40px;
    gap: 16px;
    color: #1C2B4A;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: normal;
}

.aboutBtnWrapper:hover {
    color: #1C2B4A;
}

.aboutLocationBtnCircle {
    flex: 0 0 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #1C2B4A;
    border-radius: 50%;
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

.fullServiceImageWrap {
    max-width: 720px;
}

.fullServiceImageWrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fullServiceTextWrap {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.fullServiceInnerWrap {
    max-width: 540px;
}

.fullServiceLogoWrapper {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
}

.fullServicelogoImageWrap {
    max-width: 120px;
}

.fullServicelogoImageWrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.aboutLinkSection {
    margin: 80px 0;
}

.aboutLinkCard {
    padding: 25px 15px 29px 15px;
    background-color: #1C2B4A;
    border-radius: 12px;
    min-height: 292px;
}

.aboutLinkTitle {
    color: #FFF;
    text-align: center;
    font-family: "DM Sans";
    font-size: 20px;
    font-style: normal;
    font-weight: 900;
    line-height: 28px;
}

.col-5ths {
    flex: 1 1 calc(20% - 30px);
    max-width: calc(20% - 30px);
    min-height: 272px;
}

.aboutLinkCardsWrapper {
    display: flex;
    align-items: flex-start;
    gap: 30px;
}

.customGrowControl {
    flex: 1 1 272px;
}

.aboutSectionMargin {
    margin: 80px 0;
}

.about360CardWrap{
    width: 100%;
    min-height: 500px;
    padding: 0 20px;
}

.about360CardWrap iframe{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.about360Section{
    margin-bottom: 80px;
}

/* about page css ends here */

/* location page css starts here */

.locationMapOuterWrap {
    height: 400px;
}

.locationMap {
    min-height: 400px;
}

.locationMap iframe {
    min-height: 400px;
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin-top: 40px;
}

.locationWeatherWrapper {
    height: 100%;
}

.locationWeatherInnerWrap {
    max-width: 480px;
    margin: 0 auto;
}

.weatherInfoCard {
    border-radius: 12px;
    border: 1px solid #E1E1E1;
    background: #F7F7F7;
    padding: 26px 34px;
}

.weatherTempAndConditionWrap {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 30px;
}

.weatherBoldText {
    color: #000;
    font-family: Inter;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
}

.weatherDetailTitle {
    color: #4B5563;
    font-family: Inter;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
}

.weatherDetailsContainer {
    display: flex;
    justify-content: space-between;
    gap: 30px;
    flex-wrap: wrap;
}

.locationAndWeatherBtnWrap {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 40px;
}

.locationRedBtn {
    flex: 0 0 calc(50% - 16px);
}

.marinaSpecificationSection {
    margin: 80px 0 64px 0;
    padding: 64px 15px;
    border-top: 1px solid #E1E1E1;
    border-bottom: 1px solid #E1E1E1;
    background: #F7F7F7;
}

.locationSpecsCard {
    min-height: 192px;
    padding: 25px 15px 29px 15px;
    background-color: #1C2B4A;
    border-radius: 12px;
}

.serviceAtCharlesImageWrap {
    position: relative;
    padding-top: 75%;
}

.serviceAtCharlesImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.serviceAtCharlesTextWrap {
    display: flex;
    height: 100%;
    align-items: center;
}

.serviceAtCharlesTextInnerWrap {
    max-width: 320px;
    margin: 0 auto;
}

.serviceCardCustomMargin {
    margin-bottom: 64px;
}

.salesClubLakeAndCard {
    position: relative;
    padding-top: 53%;
    border-radius: 12px;
    overflow: hidden;
}

.salesClubLakeAndCard img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.salesClubLakeContent {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

.salesClubLakeTitle {
    color: #FFF;
    font-family: "DM Sans";
    font-size: 32px;
    font-style: normal;
    font-weight: 900;
    line-height: 32px;
    letter-spacing: -0.96px;
    text-align: center;
}

.salesWhiteBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: #FFF;
    text-align: right;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 900;
    line-height: normal;
    border: none;
    outline: none;
    background-color: transparent;
}

.salesWhiteBtn:hover {
    color: #FFF;
}

.ohioCleanMarinaSection {
    margin: 64px 0;
    border-top: 1px solid #E1E1E1;
    border-bottom: 1px solid #E1E1E1;
    background: #F7F7F7;
    padding: 66px 15px;
}

.ohioCleanContainer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 120px;
}

.ohioCleanLogowrap {
    max-width: 280px;
}

.ohioCleanLogowrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.ohioCleanTextWrap {
    max-width: 760px;
}

.locationLiveCamImageWrap {
    position: relative;
    padding-top: 50%;
}

.locationLiveCamImageWrap img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.locationLiveCamCard {
    padding: 0 20px;
}

.awardSection {
    background-color: #1C2B4A;
    padding: 64px 15px;
    margin-top: 64px;
}

.awardsCard {
    background: rgba(255, 255, 255, 0.10);
    padding: 54px 46px;
    margin: 0 20px;
    display: flex;
    align-items: center;
    gap: 51px;
    justify-content: center;
}

.awardTitle {
    color: #FFF;
    font-family: Inter;
    font-size: 22.917px;
    font-style: normal;
    font-weight: 800;
    line-height: 32px;
}

/* location page css ends here */

/* brand page css starts here */
.brandHeaderSection {
    position: relative;
    padding-top: 25%;
    min-height: 400px;
}

.brandHeaderSection .brandHeaderMedia {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.brandIntroSection {
    max-width: 1520px;
    margin: 100px auto 100px;
    padding: 0 15px;
}

.brandIntroContainer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
}

/* .brandLogoContainer {
    max-width: 350px;
    background-color: #000;
    height: 91px;
} */

.brandLogoContainer img {
    width: 220px;
    height: 100%;
    object-fit: contain;
      filter: invert(1) brightness(0);
}

.brandParawrapper {
    max-width: 900px;
}

.brandTagLing {
    color: #222;
    /* font-family: Gantari; */
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 25px;
}


.brandPromoSection {
    max-width: 1520px;
    padding: 0 15px;
    margin: 0 auto 150px auto;
    border: 1px solid #E6E6E6;
    background-color: #FAFAFA;
    padding: 13px 15px;
    text-align: center;
}

.brandPromotionText {
    color: #222;
    text-align: center;
    font-family: Aboreto;
    font-size: 30px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
}

.brandInventorySection {
    max-width: 1520px;
    margin: 80px auto 90px auto;
}

.brandInventoryHeadeingWrap {
    margin-bottom: 20px;
}

.fearuredCardLocation {
    color: rgba(34, 34, 34, 0.60);
    font-family: Gantari;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 30px;
}

.textAfterLine {
    position: relative;
}

.textAfterLine::after {
    content: '';
    position: absolute;
    top: 50%;
    right: -20px;
    transform: translateY(-50%);
    width: 1.5px;
    height: 15px;
    background-color: rgba(21, 21, 21, 0.60);
}

.brandTagLineText {
    color: #151515;
    text-align: center;
    /* font-family: Gantari; */
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 22px;
    letter-spacing: 0.54px;
}

.brandBottomTagLineWrap {
    margin-top: 40px;
    margin-bottom: 120px;
}

.brandInventoryImageContainer {
    position: relative;
    padding-top: 65%;
}

.brandInventoryImageContainer img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.brandInventoryCard {
    margin-bottom: 60px;
    padding: 0 5px;
}

.brandCardContent {
    margin-top: 12px;
}

/* brand page css ends here */

@media screen and (max-width: 1600px) {}

@media screen and (max-width: 1440px) {
    .desktopHeader {
        padding: 4px 2%;
    }

    .desktopNavList {
        gap: 24px;
    }

    .resourcesAndContactWrap {
        gap: 20px;
    }

    .siteLogosWrapper {
        gap: 20px;
    }

    .commonSectionInnerWrap {
        gap: 40px;
    }
}

@media screen and (max-width: 1200px) {
    .featuredBoatsCarousel .owl-prev {
        left: 0;
    }

    .featuredBoatsCarousel .owl-next {
        right: 0;
    }

    .contactHeaderContent {
        position: absolute;
        left: 50%;
        bottom: 0;
        top: 20%;
        transform: translateX(-50%);
        text-align: center;
        height: fit-content;
    }

    .contactFormWrapper {
        position: absolute;
        right: 50%;
        bottom: 0;
        border: 1px solid #E1E1E1;
        background: #F7F7F7;
        padding: 40px 60px;
        min-width: unset;
        transform: translateX(50%);
        top: 45%;
        min-height: 680px;
        width: 90%;
        max-width: 500px;
    }

    .contactLocationSection {
        margin: 100px 0 80px 0;
    }
}

@media screen and (max-width: 991px) {
    .brandIntroContainer {
        flex-wrap: wrap;
        justify-content: center;
        text-align: center;
        gap: 0;
    }
    .brandLogoContainer img {
        width: 250px;
    }
    .brandIntroSection {
        margin: 40px 0;
        padding: 0;
    }
    .brandParawrapper{
        padding: 20px;
    }
    .desktopHeader {
        display: none;
    }

    .mobileHeader {
        display: block;
    }

    .headerBannerCardTitle {
        font-size: 24px;
        line-height: 28px;
        letter-spacing: -0.72px;
    }

    .heroSectionInnerWrap {
        align-items: start;
        flex-direction: column;
        max-width: 90%;
        margin: 0 auto;
    }

    .heroSection {
        margin: 40px 0 40px 0;
    }

    .socailSection {
        padding: 60px 0;
    }

    .featuredBoatsSection {
        margin: 40px 0 40px 0;
    }

    .topBar {
        margin-bottom: 4px;
    }

    .pageHeroSection {
        margin: 40px auto;
    }

    .pageHeroInnerWrap {
        flex-direction: column;
    }

    .midOhioHeaderContent {
        padding: 46px 40px 32px 40px;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        min-height: 300px;
    }

    .whiteHeading {
        font-size: 32px;
        line-height: 40px;
        letter-spacing: -0.96px;
    }

    .midOhioHeroSection {
        margin: 40px auto;
        padding: 0 15px;
    }

    .secondaryWhiteHeading {
        font-size: 24px;
        font-weight: 900;
        line-height: 32px;
        letter-spacing: -0.72px;
    }

    .howItWorksCardWrapper {
        padding: 64px 15px 80px 15px;
    }

    .rentalFleetWrapper {
        padding: 64px 15px 80px 15px;
    }

    .midOhioFaqWrapper {
        padding: 64px 15px 80px 15px;
    }

    .fleetInnerCardsContainer {
        flex-direction: column;
    }

    .fleetInnerCard {
        width: 100%;
    }

    .aboutSectionMargin {
        margin: 40px 0;
    }

    .aboutLinkSection {
        margin: 40px 0;
    }

    .tabsContent {
        padding: 40px 20px 79px 20px;
    }

    .infoTab {
        padding: 15px 20px;
    }

    .liveCamLogoWrap {
        margin: auto;
    }

    .commonSectionInnerWrap {
        flex-direction: column;
        gap: 40px;
    }

    .thank-you-content-box {
        width: 100%;
    }

    .commonSectionImageWrapper {
        width: 100%;
    }

    .firstSectionTopMargin{
        margin-top: 40px;
    }

    .footerLinkList{
        margin: 0 auto;
    }

    .footerLinksHeading{
        text-align: center;
    }

    .ohioCleanContainer{
        gap: 60px;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }
}

@media screen and (max-width: 767px) {
    .footerLinksHeading {
        text-align: center;
        display: none;
    }

    .midOhioHeaderContent {
        padding: 20px 15px 32px 20px;
        width: 90%;
    }

    .footerLinkList {
        margin: 26px auto 20px auto;
        max-width: 90%;
        display: none;
    }

    .mainHeading {
        font-size: 22px;
        line-height: normal;
        letter-spacing: -0.96px;
    }

    .joinHeading {
        font-size: 24px;
        font-weight: 700;
        line-height: 32px;
        letter-spacing: -0.72px;
    }

    .mainFooter {
        background-color: #1C2B4A;
        padding: 40px 0 80px 0;
    }

    .topBarInnerWrap {
        justify-content: center;
        flex-wrap: wrap;
        gap: 24px;
    }

    .secondaryHeading {
        font-size: 24px;
        line-height: 32px;
        letter-spacing: -0.72px;
    }

    .contactFormWrapper {
        width: 90%;
        min-width: unset;
    }

    .slipAndDockingRateRow {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        gap: 40px;
    }

    .slipAndDockingClassWrap {
        padding-left: 0;
    }

    .slipAndDcokingRatesWrap {
        width: 100%;
    }

    .slipAndDockingClassWrap {
        width: 100%;
    }
}

@media screen and (max-width: 576px) {
    .featuredBoatsHeader {
        flex-direction: column;
        align-items: flex-start;
    }

    .brandLogosSection {
        gap: 40px;
    }

    .brandLogoWrap {
        max-width: 200px;
        flex: 1 1 calc(100% / 4);
    }

    .brokerAndFinancingCard {
        gap: 20px;
    }

    .brokerAndFinancingImageWrap {
        max-width: 140px;
    }

    .charlesBlogImageWrap {
        display: none;
    }

    .charlesMillBlogSection {
        margin: 40px 0 60px 0;
    }

    .camAndEventTitle {
        font-size: 24px;
        line-height: 32px;
        letter-spacing: -0.72px;
    }

    .smallHeading {
        font-size: 20px;
        line-height: 28px;
        letter-spacing: -0.6px;
    }

    .brokerageProcessCard {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 20px;
        padding: 0 15px;
    }

    .awardsCard{
        gap: 30px;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
}

@media(max-width: 450px) {
    .footerBottom {
        flex-direction: column;
        gap: 10px;
        text-align: center;
        align-items: center;
        justify-content: center;
    }

    .footerBottomAfterLine::after {
        display: none;
    }
}
