/* ======================================== GENERAL =================================== */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html,
body {
    box-sizing: border-box;
    font-family: var(--primary-font);
    font-size: var(--normal-text);
    position: relative;
    overflow: hidden;
}

.hidden {
    height: 0 !important;
    width: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

.bring-front {
    z-index: 1300 !important;
}

.rotate-180 {
    transform: rotate(180deg);
}

.opacity-0 {
    opacity: 0;
}

.scroll-container {
    height: 100%;
    width: 100%;
    overflow-y: auto !important;
}

/* ======================================== TEXTS =================================== */
.big-text {
    font-size: var(--big-text) !important;
    line-height: calc(var(--big-text) + 7px);
}

.big-text-bold {
    font-size: var(--big-text) !important;
    line-height: calc(var(--big-text) + 7px);
    font-weight: 700;
}

.normal-text {
    font-size: var(--normal-text) !important;
    line-height: calc(var(--normal-text) + 7px);
}

.normal-text-bold {
    font-size: var(--normal-text) !important;
    line-height: calc(var(--normal-text) + 7px);
    font-weight: 700;
}

.primary-font {
    font-family: var(--primary-font) !important;
}

.code-font {
    font-family: var(--code-font) !important;
}

.normal-text.icon-text img {
    width: calc(var(--normal-text) + 3px) !important;
    height: calc(var(--normal-text) + 3px) !important;
    margin-bottom: -3px;
}

.big-text.icon-text {
    width: calc(var(--big-text) + 3px) !important;
    height: calc(var(--big-text) + 3px) !important;
    margin-bottom: -3px;
}

/* ======================================== COLORS =================================== */
.color-black {
    color: var(--black);
}

.color-white {
    color: var(--white);
}

.color-orange {
    color: var(--orange);
}

.color-green {
    color: var(--green);
}

.color-red {
    color: var(--red);
}

.color-grey {
    color: var(--grey);
}

.black-icon {
    filter: var(--black-icon);
}

.white-icon {
    filter: var(--white-icon);
}

.orange-icon {
    filter: var(--orange-icon);
}

.red-icon {
    filter: var(--red-icon);
}

.blue-icon {
    filter: var(--blue-icon);
}

.green-icon {
    filter: var(--green-icon);
}

/* ======================================== BACKGROUNDS =================================== */
.bg-black {
    background-color: var(--black);
}

.bg-white {
    background-color: var(--white);
}

.bg-orange {
    background-color: var(--orange);
}

/* ======================================== ICONS =================================== */

.icon-16px {
    width: 16px !important;
    height: 16px !important;
}

.icon-20px {
    width: 20px !important;
    height: 20px !important;
}

.icon-24px {
    width: 24px !important;
    height: 24px !important;
}

.icon-32px {
    width: 32px !important;
    height: 32px !important;
}

.icon-36px {
    width: 36px !important;
    height: 36px !important;
}

.icon-40px {
    width: 40px !important;
    height: 40px !important;
}

.icon-48px {
    width: 48px !important;
    height: 48px !important;
}

.icon-64px {
    width: 64px !important;
    height: 64px !important;
}

/* ======================================== UTILS =================================== */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html,
body {
    box-sizing: border-box;
    font-family: var(--primary-font);
    font-size: 16px;
    position: relative;
}

p {
    -webkit-margin-before: 0em !important;
    -webkit-margin-after: 0em !important;
}

a {
    text-decoration: none;
}

header {
    z-index: 1000 !important;
}

.display-none {
    display: none !important;
}

.display-inline {
    display: inline !important;
}

.display-flex {
    display: flex !important;
}

.position-relative {
    position: relative !important;
}

.position-absolute {
    position: absolute !important;
}

.ocultar-mobile {
    display: flex;
}

.ocultar-tablet {
    display: flex;
}

.ocultar-desktop {
    display: none;
}

.bring-front {
    z-index: 110 !important;
}

.overflow-hidden {
    overflow: hidden !important;
}

.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;
}

.cursor-pointer {
    cursor: pointer;
}

.flex-row {
    display: flex;
    flex-direction: row;
}

.flex-col {
    display: flex;
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.row-to-col {
    display: flex;
    flex-direction: row;
}

.row-to-col-reverse {
    display: flex;
    flex-direction: row;
}


@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;
}

/* ======================================== GRIDS GENERICAS =================================== */

.grid-2-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.grid-3-col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
}

.grid-4-col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
}

.grid-5-col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}

.grid-6-col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
}

.element-2-col {
    grid-column: span 2;
}

.element-3-col {
    grid-column: span 3;
}

.element-4-col {
    grid-column: span 4;
}

.element-5-col {
    grid-column: span 5;
}

.element-6-col {
    grid-column: span 6;
}

/* FLEX GRID */

.flex-2-col {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.flex-2-col div,
.flex-2-col button {
    flex: 0 0 45%;
}

.flex-3-col {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.flex-3-col div,
.flex-3-col button {
    flex: 0 0 30%;
}

.flex-4-col {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.flex-4-col div,
.flex-4-col button {
    flex: 0 0 20%;
}

.radius-full {
    border-radius: 100%;
}

.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-10px {
    margin: 10px;
}

.margin-15px {
    margin: 15px;
}

.margin-20px {
    margin: 20px;
}

.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;
    }
}

/* ======================================== PADDING =================================== */

.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;
}