:root {
    --color-primary: #20517E;
    --color-secondary: #d2082d;
    --color-accent: #bababa;
    --color-light: #ffffff;
    --color-dark: #343434;
    --color-bg: #EDEDED;
    --color-text: #343434;
    --border-radius: none;
    --box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.2);
    --size-xxl: 120px;
    --size-xl: 100px;
    --size-l: 60px;
    --size-ml: 45px;
    --size-m: 30px;
    --size-sm: 20px;
    --size-s: 15px;
    --size-xs: 10px;
    --size-xxs: 5px;
    --text-xxl: 44px;
    --text-xl: 32px;
    --text-l: 26px;
    --text-ml: 24px;
    --text-m: 22px;
    --text-sm: 18px;
    --text-s: 16px;
    --text-xs: 14px;
    --text-xxs: 12px;
    --nav-height: 80px;
}
body,
html {
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    color: var(--color-text);
    overflow: hidden;
}
body {
    overflow-y: auto;
}
body.contrast-active{
    filter: contrast(1.25) brightness(1);
    font-weight: 500;
}
body.contrast-active{
    --color-primary: #183E5D;
    --color-secondary: #7A061B;
    --color-accent: #D1D1D1;
    --color-light: #ffffff;
    --color-dark: #1F1F1F;
    --color-bg: #ececec;
    --color-text: #1F1F1F;
}
body.contrast-active img{
    filter: brightness(0.7) contrast(2);
}

.disabel-contrast{ display: none; }
.enable-contrast{ display: list-item; }
body.contrast-active .disabel-contrast{ display: list-item; }
body.contrast-active .enable-contrast{ display: none; }

header { z-index: 90; }
.modal{ z-index: 100; }
.modal-backdrop{ z-index: 99; }

.modal-title{ color: var(--color-light) !important; }
.modal-header{ background: var(--color-primary) !important; }
.modal-footer .btn{ margin-top: 0 !important; }
.first_section {
    display: flex;
    align-items: center;
    box-sizing: content-box;
    margin: 0;
    padding: var(--size-l) 0;
    margin-top: var(--nav-height);
    height: calc(55vh - var(--nav-height));
    position: relative;
}
.first_section h1 {
    color: var(--color-light) !important;
    text-shadow: 1px 1px 4px var(--color-text);
}
h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--color-primary) !important;
    font-weight: 500 !important;
}
h4,
h5,
h6 {
    color: var(--color-secondary) !important;
}
section {
    padding: var(--size-ml) 0;
}
p {
    color: var(--color-text);
}
b,
strong,
a,
.text-blue {
    color: var(--color-primary);
}
.btn,
a.btn {
    background: var(--color-primary);
    font-weight: 500;
    color: var(--color-light);
    margin-top: var(--size-m);
    margin-right: var(--size-xs);
    margin-left: var(--size-xs);
    border-radius: var(--size-m);
    padding: var(--size-xxs) var(--size-s);
    border: none !important;
    text-decoration: none !important;
    box-shadow: var(--box-shadow) !important;
    transition: background 0.35s, box-shadow 0.35s;
}
.btn *,
a.btn * {
    color: inherit;
    font-weight: inherit;
}
.btn:hover,
.btn:active {
    color: var(--color-light);
    background: var(--color-secondary);
}
.btn:active {
    box-shadow: none !important;
}
.bold {
    font-weight: bold;
}
.semi-bold {
    font-weight: 500;
}
.justify-content-strech {
    justify-content: stretch;
}
.br-bottom-primary {
    position: relative;
    border-bottom: solid var(--size-xxs) var(--color-primary);
}
.br-top-primary {
    border-top: solid var(--size-xxs) var(--color-primary);
}
.br-left-primary {
    border-left: solid var(--size-xxs) var(--color-primary);
}
.br-right-primary {
    border-right: solid var(--size-xxs) var(--color-primary);
}
.br-bottom-secondary {
    border-bottom: solid var(--size-xxs) var(--color-secondary);
}
.br-top-secondary {
    border-top: solid var(--size-xxs) var(--color-secondary);
}
.br-left-secondary {
    border-left: solid var(--size-xxs) var(--color-secondary);
}
.br-right-secondary {
    border-right: solid var(--size-xxs) var(--color-secondary);
}
.col-image img {
    max-width: 100%;
    min-height: 100%;
    object-fit: contain;
    object-position: center;
}
.card {
    border: none;
    height: 100%;
    position: relative;
    box-shadow: var(--box-shadow);
    padding: var(--size-m);
    overflow: hidden;
    border-radius: var(--size-xxs);
}
.card .card-body {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    align-items: flex-start;
    gap: 0 var(--size-s);
    padding: 0 !important;
}
.card .card-body > * {
    flex: 1;
}
.card .card-body > .img-fluid {
    max-height: 100px;
    object-fit: contain;
}
.card .card-body .card-title {
    margin: 0;
    text-align: left;
    font-size: var(--text-sm);
}
.card .card-body .card-text {
    width: 100%;
    margin: 0 !important;
    height: fit-content;
    margin-top: var(--size-m);
}
.card .card-img-top,
.card .card-bg {
    position: relative;
    z-index: 0;
    object-fit: cover;
    object-position: center;
    width: calc(100% + var(--size-m) * 2) !important;
    left: calc(-1* var(--size-m));
    top: calc(-1* var(--size-m));
    margin-bottom: calc(-1* var(--size-m));
}
.card.card_transparente {
    border: none !important;
}
.card.card_transparente > img {
    width: 100%;
    height: 320px;
    object-fit: contain;
    object-position: top;
    margin-bottom: var(--size-sm) !important;
}
.card.card_transparente .card-body {
    flex-direction: column;
    align-items: stretch;
}
.card.card_transparente .card-body .card-title {
    flex: none;
    width: 100%;
    height: auto;
    text-align: left !important;
    font-size: var(--size-m);
    color: var(--color-secondary) !important;
    border-bottom: solid 2px var(--color-text);
    padding-bottom: var(--size-xxs);
    margin-bottom: var(--size-s);
}
.card.card_blog .card-body,
.card.card_azul .card-body {
    align-items: center;
    flex-direction: column;
}
.card.card_blog .card-body > .img-fluid,
.card.card_azul .card-body > .img-fluid {
    margin-bottom: var(--size-sm);
}
.card.card_blog .card-body .card-title,
.card.card_azul .card-body .card-title {
    text-align: center;
}
.card.card_blog .card-body .card-text,
.card.card_azul .card-body .card-text {
    text-align: center !important;
}
.card.card_blog .card-body {
    margin: var(--size-xs) 0;
}
.card.card_rojo,
.card.card_azul,
.card.card_blog,
.card.card_transparente {
    padding: var(--size-sm);
    box-shadow: var(--box-shadow);
    border-bottom: solid var(--size-xxs) var(--color-primary);
}
.card.card_transparente {
    box-shadow: none;
}
.row > div:nth-of-type(even) .card.card_rojo {
    border-bottom: solid var(--size-xxs) var(--color-secondary);
}
.row > div:nth-of-type(even) .card.card_rojo .card-title {
    color: var(--color-secondary) !important;
}
.card:before {
    content: "";
    pointer-events: none;
    position: absolute;
    z-index: 10;
    top: calc(var(--size-m) / 2);
    left: calc(var(--size-m) / 2);
    width: calc(100% - var(--size-m));
    height: calc(100% - var(--size-m));
    border-radius: inherit;
    border: solid 1px darkgrey;
    mix-blend-mode: exclusion;
}
.card.card_rojo:before,
.card.card_azul:before,
.card.card_transparente:before {
    display: none;
}
section {
    background: var(--color-bg);
}
section.bg-light {
    background: var(--color-light) !important;
}
section.first_section.section_home {
    background-image: url('../img/headers/hombre-adulto-silla-ruedas-trabajando-computadora-portatil.jpg');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center right;
    position: relative;
}
section.first_section.section_home p {
    font-weight: 500;
}
section.first_section.section_home:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, white 35%, transparent);
}
header {
    width: 100%;
    display: block;
    height: var(--nav-height);
    position: fixed;
    top: 0;
    left: 0;
    background: var(--color-light);
    box-shadow: var(--box-shadow);
}
header a{ text-decoration: none !important; }
header .container_top_nav {
    margin: 0 !important;
    padding: 0 var(--size-l);
    height: 100%;
    width: 100%;
    max-width: none;
    box-sizing: border-box;
}
header .container_top_nav nav:first-of-type {
    display: none;
}
header .container_top_nav .navbar-hc {
    width: 100%;
    height: 100%;
    padding: 0;
    box-sizing: border-box;
    box-shadow: none !important;
}
header .container_top_nav .navbar-hc > a {
    width: 15%;
    padding: 0;
    margin-right: var(--size-ml);
}
header .container_top_nav .navbar-hc > a img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
header .container_top_nav .navbar-hc > .navbar-collapse {
    height: 100%;
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav {
    width: 100%;
    padding: 0;
    display: flex;
    height: 100%;
    align-items: stretch;
    flex-direction: row;
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item.active {
    display: flex;
    align-items: center;
    transition: background 0.15s;
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item a,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item.active a,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item button,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item.active button {
    flex: 1;
    background: none;
    font-weight: 500;
    font-size: var(--text-s);
    line-height: calc(var(--text-s) + 3px);
    transition: all 0.15s;
    padding: var(--size-s);
    margin: 0;
    border-radius: 0;
    box-shadow: none !important;
    color: var(--color-primary);
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item #btn_carrito,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item.active #btn_carrito {
    min-width: 85px;
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item #btn_carrito span,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item.active #btn_carrito span {
    margin-left: var(--size-xs);
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:nth-child(odd) a,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item.active:nth-child(odd) a,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:nth-child(odd) button,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item.active:nth-child(odd) button {
    color: var(--color-secondary);
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item.active {
    background: var(--color-bg);
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:hover,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:active {
    background: var(--color-primary);
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:hover a,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:active a,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:hover button,
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:active button {
    color: var(--color-light) !important;
    text-decoration: none;
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:last-of-type {
    background: none !important;
}
header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item:last-of-type a {
    color: var(--color-primary) !important;
}
.plan_container_col .plan_container {
    border: none;
    height: 100%;
    position: relative;
    box-shadow: var(--box-shadow);
    padding: var(--size-s);
    overflow: hidden;
    border-radius: var(--size-xxs);
    background: var(--color-light);
}
.plan_container_col .plan_container .encabezado_planes {
    height: var(--size-xl) !important;
    color: var(--color-primary) !important;
    display: flex;
    justify-content: center;
    align-items: center;
}
.plan_container_col .plan_container .encabezado_planes > * {
    color: inherit !important;
    margin: 0 !important;
}
.plan_container_col .plan_container .costo_planes {
    position: relative;
    width: calc(100% + var(--size-s) * 2);
    left: calc(-1 * var(--size-s));
    box-sizing: border-box;
    padding: var(--size-s) calc(2 * var(--size-s));
    background: var(--color-bg);
    display: flex;
    justify-content: center;
    align-items: center;
}
.plan_container_col .plan_container .costo_planes p {
    font-size: var(--text-ml) !important;
    color: var(--color-primary);
}
.plan_container_col button,
.plan_container_col .btn {
    top: auto;
    position: relative;
    bottom: var(--size-l);
    margin-top: 0 !important;
    margin-bottom: var(--size-sm);
}
.section-products{
    border: none !important;
}
/*.section-products{
    background: linear-gradient(90deg, var(--color-bg) 30%, #e1e1e1 30%);
}*/
.section-products .container{ position: relative; }
/*.section-products .container::before{
   content: "";
   position: absolute;
   top: calc(-1 * var(--size-ml));
   left: 0;
   width: 100%;
   height: calc(100% + (var(--size-ml) * 2));
   background-image: url("../img/sections/Fondo_HC.png");
   background-position: bottom right;
   background-size: auto 130%;
   background-repeat: no-repeat;
}*/
#btn_carrito{
    display: none !important;
}
.grecaptcha-badge{
    opacity: 0; pointer-events: none !important;
}

a, button, input, select, option{
    transition: outline 0s !important;
}
*:focus {
    outline: solid 3px var(--color-dark) !important;
    z-index: 100;
}
#footer {
    margin: 0 !important;
}
#footer > section {
    margin: 0 !important;
}
.container_top_nav .nav_salto_bloques {
    display: block !important;
    position: relative;
    width: 100%;
    height: 0;
    overflow-y: visible;
    top: 0%;
    transition: top 0.25s;
    z-index: 0;
}
.container_top_nav .nav_salto_bloques .navbar-nav{
    justify-content: flex-end;
    position: relative;
}
.container_top_nav .nav_salto_bloques .nav-item {
    width: auto;
    position: relative;
    border-right: solid 1px var(--color-light);
}

.container_top_nav .nav_salto_bloques .enable-contrast,
.container_top_nav .nav_salto_bloques .disabel-contrast{
    position: absolute;
    right: 0;
    border: none;
    background: var(--color-primary);
}
.container_top_nav .nav_salto_bloques .nav-item a {
    padding: var(--size-xxs) var(--size-xs);
}
.container_top_nav .nav_salto_bloques .nav-item:focus-within {
    z-index: 10;
}
/*.container_top_nav:hover .nav_salto_bloques,
.container_top_nav:active .nav_salto_bloques,
.container_top_nav:focus .nav_salto_bloques,
.container_top_nav:focus-within .nav_salto_bloques*/
.nav_salto_bloques:focus-within{
    top: 100%;
}

@media screen and (max-width: 999px) {
    #hj-survey-toggle-1{
        display: none !important;
    }
    header .container_top_nav {
        padding: 0;
    }
    header .container_top_nav .navbar-hc .navbar-toggler {
        outline: none;
    }
    header .container_top_nav .navbar-hc .navbar-toggler path {
        fill: var(--color-secondary);
        transition: fill 0.35s;
    }
    header .container_top_nav .navbar-hc .navbar-toggler.collapsed path {
        fill: var(--color-primary);
    }
    header .container_top_nav .navbar-hc > .navbar-collapse {
        display: flex;
        position: absolute;
        background: var(--color-light);
        left: 0;
        top: var(--nav-height);
        width: 100%;
        height: calc(100vh - var(--nav-height));
        transform: translatex(100%);
        transition: transform 0.5s;
    }
    header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        margin-top: var(--size-l);
        padding: 0 var(--size-l);
        gap: var(--size-s) 0;
    }
    header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item {
        width: 100%;
        text-align: left;
        height: fit-content;
        justify-content: center;
    }
    header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item br {
        display: none;
    }
    header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item #btn_carrito {
        position: absolute;
        height: var(--nav-height);
        display: flex;
        align-items: center;
        justify-content: center;
        right: var(--size-l);
        top: calc(-1 * var(--nav-height));
        opacity: 0;
        transition-delay: 0s;
        transition: opacity 0.35s;
    }
    header .container_top_nav .navbar-hc > .navbar-collapse > .navbar-nav .nav-item .btn_modal_iniciar_sesion {
        max-width: 50%;
        position: absolute;
        bottom: var(--size-m);
        color: var(--color-light) !important;
        background: var(--color-secondary);
    }
    header .container_top_nav .navbar-hc > .navbar-collapse.show {
        transform: translatex(0%);
    }
    header .container_top_nav .navbar-hc > .navbar-collapse.show > .navbar-nav .nav-item #btn_carrito {
        opacity: 1;
        transition-delay: 0.5s;
    }
    .row {
        gap: var(--size-m) 0;
    }
    .card.card_rojo {
        margin-bottom: 30px;
    }
    .card.card_rojo .card-body {
        text-align: center;
        align-items: center;
        justify-content: center;
        flex-direction: column;
    }
    .card.card_rojo .img-fluid {
        margin-bottom: var(--size-m);
    }
    .section-products {
        background: var(--color-bg);
    }
    .section-products .container:before {
        display: none;
    }
    .container_top_nav {
        max-height: 60px;
    }
    .container_top_nav .collapse:not(.show) {
        display: block !important;
    }
    .container_top_nav .nav_salto_bloques {
        transform: translatey(100%) !important;
        width: 100vw;
        left: 0;
        bottom: 0;
        position: fixed;
        z-index: 10;
    }
    .container_top_nav .nav_salto_bloques > button {
        display: none;
    }
    .container_top_nav .nav_salto_bloques .navbar-nav {
        width: 100%;
        gap: 1px !important;
        align-items: stretch;
        justify-content: center;
        flex-direction: row !important;
    }
    .container_top_nav .nav_salto_bloques .navbar-nav .nav-item {
        flex: 1;
        display: flex;
        justify-content: center;
        align-items: center;
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
    }
    .container_top_nav .nav_salto_bloques .navbar-nav .nav-item a {
        padding: 0 !important;
    }
    .container_top_nav .container_top_nav {
        z-index: 10 !important;
    }
    .container_top_nav > .navbar-hc {
        max-height: 100%;
    }
    .container_top_nav > .navbar-hc .navbar-collapse {
        top: 60px !important;
        height: calc(100vh - 60px) !important;
    }
    .container_top_nav > .navbar-hc .navbar-nav.ml-auto {
        margin: 0 !important;
        position: absolute;
        top: 0;
        left: 0;
        max-height: calc(100% - 70px);
        overflow-y: auto;
    }
    .container_top_nav > .navbar-hc .navbar-nav.ml-auto .btn_modal_iniciar_sesion {
        position: sticky !important;
        top: auto !important;
        bottom: 0 !important;
    }
    .container_top_nav:hover .nav_salto_bloques,
    .container_top_nav:active .nav_salto_bloques,
    .container_top_nav:focus .nav_salto_bloques,
    .container_top_nav:focus-within .nav_salto_bloques {
        transform: translatey(0%) !important;
    }
    .first_section {
        padding: 0;
        height: auto;
        height: 75vh;
        position: relative;
    }
    .first_section .container {
        max-height: 100%;
        margin: 0;
        max-width: 100%;
        padding-right: 25%;
        overflow-x: hidden;
        overflow-y: auto;
        position: absolute;
        top: 0;
        left: 0;
    }
}
@media screen and (max-width: 1199px) {
    .plan_container_col button,
    .plan_container_col .btn {
        max-width: calc(100% - var(--size-sm));
        bottom: calc(var(--size-xl) + var(--size-sm)) !important;
    }
}