@font-face {
    font-family: "Marmalede";
    src: url("../fonts/MarmaledeRegular/MarmaledeRegular.woff2") format("woff2"), url("../fonts/MarmaledeRegular/MarmaledeRegular.woff") format("woff");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Halloween Secret";
    src: url("../fonts/HalloweenSecret/HalloweenSecret.woff2") format("woff2"), url("../fonts/HalloweenSecret/HalloweenSecret.woff") format("woff");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Hero New SemiBold";
    src: local("Hero New SemiBold"), url("../fonts/hero-new-webfont/Hero New SemiBold.woff") format("woff");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Hero New Bold";
    src: local("Hero New ExtraBold"), url("../fonts/hero-new-webfont/Hero New ExtraBold.woff") format("woff");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Luckiest Guy";
    src: url("../fonts/LuckiestGuy-Regular.woff2") format("woff2"), url("../fonts/LuckiestGuy-Regular.woff") format("woff");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Attack Of Monster';
    src: url('../fonts/AttackOfMonster/AttackOfMonsterRegular.woff2') format('woff2'),
        url('../fonts/AttackOfMonster/AttackOfMonsterRegular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
/* Global Styles */
.section-heading {
    margin: 0;
    font-size: 18px;
    color: var(--secendery);
    position: relative;
}
.view-all-btn {
    border: 1px solid var(--secendery);
    color: var(--secendery);
    font-weight: 400;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    transition: all 0.3s ease-in-out;
    padding: 5px 12px;
    border-radius: 10px;
    font-size: 12px;
}
.view-all-btn:hover {
    background-color: var(--secendery);
    color: #fff;
}
.view-all-btn svg {
    font-size: 20px;
}
@media (min-width: 991px) {
    .section-heading {
        font-size: 25px;
    }
    .view-all-btn {
        padding: 8px 20px;
        border-radius: 10px;
        font-size: 14px;
        gap: 7px;
    }      
}

/* Banner Section */
.carousel-pagination-box {
    width: 100%;
    height: auto;
    display: block;
    position: relative;
}
.carousel-pagination-box ul.carousel-indicators,
.banner-bottom-slider ul.carousel-indicators {
    padding: 25px 0 0;
    margin: 0;
    position: relative;
    display: flex;
    justify-content: center;
    padding-left: 0;
    list-style: none;
}
.carousel-pagination-box ul li,
.banner-bottom-slider ul li {
    height: 10px;
    width: 10px;
    background-color: #ddd;
    border-radius: 30px;
    border: 0;
    font-size: 0;
}
.banner-bottom-slider ul li button::before {
    content: none;
}
.carousel-pagination-box ul li .pagination-title,
.banner-bottom-slider ul li .pagination-title {
    font-size: 0;
}
.carousel-pagination-box ul.carousel-indicators .active,
.banner-bottom-slider ul li.slick-active {
    background-color: var(--secendery);
    width: 20px;
    transition: all 0.5s ease-out;
}
#main-slider .carousel-item > a {
    padding-top: 58%;
    display: block;
    position: relative;
}
#main-slider .carousel-item a img {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: contain;
}
@media (min-width: 768px) {
    #main-slider .carousel-item > a {
        padding-top: 39.474%;
    }
}
@media (max-width: 767px) {
    /* #main-slider .carousel-inner {
        margin-top: 3.125rem;
    } */
    .hero-section .container {
        padding: 0;
    }
    .carousel-pagination-box ul.carousel-indicators,
    .banner-bottom-slider ul.carousel-indicators {
        padding: 20px 0 0;
    }
}

/* Desktop Timer Section */
.homepage-slider-countdown.countdown1 {
     position: absolute;
    top: 69.62%;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
    align-items: center;
    width: max-content;
    left: 68.3%;
}

.homepage-slider-countdown .time-ends-in {
    position: absolute;
    display: none;
    font-size: 1rem;
    color: #614f3a;
    font-weight: 400;
    transform: rotate(0deg);
    top: -35%;
    width: 100%;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
}
.homepage-slider-countdown .time-box {
   margin: 0 clamp(4px, 0.6vw, 7px);
}
.homepage-slider-countdown .time-separator {
    display: none;
}
.homepage-slider-countdown .time-box .time-countdown {
     color: #614f3a;
    font-size: clamp(18px, 3vw, 35px);
    background: transparent;
    font-weight: 700;
    width:  clamp(40px, 5vw, 65px);
    height: clamp(40px, 5vw, 65px);
    border-radius: 11px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid #614f3a;
    line-height: 1;
}



.homepage-slider-countdown .time-box .time-countdown-label {
       display: block;
    color: #614f3a;
    padding: 0px 0px;
    text-transform: uppercase;
    font-weight: 500;
     font-size: clamp(10px, 0.6vw, 15px);
    line-height: 0px;
    margin-top: 15px;
    text-align: center;
    letter-spacing: 2px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.hero-bottom {
    padding-top: 25px;
}
.product-wrapper,
#banner-slider-container {
    max-width: 1260px;
    margin: auto;
}
.banner-bottom-slider-card {
    padding: 0 10px;
}
.banner-bottom-slider-card a:not(.btn-promo-banner) {
    padding-top: 100%;
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 7px;
    border: 1px solid #dadada;
}
.banner-bottom-slider-card a img {
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover;
    z-index: 1;
    min-width: 100%;
    transform: scale(1);
    transition: all 0.3s ease-out 0s;
}
.banner-bottom-slider-skeleton {
    display: flex;
    gap: 20px;
    padding: 0 10px;
}
.skeleton-card {
    flex: 1;
}
.banner-bottom-skeleton-inner {
    padding-top: 100%;
    display: block;
    position: relative;
    overflow: hidden;
    background: linear-gradient(90deg, #f0f0f0 25%, #e4e4e4 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    border-radius: 7px;
    animation: skeleton-loading 1.2s infinite;
}
.banner-bottom-skeleton-inner span {
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover;
    z-index: 1;
    min-width: 100%;
    display: block;
}
@keyframes skeleton-loading {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

@media (max-width: 991px) {
    .banner-bottom-slider-skeleton .skeleton-card:last-child {
        display: none;
    }
}
@media (max-width: 767px) {
    .banner-bottom-slider {
        margin: 0 -10px;
    }
    .banner-bottom-slider-skeleton {
        padding: 0 0;
    }
}
@media (max-width: 574px) {
    .banner-bottom-slider-card {
        padding: 0 5px;
    }
    .banner-bottom-slider {
        margin: 0 -5px;
    }
    .banner-bottom-slider-skeleton {
        gap: 10px;
    }
}
/* Eight Card Category Banner Section */
.eight-card-category-banner-card-main {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.eight-card-category-banner-card {
    position: relative;
    overflow: hidden;
    border-radius: 7px;
}
.eight-card-category-banner-card a:not(.btn-promo-banner) {
    padding-top: 100%;
    display: block;
    position: relative;
    overflow: hidden;
}
.eight-card-category-banner-card a img {
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover;
    z-index: 1;
    min-width: 100%;
    transform: scale(1);
    transition: all 0.3s ease-out 0s;
}
.eight-card-category-banner-card > .eight-card-category-banner-img img:hover {
    transform: scale(1.1);
}
h2.eight-card-category-banner-title {
    font-size: 14px;
    padding: 7px 25px;
    position: absolute;
    text-align: center;
    bottom: 0px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    width: max-content;
    color: #ffffff;
    border-radius: 8px 8px 0px 0;
    margin: 0;
    background: linear-gradient(90deg, rgba(198, 41, 76, 1) 0%, rgba(37, 57, 96, 1) 100%);
}
.eight-card-category-banner-card .custom-shadow {
    position: absolute;
    width: 100%;
    box-shadow: 0px 110px 70px 250px #30303047;
    z-index: 1;
}
@media (max-width: 991px) {
    .eight-card-category-banner-card .custom-shadow {
        box-shadow: 0px 110px 70px 200px #303030cf;
    }
}
@media (min-width: 575px) {
    .eight-card-category-banner-card-main {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 20px;
    }
}
@media (min-width: 1024px) {
    .eight-card-category-banner-card-main {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

/* Great Brands Wrapper Section */
.brand-marquee {
    overflow: hidden;
}
.marquee-content {
    display: flex;
    white-space: nowrap;
    will-change: transform;
    align-items: center;
    gap: 50px;
}
.brand-img {
    flex: 0 0 auto;
    object-fit: contain;
    transition: transform 0.3s ease, filter 0.3s ease;
    filter: grayscale(1);
    max-height: 70px;
    min-height: 70px;
    max-width: 110px;
    min-width: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.brand-img img {
    object-fit: contain;
    max-height: 70px;
    min-height: 70px;
    max-width: 110px;
    min-width: 100px;
}
.brand-img span {
    display: block;
    margin-top: 6px;
    color: #333;
}
.brand-img:hover {
    cursor: pointer;
    filter: none;
}
@media (max-width: 767px) {
    .marquee-content {
        gap: 30px;
    }
    .brand-img {
        max-width: 90px;
        min-width: 90px;
    }
    .brand-img img {
        max-width: 90px;
        min-width: 90px;
    }
}
/* Global Services Wrapper Section */
.global-services-wrapper {
    width: 100%;
    position: relative;
    /* border-top: 1px solid #e7e7e7; */
}
.global-services-wrapper-inner {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.global-service-box {
    color: var(--secendery);
    background-color: #fff;
    padding: 10px 5px;
    height: 100%;
    width: 100%;
    border-radius: 7px;
    box-shadow: 0 1px 2px 0 rgb(90 91 95 / 15%);
    border: 1px solid #efefef;
    transition: all 0.3s ease-in-out;
    display: flex;
    align-items: center;
    text-align: center;
    gap: 5px;
    justify-content: center;
    flex-direction: column;
}
.global-service-box:hover {
    transform: translateY(-10px);
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.15);
}
.global-service-icon > svg {
    font-size: 32px;
}
.global-service-text {
    font-size: 11px;
    font-weight: 400;
    flex-direction: column;
    display: flex;
    height: 100%;
}
.global-service-heading h4 {
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 0;
    flex-grow: 1;
}
.global-service-box .trustpilot-widget iframe {
    height: 75px !important;
    width: 105px !important;
}
.global-service-box.global-service-box1 {
    cursor: pointer;
}
@media (min-width: 575px) {
    .global-service-box .trustpilot-widget iframe {
        height: 85px !important;
        width: 173px !important;
    }
}
@media (min-width: 768px) {
    .global-service-box {
        padding: 20px 25px;
        border-radius: 12px;
        gap: 15px;
        flex-direction: row;
        text-align: left;
    }
    .global-service-box.global-service-box1 {
        padding: 5px 25px;
    }
    .global-service-icon > svg {
        font-size: 40px;
    }
    .global-service-text {
        font-size: 13px;
    }
    .global-service-heading h4 {
        font-size: 16px;
        margin-bottom: 5px;
    }
}
@media (min-width: 991px) {
    .global-service-heading h4 {
        font-size: 18px;
    }
    .global-service-text {
        font-size: 14px;
    }
}
@media (min-width: 1350px) {
    .global-services-wrapper-inner {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 20px;
    }
}

/* Trending Products Section */
.trending-products-section .tab-content {
    max-width: 1260px;
    margin: auto;
}
.trending-products-section .custom-tabs {
    display: flex;
    justify-content: center;
    gap: 5px;
    border: 1px solid var(--secendery);
    padding: 5px;
    border-radius: 8px;
}
.trending-products-section .tab-button {
    padding: 5px 10px;
    background-color: transparent;
    border-radius: 7px;
    color: var(--secendery);
    font-size: 12px;
    border: none;
    transition: all 0.3s ease-in-out;
}
.trending-products-section .tab-button.active {
    background-color: var(--secendery);
    color: white;
}
.trending-products-section .tab-panel {
    display: none;
}
.trending-products-section .tab-panel.active {
    display: block;
}
@media (min-width: 575px) {
    .trending-products-section .tab-button {
        padding: 7px 15px;
        font-size: 14px;
    }
}

/* Bathrooms, Showering and Heating Section */
.showering-heating-wrapper {
    border-top: 1px solid #f1f1f1;
    border-bottom: 1px solid #f1f1f1;
}
.showering-heating-wrapper .description {
    max-width: 900px;
}
.showering-heating-wrapper .highlight-card-main {
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 700px;
    margin: auto;
}
.showering-heating-wrapper .highlight-card {
    background-color: #fff;
    border-radius: 8px;
    padding: 20px;
    box-shadow: 0 1px 7px rgb(0 0 0 / 3%);
    height: 100%;
    text-align: center;
    display: block;
}
.showering-heating-wrapper .highlight-card svg {
    font-size: 50px;
    margin-bottom: 10px;
}
.showering-heating-wrapper .highlight-title {
    font-weight: 600;
    font-size: 16px;
}
@media (max-width: 768px) {
    .showering-heating-wrapper .highlight-card svg {
        font-size: 36px;
    }
    .showering-heating-wrapper .highlight-title {
        font-size: 14px;
    }
    .showering-heating-wrapper .highlight-card {
        padding: 10px;
    }
}

/* Our Mission Section */
.our-mission {
    padding: 20px;
    border-radius: 8px;
    max-width: 1000px;
    margin: 40px auto 0;
    border: 1px solid #efefef;
    background-image: url("https://www.heatandplumb.com/acatalog/images/body-bg.png");
    background-color: var(--secendery);
    color: white;
}
.our-mission .section-heading {
    color: white;
}
.our-mission .block-text p {
    line-height: 25px;
}
@media (min-width: 991px) {
    .our-mission {
        padding: 40px;
    }
}
@media (max-width: 991px) {
    .our-mission h3 {
        font-size: 1.3rem;
        margin-bottom: 0;
        font-weight: 500;
        margin-top: 0.875rem !important;
    }
}

/* Feature Card Section */
.feature-card-main {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 20px;
}
.feature-card {
    color: var(--secendery);
    background-color: #fff;
    padding: 10px;
    height: 100%;
    width: 100%;
    border-radius: 7px;
    box-shadow: 0 1px 2px 0 rgb(90 91 95 / 15%);
    transition: all 0.3s ease-in-out;
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid #efefef;
}
.feature-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.15);
}
.feature-icon {
    font-size: 40px;
}
.feature-title {
    font-weight: 500;
    margin-bottom: 5px;
    font-size: 16px;
}
.feature-desc {
    font-size: 14px;
    color: #555;
    line-height: 1.5;
    margin: 0;
}
@media (min-width: 575px) {
    .feature-card-main {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }
}
@media (min-width: 768px) {
    .feature-card {
        padding: 20px 25px;
        border-radius: 12px;
        gap: 15px;
    }
}
@media (min-width: 1350px) {
    .feature-card-main {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 20px;
    }
}
/* Box Placeholder Loading */
body .product-item-list .placeholder-content {
    overflow: hidden;
    background: #f6f7f8;
    position: relative;
    animation-duration: 1.7s;
    animation-fill-mode: forwards;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
    animation-name: placeholderAnimate;
    background: linear-gradient(to right, #eee 2%, #ddd 18%, #eee 33%);
    background-size: 1300px;
}
.placeholder-content_item:after,
.placeholder-content_item:before {
    width: inherit;
    height: inherit;
    content: "";
    position: absolute;
}
.placeholder-content {
    height: 30px;
    margin-bottom: 5px;
}
.deals-of-the-week-slider .slick-track {
    margin-left: 0;
    margin-right: 0;
}
@-webkit-keyframes placeholderAnimate {
    0% {
        background-position: -650px 0;
    }
    100% {
        background-position: 650px 0;
    }
}
@keyframes placeholderAnimate {
    0% {
        background-position: -650px 0;
    }
    100% {
        background-position: 650px 0;
    }
}

/* Extra CSS */
.row.deals-of-the-week-slider,
.row.best_seller,
.row.newly_added {
    margin-right: -10px;
    margin-left: -10px;
}
a.product-name-link {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
}
.section-block {
    padding: 0 0 50px;
}
.section-block2 {
    padding-top: 50px;
}
@media (max-width: 991px) {
    .section-block {
        padding: 0 0 25px;
    }
    .section-block2 {
        padding-top: 25px;
    }
}