@import url("config.css");
@import url("external/owl-config.css");
@import url("external/owl.carousel.min.css");
@import url("external/owl.theme.default.min.css");
@import url("external/plyr.css");
@import url("external/aos.css");
@import url("external/notyf.min.css");

/* ******************************************************** BANNER */
header[id='banner'] {
    background-image: url("../img/banner/img-bn-001.webp");
    background-repeat: no-repeat;
    background-size: cover;
    height: 100vh;
    flex-direction: column;
    overflow: hidden;
    background-position: bottom left;
}
#about {
    background-image: url("../img/banner/img-bn-002.webp");
    background-repeat: no-repeat;
    background-position: top left;
    background-size: cover;
    min-height: 100vh;
    flex-direction: column;
    overflow: hidden;
}
#about .container {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}
#about .container .info {
    display: flex;
    flex-direction: column;
}
#about .container .info .title {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    text-align: center;
    flex-direction: column;
}
#about .container .info .title h3 {
    font-size: 3rem;
    color: var(--c4);
    font-family: 'f4';
}
#about .container .info .title b {
    font-size: 2rem;
    background: black;
    color: white;
    width: 10rem;
    border-radius: 4px;
}
#about .container .info {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
#about .container .info p {
    width: 40rem;
    text-align: center;
    padding: 1rem;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.8);
    font-family: 'f1';
    font-size: 1rem;
}
#about .container .info a:hover {
    background: var(--c5);
}
#about .container .info a {
    background: var(--c4);
    font-family: 'f4';
    height: 3rem;
    width: 10rem;
    border-radius: 4px;
    color: white;
}
#about .container .items {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 4rem;
    margin-top: 2rem;
}
#about .container .items .item {
    min-height: 8rem;
    display: grid;
    grid-template-columns: 5rem auto;
    gap: 1rem;
    background: white;
    align-items: center;
    padding: 0.5rem;
    border: solid 2px var(--c4);
}
#about .container .items .item u {
    padding: 0.5rem;
    width: 100%;
    height: 4rem;
    justify-content: center;
}
#about .container .items .item u .cls-1 {
    fill: var(--c4) !important;
}
#about .container .items .item span {
    display: grid;
    grid-template-rows: 1.5rem auto;
    gap: 0.5rem;
}
#about .container .items .item span b {
    font-size: 1rem;
    font-family: 'f4';
    display: flex;
    align-items: center;
}
#about .container .items .item span p {
    font-family: 'f1';
    font-size: 0.8rem;
}
/* ************************************************PRODUCTOS */
#product {
    display: flex;
    flex-direction: column;
    padding: 0;
    background: var(--c8);
}
#product > figure {
    width: 100%;
    height: 20rem;
    background-image: url("../img/others/bg-img-010.webp");
    position: relative;
    background-repeat: no-repeat;
    background-position: inherit;
    flex-direction: column;
    background-attachment: fixed;
    background-size: cover;
}
#product .title {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    z-index: 30;
}
#product .title h2 {
    font-size: 3rem;
    color: var(--c4);
    font-family: 'f4';
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
}
#product .title u {
    width: 10rem;
    height: 0.5rem;
    background: white;
    border-radius: 2rem;
}

#product .title p {
    font-family: 'f2';
    color: white;
    font-size: 1.5rem;
}
#product .container article {
    width: 100%;
    padding: 3rem 0;
}
#product .product-type .cont {
    width: 100%;
    display: flex;
    overflow: hidden;
}

#product .info {
    display: grid;
    grid-template-columns: auto 25rem;
    gap: 1rem;
}
#product .info .cont {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1rem;
}
#product .info .cont strong {
    font-family: 'f4';
    font-size: 2rem;
    color: var(--c4);
    width: 80%;

}
#product .info .cont span {
    width: 60%;
}
#product .info .cont span p {
    font-size: 1rem;
    font-family: 'f1';

}
#product .info .cont span b {
    color: var(--c4);
    font-family: 'f4';
}
#product .info .cont a {
    width: 20rem;
    height: 3rem;
    background: var(--c1);
    color: white;
}
#product .info .cont a:hover {
    background: var(--c4);
}

/* *********************************************SUSCRIPCION */
#subscription {
    width: 100%;
    height: 15rem;
    background: var(--c1);
}
#subscription .container {
    width: 35rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
#subscription .container .form {
    width: 100%;
    display: grid;
    grid-template-columns: auto 8rem;
}
#subscription .container .form button {
    background: var(--c4);
}
#subscription .container b {
    text-align: center;
    font-family: 'f2';
    font-size: 1.2rem;
    color: white;
}
/* ************************************************SERVICIOS */
#services {
    display: flex;
    flex-direction: column;
    padding: 0;
}
#services > figure {
    width: 100%;
    height: 20rem;
    background-image: url("../img/others/bg-img-011.webp");
    position: relative;
    background-repeat: no-repeat;
    background-position: inherit;
    flex-direction: column;
    background-attachment: fixed;
    background-size: cover;
}
#services .title {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    z-index: 30;
}
#services .title h2 {
    font-size: 3rem;
    color: var(--c4);
    font-family: 'f4';
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
}
#services .title u {
    width: 10rem;
    height: 0.5rem;
    background: white;
    border-radius: 2rem;
}
#services .title p {
    font-family: 'f2';
    color: white;
    font-size: 1.5rem;
}

#services .cont {
    width: 100%;
    display: flex;
    flex-direction: column;
}
#services .cont .item {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    min-height: 50vh;
}
#services .cont .item span {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2rem 2rem 2rem 4rem;
    gap: 1rem;
}
#services .cont .item span b {
    font-family: 'f4';
    font-size: 1.5rem;
    color: var(--c4);
    line-height: 1.8rem;
}
#services .cont .item span p {
    font-family: 'f1';
    font-size: 1rem;
    color: gray;
}
#services .cont .item figure {
    position: relative;
}
#services .cont .item figure .icon u {
    position: absolute;
    width: 8rem;
    height: 8rem;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 50%;
    padding: 2rem;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 50;
}
#services .cont .item figure .icon u .cls-1 {
    fill: var(--c1) !important;
}
#services .cont .item figure .icon {
    position: absolute;
    z-index: 40;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
#services .cont .item figure .icon div {
    background: rgba(255, 255, 255, 0.4);
    width: 8rem;
    height: 8rem;
    border-radius: 50%;
    z-index: 40;
    animation: icon_service 2s infinite;
}
@keyframes icon_service {
    0% {
        transform: scale(1);
    }
    30% {
        transform: scale(1.4);
    }
    70% {
        transform: scale(1.4);
    }
    100% {
        transform: scale(1);
    }
}

#product-type {
    position: relative;
}
#product-like {
    position: relative;
    box-shadow: rgba(0, 0, 0, 0.3) 8px 8px 4px;
    border-radius: 0.5rem;
}
#company .container {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}
#company .title {
    width: 50%;
}
#company .title h2 {
    text-align: center;
    font-size: 2rem;
    font-family: 'f2';
    color: white;
}
#company .title p {
    text-align: center;
    font-size: 1rem;
    font-family: 'f1';
    color: white;
}
#company {
    padding: 4rem 0;
    background: var(--c4);
}

.tmp-product {
    height: 35rem;
}
@media only screen and (min-width: 1920px) {}
@media only screen and (max-width: 1919px) and (min-width: 1440px) {}
@media only screen and (max-width: 1439px) and (min-width: 1280px) {}
@media only screen and (max-width: 1279px) and (min-width: 1024px) {}
@media only screen and (max-width: 1023px) and (min-width: 768px) {
    #about .container .items {
        gap: 1rem;
    }
    #about .container .items .item u {
        padding: 0;
    }
    #about .container .items .item {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
    }
    #about .container .items .item span {
        display: flex;
        text-align: center;
        justify-content: center;
        align-items: center;
        flex-direction: column;
    }
    #about .container .items .item span b {
        text-align: center;
    }
}
@media only screen and (max-width: 767px) and (min-width: 480px) {
    #about .container .items {
        grid-template-columns: auto;
        gap: 1rem;
    }
    #product .info {
        grid-template-columns: auto;
    }
    #product .info .cont {
        width: 100%;
    }
    #product .container article {
        display: flex;
        flex-direction: column;
        width: 100%;
        gap: 1rem;
    }
    #product .info .cont span {
        width: 100%;
    }
    #company .title {
        width: 100%;
    }
    #services .title h2 {
        font-size: 1.5rem;
    }
    #services .title p {
        font-size: 1rem;
    }
    #services .cont .item {
        display: grid;
        grid-template-columns: auto;
    }
    #services .cont .item figure {
        min-height: 25rem;
        display: none;
    }
}
@media only screen and (max-width: 479px) and (min-width: 360px) {
    #about .container .items {
        grid-template-columns: auto;
        gap: 1rem;
    }
    #product .info {
        grid-template-columns: auto;
    }
    #product .info .cont {
        width: 100%;
    }
    #product .container article {
        display: flex;
        flex-direction: column;
        gap: 1rem;
        width: 100%;
    }
    #product .info .cont span {
        width: 100%;
    }
    #company .title {
        width: 100%;
    }
    #services .title h2 {
        font-size: 1.5rem;
    }
    #services .title p {
        font-size: 1rem;
    }
    #services .cont .item {
        display: grid;
        grid-template-columns: auto;
    }
    #services .cont .item figure {
        min-height: 25rem;
        display: none;
    }
}
@media only screen and (max-width: 359px) and (min-width: 10px) {
    #about .container .items {
        grid-template-columns: auto;
        gap: 1rem;
    }
    #product .info {
        grid-template-columns: auto;
    }
    #product .info .cont {
        width: 100%;
    }
    #product .container article {
        display: flex;
        flex-direction: column;
        gap: 1rem;
        width: 100%;
    }
    #product .info .cont span {
        width: 100%;
    }
    #company .title {
        width: 100%;
    }
    #services .title h2 {
        font-size: 1.5rem;
    }
    #services .title p {
        font-size: 1rem;
    }
    #services .cont .item {
        display: grid;
        grid-template-columns: auto;
    }
    #services .cont .item figure {
        min-height: 25rem;
        display: none;
    }
}
@media only screen and (min-height: 1280px) {}
@media only screen and (max-height: 1279px) and (min-height: 1024px) {}
@media only screen and (max-height: 1023px) and (min-height: 768px) {}
@media only screen and (max-height: 767px) and (min-height: 480px) {}
@media only screen and (max-height: 479px) and (min-height: 360px) {}
@media only screen and (max-height: 359px) and (min-height: 10px) {}