/* ======================================== UTILS =================================== */

.contenedor {
    width: 100%;
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 15px;

}

.ocultar-mobile {
    display: flex;
}

.ocultar-tablet {
    display: flex;
}

.ocultar-desktop {
    display: none;
}

@media screen and (max-width: 1400px) {
    .contenedor {
        max-width: 1200px;
    }
}

@media screen and (max-width: 1200px) {
    .contenedor {
        max-width: 1024px;
    }
}

@media screen and (max-width: 992px) {
    .contenedor {
        max-width: 768px;
    }

    .ocultar-desktop {
        display: flex;
    }

    .ocultar-tablet {
        display: none !important;
    }
}

@media screen and (max-width: 768px) {
    .contenedor {
        max-width: 100%;
    }
}

@media screen and (max-width: 576px) {
    .contenedor {
        max-width: 100%;
    }

    .ocultar-mobile {
        display: none !important;
    }
}

/* ======================================== GENERAL =================================== */

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html,
body {
    box-sizing: border-box;
    font-family: var(--fuente-primaria);
    font-size: 16px;
    position: relative;
    /* height: 100vh; */
}

p {
    -webkit-margin-before: 0em !important;
    -webkit-margin-after: 0em !important;
}

a {
    text-decoration: none;
    color: inherit;
}

header {
    z-index: 1000 !important;
}

.display-none {
    display: none !important;
}

.display-inline {
    display: inline !important;
}

.position-relative {
    position: relative !important;
}

.position-absolute {
    position: absolute !important;
}

.bring-front {
    z-index: 110 !important;
}

.overflow-hidden {
    overflow: hidden !important;
}

.cursor-pointer {
    cursor: pointer;
}

/* ======================================== FLEX =================================== */

.display-flex {
    display: flex !important;
}

.flex-row {
    display: flex;
    flex-direction: row;
}

.flex-col {
    display: flex;
    flex-direction: column;
}

.row-to-col {
    display: flex;
    flex-direction: row;
}

.row-to-col-reverse {
    display: flex;
    flex-direction: row;
}

@media screen and (max-width: 1024px) {
    .producto-contenido {
        margin-top: 60px !important;
    }
}

@media screen and (max-width: 768px) {
    .row-to-col {
        display: flex;
        flex-direction: column;
    }

    .row-to-col-reverse {
        display: flex;
        flex-direction: column-reverse;
    }
}

.justify-content-center {
    justify-content: center;
}

.justify-content-start {
    justify-content: flex-start;
}

.justify-content-end {
    justify-content: flex-end;
}

.justify-content-around {
    justify-content: space-around;
}

.justify-content-between {
    justify-content: space-between;
}

.align-items-center {
    align-items: center;
}

.align-items-start {
    align-items: flex-start;
}

.align-items-end {
    align-items: flex-end;
}

.align-self-start {
    align-self: flex-start;
}

.align-self-center {
    align-self: center;
}

.align-self-end {
    align-self: flex-end;
}

.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

.text-justify {
    text-align: justify;
}

/* ======================================== WIDTH/HEIGHT =================================== */

.w-100 {
    width: 100% !important;
}

.w-90 {
    width: 90% !important;
}

.w-80 {
    width: 80% !important;
}

.w-70 {
    width: 70% !important;
}

.w-60 {
    width: 60% !important;
}

.w-50 {
    width: 50% !important;
}

.w-40 {
    width: 40% !important;
}

.w-30 {
    width: 30% !important;
}

.w-20 {
    width: 20% !important;
}

.w-10 {
    width: 10% !important;
}

.w-50px {
    width: 50px !important;
}

.w-100px {
    width: 100px !important;
    max-width: 100% !important;
}

.w-150px {
    width: 150px !important;
    max-width: 100% !important;
}

.w-200px {
    width: 200px !important;
    max-width: 100% !important;
}

.w-300px {
    width: 300px !important;
    max-width: 100% !important;
}

.w-400px {
    width: 400px !important;
    max-width: 100% !important;
}

.w-500px {
    width: 500px !important;
    max-width: 100% !important;
}

.w-fit-content {
    width: fit-content !important;
}

.h-100 {
    height: 100% !important;
}

.h-90 {
    height: 90% !important;
}

.h-80 {
    height: 80% !important;
}

.h-70 {
    height: 70% !important;
}

.h-60 {
    height: 60% !important;
}

.h-50 {
    height: 50% !important;
}

.h-40 {
    height: 40% !important;
}

.h-30 {
    height: 30% !important;
}

.h-20 {
    height: 20% !important;
}

.h-10 {
    height: 10% !important;
}

.h-fit-content {
    height: fit-content !important;
}

.h-600px {
    height: 600px !important;
}

.h-500px {
    height: 500px !important;
}

.h-450px {
    height: 450px !important;
}

.h-400px {
    height: 400px !important;
}

.h-350px {
    height: 350px !important;
}

.h-300px {
    height: 300px !important;
}

.h-250px {
    height: 250px !important;
}

.h-200px {
    height: 200px !important;
}

.h-150px {
    height: 150px !important;
}

.h-100px {
    height: 100px !important;
}

.h-75px {
    height: 75px !important;
}

.h-50px {
    height: 50px !important;
}

/* ======================================== RADIUS =================================== */

.radius-full {
    border-radius: 100%;
}

.radius-500px {
    border-radius: 500px;
}

.radius-100px {
    border-radius: 100px;
}

.radius-30px {
    border-radius: 30px;
}

.radius-25px {
    border-radius: 25px;
}

.radius-20px {
    border-radius: 20px;
}

.radius-15px {
    border-radius: 15px;
}

.radius-10px {
    border-radius: 10px;
}

.radius-5px {
    border-radius: 5px;
}

@media screen and (max-width: 1200px) {
    .radius-30px {
        border-radius: 25px;
    }

    .radius-25px {
        border-radius: 20px;
    }

    .radius-20px {
        border-radius: 15px;
    }

    .radius-15px {
        border-radius: 10px;
    }

    .radius-10px {
        border-radius: 5px;
    }

    .radius-5px {
        border-radius: 3px;
    }
}

@media screen and (max-width: 768px) {
    .radius-30px {
        border-radius: 20px;
    }

    .radius-25px {
        border-radius: 15px;
    }

    .radius-20px {
        border-radius: 10px;
    }

    .radius-15px {
        border-radius: 5px;
    }

    .radius-10px {
        border-radius: 3px;
    }

    .radius-5px {
        border-radius: 1px;
    }
}

/* ======================================== SPACING =================================== */

.gap-100px {
    gap: 100px;
}

.gap-75px {
    gap: 75px;
}

.gap-50px {
    gap: 50px;
}

.gap-40px {
    gap: 40px;
}

.gap-35px {
    gap: 35px;
}

.gap-30px {
    gap: 30px;
}

.gap-25px {
    gap: 25px;
}

.gap-20px {
    gap: 20px;
}

.gap-15px {
    gap: 15px;
}

.gap-10px {
    gap: 10px;
}

.gap-5px {
    gap: 5px;
}

.padding-0 {
    padding: 0;
}

.padding-5px {
    padding: 5px;
}

.padding-10px {
    padding: 10px;
}

.padding-15px {
    padding: 15px;
}

.padding-20px {
    padding: 20px;
}

.padding-25px {
    padding: 25px;
}

.padding-30px {
    padding: 30px;
}

.padding-35px {
    padding: 35px;
}

.padding-40px {
    padding: 40px;
}

.padding-45px {
    padding: 45px;
}

.padding-50px {
    padding: 50px;
}

.padding-75px {
    padding: 75px;
}

.padding-100px {
    padding: 100px;
}

.margin-auto {
    margin: 0 auto;
}

.margin-0 {
    margin: 0;
}

.margin-50px {
    margin: 50px;
}

.margin-100px {
    margin: 100px;
}

@media screen and (max-width: 1200px) {
    .gap-100px {
        gap: 70px;
    }

    .gap-75px {
        gap: 52px;
    }

    .gap-50px {
        gap: 35px;
    }

    .gap-40px {
        gap: 28px;
    }

    .gap-35px {
        gap: 24px;
    }

    .gap-30px {
        gap: 21px;
    }

    .gap-25px {
        gap: 17px;
    }

    .gap-20px {
        gap: 16px;
    }

    .gap-15px {
        gap: 12px;
    }

    .gap-10px {
        gap: 8px;
    }

    .gap-5px {
        gap: 4px;
    }

    .padding-100px {
        padding: 70px;
    }

    .padding-75px {
        padding: 52px;
    }

    .padding-50px {
        padding: 35px;
    }

    .padding-45px {
        padding: 31px;
    }

    .padding-40px {
        padding: 28px;
    }

    .padding-35px {
        padding: 24px;
    }

    .padding-30px {
        padding: 21px;
    }

    .padding-25px {
        padding: 17px;
    }

    .padding-20px {
        padding: 16px;
    }

    .padding-15px {
        padding: 12px;
    }

    .padding-10px {
        padding: 8px;
    }

    .padding-5px {
        padding: 4px;
    }

    .margin-100px {
        margin: 70px;
    }

    .margin-50px {
        margin: 35px;
    }

}

@media screen and (max-width: 768px) {
    .padding-100px {
        padding: 40px;
    }

    .padding-75px {
        padding: 30px;
    }

    .padding-50px {
        padding: 20px;
    }

    .padding-45px {
        padding: 18px;
    }

    .padding-40px {
        padding: 16px;
    }

    .padding-35px {
        padding: 14px;
    }

    .padding-30px {
        padding: 12px;
    }

    .padding-25px {
        padding: 10px;
    }

    .padding-20px {
        padding: 12px;
    }

    .padding-15px {
        padding: 10px;
    }

    .padding-10px {
        padding: 8px;
    }

    .padding-5px {
        padding: 4px;
    }

    .margin-100px {
        margin: 40px;
    }

    .margin-50px {
        margin: 20px;
    }
}

.px-50px {
    padding-inline: 50px;
}

.px-40px {
    padding-inline: 40px;
}

.px-30px {
    padding-inline: 30px;
}

.px-20px {
    padding-inline: 20px;
}

.px-10px {
    padding-inline: 10px;
}

.px-5px {
    padding-inline: 5px;
}

.pt-0 {
    padding-top: 0;
}

.pt-5px {
    padding-top: 5px;
}

.pt-10px {
    padding-top: 10px;
}

.pt-15px {
    padding-top: 15px;
}

.pt-20px {
    padding-top: 20px;
}

.pt-25px {
    padding-top: 25px;
}

.pt-30px {
    padding-top: 30px;
}

.pt-40px {
    padding-top: 40px;
}

.pt-50px {
    padding-top: 50px;
}

.pb-0 {
    padding-bottom: 0;
}

.pb-5px {
    padding-bottom: 5px;
}

.pb-10px {
    padding-bottom: 10px;
}

.pb-15px {
    padding-bottom: 15px;
}

.pb-20px {
    padding-bottom: 20px;
}

.pb-25px {
    padding-bottom: 25px;
}

.pb-30px {
    padding-bottom: 30px;
}

.pb-40px {
    padding-bottom: 40px;
}

.pb-50px {
    padding-bottom: 50px;
}

.pr-0 {
    padding-right: 0;
}

.pr-5px {
    padding-right: 5px;
}

.pr-10px {
    padding-right: 10px;
}

.pr-15px {
    padding-right: 15px;
}

.pr-20px {
    padding-right: 20px;
}

.pr-25px {
    padding-right: 25px;
}

.pr-30px {
    padding-right: 30px;
}

.pl-0 {
    padding-left: 0;
}

.pl-5px {
    padding-left: 5px;
}

.pl-10px {
    padding-left: 10px;
}

.pl-15px {
    padding-left: 15px;
}

.pl-20px {
    padding-left: 20px;
}

.pl-25px {
    padding-left: 25px;
}

.pl-30px {
    padding-left: 30px;
}

.mb-auto {
    margin-bottom: auto;
}

.mb-100px {
    margin-bottom: 100px;
}

.mb-75px {
    margin-bottom: 75px;
}

.mb-50px {
    margin-bottom: 50px;
}

.mb-45px {
    margin-bottom: 45px;
}

.mb-40px {
    margin-bottom: 40px;
}

.mb-35px {
    margin-bottom: 35px;
}

.mb-30px {
    margin-bottom: 30px;
}

.mb-25px {
    margin-bottom: 25px;
}

.mb-20px {
    margin-bottom: 20px;
}

.mb-15px {
    margin-bottom: 15px;
}

.mb-10px {
    margin-bottom: 10px;
}

.mb-5px {
    margin-bottom: 5px;
}

.mb-0 {
    margin-bottom: 0;
}

.mt-auto {
    margin-top: auto;
}

.mt-50px {
    margin-top: 50px;
}

.mt-45px {
    margin-top: 45px;
}

.mt-40px {
    margin-top: 40px;
}

.mt-35px {
    margin-top: 35px;
}

.mt-30px {
    margin-top: 30px;
}

.mt-25px {
    margin-top: 25px;
}

.mt-20px {
    margin-top: 20px;
}

.mt-15px {
    margin-top: 15px;
}

.mt-10px {
    margin-top: 10px;
}

.mt-5px {
    margin-top: 5px;
}

.mt-0 {
    margin-top: 0;
}

.mr-auto {
    margin-right: auto;
}

.mr-100px {
    margin-right: 100px;
}

.mr-50px {
    margin-right: 50px;
}

.mr-40px {
    margin-right: 40px;
}

.mr-30px {
    margin-right: 30px;
}

.mr-25px {
    margin-right: 25px;
}

.mr-20px {
    margin-right: 20px;
}

.mr-15px {
    margin-right: 15px;
}

.mr-10px {
    margin-right: 10px;
}

.mr-5px {
    margin-right: 5px;
}

.mr-0 {
    margin-right: 0;
}

.ml-auto {
    margin-left: auto;
}

.ml-100px {
    margin-left: 100px;
}

.ml-50px {
    margin-left: 50px;
}

.ml-40px {
    margin-left: 40px;
}

.ml-30px {
    margin-left: 30px;
}

.ml-25px {
    margin-left: 25px;
}

.ml-20px {
    margin-left: 20px;
}

.ml-15px {
    margin-left: 15px;
}

.ml-10px {
    margin-left: 10px;
}

.ml-5px {
    margin-left: 5px;
}

.ml-0 {
    margin-left: 0;
}