/* about us */
.aboutus-brand-list {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
    margin: 0;
}

.aboutus-brand-list li {
    margin: 10px;
}

.aboutus-brand-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 120px;
    height: 50px;
    border: 2px solid #007bff;
    text-decoration: none;
    color: #007bff;
    transition: background-color 0.3s, color 0.3s;
}

.aboutus-brand-link:hover {
    background-color: #007bff;
    color: #fff;
}

.aboutus-brand-name {
    font-size: 14px;
    text-transform: uppercase;
    font-weight: 600;
    margin: 0;
    text-align: center;
}


/* fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap');
@font-face {
  font-family: sharetect;
  src: url(https://cdn.revolutionparts.io/d168724655a991791808bafd95e3239e/design/ShareTech-Regular.woff),
      url(https://cdn.revolutionparts.io/d168724655a991791808bafd95e3239e/design/ShareTech-Regular.woff2);
}

/* globals */
body, html {
	font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji';
    font-size: 16px;
}

.container-wrap {
	padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.overflow-hidden {
	overflow: hidden;
}

.page-builder-page-layout .page-builder-layout-column.block-modules .page-builder-layout-module+.page-builder-layout-module {
	margin-top: 0;
}

.d-none {
	display: none;
}

.page-subheader-component .page-bread-crumbs {
	padding: 15px 0;
}

/* header */
body.stuck .themeHeaderNavSection {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 900;
}

.themeTopHeaderSection {
	padding: 20px 0;
}

@media screen and (max-width: 1100px) {
    .themeTopHeaderSection {
    	padding-bottom: 20px;
    }
}

.themeTopHeaderSection .container-wrap {
    max-width: 1536px !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
}

@media screen and (max-width: 767px) {
    .themeTopHeaderSection .container-wrap {
    	padding-left: 10px !important;
    	padding-right: 10px !important;
    }
}

.themeTopHeaderSection .page-builder-layout-column-wrap {
	display: flex;
    align-items: center;
}

@media screen and (max-width: 1100px) {
    .themeTopHeaderSection .page-builder-layout-column-wrap {
    	flex-wrap: wrap;
        flex-direction: column;
    }
}

.themeTopHeaderSection .page-builder-layout-column-wrap .page-builder-layout-module:nth-child(2) {
	flex: 1;
}

.themeTopHeaderSection .store-logo-module .store-logo-link img {
	margin: 0;
    /*max-height: 100%;*/
}

@media screen and (max-width: 1150px) {
    .themeTopHeaderSection .store-logo-module .store-logo-link img {
    	max-height: 48px;
    }
}

@media screen and (max-width: 500px) {
    .themeTopHeaderSection .store-logo-module .store-logo-link img {
    	max-height: 30px;
    }
}

@media screen and (max-width: 350px) {
    .themeTopHeaderSection .store-logo-module .store-logo-link img {
    	max-height: 25px;
    }
}

.themeTopHeaderSection .page-builder-layout-column-wrap .page-builder-layout-module p {
	margin-bottom: 0;
    font-size: 16px;
    margin-left: 1.5rem;
}

@media screen and (max-width: 1100px) {
    .themeTopHeaderSection .page-builder-layout-column-wrap .page-builder-layout-module p {
    	margin-bottom: 15px;
        margin-left: 0;
    }
}

.themeTopHeaderSection .links-list-module.links-display-block .links-list {
	display: flex !important;
    align-items: center;
    gap: 40px;
}

@media screen and (max-width: 500px) {
    .themeTopHeaderSection .links-list-module.links-display-block .links-list {
    	gap: 15px;
    }
}

.themeTopHeaderSection .links-list-module.links-display-block .links-list a {
	font-size: 16px;
    color: #000;
    position: relative;
    padding-left: 30px;
}

@media screen and (max-width: 500px) {
    .themeTopHeaderSection .links-list-module.links-display-block .links-list a {
    	padding-left: 20px;
        font-size: 12px;
    }
}

.themeTopHeaderSection .links-list-module.links-display-block .links-list a:hover,
.themeTopHeaderSection .links-list-module.links-display-block .links-list a:focus {
	opacity: .6;
    text-decoration: none;
}

.themeTopHeaderSection .links-list-module.links-display-block .links-list li a::before {
	width: 16px;
    height: 16px;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
}

.themeTopHeaderSection .links-list-module.links-display-block .links-list li:nth-child(1) a::before {
	content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" class="h-4 w-4 mr-2 fill-current text-blue" viewBox="0 0 20 20"><path d="M10.707 2.293a1 1 0 00-1.414 0l-7 7a1 1 0 001.414 1.414L4 10.414V17a1 1 0 001 1h2a1 1 0 001-1v-2a1 1 0 011-1h2a1 1 0 011 1v2a1 1 0 001 1h2a1 1 0 001-1v-6.586l.293.293a1 1 0 001.414-1.414l-7-7z"></path></svg>');
}

.themeTopHeaderSection .links-list-module.links-display-block .links-list li:nth-child(2) a::before {
	content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" class="h-4 w-4 mr-2 fill-current text-blue" viewBox="0 0 20 20"><path d="M9 4.804A7.968 7.968 0 005.5 4c-1.255 0-2.443.29-3.5.804v10A7.969 7.969 0 015.5 14c1.669 0 3.218.51 4.5 1.385A7.962 7.962 0 0114.5 14c1.255 0 2.443.29 3.5.804v-10A7.968 7.968 0 0014.5 4c-1.255 0-2.443.29-3.5.804V12a1 1 0 11-2 0V4.804z"></path></svg>');
}

.themeTopHeaderSection .links-list-module.links-display-block .links-list li:nth-child(3) a::before {
	content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" class="h-4 w-4 mr-2 fill-current text-blue" viewBox="0 0 20 20"><path d="M2.003 5.884L10 9.882l7.997-3.998A2 2 0 0016 4H4a2 2 0 00-1.997 1.884z"></path><path d="M18 8.118l-8 4-8-4V14a2 2 0 002 2h12a2 2 0 002-2V8.118z"></path></svg>');
}

.themeTopHeaderSection .links-list-module.links-display-block .links-list li:nth-child(4) a::before {
	content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" class="h-4 w-4 mr-2 fill-current text-blue" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M18 13V5a2 2 0 00-2-2H4a2 2 0 00-2 2v8a2 2 0 002 2h3l3 3 3-3h3a2 2 0 002-2zM5 7a1 1 0 011-1h8a1 1 0 110 2H6a1 1 0 01-1-1zm1 3a1 1 0 100 2h3a1 1 0 100-2H6z" clip-rule="evenodd"></path></svg>');
}

@media screen and (max-width: 1100px) {
    .themeHeaderNavSection {
    	display: none;
    }
    .themeHeaderNavSection.openNav {
		display: block;
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        z-index: 9;
        padding: 20px 0;
        overflow: auto;
	}
    .themeHeaderNavSection.openNav .links-list-module.links-display-block .heading {
        padding: 0 10px;
        font-size: 20px;
        display: block;
        font-weight: 700;
        margin-bottom: 20px;
        color: #fff;
        font-family: "Inter", sans-serif;
    }
    .themeHeaderNavSection.openNav .links-list {
    	flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
    }
    .themeHeaderNavSection.openNav .links-list li {
    	width: 100%;
        border-top: 1px solid #333333;
    }
    .themeHeaderNavSection.openNav .links-list li:last-child {
    	border-top: 0;
    }
    .themeHeaderNavSection.openNav .links-list a {
    	width: 100%;
        padding: 10px;
        font-family: "Inter", sans-serif;
        font-size: 16px;
        text-transform: capitalize;
    }
}

.themeHeaderNavSection .links-list-module.links-display-block .heading {
	display: none;
}

.themeHeaderNavSection .links-list {
	display: flex !important;
    align-items: center;
    justify-content: center;
}

.themeHeaderNavSection .links-list a {
	color: #fff;
    text-transform: uppercase;
    font-size: 16px;
    padding: 0.5rem;
    transition: all .3s ease-in-out;
    display: inline-block;
}

.themeHeaderNavSection .links-list a:hover,
.themeHeaderNavSection .links-list a:focus {
	text-decoration: none;
    background-color: rgba(31, 31, 31, 1);
}

.themeHamburger {
	display: none;
    position: absolute;
    left: 0px;
    top: 15px;
    width: 25px;
    height: 20px;
    cursor: pointer;
}

@media screen and (max-width: 1100px) {
    .themeHamburger {
    	display: block;
    }
}

.themeHamburger span {
    width: 25px;
    height: 3px;
    position: absolute;
    background-color: #000;
}

.themeHamburger span:nth-child(1) {
    top: 0;
}

.themeHamburger.openBurger span:nth-child(1) {
    transform: rotate(45deg);
    top: 8px;
    background-color: #fff;
}

.themeHamburger span:nth-child(2) {
    top: 8.5px;
}

.themeHamburger.openBurger span:nth-child(2) {
    display: none;
}

.themeHamburger span:nth-child(3) {
    bottom: 0;
}

.themeHamburger.openBurger span:nth-child(3) {
    transform: rotate(-45deg);
    bottom: 9px;
    background-color: #fff;
}

.themeHamburger.openBurger {
    left: auto;
    right: 20px;
    z-index: 99;
    top: 25px;
}

.loading_container {
	position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: rgba(255,255,255,0.8);
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
}

.share-tech-regular {
            font-family: sharetect;
            font-weight: 400;
            font-style: normal;
            font-size: 22px;
            text-transform: uppercase;
			color: #333;
        }

.loader_wrapper {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
        }

        .loader { 
            overflow: hidden;
            position: relative;
        } 

.loader::before {
	content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border: 3px solid #333; 
    /* Light grey */ 
    border-top: 3px solid #ed6969; 
    /* Redish */ 
    border-radius: 50%; 
    width: 100px; 
    height: 100px; 
    animation: spinloader 2s linear infinite; 
}

        .loader img { 
            height: 100px; 
            width: 100px; 
        } 

        .searching {
            font-family: sharetect;
            display: flex;
            align-items: center;
            margin-top: 20px; /* Add some space between loader and text */
        }

        .dot {
            animation: blink 1s infinite steps(1, end) both;
        }

        .dot:nth-child(2) {
            animation-delay: 0.2s;
        }

        .dot:nth-child(3) {
            animation-delay: 0.4s;
        }

        @keyframes spinloader { 
            0% { 
                transform: rotate(0deg); 
            } 

            100% { 
                transform: rotate(360deg); 
            } 
        } 

        @keyframes spinlogo { 
            0% { 
                transform: rotate(360deg); 
            } 

            100% { 
                transform: rotate(0deg); 
            } 
        } 

        @keyframes blink {
            0%, 100% { opacity: 0; }
            50% { opacity: 1; }
        }
  
/* page content */
.themePopularList {
    display: flex;
    flex-wrap: wrap;
    justify-content: center; /* Center items horizontally */
    align-items: center;
    margin-bottom: 0;
    list-style: none;
    padding: 0;
    gap: 25px;
}

.themePopularList li {
    max-width: 110px;
}

@media screen and (max-width: 600px) {
    /*.themePopularList li {
        flex: 0 0 50%;
        max-width: 50%;
    }*/
}

.themePopularList li a {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media screen and (max-width: 768px) {
    /*.themePopularList li a {
        height: 45px;
    }*/
}

.topPageSection {
    padding: 100px 0;
    background-color: #e0e0e0;
    position: relative;
    z-index: 2;
}

@media screen and (max-width: 768px) {
    .topPageSection {
        padding: 50px 0;
    }
}

.topPageSection::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    width: 400px;
    height: 400px;
    margin: auto;
    background-image: url(https://rp-superstore-space.sfo3.digitaloceanspaces.com/public/oem-trans.webp);
    background-size: contain;
    background-repeat: no-repeat;
    z-index: -1;
}

@media screen and (max-width: 768px) {
    .topPageSection::before {
        width: 200px;
        height: 200px;
    }
}

.topPageContainer {
    padding: 0 15px;
}

.topPageContentTitle {
    text-align: center;
    margin-bottom: 60px;
}

@media screen and (max-width: 768px) {
    .topPageContentTitle {
        margin-bottom: 20px;
    }
}

.topPageContentTitle h2 {
    text-transform: uppercase;
    font-family: "Inter", sans-serif;
    font-weight: 900;
    line-height: normal;
    font-size: calc(20px + (60 - 20) * ((100vw - 768px) / (1900 - 768)));
    margin-bottom: 10px;
}

@media screen and (max-width: 768px) {
    .topPageContentTitle h2 {
        font-size: 20px;
    }
}

.topPageContentTitle p {
    font-size: calc(16px + (50 - 16) * ((100vw - 768px) / (1900 - 768)));
    color: #217de9;
    text-transform: uppercase;
}

@media screen and (max-width: 768px) {
    .topPageContentTitle p {
        font-size: 16px;
    }
}

.topPageContent {
    max-width: 1200px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.topPageContent p {
    text-align: center;
    margin-bottom: 1rem;
}

/* banner */
.topBanner {
    padding: 100px 0 50px 0;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

@media screen and (max-width: 768px) {
    .topBanner {
        padding: 50px 0 20px 0;
    }
}

.topBannerContainer {
    padding: 0 15px;
}

.topBannerSearch {
    margin-bottom: 95px;
    max-width: 1082px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

@media screen and (max-width: 768px) {
    .topBannerSearch {
        margin-bottom: 60px;
    }
}

.topBannerPopularSearch p {
    text-align: center;
    font-size: 32px;
    text-shadow: 2px 2px 0 rgba(0,0,0,1);
    font-family: "Inter", sans-serif;
    color: #fff;
    margin-bottom: 25px;
}

@media screen and (max-width: 768px) {
    /*.topBannerPopularSearch p {
        font-size: 18px;
        margin-bottom: 0;
    }*/
}

.topBannerPopularSearch {
    max-width: 800px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.topBannerContent {
    text-align: center;
    margin-bottom: 60px;
    max-width: 1082px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

@media screen and (max-width: 768px) {
    .topBannerContent {
        margin-bottom: 30px;
    }
}

.topBannerContent h1 {
    color: #fff;
    font-family: "Inter", sans-serif;
    font-weight: 900;
    line-height: normal;
    font-size: calc(18px + (70 - 50) * ((100vw - 768px) / (1900 - 768)));
    text-transform: uppercase;
    text-shadow: 2px 2px 0 rgba(0,0,0,1);
}
  
@media screen and (max-width: 768px) {
    .topBannerContent h1 {
        font-size: 20px;
    }
}
  
  .topBannerContent p {
  	color: #fff;
	font-family: "Inter", sans-serif;
	font-size: calc(12px + (32 - 12) * ((100vw - 768px) / (1900 - 768)));
	text-shadow: 2px 2px 0 rgba(0,0,0,1);
	margin-bottom: 1rem;
  }
  
   @media screen and (max-width: 768px) {
	.topBannerContent p {
		font-size: 12px;
	}
  }
  
/* header */
  .themeHamburger {
  	display: none;
  }
  .themeMobileNav {
  	display: none;
  }
  @media screen and (max-width: 1023px) {
	.themeMobileNav {
        position: fixed;
        left: 0;
        right: 0;
        background-color: #252525;
        z-index: 9;
        top: 0;
        bottom: 0;
	  	overflow: auto;
	  	padding: 20px 0;
	  	display: flex;
	  	flex-direction: column;
	  	transform: translateX(-2000px);
        transition: all .3s ease-in-out;
	}
	.themeMobileNav.openNav {
		transform: translateX(0);
	}
	.themeMobileNav .themeMobileTitle {
		padding: 0 10px;
		font-size: 20px;
		display: block;
		font-weight: 700;
		margin-bottom: 20px;
	  	color: #fff;
	  	font-family: "Inter", sans-serif;
	}
	.themeMobileNav li {
		border-top: 1px solid #333333;
	}
	.themeMobileNav li:first-child {
		border-top: 0;
	}
	.themeMobileNav ul a {
		padding: 10px 10px;
    	display: block;
	  	color: #fff;
	   	font-family: "Inter", sans-serif;
	}
  	#header-main {
		position: relative;
	}
	.themeHamburger {
		display: block;
        position: absolute;
        left: 10px;
        top: 5px;
        width: 25px;
        height: 20px;
	  	cursor: pointer;
	}
	.themeHamburger.openBurger {
		left: auto;
	  	right: 20px;
	  	z-index: 99;
	  	top: 0px;
	}
	.themeHamburger.openBurger span:nth-child(2) {
		display: none;
	}
	.themeHamburger.openBurger span:nth-child(1) {
		transform: rotate(45deg);
    	top: 8px;
	  	background-color: #fff;
	}
	.themeHamburger.openBurger span:nth-child(3) {
		transform: rotate(-45deg);
    	bottom: 9px;
	  	background-color: #fff;
	}
	.themeHamburger span {
		width: 25px;
	  	height: 3px;
	  	position: absolute;
	  	background-color: #000;
	}
	.themeHamburger span:nth-child(1) {
		top: 0;
	}
	.themeHamburger span:nth-child(2) {
		top: 8.5px;
	}
	.themeHamburger span:nth-child(3) {
		bottom: 0;
	}
  }
  
  @media screen and (max-width: 767px) {
	#header-main img {
		width: 250px;
	}
	#header-main ul.flex {
		gap: 20px;
	}
	#header-main ul.flex li.px-5 {
		padding-left: 0 !important;
	  	padding-right: 0 !important;
	}
	#header-main ul.flex li.px-5 a {
		font-size: 12px;
	}
  }
      .search-container {
        width: 80%;
        max-width: 800px;
        display: flex;
        justify-content: center;
        align-items: stretch;
        margin-bottom: 20px;
		margin-left: auto;
		margin-right: auto;
      }
      .dropdown {
        padding: 10px;
        font-size: 16px;
        border: 1px solid #ccc;
        background-color: #f1f1f1;
        appearance: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        cursor: pointer;
        width: 175px;
        color: #333;
        border-radius: 5px 0 0 5px;
      }
      .search-box-container {
        position: relative;
        flex: 1;
      }
      .search-box {
        padding: 10px;
        font-size: 16px;
        border: 1px solid #ccc;
        border-left: none;
        background-color: #fff;
        padding-left: 40px;
        width: 100%;
        border-radius: 0 5px 5px 0;
      }
      .error-message-container {
        width: 30%;
        text-align: center;
        margin-top: 10px;
        height: 20px;
		margin-left: auto;
		margin-right: auto;
      }
      .error-message {
        color: red;
        background-color: #000307;
        padding: 10px;
        border-radius: 5px;
        display: none;
      }
      .search-icon {
        position: absolute;
        left: 10px;
        top: 50%;
        transform: translateY(-50%);
        width: 20px;
        height: 20px;
        fill: #808080;
      }
      .search-button {
        padding: 10px 15px;
        font-size: 16px;
        border: 1px solid #ccc;
        background-color: #f1f1f1;
        cursor: pointer;
        border-radius: 5px;
        color: #333;
        margin-left: 10px;
      }
      .search-button:hover {
        background-color: #e6e6e6;
      }

      @media (max-width: 800px) {
        .search-container {
          flex-direction: column;
          width: 100%;
          align-items: center;
        }
        .dropdown {
          max-width: none;
          border-radius: 5px 5px 0 0;
          border-bottom: none;
          width: 85%;
          font-size: 16px;
          padding: 10px;
        }
        .search-box-container {
          width: 85%;
          position: relative;
          margin-top: 5px;
          display: flex;
          justify-content: center;
        }
        .search-box {
          border: 1px solid #ccc;
          border-radius: 5px;
          width: 100%;
          font-size: 16px;
          padding: 10px 10px 10px 40px;
        }
        .search-icon {
          position: absolute;
          left: 10px;
          top: 50%;
          transform: translateY(-50%);
          width: 20px;
          height: 20px;
          fill: #808080;
        }
        .search-button {
          width: 30%;
          margin-top: 10px;
          font-size: 16px;
          padding: 10px;
        }
        .error-message-container {
          width: 87%;
        }
        .error-message {
          font-size: 14px;
        }
      }


/* footer */
.themeFooterSection {
	background-color: #252525;
    padding: 3rem 0;
}

.themeFooterSection .container-wrap {
    max-width: 1536px !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
}

.themeFooterSection .page-builder-layout-column-wrap {
	display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 10px;
}

@media screen and (max-width: 767px) {
    .themeFooterSection .page-builder-layout-column-wrap {
    	grid-template-columns: repeat(1, 1fr);
        gap: 20px;
    }
}

.themeFooterSection .links-list-module.links-display-block .heading {
	color: #fff;
    display: block;
    font-weight: 600;
    border-bottom: 2px dotted rgba(255, 255, 255, 0.5);
    padding-bottom: 5px;
    margin-bottom: 15px;
}

.themeFooterSection .links-list-module.links-display-block .links-list {
	display: flex !important;
    flex-direction: column;
    gap: 10px;
}

.themeFooterSection .links-list-module.links-display-block .links-list a {
	color: #fff;
    opacity: .75;
}

.themeFooterSection .links-list-module.links-display-block .links-list a:hover,
.themeFooterSection .links-list-module.links-display-block .links-list a:focus {
	text-decoration: none;
    opacity: 1;
}

.themeFooterCopyright {
	padding: 1.5rem 0;
}

.themeFooterCopyright .container-wrap {
    max-width: 1536px !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
}

.themeFooterCopyright .links-list-module.links-display-block .links-list {
	display: flex;
    align-items :center;
    justify-content: space-between;
}

@media screen and (max-width: 520px) {
    .themeFooterCopyright .links-list-module.links-display-block .links-list {
    	flex-direction: column;
        justify-content: center;
        gap: 10px;
    }
}

.themeFooterCopyright .links-list-module.links-display-block .links-list li,
.themeFooterCopyright .links-list-module.links-display-block .links-list a {
	color: #fff;
    font-size: 12px;
}