/*
 Theme Name:   GeneratePress Child for LinearLED
 Theme URI:    https://generatepress.com
 Description:  LinearLED
 Author:       Jenny Chan
 Author URI:   https://jennychan.dev
 Template:     generatepress
 Version:      0.1
 Text Domain:  linearled
*/

.entry-header {
    display: none;
}

body.full-width-content .container {
    padding: 0;
}

hr {
    margin-block-start: 0;
    margin-block-end: 0;
}

/* Navigation */
.menu-item-5584 a,
.menu-item-5648 a {
    background-color: #457AAC;
    color: #fff !important;
    padding: 0 10px;
    line-height: 40px !important;
}

.menu-item-5584 a:hover,
.menu-item-5648 a:hover {
    background-image: linear-gradient(rgb(0 0 0 / 30%) 0 0);
}

/* Shop Page */
.woocommerce-shop .woocommerce-breadcrumb,
.woocommerce-shop .woocommerce-products-header__title,
.woocommerce-shop .wc-product-image {
    display: none;
}

.woocommerce-shop .wc-columns-container.wc-columns-4 .products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.woocommerce-shop ul.products li.product-category {
    background-color: #fff;
    border-radius: .5rem;
    overflow: hidden;
    border: .4rem solid transparent;
    cursor: pointer;
    padding: 5rem;
    transition: all .2s ease-in;
    box-shadow: 0 0.5px 0.7px rgba(0, 0, 0, 0.035), 0 1.3px 1.9px rgba(0, 0, 0, 0.05), 0 3px 4.5px rgba(0, 0, 0, 0.065), 0 10px 15px rgba(0, 0, 0, 0.1);;
}

.woocommerce-shop ul.products li.product-category:hover {
    background-color: #337ab7;
}

.woocommerce-shop ul.products li.product-category:hover .woocommerce-loop-category__title,
.woocommerce-shop ul.products li.product-category:hover .count {
    color: #fff;
}

.woocommerce-shop ul.products li.product-category .woocommerce-loop-category__title {
    font-size: 2rem;
}

.woocommerce-breadcrumb {
    font-size: 1.6rem !important;
}

.single-product-description ul {
    margin-block-start: 0;
    margin-left: 3rem;
}

.single-product .attribute-label {
    font-weight: bold;
}

@supports (display: grid) {
    .woocommerce ul.products li.product {
        justify-content: center;
    }
}

/* Product Listing */
.woocommerce .filter-categories {
    display: flex;
    column-gap: 1rem;
}

@media screen and (max-width: 768px) {
    .woocommerce .filter-categories {
        flex-direction: column;
    }
}

.woocommerce ul.products {
    margin-top: 3rem;
}

.clear-filters {
    padding: 5px 10px;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    box-shadow: 0 0.5px 0.7px rgba(0, 0, 0, 0.035), 0 1.3px 1.9px rgba(0, 0, 0, 0.05), 0 3px 4.5px rgba(0, 0, 0, 0.065), 0 10px 15px rgba(0, 0, 0, 0.1);
    padding: 1.5rem;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
    transform: scale(1.05);
    transition: all .2s ease-in;
}

.woocommerce ul.products li.product .inside-wc-product-image,
.woocommerce-page ul.products li.product .inside-wc-product-image {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 3rem;
    padding: 1rem;
}

.woocommerce ul.products li.product .wc-product-image .attachment-woocommerce_thumbnail,
.woocommerce-page ul.products li.product .wc-product-image .attachment-woocommerce_thumbnail {
    display: block;
    width: 75%;
    max-width: 100%;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    text-transform: uppercase;
    letter-spacing: .2em;
    font-size: 1.8rem !important;
    font-weight: bold;
    color: #457AAC;
    text-align: left;
    margin-bottom: 1rem !important;
}

.woocommerce .woocommerce-products-header,
.woocommerce .woocommerce-result-count {
    display: none;
}

.product-short-description {
    font-size: 1.4rem;
    line-height: 1.9;
    text-align: left;
    margin-bottom: 2rem;
}

/* Single Product */
.single-product .product_title {
    font-weight: bold;
}

.single-product .product_meta {
    display: none;
}

.single-product-description {
    clear: both;
}

.single-product .woocommerce-breadcrumb {
    margin-bottom: 3rem;
}

.woocommerce div.product div.images {
    margin-bottom: 0;
}

.woocommerce div.product div.summary {
    margin-bottom: 0;
}

.editor-styles-wrapper .hero,
.editor-styles-wrapper .full-width {
    margin-left: 0;
    width: 100%;
}

/* Newsletter */
.newsletter {
    padding-top: 80px;
    padding-bottom: 45px;
    background: #eee;
    width: 100%;
    display: block;
    position: relative;
    overflow: hidden;
    zoom: 1;
}

.newsletter-container {
    background: #eee;
    max-width: 1200px;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}

.newsletterform {
    float: right;
    border: none;
    margin: 0;
    padding: 0;
}

@media only screen and (max-width: 992px) {
    .newsletterform {
        float: none;
        text-align: center;
    }

    #mce-EMAIL {
        text-align: center;
    }
}

#mce-EMAIL {
    width: 350px;
    font-size: 21px;
    font-family: 'Lato', Arial, Helvetica, sans-serif;
    font-weight: 400;
    border: none;
    border-bottom: 1px solid #a6a7a9;
    border-radius: 0px;
    background: transparent;
    color: #4b4e53;
    margin: 0 80px 30px 0;
    outline: medium none;
    padding: 8px 20px 8px 0;
}

#mc-embedded-subscribe {
    font-family: 'Open Sans', Arial, Helvetica, sans-serif;
    font-weight: normal;
    margin-bottom: 30px;
    color: #fff;
}

.home .site-content {
    display: block;
    padding-bottom: 0;
}

.site-footer .menu a {
    color: #7e8082;
    text-decoration: none;
    font-weight: bold;
}

.site-footer .menu a:hover {
    color: #000;
}

/* #REVO #SLIDER custom
================================================== */
.tp-banner{
    width:100%;
    position:relative;
}
.dark-bg {
    background:#303236;
}
.tp-banner-fullscreen-container {
    width:100%;
    position:relative;
    padding:0;
}
.rs-fullscr-container .tp-leftarrow, .rs-fullscr-container .tp-rightarrow{
    z-index: 27;
}
.tparrows.preview4 .tp-arr-titleholder {
    font-weight:normal;
}
.rs-fullscr-container {
    display: block;
    position: relative;
    overflow: hidden;
    padding: 0;
    height: 100vh;
    width: 100vw;
    margin-left: calc(50% - 50vw);
}
.page-section  {
    width: 100%;
    display: block;
    position: relative;
    overflow: hidden;
}
/******   CAPTIONS   ******/
.tp-caption {
    white-space: normal !important;
    line-height: 1.5;
}
.tp-caption.dark-light-32 {
    color:#FFF;
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 24px;
    line-height: 26px;
    font-weight: 400;
    width:100%;
    text-align: center;
    left:0 !important;
}
.tp-caption.dark-black-100 {
    color:#4b4e53;
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 100px;
    line-height: 100px;
    font-weight: 900;
}
.tp-caption.dark-light-100 {
    color:#FFF;
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 60px;
    line-height: 70px;
    font-weight: 600;
    width:100%;
    text-align: center;
    left:0 !important;
}
.slider-1-cap-line {
    height:3px;
    width:100px;
    background-color: #4b4e53;
}
.slider-bg-white-cap {
    display:none;
    visibility: hidden;
}
/******   CAPTIONS REVO FULL WIDTH  ******/
.font-white, .font-white a{
    color:#fff !important;
}
.light-72-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 72px;
    line-height: 72px;
    font-weight: 300;
    letter-spacing:25px;
    color:#4b4e53;
}
.light-70-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 70px;
    line-height: 70px;
    font-weight: 300;
    letter-spacing:24px;
    color:#4b4e53;
}
.light-69-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 69px;
    line-height: 69px;
    font-weight: 300;
    letter-spacing:20px;
    color:#4b4e53;
}
.light-60-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 60px;
    line-height: 60px;
    font-weight: 300;
    letter-spacing:15px;
    color:#4b4e53;
}
.light-60{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 60px;
    line-height: 60px;
    font-weight: 300;
    color:#4b4e53;
}
.light-56-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 56px;
    line-height: 56px;
    font-weight: 300;
    letter-spacing:25px;
    color:#4b4e53;
}
.light-52-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 54px;
    line-height: 56px;
    font-weight: 300;
    letter-spacing:10px;
    color:#4b4e53;
}
.light-50-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 50px;
    line-height: 64px;
    font-weight: 300;
    letter-spacing:3px;
    color:#4b4e53;
}
.light-42-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 42px;
    line-height: 46px;
    font-weight: 300;
    letter-spacing:2px;
    color:#4b4e53;
}
.norm-42-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 42px;
    line-height: 46px;
    letter-spacing:2px;
    color:#4b4e53;
}
.norm-40-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 40px;
    line-height: 46px;
    letter-spacing:2px;
    color:#4b4e53;
}
.norm-16-wide{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 16px;
    line-height: 18px;
    font-weight: 300;
    letter-spacing:3px;
    color:#4b4e53;
}
.norm-16{
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 16px;
    line-height: 25px;
    font-weight: 400;
    color:#4b4e53;
}
.w-50{
    width:50%;
}
.a-100, .a-100 span{
    font-size:100px;
    line-height:100px;
}


/*==========  Mobile  ==========*/
@media only screen and (max-width : 478px) {
    .tp-left{
        left:60px !important;
    }
    .tp-caption.center-0-478{
        left: 50% !important;
        -webkit-transform: translateX(-50%) !important;
        -moz-transform: translateX(-50%) !important;
        -ms-transform: translateX(-50%) !important;
        -o-transform: translateX(-50%) !important;
        transform: translateX(-50%) !important;
        -transform: translateZ(0);
    }
    .hide-0-736 {
        display:none;
        visibility: hidden;
    }
    /***** SLIDE 2 Captions	*****/
    .dark-light-61.tp-resp-24 {
        top:44%!important;
    }
    .dark-light-54.tp-resp-24 {
        top:49%!important;
    }
    .dark-black-63.tp-resp-24 {
        top:54%!important;
    }
    /***** SLIDE 3 Captions	*****/
    .dark-light-60.tp-resp-24 {
        top:42%!important;
    }
    .dark-black-60.tp-resp-24 {
        top:47%!important;
    }
}

@media only screen and (max-width : 736px){
    .fs16-when-0-736{
        font-size: 16px !important;
        line-height: 24px !important;
    }
    .fs24-when-0-736 {
        font-size: 24px !important;
        line-height: 36px !important;
    }
}
@media only screen and (min-width : 479px) and (max-width : 736px){
    .hide-0-736, .hide-479-736 {
        display:none !important;
        visibility: hidden;
    }
}

/*****  SLIDE 2   *****/
.tp-caption.dark-light-61 {
    color:#4b4e53;
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 61px;
    font-weight: 300;
    letter-spacing:7px;
}
.tp-caption.dark-black-63 {
    color:#4b4e53;
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 63px;
    font-weight: 900;
    letter-spacing:5px;
}
.tp-caption.dark-light-54 {
    color:#4b4e53;
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 54px;
    font-weight: 300;
    letter-spacing:7px;
}

/*****  SLIDE 3   *****/
.tp-caption.dark-light-60 {
    color:#4b4e53;
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 75px;
    line-height: 85px;
    font-weight: 300;
}
.tp-caption.dark-black-60 {
    color:#4b4e53;
    font-family: 'Lato',Arial,Helvetica,sans-serif;
    font-size: 75px;
    line-height: 85px;
    font-weight: 900;
}
.local-scroll-cont {
    width: 40px;
    height: 40px;
    position:absolute;
    bottom: 0;
    left: 50%;
    margin-left: -20px;
    text-align: center;
    z-index: 20;

    -webkit-animation: scroll-down-anim ease-in-out 1s infinite;
    -moz-animation: scroll-down-anim ease-in-out 1s infinite;
    -o-animation: scroll-down-anim ease-in-out 1s infinite;
    animation: scroll-down-anim ease-in-out 1s infinite;
}
.scroll-down {
    color: #FFF;
    font-size: 32px;
}

@-webkit-keyframes scroll-down-anim {
    0%{ -webkit-transform: translateY(-8px); transform: translateY(-8px); }
    50%{ -webkit-transform: translateY(0px); transform: translateY(0px); }
    100%{ -webkit-transform: translateY(-8px); transform: translateY(-8px); }
}
@-moz-keyframes scroll-down-anim {
    0%{ -moz-transform: translateY(-8px); transform: translateY(-8px); }
    50%{ -moz-transform: translateY(0px); transform: translateY(0px); }
    100%{ -moz-transform: translateY(-8px); transform: translateY(-8px); }
}
@-o-keyframes scroll-down-anim {
    0%{ -o-transform: translateY(-8px); transform: translateY(-8px); }
    50%{ -o-transform: translateY(0px); transform: translateY(0px); }
    100%{ -o-transform: translateY(-8px); transform: translateY(-8px); }
}
@keyframes scroll-down-anim {
    0%{ transform: translateY(-8px); }
    50%{ transform: translateY(0px); }
    100%{ transform: translateY(-8px); }
}


.home-intro{
    display: flex;
    flex-direction: row;
    width: 100vw;
    margin-left: calc(50% - 50vw);
}

.home-intro h2{
    color:#FFF;
    font-weight: 600;
    font-size: 3.2vw;
    line-height: 1.2;
    margin-bottom: 40px;
    padding-bottom: 40px;
    position: relative;
}

.home-intro h2:before{
    content: '';
    width:50px;
    height:5px;
    background: #FFF;
    position: absolute;
    bottom:5px;
    left:0;
}

.home-intro .btn.btn-primary{
    background: transparent;
    padding:0 40px;
    line-height: 45px;
    height:50px;
    color:#FFF;
    border-radius: 25px;
    border:1px solid #FFF;
    font-weight: 600;
    font-size: 22px;
    text-transform: lowercase;
    margin-top: 30px;
    margin-bottom: 30px;
}

.home-intro-item{
    flex-basis: 50%;
    flex-grow:1;
    padding:80px;
}

.home-intro-item--quote{
    color:#FFF;
    background: #b5b5b5;
}

.home-intro-icons .fes1-box{
    padding-left:0;
    margin-top: 20px;
    margin-bottom: 40px;
    max-width: 280px;
}

.home-intro-icons .fes1-box h3{
    color:#000;
    font-size: 22px;
    margin-top: 15px;
    margin-bottom: 15px;
    padding-bottom: 15px;
    position: relative;
}

.home-intro-icons .fes1-box h3:before{
    content:'';
    width:50px;
    height:1px;
    background: #d2d2d2;
    position: absolute;
    bottom:0;
    left:0;
}

.home-intro-icons .fes1-box-icon{
    position: relative;
    width:100%;
    top:auto;
    left:auto;
}

.fes1-box-icon {
    position: absolute;
    top: 0;
    left: 0;
    color: #4b4e53;
    font-size: 35px;
}

.home-intro .btn.btn-primary {
    background: transparent;
    padding: 0 40px;
    line-height: 45px;
    height: 50px;
    color: #FFF;
    border-radius: 25px;
    border: 1px solid #FFF;
    font-weight: 600;
    font-size: 22px;
    text-transform: lowercase;
    margin-top: 30px;
    margin-bottom: 30px;
    text-decoration: none;
}

@media (max-width: 1024px){
    .home-intro{
        flex-wrap: wrap;
    }
    .home-intro-item{
        flex-basis: 100%;
    }

    .home-intro h2{
        font-size: 40px;
    }
    .page-title-cont-img{
        padding-top: 180px;
    }

    .cd-header-buttons{
        margin-top: -55px;
        margin-right: 50px;
    }

    .cd-search-trigger{
        line-height: 44px;
    }

    .cd-search-trigger:before{
        top:15px;
    }
    .cd-search-trigger:after{
        bottom:15px;
    }
    .cd-search-trigger.search-is-visible{
        right:0;
        top:5px;
    }
}

@media (max-width: 768px){
    .home-intro h2{
        font-size: 30px;
    }
    .home-intro-item{
        padding:30px;
    }
    .home-intro-icons{
        text-align: center;
    }
    .home-intro-icons .fes1-box{
        max-width: 100%;
    }
    .home-intro-icons .fes1-box h3:before{
        left:50%;
        margin-left: -25px;
    }

    .page-title-cont-img{
        padding-top: 80px;
    }
}